/* ====================================================
   DVTV-056 回覧板 — 統合スタイルシート
   テーマ干渉防止: 全要素に !important + 多段セレクタ
==================================================== */

/* --- ラッパー --- */
.dvtv-kanran-wrap {
    font-family: "Hiragino Kaku Gothic ProN", "Meiryo", sans-serif !important;
    color: #333 !important;
    line-height: 1.6 !important;
    box-sizing: border-box !important;
}
.dvtv-kanran-wrap *,
.dvtv-kanran-wrap *::before,
.dvtv-kanran-wrap *::after {
    box-sizing: border-box !important;
}

/* --- 見出し (テーマ干渉ブロック) --- */
.dvtv-kanran-wrap h2,
.dvtv-kanran-wrap h3,
.dvtv-kanran-wrap h4 {
    background: none !important;
    border: none !important;
    color: #333 !important;
    padding: 0 !important;
    margin: 0 0 10px 0 !important;
    font-weight: bold !important;
    line-height: 1.4 !important;
    text-shadow: none !important;
    letter-spacing: normal !important;
}
.dvtv-kanran-wrap h2 { font-size: 20px !important; }
.dvtv-kanran-wrap h3 { font-size: 17px !important; }
.dvtv-kanran-wrap h4 { font-size: 15px !important; }

/* --- テーブル (テーマ干渉ブロック) --- */
.dvtv-kanran-wrap table {
    width: 100% !important;
    border-collapse: collapse !important;
    margin-top: 10px !important;
    background: none !important;
}
.dvtv-kanran-wrap table th,
.dvtv-kanran-wrap table td {
    border: 1px solid #ddd !important;
    padding: 8px !important;
    text-align: left !important;
    background: none !important;
    color: #333 !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    vertical-align: middle !important;
}
.dvtv-kanran-wrap table th {
    background-color: #f2f2f2 !important;
    font-weight: bold !important;
}
.dvtv-kanran-wrap table tr:hover td {
    background-color: #fafafa !important;
}

/* --- ラベル / input (テーマ干渉ブロック) --- */
.dvtv-kanran-wrap label {
    color: #333 !important;
    font-weight: normal !important;
    background: none !important;
}
.dvtv-kanran-wrap input[type="text"],
.dvtv-kanran-wrap input[type="number"],
.dvtv-kanran-wrap select {
    border: 1px solid #ccc !important;
    border-radius: 4px !important;
    padding: 6px 8px !important;
    font-size: 14px !important;
    background: #fff !important;
    color: #333 !important;
}
.dvtv-kanran-wrap input[type="text"]:focus,
.dvtv-kanran-wrap select:focus {
    border-color: #007bff !important;
    outline: none !important;
    box-shadow: 0 0 0 2px rgba(0,123,255,0.15) !important;
}

/* --- ボタン --- */
.dvtv-kanran-wrap .kanran-btn {
    padding: 8px 18px !important;
    background-color: #007bff !important;
    color: #fff !important;
    font-weight: bold !important;
    border: none !important;
    border-radius: 5px !important;
    margin: 4px !important;
    cursor: pointer !important;
    text-decoration: none !important;
    display: inline-block !important;
    font-size: 14px !important;
    line-height: 1.4 !important;
    transition: background-color .15s !important;
}
.dvtv-kanran-wrap .kanran-btn:hover {
    background-color: #0056b3 !important;
    color: #fff !important;
    text-decoration: none !important;
}
.dvtv-kanran-wrap .kanran-btn-sm {
    padding: 4px 10px !important;
    font-size: 12px !important;
    background-color: #007bff !important;
    color: #fff !important;
    font-weight: bold !important;
    border: none !important;
    border-radius: 5px !important;
    margin: 2px !important;
    cursor: pointer !important;
    text-decoration: none !important;
    display: inline-block !important;
    transition: background-color .15s !important;
}
.dvtv-kanran-wrap .kanran-btn-sm:hover {
    background-color: #0056b3 !important;
    color: #fff !important;
}
.dvtv-kanran-wrap .kanran-btn-danger {
    background-color: #dc3545 !important;
    color: #fff !important;
    font-weight: bold !important;
    border: none !important;
    border-radius: 5px !important;
    cursor: pointer !important;
    transition: background-color .15s !important;
}
.dvtv-kanran-wrap .kanran-btn-danger:hover {
    background-color: #b02a37 !important;
}
.dvtv-kanran-wrap .kanran-btn-danger.kanran-btn-sm {
    padding: 4px 10px !important;
    font-size: 12px !important;
}
.dvtv-kanran-wrap .kanran-btn-danger.kanran-btn {
    padding: 8px 18px !important;
    font-size: 14px !important;
}
.dvtv-kanran-wrap .kanran-btn-toggle {
    padding: 4px 10px !important;
    font-size: 12px !important;
    border: none !important;
    border-radius: 5px !important;
    cursor: pointer !important;
    margin: 2px !important;
    font-weight: bold !important;
    color: #fff !important;
}
.dvtv-kanran-wrap .kanran-btn-toggle.is-visible {
    background-color: #6c757d !important;
}
.dvtv-kanran-wrap .kanran-btn-toggle.is-hidden {
    background-color: #28a745 !important;
}
.dvtv-kanran-wrap .kanran-buttons {
    margin-top: 12px !important;
}

/* --- チェックボックス --- */
.dvtv-kanran-wrap .large-checkbox {
    width: 22px !important;
    height: 22px !important;
    cursor: pointer !important;
}
.dvtv-kanran-wrap .checked-a-cell {
    background-color: #007bff !important;
    color: #fff !important;
}
.dvtv-kanran-wrap .checked-b-cell {
    background-color: #ff8c00 !important;
    color: #fff !important;
}

/* --- チェックボックスグリッド (ユーザー選択) --- */
.dvtv-kanran-wrap .checkbox-grid {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 6px 12px !important;
    margin: 8px 0 !important;
}
.dvtv-kanran-wrap .checkbox-grid label {
    white-space: nowrap !important;
    font-size: 13px !important;
}

/* --- セクション --- */
.dvtv-kanran-wrap .kanran-section {
    margin: 15px 0 !important;
}
.dvtv-kanran-wrap .kanran-header {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 10px 20px !important;
    align-items: center !important;
    margin-bottom: 12px !important;
}
.dvtv-kanran-wrap .kanran-header label {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
}

/* --- コンボボックス (オートコンプリート) --- */
.dvtv-kanran-wrap .combo-box-wrapper {
    position: relative !important;
    width: 100% !important;
    max-width: 250px !important;
}
.dvtv-kanran-wrap .combo-box-input {
    width: 100% !important;
    padding: 7px 8px !important;
    border: 1px solid #ccc !important;
    border-radius: 4px !important;
    font-size: 14px !important;
    background: #fff !important;
    color: #333 !important;
}
.dvtv-kanran-wrap .combo-box-input:focus {
    outline: none !important;
    border-color: #007bff !important;
    box-shadow: 0 0 0 2px rgba(0,123,255,0.15) !important;
}
.dvtv-kanran-wrap .combo-box-dropdown {
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    right: 0 !important;
    max-height: 200px !important;
    overflow-y: auto !important;
    background: #fff !important;
    border: 1px solid #ccc !important;
    border-top: none !important;
    border-radius: 0 0 4px 4px !important;
    box-shadow: 0 3px 8px rgba(0,0,0,0.12) !important;
    z-index: 9999 !important;
    display: none !important;
}
.dvtv-kanran-wrap .combo-box-dropdown.active {
    display: block !important;
}
.dvtv-kanran-wrap .combo-box-option {
    padding: 7px 10px !important;
    cursor: pointer !important;
    border-bottom: 1px solid #f0f0f0 !important;
    color: #333 !important;
    background: #fff !important;
    font-size: 13px !important;
}
.dvtv-kanran-wrap .combo-box-option:hover,
.dvtv-kanran-wrap .combo-box-option.selected {
    background-color: #007bff !important;
    color: #fff !important;
}
.dvtv-kanran-wrap .combo-box-option:last-child {
    border-bottom: none !important;
}
.dvtv-kanran-wrap .combo-box-no-results {
    padding: 8px !important;
    color: #999 !important;
    text-align: center !important;
    font-size: 13px !important;
}

/* --- PDF アップロードエリア --- */
.dvtv-kanran-wrap .pdf-upload-wrapper {
    position: relative !important;
    width: 100% !important;
    max-width: 220px !important;
}
.dvtv-kanran-wrap .pdf-upload {
    opacity: 0 !important;
    width: 100% !important;
    height: 100% !important;
    position: absolute !important;
    top: 0 !important;
    left: 0 !important;
    z-index: 2 !important;
    cursor: pointer !important;
}
.dvtv-kanran-wrap .drop-area {
    border: 2px dashed #ccc !important;
    padding: 10px !important;
    text-align: center !important;
    background-color: #f9f9f9 !important;
    border-radius: 5px !important;
    font-size: 12px !important;
    color: #666 !important;
    transition: background-color .2s, border-color .2s !important;
    min-height: 30px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}
.dvtv-kanran-wrap .drop-area.dragover {
    border-color: #007bff !important;
    background-color: #e9f5ff !important;
}
.dvtv-kanran-wrap .file-status {
    display: block !important;
    font-size: 12px !important;
    color: #666 !important;
    margin-top: 4px !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
}
.dvtv-kanran-wrap .pdf-item {
    display: inline-flex !important;
    align-items: center !important;
    gap: 4px !important;
    margin: 2px 0 !important;
}

/* --- オーバーレイ / ポップアップ --- */
.dvtv-kanran-overlay {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100% !important;
    height: 100% !important;
    background: rgba(0,0,0,0.5) !important;
    z-index: 99999 !important;
    justify-content: center !important;
    align-items: center !important;
    display: none !important;
}
.dvtv-kanran-overlay.dvtv-active {
    display: flex !important;
}
.dvtv-kanran-overlay .overlay-content {
    background: #fff !important;
    padding: 20px !important;
    max-width: 92% !important;
    max-height: 90% !important;
    overflow-y: auto !important;
    border-radius: 8px !important;
    position: relative !important;
    width: 850px !important;
    box-shadow: 0 8px 30px rgba(0,0,0,0.25) !important;
}
.dvtv-kanran-overlay .overlay-content h3 {
    margin-top: 0 !important;
}
.dvtv-kanran-overlay .close-overlay {
    position: absolute !important;
    top: 10px !important;
    right: 10px !important;
    background: #f28c38 !important;
    color: #fff !important;
    border: none !important;
    border-radius: 5px !important;
    padding: 5px 12px !important;
    cursor: pointer !important;
    font-weight: bold !important;
    z-index: 1 !important;
}
.dvtv-kanran-overlay .close-overlay:hover {
    background: #d97520 !important;
}

/* --- 未回答バー --- */
.dvtv-kanran-unanswered-bar {
    background: #fce4ec !important;
    text-align: center !important;
    padding: 10px !important;
    border-radius: 6px !important;
    margin-bottom: 10px !important;
    color: #333 !important;
    font-weight: bold !important;
}

/* --- 非表示行 --- */
.dvtv-kanran-wrap table tr.hidden-row td {
    background-color: #f0f0f0 !important;
    color: #999 !important;
    opacity: 0.7 !important;
}

/* --- 編集行 --- */
.dvtv-kanran-wrap .edit-row {
    background: #f9f9f9 !important;
}
.dvtv-kanran-wrap .edit-content {
    padding: 15px !important;
    background: #f9f9f9 !important;
}

/* --- ページネーション --- */
.dvtv-kanran-wrap .pagination-wrap {
    text-align: center !important;
    margin: 20px 0 !important;
}
.dvtv-kanran-wrap .pagination-wrap .page-numbers {
    display: inline-block !important;
    padding: 7px 12px !important;
    margin: 0 2px !important;
    border: 1px solid #ddd !important;
    text-decoration: none !important;
    color: #007bff !important;
    border-radius: 4px !important;
    cursor: pointer !important;
    background: #fff !important;
    font-size: 13px !important;
}
.dvtv-kanran-wrap .pagination-wrap .page-numbers.current,
.dvtv-kanran-wrap .pagination-wrap .page-numbers:hover {
    background-color: #007bff !important;
    color: #fff !important;
    border-color: #007bff !important;
}

/* --- AJAX ローディング --- */
.dvtv-kanran-loading {
    opacity: 0.5 !important;
    position: relative !important;
    pointer-events: none !important;
}
.dvtv-kanran-loading::after {
    content: '読み込み中...' !important;
    position: absolute !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%,-50%) !important;
    background: rgba(255,255,255,0.9) !important;
    padding: 10px 20px !important;
    border-radius: 5px !important;
    font-weight: bold !important;
    color: #333 !important;
    z-index: 10 !important;
}

/* --- 段落 --- */
.dvtv-kanran-wrap p {
    background: none !important;
    color: #333 !important;
}
.dvtv-kanran-wrap a {
    color: #007bff !important;
}
.dvtv-kanran-wrap a:hover {
    color: #0056b3 !important;
}

/* =========================================================
   dvtv_kanran_mine - 自分の回覧板リッチUI (v2.1.0)
========================================================= */
.dvtv-kanran-wrap .dvtv-kanran-mine-table {
    border-collapse: separate !important;
    border-spacing: 0 8px !important;
    width: 100% !important;
    background: transparent !important;
}
.dvtv-kanran-wrap .dvtv-kanran-mine-table thead tr {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
}
.dvtv-kanran-wrap .dvtv-kanran-mine-table thead th {
    color: #fff !important;
    padding: 12px 16px !important;
    font-weight: 600 !important;
    text-align: left !important;
    border: none !important;
}
.dvtv-kanran-wrap .dvtv-kanran-mine-table thead th:first-child { border-radius: 10px 0 0 10px !important; }
.dvtv-kanran-wrap .dvtv-kanran-mine-table thead th:last-child  { border-radius: 0 10px 10px 0 !important; }

.dvtv-kanran-wrap .dvtv-kanran-mine-table tbody tr {
    background: #fff !important;
    box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
    transition: all 0.2s ease !important;
}
.dvtv-kanran-wrap .dvtv-kanran-mine-table tbody tr:hover {
    box-shadow: 0 4px 16px rgba(0,0,0,0.12) !important;
    transform: translateY(-1px) !important;
}
.dvtv-kanran-wrap .dvtv-kanran-mine-table tbody td {
    padding: 14px 16px !important;
    border: none !important;
    border-top: 1px solid #f0f0f0 !important;
    border-bottom: 1px solid #f0f0f0 !important;
    vertical-align: middle !important;
}
.dvtv-kanran-wrap .dvtv-kanran-mine-table tbody td:first-child {
    border-left: 1px solid #f0f0f0 !important;
    border-radius: 10px 0 0 10px !important;
}
.dvtv-kanran-wrap .dvtv-kanran-mine-table tbody td:last-child {
    border-right: 1px solid #f0f0f0 !important;
    border-radius: 0 10px 10px 0 !important;
}

/* 未確認行（ピンクハイライト） */
.dvtv-kanran-wrap .kanran-row-pending {
    background: linear-gradient(90deg, #fff5f7 0%, #ffeef2 100%) !important;
}
.dvtv-kanran-wrap .kanran-row-pending td {
    border-color: #ffd4dc !important;
}
/* 確認済み行 */
.dvtv-kanran-wrap .kanran-row-done {
    background: linear-gradient(90deg, #f0fdf4 0%, #e8faf0 100%) !important;
    opacity: 0.85 !important;
}
.dvtv-kanran-wrap .kanran-row-done td {
    border-color: #c7f0d8 !important;
}

/* バッジ */
.dvtv-kanran-wrap .kanran-badge {
    display: inline-block !important;
    padding: 5px 12px !important;
    border-radius: 20px !important;
    font-size: 12px !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px !important;
    white-space: nowrap !important;
}
.dvtv-kanran-wrap .kanran-badge-pending {
    background: linear-gradient(135deg, #ff6b6b 0%, #ee5a6f 100%) !important;
    color: #fff !important;
    box-shadow: 0 2px 6px rgba(238,90,111,0.35) !important;
    animation: dvtv-kanran-pulse 2s ease-in-out infinite !important;
}
.dvtv-kanran-wrap .kanran-badge-done {
    background: linear-gradient(135deg, #48bb78 0%, #38a169 100%) !important;
    color: #fff !important;
    box-shadow: 0 2px 6px rgba(56,161,105,0.3) !important;
}
@keyframes dvtv-kanran-pulse {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.04); }
}

.dvtv-kanran-wrap .kanran-state-cell {
    width: 110px !important;
    text-align: center !important;
}

/* アクションボタン */
.dvtv-kanran-wrap .kanran-btn-primary {
    background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
    color: #fff !important;
    border: none !important;
    padding: 7px 14px !important;
    border-radius: 6px !important;
    text-decoration: none !important;
    font-weight: 600 !important;
    transition: all 0.2s !important;
    display: inline-block !important;
}
.dvtv-kanran-wrap .kanran-btn-primary:hover {
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 12px rgba(102,126,234,0.4) !important;
    color: #fff !important;
}

/* ダークモード対応 */
body[data-theme="dark"] .dvtv-kanran-wrap .dvtv-kanran-mine-table tbody tr,
.dvtv-kanran-wrap.dvtv-dark .dvtv-kanran-mine-table tbody tr {
    background: #2a2a2a !important;
}
body[data-theme="dark"] .dvtv-kanran-wrap .dvtv-kanran-mine-table tbody td,
.dvtv-kanran-wrap.dvtv-dark .dvtv-kanran-mine-table tbody td {
    color: #e0e0e0 !important;
    border-color: #3a3a3a !important;
}
body[data-theme="dark"] .dvtv-kanran-wrap .kanran-row-pending,
.dvtv-kanran-wrap.dvtv-dark .kanran-row-pending {
    background: linear-gradient(90deg, #3a2030 0%, #3e2535 100%) !important;
}
body[data-theme="dark"] .dvtv-kanran-wrap .kanran-row-done,
.dvtv-kanran-wrap.dvtv-dark .kanran-row-done {
    background: linear-gradient(90deg, #1f3028 0%, #24362d 100%) !important;
}
