/* ====================================================
   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;
}
