/* ========================================
   admin-css-hadih.css
   管理画面スタイル（hadih- 接頭辞統一）
======================================== */

/* 管理画面基本UI */
.hadih-container { max-width: 1200px; margin: 0 auto; background: #fff; padding: 30px; border-radius: 8px; box-shadow: 0 4px 6px rgba(0,0,0,0.1); font-family: sans-serif; }
.hadih-container h1 { text-align: center; color: #2c3e50; margin-bottom: 30px; font-size: 1.8em; }
.hadih-section { margin-bottom: 35px; padding: 20px; border: 1px solid #ddd; border-radius: 6px; background: #fcfcfc; }
.hadih-section-title { margin-top: 0; font-size: 1.25em; color: #2c3e50; border-bottom: 2px solid #4a90e2; padding-bottom: 5px; margin-bottom: 15px; }
.hadih-instruction { font-size: 0.85em; color: #555; margin-bottom: 15px; line-height: 1.5; }
.hadih-container textarea { width: 100%; height: 120px; padding: 10px; box-sizing: border-box; border: 1px solid #ccc; border-radius: 4px; font-family: monospace; resize: vertical; }
.hadih-btn-group { display: flex; gap: 10px; }
.hadih-container button { background-color: #4a90e2; color: white; border: none; padding: 10px 20px; border-radius: 4px; cursor: pointer; font-weight: bold; font-size: 0.95em; }
.hadih-container button:hover { opacity: 0.9; }
.hadih-container .hadih-btn-green { background-color: #2ecc71; font-size: 1.1em; padding: 12px 30px; }
.hadih-container .hadih-btn-secondary { background-color: #7f8c8d; }
.hadih-btn-small-blue { background-color: #3498db !important; padding: 6px 12px !important; font-size: 0.85em !important; }

.hadih-edit-controls { display: flex; gap: 15px; margin-bottom: 15px; align-items: center; }
.hadih-search-box-mini { flex: 1; padding: 10px; border: 1px solid #ccc; border-radius: 4px; font-size: 0.9em; }

/* AI提出用テキストエリア：3行程度 */
#hadih-ai-prompt-area { height: 72px !important; }

/* 警告アラートスタイル */
.hadih-warning-alert {
    padding: 10px 14px;
    background-color: #fff5f5;
    border: 1px solid #ffcccc;
    border-left: 5px solid #e74c3c;
    border-radius: 4px;
    color: #c0392b;
    font-size: 0.9em;
    line-height: 1.5;
    cursor: pointer;
}
.hadih-warning-alert:hover { background-color: #ffe8e8; }
/* 未登録用語リスト：3行程度に制限 */
.hadih-warning-word-list {
    margin-top: 5px;
    max-height: 4.5em;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    font-size: 0.92em;
    color: #a93226;
}

/* 編集アコーディオン：1行3列グリッド */
.hadih-edit-accordion-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 12px;
    align-items: start;
}

.hadih-edit-genre-group { border: 1px solid #ccc; border-radius: 4px; overflow: hidden; }
.hadih-edit-genre-header { background: #eaedf1; padding: 10px 15px; font-weight: bold; color: #2c3e50; cursor: pointer; display: flex; justify-content: space-between; align-items: center; user-select: none; font-size: 0.9em; }
/* コンテンツ：デフォルト閉じ */
.hadih-edit-genre-content { display: none; padding: 10px; background: #fff; overflow-x: auto; }
.hadih-edit-genre-group.hadih-open .hadih-edit-genre-content { display: block; }
/* 開いているグループは全幅に展開 */
.hadih-edit-genre-group.hadih-open { grid-column: 1 / -1; }

/* 未確定グループ：淡い黄色背景 */
.hadih-edit-genre-group.hadih-pending { border-color: #f0c040; }
.hadih-edit-genre-group.hadih-pending .hadih-edit-genre-header { background: #fffbe6; color: #7a5c00; border-bottom: 1px solid #f0c040; }
.hadih-pending-badge { font-size: 0.75em; font-weight: bold; color: #fff; background: #e6a817; padding: 2px 8px; border-radius: 10px; margin-left: 8px; vertical-align: middle; }
.hadih-accordion-arrow { font-size: 0.8em; }

/* 確定済み行：説明文3行省略 */
.hadih-desc-clamp { display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; color: #555; }

.hadih-table { width: 100%; border-collapse: collapse; font-size: 0.85em; text-align: left; min-width: 1000px; }
.hadih-table th, .hadih-table td { border: 1px solid #ddd; padding: 8px; vertical-align: middle; }
.hadih-edit-tr:hover { background: #fcfcfc; }
.hadih-edit-tr.hadih-tr-pending { background: #fffdf0; }
.hadih-btn-edit-row { background-color: #f39c12 !important; padding: 5px 10px !important; font-size: 0.8em !important; margin-bottom: 5px; display: inline-block; width: 100%; box-sizing: border-box; }
.hadih-btn-delete-row { background-color: #7f8c8d !important; padding: 5px 10px !important; font-size: 0.8em !important; display: inline-block; width: 100%; box-sizing: border-box; }

/* 編集モーダル */
.hadih-modal-overlay { display: none; position: fixed; top:0; left:0; width:100%; height:100%; background:rgba(0,0,0,0.5); z-index:9999; justify-content:center; align-items:center; }
.hadih-modal-overlay.hadih-show { display: flex; }
.hadih-modal-content { background:#fff; padding:25px; border-radius:8px; width:90%; max-width:650px; box-shadow:0 4px 15px rgba(0,0,0,0.2); display: flex; flex-direction: column; max-height: 85vh; }
.hadih-modal-content h3 { margin-top:0; border-bottom:2px solid #f39c12; padding-bottom:8px; margin-bottom: 15px; }
.hadih-modal-scroll-area { overflow-y: auto; flex: 1; padding-right: 5px; margin-bottom: 15px; }
.hadih-modal-grid { display: grid; grid-template-columns: 140px 1fr; gap: 12px; align-items: center; }
.hadih-modal-grid label { font-weight: bold; font-size: 0.9em; color:#444; }
.hadih-modal-grid input[type="text"], .hadih-modal-grid textarea { width:100%; box-sizing:border-box; padding:8px; border:1px solid #ccc; border-radius:4px; font-family:inherit; }
.hadih-modal-grid textarea { height: 600px; resize: vertical; }
.hadih-modal-hr { border: 0; border-top: 2px dashed #ddd; margin: 20px 0 15px 0; }
.hadih-modal-content h4 { margin: 0 0 10px 0; color: #2c3e50; }

.hadih-modal-article-row { display: flex; gap: 8px; margin-bottom: 8px; align-items: center; }
.hadih-modal-article-row input[type="text"] { padding: 6px; border: 1px solid #ccc; border-radius: 4px; font-size: 0.9em; box-sizing: border-box; }
.hadih-modal-article-text { flex: 2; }
.hadih-modal-article-url { flex: 3; }
.hadih-btn-delete-article { background-color: #7f8c8d !important; padding: 6px 10px !important; font-size: 0.85em !important; }
.hadih-modal-actions { display:flex; justify-content: flex-end; gap:10px; border-top: 1px solid #eee; padding-top: 15px; }

/* --- 3番：一般ユーザー閲覧画面シミュレーター --- */
.hadih-hero { background-size: cover; background-position: center; border-radius: 10px; padding: 40px 30px; margin-bottom: 20px; display: flex; align-items: center; justify-content: center; }
.hadih-hero .hadih-search-box-wrap { margin-bottom: 0; width: 100%; max-width: 700px; }
.hadih-hero .hadih-search-box { background: rgba(255,255,255,0.78); backdrop-filter: blur(4px); }

.hadih-search-box-wrap { position: relative; margin-bottom: 25px; }
.hadih-search-icon { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); font-size: 1em; pointer-events: none; }
.hadih-search-box { width: 100%; padding: 12px 12px 12px 42px; font-size: 1em; border: 1px solid #ccc; border-radius: 999px; box-sizing: border-box; outline: none; }
.hadih-search-box:focus { border-color: #4a90e2; box-shadow: 0 0 0 2px rgba(74,144,226,0.2); }

/* スライダー */
.hadih-slider-section { position: relative; overflow: hidden; border-radius: 10px; margin-bottom: 30px; }
.hadih-slider-track { display: flex; transition: transform 0.5s ease; }
.hadih-slide { min-width: 100%; background-size: cover; background-position: center; padding: 30px 20px; display: flex; gap: 16px; justify-content: center; align-items: flex-start; box-sizing: border-box; }

/* スライド内カード */
.hadih-slide-card { background: #fff; border-radius: 10px; padding: 14px; width: 160px; flex-shrink: 0; display: flex; flex-direction: column; align-items: center; gap: 8px; box-shadow: 0 2px 8px rgba(0,0,0,0.12); }
.hadih-slide-card-img { width: 100%; height: 100px; overflow: hidden; border-radius: 6px; display: flex; align-items: center; justify-content: center; background: #f5f5f5; }
.hadih-slide-card-img img { width: 100%; height: 100%; object-fit: cover; }
.hadih-slide-card-noimg { font-size: 0.75em; color: #aaa; }
.hadih-slide-card-word { font-size: 0.9em; font-weight: bold; color: #2c3e50; text-align: center; margin: 0; }
.hadih-slide-card-btn { background: #e0e0e0; color: #555; border: none; border-radius: 999px; padding: 5px 14px; font-size: 0.8em; cursor: pointer; }
.hadih-slide-card-btn:hover { background: #c8c8c8; }

/* ドットナビ */
.hadih-slider-dots { text-align: center; padding: 8px 0; }
.hadih-slider-dot { display: inline-block; width: 8px; height: 8px; border-radius: 50%; background: #ccc; margin: 0 4px; cursor: pointer; transition: background 0.2s; }
.hadih-slider-dot.hadih-dot-active { background: #4a90e2; }

.hadih-category-block { margin-bottom: 20px; }
.hadih-category-main-title { font-size: 1.4em; color: #2c3e50; margin: 0 0 15px 0; padding-left: 5px; border-left: 5px solid #2c3e50; line-height: 1.2; }
.hadih-category-divider { border: 0; border-top: 3px double #ccc; margin: 30px 0; }

.hadih-accordion-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; align-items: start; }

.hadih-genre-section { border: 1px solid #ddd; border-radius: 12px; overflow: hidden; background: #fff; box-shadow: none; }
.hadih-genre-section.hadih-open { grid-column: 1 / -1; }

.hadih-genre-header { padding: 15px 20px; font-size: 1.05em; font-weight: bold; color: #2c3e50; background: #fff; border: 1px solid #ccc; cursor: pointer; display: flex; align-items: center; justify-content: space-between; user-select: none; transition: background 0.15s ease; }
.hadih-genre-header:hover { background: #f5f5f5; }

.hadih-genre-toggle-icon { display: inline-block; width: 10px; height: 10px; border-top: 2px solid #2c3e50; border-right: 2px solid #2c3e50; transform: rotate(135deg); transition: transform 0.2s ease; margin-right: 5px; }
.hadih-genre-section.hadih-open .hadih-genre-toggle-icon { transform: rotate(-45deg); margin-top: 5px; }

.hadih-genre-content { display: none; padding: 20px 20px 5px 20px; background: #fff; border-top: 1px solid #eee; }
.hadih-genre-section.hadih-open .hadih-genre-content { display: block; }

.hadih-term-item { padding: 20px; border: 1px solid #eee; border-radius: 6px; background: #fff; margin-bottom: 20px; box-shadow: 0 2px 4px rgba(0,0,0,0.02); display: flex; gap: 20px; align-items: flex-start; justify-content: space-between; }

.hadih-card-left { flex: 2; min-width: 0; }
.hadih-card-right { flex: 1; max-width: 320px; width: 100%; padding: 15px; box-sizing: border-box; }

.hadih-term-item.hadih-no-right-content .hadih-card-left { flex: 1; }
.hadih-term-item.hadih-no-right-content .hadih-card-right { display: none !important; }

.hadih-term-header { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; flex-wrap: wrap; }
.hadih-term-genre { color: white; padding: 3px 10px; border-radius: 4px; font-size: 0.8em; font-weight: bold; }

.hadih-title-wrap { display: flex; align-items: baseline; gap: 6px; flex-wrap: wrap; }
.hadih-term-title { font-size: 1.3em; font-weight: bold; margin: 0; color: #232323; line-height: 1.2; }
.hadih-term-yomi { font-size: 0.85em; color: #666; }

.hadih-tag-100yen-text { color: #555555; font-size: 0.82em; font-weight: normal; margin-left: 6px; display: inline-block; user-select: none; }

.hadih-term-desc { margin: 0; line-height: 1.6; color: #333; font-size: 0.95em; }
.hadih-line { border: 0; border-top: 1px solid #eee; margin: 12px 0; }

.hadih-term-rel { font-size: 0.9em; color: #555; }
.hadih-rel-tag { display: inline-block; background: #f0f0f0; border: 1px solid #ddd; border-radius: 4px; padding: 2px 8px; margin-right: 5px; font-size: 0.85em; color: #4a90e2; font-weight: bold; cursor: pointer; transition: background-color 0.1s ease; user-select: none; }
.hadih-rel-tag:hover { background-color: #e5e9ec; color: #2475d2; }

.hadih-term-note { padding: 12px 15px; background: #fff5f5; border-left: 4px solid #ff7675; border-radius: 0 4px 4px 0; color: #c0392b; font-size: 0.9em; line-height: 1.5; }

.hadih-card-image-wrapper { width: 100%; margin-bottom: 15px; border-radius: 4px; overflow: hidden; border: 1px solid #eee; display: flex; }
.hadih-card-image { width: 100%; height: auto; object-fit: cover; max-height: 180px; }

.hadih-articles-title { font-size: 0.95em; font-weight: bold; color: #2c3e50; margin: 0 0 10px 0; display: flex; align-items: center; gap: 5px; border-bottom: 1px solid #eee; padding-bottom: 5px; }
.hadih-articles-list { margin: 0; padding-left: 18px; }
.hadih-articles-list li { margin-bottom: 8px; font-size: 0.88em; line-height: 1.4; color: #333; }
.hadih-articles-link { color: #4a90e2; text-decoration: none; font-weight: 500; word-break: break-all; }
.hadih-articles-link:hover { text-decoration: underline; }

.hadih-hidden { display: none !important; }

@media (max-width: 900px) {
    .hadih-edit-accordion-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .hadih-accordion-grid { grid-template-columns: 1fr; }
    .hadih-term-item { flex-direction: column; gap: 15px; }
    .hadih-card-right { max-width: 100%; }
}
