/* ═══════════════ Pages d'aide — composants partagés ═══════════════ */

/* ── Table des matières ── */
.toc-box { background: var(--accent-faint); border: 1px solid var(--accent-glow); border-radius: 14px; padding: 1.5rem 1.75rem; }
.toc-title { font-family: 'Cinzel',serif; font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-muted); margin-bottom: 1rem; }
.toc-list { list-style: none; display: flex; flex-direction: column; gap: 0.45rem; }
.toc-list li { display: flex; align-items: center; gap: 0.6rem; }
.toc-num {
    flex-shrink: 0; width: 1.5rem; height: 1.5rem;
    background: var(--accent-glow); border: 1px solid var(--accent-mid);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-family: 'Cinzel',serif; font-size: 0.6rem; color: var(--accent-soft); font-weight: 700;
}
.toc-list a { color: var(--text-secondary); text-decoration: none; font-size: 0.83rem; transition: color 0.2s; }
.toc-list a:hover { color: var(--accent-light); }

/* ── Section (carte avec en-tête + corps) ── */
.aide-section { background: var(--bg-surface); border: 1px solid var(--border); border-radius: 16px; overflow: hidden; }
.aide-section-header {
    display: flex; align-items: center; gap: 1rem;
    padding: 1.35rem 1.75rem; border-bottom: 1px solid var(--border);
    background: var(--accent-faint);
}
.aide-section-icon {
    flex-shrink: 0; width: 2.4rem; height: 2.4rem;
    background: var(--accent-glow); border: 1px solid var(--accent-mid);
    border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.1rem;
}
.aide-section-header h2 { font-family: 'Cinzel',serif; font-weight: 700; font-size: 1rem; color: var(--accent-bright); letter-spacing: 0.04em; }
.aide-section-header p { font-size: 0.78rem; color: var(--text-muted); margin-top: 0.15rem; }
.aide-section-body { padding: 1.5rem 1.75rem; display: flex; flex-direction: column; gap: 1.5rem; }
.aide-section-body p { font-size: 0.88rem; color: var(--text-secondary); line-height: 1.75; }
.aide-section-body p strong { color: var(--accent-bright); font-weight: 600; }
.aide-section-body a { color: var(--accent-soft); text-decoration: underline; text-underline-offset: 3px; transition: color 0.2s; }
.aide-section-body a:hover { color: var(--accent-light); }

.aide-sub { font-family: 'Cinzel',serif; font-size: 0.8rem; font-weight: 700; color: var(--accent-light); letter-spacing: 0.07em; margin-bottom: -0.75rem; }

/* ── Étapes numérotées ── */
.aide-steps { display: flex; flex-direction: column; gap: 0.75rem; }
.aide-step { display: flex; gap: 0.9rem; align-items: flex-start; }
.step-num {
    flex-shrink: 0; width: 1.6rem; height: 1.6rem;
    background: var(--accent-glow); border: 1px solid var(--accent-dim);
    border-radius: 50%; display: flex; align-items: center; justify-content: center;
    font-family: 'Cinzel',serif; font-size: 0.65rem; color: var(--accent-light); font-weight: 700; margin-top: 0.1rem;
}
.step-text { font-size: 0.88rem; color: var(--text-secondary); line-height: 1.7; }
.step-text strong { color: var(--accent-bright); }

/* ── Listes ── */
.aide-list { display: flex; flex-direction: column; gap: 0.5rem; padding-left: 0.25rem; }
.aide-list li { position: relative; padding-left: 1.1rem; font-size: 0.88rem; color: var(--text-secondary); line-height: 1.65; list-style: none; }
.aide-list li::before { content: '›'; position: absolute; left: 0; top: 0; color: var(--accent-strong); }
.aide-list li strong { color: var(--accent-bright); }

/* ── Grille d'outils ── */
.tools-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 0.75rem; }
.tool-card { display: flex; gap: 0.75rem; align-items: flex-start; background: rgba(255,255,255,0.02); border: 1px solid var(--border); border-radius: 10px; padding: 0.85rem 1rem; }
.tool-icon {
    flex-shrink: 0; width: 2rem; height: 2rem;
    background: var(--accent-glow); border: 1px solid var(--accent-mid);
    border-radius: 7px; display: flex; align-items: center; justify-content: center;
    font-size: 0.8rem; color: var(--accent-light); font-family: 'Inter', sans-serif; font-weight: 700;
}
.tool-label { font-family: 'Cinzel',serif; font-size: 0.72rem; color: var(--accent-bright); letter-spacing: 0.04em; }
.tool-desc { font-size: 0.76rem; color: var(--text-muted); margin-top: 0.2rem; line-height: 1.5; }
.tool-kbd { display: inline-block; font-family: 'Inter',sans-serif; font-size: 0.6rem; letter-spacing: 0.04em; background: var(--border); border: 1px solid var(--border-strong); border-radius: 4px; padding: 0.1rem 0.35rem; color: var(--text-secondary); margin-top: 0.25rem; }

/* ── Tableau raccourcis ── */
.shortcuts-table { width: 100%; border-collapse: collapse; }
.shortcuts-table th { font-family: 'Cinzel',serif; font-size: 0.65rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--text-faint); text-align: left; padding: 0 0 0.6rem; border-bottom: 1px solid var(--border); }
.shortcuts-table td { padding: 0.55rem 0; font-size: 0.84rem; color: var(--text-secondary); border-bottom: 1px solid var(--bg-surface); vertical-align: middle; }
.shortcuts-table tr:last-child td { border-bottom: none; }
.shortcuts-table td:first-child { padding-right: 1rem; }
.shortcuts-table kbd,
.aide-section-body kbd { display: inline-block; font-family: 'Inter',sans-serif; font-size: 0.7rem; background: var(--border); border: 1px solid rgba(255,255,255,0.14); border-radius: 5px; padding: 0.15rem 0.4rem; color: var(--accent-light); }

/* ── Encadrés info / warning ── */
.aide-info { display: flex; gap: 0.75rem; align-items: flex-start; background: var(--color-info-bg); border: 1px solid var(--color-info-border); border-radius: 10px; padding: 0.9rem 1.1rem; }
.aide-info-icon { flex-shrink: 0; font-size: 1rem; margin-top: 0.05rem; }
.aide-info p { font-size: 0.82rem; color: var(--color-info); line-height: 1.65; margin: 0; }
.aide-info p strong { color: var(--color-info-light); }

.aide-warn { display: flex; gap: 0.75rem; align-items: flex-start; background: var(--color-warning-bg); border: 1px solid var(--color-warning-border); border-radius: 10px; padding: 0.9rem 1.1rem; }
.aide-warn p { font-size: 0.82rem; color: var(--color-warning); line-height: 1.65; margin: 0; }
.aide-warn p strong { color: var(--color-warning-light); }

/* ── Ornement séparateur ── */
.aide-ornament { display: flex; align-items: center; justify-content: center; gap: 0.75rem; color: var(--accent-dim); }
.aide-ornament::before, .aide-ornament::after { content: ''; flex: 1; height: 1px; background: linear-gradient(to right, transparent, var(--accent-mid), transparent); }

/* ── Responsive ── */
@media (max-width: 640px) {
    .aide-hero { padding: 3rem 1rem 2rem; }
    .aide-section-header { padding: 1.1rem 1.25rem; }
    .aide-section-body { padding: 1.25rem; }
    .tools-grid { grid-template-columns: 1fr; }
}
