/* ═══════════════════════════════════════════════════════════
   Génogramme Familial – genogramme.css  v4.5
   McGoldrick & Gerson · Constellations Familiales
═══════════════════════════════════════════════════════════ */

*,*::before,*::after { box-sizing: border-box; margin: 0; padding: 0; }

body {
    --theme-accent: #d4a017;
    --theme-accent-dark: #9b8500;
    --theme-surface: #fffef7;
    --theme-panel: #fff8db;
    --theme-panel-soft: #f5e6a3;
    --theme-title: #3d2e00;
    --theme-subtitle: #6b5a00;
    --theme-connector: #8b7500;
    --balance-risk-soft: rgba(229,62,62,.18);
    --balance-risk-mid: rgba(229,62,62,.12);
    --balance-growth-soft: rgba(56,161,105,.18);
    --balance-growth-mid: rgba(56,161,105,.12);
    --balance-fill-start: #f6e05e;
    --balance-fill-end: #38a169;
    font-family: 'Segoe UI', Arial, sans-serif;
    background:
        radial-gradient(circle at top left, rgba(240, 199, 94, .45), transparent 28%),
        radial-gradient(circle at top right, rgba(212, 160, 23, .22), transparent 24%),
        linear-gradient(135deg, #fffde7 0%, #fff8db 46%, #f5e6a3 100%);
    min-height: 100vh;
    padding: 16px;
    color: #2d3748;
}

.container {
    max-width: 1300px;
    margin: 0 auto;
    background: rgba(255,255,255,.94);
    backdrop-filter: blur(10px);
    border-radius: 18px;
    border: 1px solid rgba(212, 160, 23, .18);
    box-shadow: 0 18px 48px rgba(61,46,0,.14);
    overflow: hidden;
}

/* ── Header ── */
header {
    text-align: center;
    padding: 22px 20px 16px;
    background:
        linear-gradient(135deg, rgba(255,253,231,.98) 0%, rgba(245,230,163,.82) 100%);
    border-bottom: 1px solid rgba(212,160,23,.24);
    position: relative;
}
h1 { font-size: 1.78em; color: var(--theme-title); letter-spacing: -.5px; }
.subtitle { font-size: .86em; color: var(--theme-subtitle); margin-top: 6px; }

/* ── Lien retour accueil ── */
.geno-home-link {
    position: absolute;
    top: 10px;
    left: 12px;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    text-decoration: none;
    color: var(--theme-subtitle);
    font-size: .75em;
    font-family: 'Segoe UI', Arial, sans-serif;
    padding: 3px 9px 3px 5px;
    border-radius: 20px;
    border: 1px solid transparent;
    transition: background .15s, color .15s, border-color .15s;
    z-index: 5;
    max-width: 180px;
}
.geno-home-link:hover {
    background: rgba(212,160,23,.12);
    color: var(--theme-title);
    border-color: rgba(212,160,23,.25);
    text-decoration: none;
}
.geno-home-logo {
    width: 22px;
    height: 22px;
    border-radius: 4px;
    object-fit: contain;
    flex-shrink: 0;
    display: block;
}
.geno-home-icon { font-size: 1em; line-height: 1; flex-shrink: 0; }
.geno-home-name {
    font-weight: 600;
    font-size: .85em;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
    max-width: 130px;
}

/* ── Tabs ── */
.tabs {
    display: flex;
    gap: 2px;
    padding: 10px 14px 0;
    background: linear-gradient(180deg, rgba(255,253,231,.95), rgba(255,248,219,.88));
    border-bottom: 1px solid rgba(212,160,23,.2);
    flex-wrap: wrap;
}
.tab {
    padding: 8px 16px;
    border: none;
    background: rgba(255,255,255,.72);
    color: #6b5a00;
    cursor: pointer;
    border-radius: 10px 10px 0 0;
    font-size: .85em;
    font-weight: 600;
    transition: background .15s, color .15s, box-shadow .15s;
}
.tab:hover  { background: rgba(255,255,255,.96); box-shadow: 0 6px 14px rgba(212,160,23,.12); }
.tab.active { background: var(--theme-surface); color: var(--theme-title); border-bottom: 2px solid var(--theme-surface); margin-bottom: -2px; box-shadow: 0 -1px 0 rgba(212,160,23,.18), 0 8px 18px rgba(61,46,0,.06); }
.tab-hint {
    display: inline-flex;
    align-items: center;
    margin-left: 8px;
    padding: 1px 7px;
    border-radius: 999px;
    background: rgba(90, 62, 142, .08);
    color: #6b46c1;
    font-size: .72em;
    font-weight: 700;
}

/* ── Tab content ── */
.tab-content { display: none; padding: 16px; background: #fff; }
.tab-content.active { display: block; }

/* ── Form layout ── */
.form-grid { display: flex; flex-direction: column; gap: 10px; }
.form-row  { display: flex; gap: 10px; flex-wrap: wrap; }
.form-group {
    display: flex;
    flex-direction: column;
    gap: 4px;
    min-width: 110px;
    flex: 1;
}
.form-group.flex-2  { flex: 2; }
.form-group.flex-3  { flex: 3; }
.form-group.full-width { flex: 100; }
.form-group.checkboxes { flex-direction: row; align-items: center; gap: 12px; flex-wrap: wrap; padding-top: 18px; }

label {
    font-size: .78em;
    font-weight: 600;
    color: #4a5568;
    text-transform: uppercase;
    letter-spacing: .5px;
    white-space: nowrap;          /* prevent long labels like "Branche familiale" from wrapping */
}
.hint-small {
    font-weight: 400;
    text-transform: none;
    color: #718096;
    font-size: .9em;
    letter-spacing: 0;
    white-space: normal;
}

input[type="text"], input[type="number"], input[type="date"], select, textarea {
    padding: 7px 10px;
    border: 1.5px solid #e2e8f0;
    border-radius: 6px;
    font-size: .88em;
    color: #2d3748;
    background: #fff;
    transition: border-color .15s, box-shadow .15s;
    width: 100%;
    font-family: inherit;
}
input:focus, select:focus, textarea:focus {
    outline: none;
    border-color: #667eea;
    box-shadow: 0 0 0 3px rgba(102,126,234,.15);
}
textarea { resize: vertical; min-height: 60px; }

.checkbox-label {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: .85em;
    cursor: pointer;
    color: #4a5568;
    white-space: nowrap;
}
.checkbox-highlight {
    background: #fff8db;
    border: 1px solid #f6e05e;
    border-radius: 18px;
    padding: 4px 10px;
}
.field-help {
    margin-top: 6px;
    font-size: .74em;
    color: #718096;
}

/* ── Markers ── */
.markers-section-label {
    font-size: .78em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.risk-label     { color: #c53030; }
.strength-label { color: #276749; }
.custom-label   { color: var(--theme-subtitle); }

.markers-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 6px 14px;
    padding: 8px 10px;
    background: #f7fafc;
    border-radius: 6px;
    border: 1px solid #e2e8f0;
}
.age-bands-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 10px 12px;
    margin-top: 8px;
}
.age-band-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 10px 12px;
    background: #fffef8;
    border: 1px solid rgba(212,160,23,.16);
    border-radius: 12px;
    box-shadow: 0 1px 2px rgba(61,46,0,.04);
}
.age-band-label {
    font-size: .74em;
    font-weight: 700;
    color: var(--theme-subtitle);
}
.age-band-card input {
    min-height: 36px;
}
.marker-label {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: .82em;
    cursor: pointer;
    color: #4a5568;
    white-space: nowrap;
}
.marker-label.strength { color: #276749; }
.mk-dot {
    width: 11px; height: 11px;
    border-radius: 50%;
    flex-shrink: 0;
    border: 1px solid rgba(0,0,0,.1);
}

/* ── Buttons ── */
.btn-primary, .btn-secondary, .btn-danger, .btn-info, .btn-sm {
    padding: 8px 14px;
    border: none;
    border-radius: 7px;
    cursor: pointer;
    font-size: .84em;
    font-weight: 600;
    transition: background .15s, transform .1s, box-shadow .15s;
    display: inline-flex;
    align-items: center;
    gap: 4px;
}
.btn-primary   { background: linear-gradient(135deg, var(--theme-accent), var(--theme-accent-dark)); color: #fff; }
.btn-primary:hover { background: linear-gradient(135deg, color-mix(in srgb, var(--theme-accent) 88%, #000), color-mix(in srgb, var(--theme-accent-dark) 88%, #000)); box-shadow: 0 8px 18px rgba(212,160,23,.28); }
.btn-secondary { background: #fffdf6; color: #5c4b11; border: 1px solid rgba(212,160,23,.16); }
.btn-secondary:hover { background: var(--theme-panel); }
.btn-secondary:disabled { opacity: .4; cursor: not-allowed; }
.btn-danger    { background: #fff1f0; color: #c53030; border: 1px solid rgba(197,48,48,.14); }
.btn-danger:hover { background: #ffe1de; }
.btn-info      { background: var(--theme-panel); color: #8a6d1f; border: 1px solid rgba(212,160,23,.2); }
.btn-info:hover { background: color-mix(in srgb, var(--theme-panel) 84%, #ffffff); }
.btn-full      { width: 100%; justify-content: center; padding: 10px; font-size: .9em; }
.btn-sm        { padding: 4px 10px; font-size: .78em; }
button:active  { transform: scale(.97); }

/* ── Toolbar ── */
.toolbar {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    padding: 10px 14px;
    background: linear-gradient(180deg, #fffef7, #fff8db);
    border-top: 1px solid rgba(212,160,23,.16);
    border-bottom: 1px solid rgba(212,160,23,.16);
}
.toolbar-sep {
    width: 1px;
    height: 24px;
    background: #e2e8f0;
    margin: 0 2px;
}
.quick-reference {
    margin: 0 14px;
    border: 1px solid rgba(212,160,23,.18);
    border-top: none;
    background: var(--theme-surface);
    border-radius: 0 0 12px 12px;
    overflow: hidden;
}
.quick-reference summary {
    list-style: none;
    cursor: pointer;
    padding: 10px 14px;
    font-size: .82em;
    font-weight: 700;
    color: var(--theme-title);
    background: linear-gradient(135deg, var(--theme-panel), var(--theme-panel-soft));
}
.quick-reference summary::-webkit-details-marker { display: none; }
.quick-reference-body {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 12px;
    padding: 12px 14px 14px;
}
.quick-ref-card {
    background: #fff;
    border: 1px solid color-mix(in srgb, var(--theme-accent) 55%, #fff);
    border-radius: 10px;
    padding: 10px 12px;
}
.quick-ref-card h4 {
    font-size: .8em;
    color: #5a3e8e;
    margin-bottom: 8px;
    text-transform: uppercase;
    letter-spacing: .4px;
}
.quick-ref-list {
    display: flex;
    flex-direction: column;
    gap: 5px;
    font-size: .79em;
    color: #4a5568;
}
.quick-ref-row {
    display: flex;
    align-items: center;
    gap: 8px;
    line-height: 1.35;
}
.quick-ref-symbol {
    min-width: 34px;
    font-weight: 700;
    color: #2d3748;
}
.quick-ref-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}
.view-filters {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px;
    background: #edf2f7;
    border-radius: 999px;
}
.layer-filters {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 2px;
    background: #f7f4e6;
    border-radius: 999px;
    border: 1px solid rgba(212,160,23,.16);
}
.view-filter {
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #4a5568;
    font-size: .76em;
    font-weight: 700;
    padding: 6px 10px;
    cursor: pointer;
    transition: background .15s, color .15s, box-shadow .15s;
}
.view-filter:hover { background: rgba(255,255,255,.75); }
.view-filter.active {
    background: #fff;
    color: #5a3e8e;
    box-shadow: 0 1px 4px rgba(0,0,0,.12);
}
.layer-filter {
    border: none;
    border-radius: 999px;
    background: transparent;
    color: #6b5a00;
    font-size: .74em;
    font-weight: 700;
    padding: 6px 10px;
    cursor: pointer;
    transition: background .15s, color .15s, box-shadow .15s, opacity .15s;
}
.layer-filter:hover { background: rgba(255,255,255,.75); }
.layer-filter.active {
    background: #fff;
    color: #5a3e8e;
    box-shadow: 0 1px 4px rgba(0,0,0,.12);
}
.layer-filter:not(.active) { opacity: .58; }

/* ── Symbol Palette ── */
.symbol-palette {
    padding: 10px 14px;
    background: linear-gradient(135deg,#fffef7,#fff8db);
    border-bottom: 1px solid rgba(212,160,23,.16);
}
.symbol-palette.collapsed .palette-grid { display: none; }
.symbol-palette.collapsed .palette-header { margin-bottom: 0; }
.palette-header {
    display: flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    margin-bottom: 8px;
}
.palette-title {
    font-size: .8em;
    font-weight: 700;
    color: #5a3e8e;
    letter-spacing: .3px;
}
.palette-gen-row {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: .78em;
    color: #4a5568;
}
.palette-gen-row select { width: auto; padding: 4px 8px; font-size: .85em; }
.palette-gen-row label  { text-transform: none; letter-spacing: 0; font-weight: 600; margin-bottom: 0; }

.palette-grid {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.pal-item {
    cursor: pointer;
    border-radius: 8px;
    border: 2px solid #e2e8f0;
    background: #fff;
    padding: 4px;
    transition: border-color .15s, background .15s, transform .1s, box-shadow .15s;
    display: flex;
    align-items: center;
    justify-content: center;
}
.pal-item:hover {
    border-color: #667eea;
    background: #eef2ff;
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(102,126,234,.2);
}
.pal-item.active {
    border-color: #5a3e8e;
    background: #f0e8ff;
    box-shadow: 0 0 0 3px rgba(90,62,142,.25);
}

/* ── Zoom bar ── */
.zoom-bar {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    background: #f7fafc;
    border-bottom: 1px solid #e2e8f0;
}
.zoom-btn {
    width: 28px; height: 28px;
    border: 1.5px solid #e2e8f0;
    border-radius: 6px;
    background: #fff;
    font-size: 1em;
    font-weight: 700;
    cursor: pointer;
    color: #4a5568;
    display: flex; align-items: center; justify-content: center;
    transition: background .15s;
}
.zoom-btn:hover { background: #edf2f7; }
.zoom-label {
    min-width: 42px;
    text-align: center;
    font-size: .82em;
    font-weight: 700;
    color: #5a3e8e;
}
.zoom-hint {
    font-size: .72em;
    color: #a0aec0;
    margin-left: 6px;
}
.status-message {
    min-height: 22px;
    padding: 4px 14px 0;
    font-size: .8em;
    color: #2b6cb0;
}
.status-message.error {
    color: #c53030;
}
.workspace-hints {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    padding: 8px 14px 2px;
}
.case-cockpit {
    margin: 8px 14px 0;
    padding: 12px 14px;
    border: 1px solid rgba(212,160,23,.18);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,253,231,.92), rgba(255,248,219,.72));
    box-shadow: inset 0 1px 0 rgba(255,255,255,.72);
}
.case-cockpit-header {
    display: flex;
    justify-content: space-between;
    gap: 12px;
    align-items: center;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.case-cockpit-header strong {
    color: var(--theme-title);
    font-size: .98em;
}
.case-cockpit-kicker {
    display: block;
    margin-bottom: 3px;
    font-size: .7em;
    font-weight: 800;
    letter-spacing: .45px;
    text-transform: uppercase;
    color: var(--theme-subtitle);
}
.case-cockpit-summary {
    font-size: .78em;
    color: #6b7280;
    font-weight: 600;
}
.case-cockpit-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
    gap: 10px;
}
.cockpit-card {
    display: flex;
    flex-direction: column;
    gap: 5px;
    padding: 10px 12px;
    border-radius: 12px;
    background: rgba(255,255,255,.76);
    border: 1px solid rgba(212,160,23,.14);
    box-shadow: 0 5px 16px rgba(61,46,0,.05);
}
.cockpit-card.is-actionable {
    cursor: pointer;
    transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.cockpit-card.is-actionable:hover {
    transform: translateY(-1px);
    border-color: rgba(212,160,23,.32);
    box-shadow: 0 8px 18px rgba(61,46,0,.09);
}
.cockpit-card.active {
    border-color: rgba(90,62,142,.34);
    box-shadow: 0 8px 18px rgba(90,62,142,.1);
}
.cockpit-card-label {
    font-size: .72em;
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: .4px;
    color: #7c6a2e;
}
.cockpit-card-value {
    font-size: 1.3em;
    font-weight: 800;
    color: #2d3748;
}
.cockpit-card-meta {
    font-size: .76em;
    color: #718096;
    line-height: 1.4;
}
.hint-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 4px 10px;
    border-radius: 999px;
    background: #f7fafc;
    border: 1px solid #e2e8f0;
    color: #4a5568;
    font-size: .74em;
    font-weight: 600;
}
.selection-quick-actions {
    margin: 8px 14px 0;
    padding: 10px 12px;
    border: 1px solid #cbd5e0;
    border-radius: 12px;
    background: linear-gradient(135deg, #f8fbff, #f7f4ff);
    display: flex;
    gap: 12px;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}
.selection-quick-info {
    display: flex;
    flex-direction: column;
    gap: 3px;
}
.selection-quick-label {
    font-size: .72em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .45px;
    color: #5a3e8e;
}
.selection-quick-info strong {
    color: #2d3748;
    font-size: .96em;
}
.selection-quick-meta {
    font-size: .78em;
    color: #718096;
}
.selection-quick-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-top: 4px;
}
.selection-quick-checklist {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-top: 10px;
}
.selection-task-chip {
    border: 1px dashed rgba(139, 107, 0, .35);
    background: rgba(255, 248, 220, .88);
    color: #5c4600;
    border-radius: 999px;
    padding: 6px 10px;
    font-size: .72em;
    font-weight: 700;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    cursor: pointer;
}
.selection-task-chip:hover {
    border-color: rgba(139, 107, 0, .6);
    background: #fff7d6;
}
.selection-task-chip.done {
    border-style: solid;
    border-color: rgba(56, 161, 105, .35);
    background: rgba(240, 255, 244, .95);
    color: #22543d;
}
.selection-summary-pill {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    padding: 3px 8px;
    border-radius: 999px;
    font-size: .72em;
    font-weight: 700;
}
.selection-summary-pill.risk {
    background: rgba(229, 62, 62, .1);
    color: #c53030;
}
.selection-summary-pill.strength {
    background: rgba(56, 161, 105, .12);
    color: #276749;
}
.selection-summary-pill.completeness {
    background: rgba(90, 62, 142, .1);
    color: #5a3e8e;
}
.selection-summary-pill.age-bands {
    background: rgba(14,165,233,.12);
    color: #0f5f87;
}
.selection-quick-buttons {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
}
.selection-quick-builder {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 280px;
    padding: 8px 10px;
    border-radius: 10px;
    background: rgba(255, 253, 231, .9);
    border: 1px solid rgba(212, 160, 23, .18);
}
.selection-quick-builder-label {
    font-size: .72em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .45px;
    color: #8a6d1f;
}
.selection-quick-builder-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    align-items: center;
}
.selection-quick-batch {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.selection-quick-batch input {
    width: 58px;
    min-width: 58px;
    text-align: center;
}
.toast-stack {
    position: fixed;
    right: 16px;
    bottom: 16px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 9999;
    pointer-events: none;
}
.toast {
    min-width: 240px;
    max-width: 360px;
    padding: 10px 12px;
    border-radius: 10px;
    box-shadow: 0 10px 24px rgba(0,0,0,.16);
    background: #2b6cb0;
    color: #fff;
    font-size: .84em;
    line-height: 1.35;
    opacity: 0;
    transform: translateY(8px);
    transition: opacity .18s ease, transform .18s ease;
}
.toast.show {
    opacity: 1;
    transform: translateY(0);
}
.toast.error {
    background: #c53030;
}
.autosave-controls {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    margin-top: 10px;
}
.autosave-info {
    margin-top: 8px;
    font-size: .9em;
    color: #4a5568;
}

/* ── Canvas ── */
.canvas-container {
    background:
        linear-gradient(rgba(212,160,23,.09) 1px, transparent 1px),
        linear-gradient(90deg, rgba(212,160,23,.09) 1px, transparent 1px),
        linear-gradient(180deg, #fffef9, #fffdf1);
    background-size: 36px 36px, 36px 36px, auto;
    overflow: hidden;
    border-bottom: 1px solid rgba(212,160,23,.16);
    position: relative;
    min-height: 420px;
}
#genogramSVG {
    display: block;
    background: transparent;
    cursor: default;
    user-select: none;
    -webkit-user-select: none;
}

/* ── Tooltip ── */
.rel-tooltip {
    position: fixed;
    background: #2d3748;
    color: #fff;
    padding: 5px 10px;
    border-radius: 6px;
    font-size: .78em;
    max-width: 280px;
    pointer-events: none;
    z-index: 9999;
    box-shadow: 0 2px 8px rgba(0,0,0,.3);
    line-height: 1.4;
}

/* ── Relation type hint ── */
.rel-type-hint {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #fffde7;
    border: 1px solid #e6cc4a;
    border-radius: 8px;
    padding: 7px 14px;
    margin-top: 4px;
    font-size: 13px;
    color: #5a4a00;
    animation: fadeIn 0.18s ease;
}
.rel-hint-icon {
    font-family: monospace;
    font-size: 15px;
    font-weight: bold;
    color: #8a6d1f;
    min-width: 40px;
    text-align: center;
    letter-spacing: 0.08em;
}
.rel-hint-desc { color: #7a6200; }

/* ── Edit Panel ── */
.edit-panel {
    margin-top: 14px;
    padding: 14px;
    background: #fffbf0;
    border: 2px solid #f6d860;
    border-radius: 10px;
}
.edit-panel h4 {
    font-size: .9em;
    color: #744210;
    margin-bottom: 10px;
    text-transform: uppercase;
    letter-spacing: .5px;
}
.edit-btns {
    display: flex;
    gap: 8px;
    margin-top: 12px;
    justify-content: flex-end;
}

/* ── Context Panel ── */
.context-panel { display: flex; flex-direction: column; gap: 12px; }

.events-layout,
.analysis-grid {
    display: grid;
    grid-template-columns: 1.15fr .85fr;
    gap: 14px;
    margin-top: 14px;
}
.analysis-summary-panel { margin-top: 14px; }
.events-column,
.analysis-panel {
    background: linear-gradient(180deg, #fffefb, #fffaf0);
    border: 1px solid rgba(212,160,23,.14);
    border-radius: 14px;
    padding: 14px;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.6);
}
.events-column h4,
.analysis-panel h4 {
    font-size: .85em;
    font-weight: 700;
    color: #5a3e8e;
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-bottom: 10px;
}
.events-list,
.analysis-insights {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.member-timeline-panel {
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.event-card,
.analysis-card {
    background: #fff;
    border: 1px solid rgba(212,160,23,.12);
    border-radius: 10px;
    padding: 10px 12px;
}
.timeline-card {
    position: relative;
    border-radius: 14px;
    background: linear-gradient(180deg, rgba(255,255,255,.98), rgba(255,250,235,.95));
    border: 1px solid rgba(212,160,23,.16);
    padding: 12px 14px 12px 24px;
    box-shadow: 0 6px 18px rgba(107, 90, 0, .06);
}
.timeline-card::before {
    content: '';
    position: absolute;
    left: 10px;
    top: 12px;
    bottom: 12px;
    width: 2px;
    background: linear-gradient(180deg, rgba(212,160,23,.88), rgba(240,199,94,.3));
}
.timeline-card::after {
    content: '';
    position: absolute;
    left: 5px;
    top: 18px;
    width: 12px;
    height: 12px;
    border-radius: 50%;
    background: #fff8de;
    border: 2px solid #d4a017;
    box-sizing: border-box;
}
.timeline-card h5 {
    margin: 0 0 4px;
    color: #4e3e00;
    font-size: .9em;
}
.timeline-meta {
    color: #7a6a36;
    font-size: .72em;
    font-weight: 700;
    margin-bottom: 6px;
}
.timeline-card p {
    margin: 0;
    line-height: 1.45;
    color: #2d3748;
}
.event-card-header {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 6px;
}
.event-date,
.event-type,
.event-link-badge,
.event-member-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .72em;
    border-radius: 999px;
    padding: 2px 8px;
}
.event-date { background: #eef2ff; color: #4c51bf; font-weight: 700; }
.event-type { background: #edf2f7; color: #4a5568; }
.event-link-badge { background: #fff8db; color: #8a6d1f; font-weight: 700; }
.event-member-badge { background: #ebf8ff; color: #2b6cb0; }
.age-band-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    border-radius: 999px;
    padding: 2px 8px;
    background: #ebf8ff;
    color: #0f5f87;
    font-size: .72em;
    font-weight: 700;
}
.event-desc {
    font-size: .84em;
    color: #2d3748;
    line-height: 1.45;
}
.event-members {
    display: flex;
    flex-wrap: wrap;
    gap: 5px;
    margin-top: 8px;
}
.prompt-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.prompt-card {
    background: #fff;
    border-left: 4px solid #667eea;
    border-radius: 8px;
    padding: 10px 12px;
    font-size: .84em;
    line-height: 1.45;
    color: #4a5568;
}
.pattern-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}
.pattern-btn {
    border: 1px solid #e2e8f0;
    background: #fff;
    border-radius: 999px;
    padding: 6px 10px;
    cursor: pointer;
    font-size: .78em;
    color: #4a5568;
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: all .15s ease;
}
.pattern-btn:hover {
    border-color: #667eea;
    background: #eef2ff;
}
.pattern-btn.active {
    border-color: #5a3e8e;
    background: #f0e8ff;
    color: #5a3e8e;
    box-shadow: 0 0 0 3px rgba(90,62,142,.12);
}
.pattern-dot,
.life-long-dot {
    width: 10px;
    height: 10px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}
.life-long-dot { background: #d4a017; }
.pattern-summary {
    margin-top: 12px;
    min-height: 48px;
    padding: 10px 12px;
    border-radius: 8px;
    background: #fff;
    border: 1px solid #e2e8f0;
    font-size: .82em;
    color: #4a5568;
    line-height: 1.45;
}
.empty-state {
    color: #a0aec0;
    font-style: italic;
}
.analysis-card h5 {
    font-size: .82em;
    color: #2d3748;
    margin-bottom: 6px;
}
.analysis-card ul {
    padding-left: 16px;
    display: flex;
    flex-direction: column;
    gap: 4px;
    font-size: .82em;
    color: #4a5568;
}
.analysis-card li { line-height: 1.4; }
.analysis-note {
    margin-top: 8px;
    font-size: .78em;
    color: #5a3e8e;
    background: #faf5ff;
    border-radius: 6px;
    padding: 7px 9px;
}
.balance-meter {
    position: relative;
    width: 100%;
    height: 12px;
    border-radius: 999px;
    background: linear-gradient(90deg, var(--balance-risk-soft) 0%, var(--balance-risk-mid) 50%, var(--balance-growth-mid) 50%, var(--balance-growth-soft) 100%);
    border: 1px solid rgba(212,160,23,.24);
    overflow: hidden;
    margin: 8px 0 10px;
}
.balance-meter-fill {
    position: absolute;
    inset: 0 auto 0 0;
    background: linear-gradient(90deg, var(--balance-fill-start) 0%, var(--balance-fill-end) 100%);
    border-radius: 999px;
}
.analysis-alert {
    margin-top: 8px;
    font-size: .78em;
    color: #9c4221;
    background: #fffaf0;
    border-left: 4px solid #dd6b20;
    border-radius: 6px;
    padding: 8px 10px;
}
.analysis-kpi {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
    gap: 8px;
}
.kpi-box {
    background: #fff;
    border: 1px solid #e2e8f0;
    border-radius: 8px;
    padding: 10px 8px;
    text-align: center;
}
.kpi-number {
    display: block;
    font-size: 1.15em;
    font-weight: 800;
    color: #5a3e8e;
}
.kpi-label {
    display: block;
    margin-top: 3px;
    font-size: .72em;
    color: #718096;
}
.focus-tools {
    display: flex;
    gap: 10px;
    align-items: flex-end;
    flex-wrap: wrap;
    margin: 12px 0 10px;
}
.focus-tools .form-group {
    min-width: 240px;
    flex: 1;
}

/* ── Tools Panel ── */
.tools-panel { display: flex; flex-direction: column; gap: 16px; }
.tools-panel h4 {
    font-size: .85em;
    font-weight: 700;
    color: #5a3e8e;
    text-transform: uppercase;
    letter-spacing: .5px;
    padding-bottom: 6px;
    border-bottom: 2px solid #edf2f7;
}
.tools-hint {
    font-size: .8em;
    color: #718096;
    background: #fffde7;
    padding: 6px 10px;
    border-radius: 6px;
    border: 1px solid #f6e05e;
}

/* ── Différenciation du moi ── */
.differentiation-layout {
    display: grid;
    grid-template-columns: minmax(0, 1.25fr) minmax(320px, .95fr);
    gap: 16px;
}
.differentiation-card {
    display: flex;
    flex-direction: column;
    gap: 12px;
    padding: 16px;
    border: 1px solid rgba(212,160,23,.18);
    border-radius: 14px;
    background: linear-gradient(135deg, rgba(255,253,231,.92), rgba(255,248,219,.7));
    box-shadow: 0 8px 24px rgba(61,46,0,.05);
}
.differentiation-card h4 {
    font-size: .86em;
    font-weight: 700;
    color: #5a3e8e;
    text-transform: uppercase;
    letter-spacing: .45px;
}
.diff-checkbox-grid {
    display: flex;
    flex-wrap: wrap;
    gap: 8px 12px;
    padding: 8px 10px;
    border-radius: 10px;
    border: 1px solid rgba(212,160,23,.16);
    background: rgba(255,255,255,.78);
}
.diff-checkbox {
    padding: 4px 8px;
    border-radius: 999px;
    background: rgba(255,255,255,.9);
    border: 1px solid rgba(212,160,23,.14);
}
.differentiation-advice {
    display: flex;
    flex-direction: column;
    gap: 8px;
    min-height: 120px;
}
.diff-stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: 10px;
}
.diff-stat-card {
    display: flex;
    flex-direction: column;
    gap: 6px;
    padding: 12px 14px;
    border-radius: 12px;
    background: rgba(255,255,255,.86);
    border: 1px solid rgba(212,160,23,.16);
    box-shadow: inset 0 1px 0 rgba(255,255,255,.5);
}
.diff-stat-label {
    font-size: .74em;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .04em;
    color: #8a6d1f;
}
.diff-stat-card strong {
    font-size: 1.02em;
    color: #2d3748;
    line-height: 1.25;
}
.diff-trend-panel {
    display: flex;
    flex-direction: column;
    gap: 10px;
    padding: 12px;
    border-radius: 12px;
    background: rgba(255,255,255,.7);
    border: 1px solid rgba(212,160,23,.14);
}
.diff-trend-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
}
.diff-trend-header h4 {
    margin: 0;
}
.diff-trend-chart {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(24px, 1fr));
    gap: 8px;
    align-items: end;
    min-height: 170px;
}
.diff-trend-day {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    min-width: 0;
}
.diff-trend-bar-wrap {
    width: 100%;
    min-height: 118px;
    display: flex;
    align-items: flex-end;
}
.diff-trend-bar {
    width: 100%;
    border-radius: 10px 10px 4px 4px;
    background: linear-gradient(180deg, #7f9cf5, #5a67d8);
    border: 1px solid rgba(90,103,216,.26);
    box-shadow: 0 4px 12px rgba(90,103,216,.18);
    min-height: 8px;
}
.diff-trend-value {
    font-size: .72em;
    font-weight: 700;
    color: #4a5568;
}
.diff-trend-date {
    font-size: .68em;
    color: #718096;
    text-align: center;
}
.diff-advice-line {
    padding: 10px 12px;
    border-radius: 10px;
    background: rgba(255,255,255,.86);
    border-left: 4px solid var(--theme-accent);
    color: #4a5568;
    line-height: 1.45;
    font-size: .88em;
}
.differentiation-summary-output {
    width: 100%;
    min-height: 220px;
    background: #fff;
}
.differentiation-history-list {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.diff-history-item {
    display: grid;
    grid-template-columns: 110px minmax(0, 1fr) minmax(0, 1fr) auto auto;
    gap: 8px;
    align-items: center;
    padding: 10px 12px;
    border-radius: 10px;
    background: rgba(255,255,255,.86);
    border: 1px solid rgba(212,160,23,.12);
    font-size: .84em;
    color: #4a5568;
}
.diff-history-item strong {
    color: #2d3748;
}
.diff-score-pill {
    justify-self: end;
    padding: 3px 10px;
    border-radius: 999px;
    background: #5a67d8;
    color: #fff;
    font-size: .78em;
    font-weight: 700;
}
.diff-history-actions {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    justify-self: end;
}
.diff-history-actions .btn-sm {
    padding: 5px 8px;
}
.differentiation-future-note {
    display: flex;
    flex-direction: column;
    gap: 4px;
    padding: 12px;
    border-radius: 12px;
    background: rgba(255,255,255,.82);
    border: 1px dashed rgba(90,62,142,.25);
    color: #5a3e8e;
    font-size: .82em;
}

.templates-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
    gap: 10px;
}
.templates-json-section {
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px dashed rgba(212, 160, 23, .22);
}
.templates-json-header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 10px;
    flex-wrap: wrap;
    margin-bottom: 10px;
}
.templates-json-header h5 {
    font-size: .82em;
    font-weight: 700;
    color: #744210;
    text-transform: uppercase;
    letter-spacing: .45px;
}
.btn-template {
    padding: 14px 12px;
    border: 2px solid #e2e8f0;
    border-radius: 10px;
    background: #fff;
    cursor: pointer;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    transition: border-color .15s, background .15s, transform .1s;
    text-align: center;
}
.btn-template:hover { border-color: #d4a017; background: #fff8db; transform: translateY(-2px); }
.btn-template-json {
    position: relative;
    overflow: hidden;
    align-items: flex-start;
    text-align: left;
    min-height: 124px;
}
.btn-template-json::after {
    content: '';
    position: absolute;
    right: -18px;
    bottom: -18px;
    width: 88px;
    height: 88px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(212, 160, 23, .18), rgba(212, 160, 23, 0));
    pointer-events: none;
}
.tpl-icon { font-size: 1.8em; }
.tpl-name { font-size: .82em; font-weight: 700; color: #2d3748; }
.tpl-desc { font-size: .72em; color: #718096; }
.tpl-meta {
    display: flex;
    align-items: center;
    gap: 6px;
    flex-wrap: wrap;
    margin-top: auto;
    font-size: .72em;
}
.tpl-chip {
    display: inline-flex;
    align-items: center;
    border-radius: 999px;
    padding: 3px 8px;
    background: #fff8db;
    color: #8a6d1f;
    font-weight: 700;
}
.tpl-count {
    color: #718096;
    font-weight: 600;
}
.template-placeholder {
    grid-column: 1 / -1;
    padding: 12px 14px;
    border: 1px dashed rgba(212, 160, 23, .4);
    border-radius: 12px;
    background: linear-gradient(135deg, #fffdf1, #fff3bf);
    color: #8a6d1f;
    font-size: .84em;
}

.shortcuts-table { display: flex; flex-direction: column; gap: 4px; }
.shortcut-row {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 5px 0;
    border-bottom: 1px solid #f0f0f0;
    font-size: .82em;
    color: #4a5568;
}
.shortcut-row:last-child { border-bottom: none; }
kbd {
    background: #edf2f7;
    border: 1px solid #cbd5e0;
    border-radius: 4px;
    padding: 2px 7px;
    font-size: .8em;
    font-family: monospace;
    white-space: nowrap;
    color: #2d3748;
}

.tips-list {
    padding-left: 16px;
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: .82em;
    color: #4a5568;
    line-height: 1.5;
}
.tips-list li { padding: 2px 0; }

/* ── Relations list ── */
.relations-list { margin-top: 10px; display: flex; flex-direction: column; gap: 4px; }
.relation-item-header {
    display: grid;
    grid-template-columns: minmax(160px, 1.2fr) minmax(160px, 1.2fr) minmax(170px, 1fr) 92px minmax(200px, 1.8fr) 36px;
    gap: 8px;
    padding: 0 10px 6px;
    font-size: .72em;
    font-weight: 700;
    color: #718096;
    text-transform: uppercase;
    letter-spacing: .45px;
}
.relation-item {
    display: grid;
    grid-template-columns: minmax(160px, 1.2fr) minmax(160px, 1.2fr) minmax(170px, 1fr) 92px minmax(200px, 1.8fr) 36px;
    gap: 8px;
    padding: 8px 10px;
    background: #f7fafc;
    border-radius: 6px;
    border: 1px solid #e2e8f0;
    font-size: .82em;
    align-items: center;
}
.relation-member {
    color: #4a5568;
    font-weight: 600;
}
.relation-item select,
.relation-item input {
    width: 100%;
    min-width: 0;
    font-size: .82em;
    padding: 6px 8px;
}
.relation-item .btn-remove { justify-self: end; }

/* ── Members panel ── */
.members-panel {
    padding: 14px;
    background: #f7fafc;
    border-top: 1px solid #e2e8f0;
}
.members-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 10px;
    flex-wrap: wrap;
}
.members-header h3 { font-size: .95em; color: #2d3748; font-weight: 700; }
.members-header-title {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.members-header-actions {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.members-count {
    font-size: .75em;
    padding: 3px 9px;
    border-radius: 999px;
    background: #edf2f7;
    color: #4a5568;
    font-weight: 700;
}
.members-panel.collapsed .members-panel-body { display: none; }
.members-panel.collapsed .members-header { margin-bottom: 0; }
.members-panel-body { display: block; }
.members-quick-filters {
    display: flex;
    gap: 8px;
    flex-wrap: wrap;
    margin-bottom: 12px;
}
.member-filter-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 5px 10px;
    border-radius: 999px;
    border: 1px solid rgba(212,160,23,.16);
    background: #fffdf6;
    color: #5c4b11;
    font-size: .76em;
    font-weight: 700;
    cursor: pointer;
    transition: background .15s, border-color .15s, color .15s, transform .12s;
}
.member-filter-chip:hover {
    background: var(--theme-panel);
    border-color: rgba(212,160,23,.28);
    transform: translateY(-1px);
}
.member-filter-chip.active {
    background: linear-gradient(135deg, rgba(212,160,23,.18), rgba(212,160,23,.28));
    border-color: rgba(155,133,0,.38);
    color: var(--theme-title);
}
.search-input {
    width: 220px;
    padding: 6px 12px;
    border: 1.5px solid #e2e8f0;
    border-radius: 20px;
    font-size: .82em;
    background: #fff;
    color: #2d3748;
    transition: border-color .15s, box-shadow .15s;
}
.search-input:focus {
    outline: none;
    border-color: #667eea;
    box-shadow: 0 0 0 3px rgba(102,126,234,.15);
}

.members-grid { display: flex; flex-direction: column; gap: 5px; }
.member-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 8px 12px;
    background: #fff;
    border-radius: 8px;
    border: 1.5px solid #e2e8f0;
    transition: border-color .15s, box-shadow .15s;
    cursor: pointer;
    position: relative;
    overflow: hidden;
}
.member-card::before {
    content: '';
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 4px;
    background: var(--member-generation-accent, #e2e8f0);
}
.member-card:hover  { border-color: #bee3f8; box-shadow: 0 2px 6px rgba(0,0,0,.06); }
.member-card.selected { border-color: #3182ce; box-shadow: 0 0 0 3px rgba(49,130,206,.2); background: #ebf8ff; }
.member-symbol {
    width: 30px; height: 30px;
    border-radius: 50%;
    background: #ebebeb;
    display: flex; align-items: center; justify-content: center;
    font-size: .75em;
    font-weight: 700;
    color: #4a5568;
    flex-shrink: 0;
    border: 2px solid #e2e8f0;
}
.member-symbol.male    { background: #d0e8ff; border-color: #90cdf4; color: #2b6cb0; }
.member-symbol.female  { background: #ffd0e8; border-color: #fbb6ce; color: #97266d; }
.member-symbol.unknown { background: #ebebeb; }
.member-info {
    flex: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 4px;
    font-size: .82em;
    min-width: 0;
}
.member-info strong { color: #2d3748; font-weight: 700; }
.completeness-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    font-size: .7em;
    font-weight: 700;
    padding: 2px 7px;
    border-radius: 999px;
    border: 1px solid rgba(90,62,142,.15);
}
.completeness-badge.level-1 {
    background: #fff5f5;
    color: #c53030;
    border-color: rgba(197,48,48,.18);
}
.completeness-badge.level-2 {
    background: #fff8db;
    color: #975a16;
    border-color: rgba(212,160,23,.28);
}
.completeness-badge.level-3 {
    background: #f0fff4;
    color: #276749;
    border-color: rgba(56,161,105,.26);
}
.ip-badge { background: #fbd38d; color: #744210; font-size: .7em; padding: 1px 5px; border-radius: 4px; font-weight: 700; }
.gen-badge  { background: #edf2f7; color: #4a5568; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.year-badge { background: #f0fff4; color: #276749; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.occ-badge  { background: #ebf8ff; color: #2b6cb0; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.eth-badge  { background: #f5f0ff; color: #553c9a; font-size: .72em; padding: 2px 7px; border-radius: 10px; font-style: italic; }
.nickname-badge { background: #faf5ff; color: #805ad5; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.role-badge { background: #fff7ed; color: #9c4221; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.branch-badge { background: #edfdfd; color: #2c7a7b; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.kinship-badge { background: #fffbea; color: #975a16; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.subsystem-badge { background: #faf5ff; color: #6b46c1; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.loss-badge { background: #fff5f7; color: #b83280; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.sibling-order-badge { background: #fff8db; color: #8a6d1f; font-size: .72em; padding: 2px 7px; border-radius: 10px; font-weight: 700; }
.sibling-role-badge { background: #fef3c7; color: #744210; font-size: .72em; padding: 2px 7px; border-radius: 10px; font-weight: 700; border: 1px solid rgba(212,160,23,.24); }
.notes-badge{ background: #fffff0; color: #744210; font-size: .72em; padding: 2px 7px; border-radius: 10px; font-style: italic; }
.life-stage-badge { background: #fff8db; color: #8a6d1f; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.locked-badge { background: #faf5ff; color: #6b46c1; font-size: .72em; padding: 2px 7px; border-radius: 10px; }
.markers-row { display: flex; gap: 3px; flex-wrap: wrap; width: 100%; }
.marker-dot { width: 10px; height: 10px; border-radius: 50%; border: 1px solid rgba(255,255,255,.6); }
.member-card.filtered {
    opacity: .55;
    background: #fbfbfd;
}
.member-actions {
    display: flex;
    gap: 6px;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
}

.btn-edit, .btn-remove, .btn-duplicate, .btn-lock {
    width: 28px; height: 28px;
    border: none;
    border-radius: 6px;
    cursor: pointer;
    font-size: .82em;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background .15s;
}
.btn-edit   { background: #ebf8ff; color: #2b6cb0; }
.btn-edit:hover   { background: #bee3f8; }
.btn-remove { background: #fed7d7; color: #c53030; }
.btn-remove:hover { background: #feb2b2; }
.btn-duplicate { background: #fff8db; color: #8a6d1f; }
.btn-duplicate:hover { background: #fef3c7; }
.btn-lock { background: #edf2f7; color: #4a5568; }
.btn-lock:hover { background: #e2e8f0; }
.btn-lock.locked { background: #faf5ff; color: #6b46c1; }

.empty-msg { font-size: .82em; color: #a0aec0; text-align: center; padding: 16px; font-style: italic; }

/* ── Household checks ── */
.household-checks { display: flex; flex-direction: column; gap: 6px; max-height: 300px; overflow-y: auto; padding: 4px 0; margin: 10px 0; }

/* ── Modals ── */
.modal-overlay {
    position: fixed; inset: 0;
    background: rgba(0,0,0,.5);
    display: flex; align-items: center; justify-content: center;
    z-index: 10500;
    padding: 20px;
}
.modal {
    background: #fff;
    border-radius: 12px;
    padding: 22px;
    width: 100%;
    max-width: 500px;
    max-height: 90vh;
    overflow-y: auto;
    box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
.modal-wide { max-width: 900px; }
.modal h3 { font-size: 1.05em; color: #2d3748; margin-bottom: 14px; }

/* ── Legend ── */
.legend-section { margin-bottom: 16px; }
.legend-section h4 { font-size: .82em; font-weight: 700; color: #5a3e8e; text-transform: uppercase; letter-spacing: .5px; margin-bottom: 10px; }
.legend-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.legend-item { display: flex; flex-direction: column; align-items: center; gap: 3px; font-size: .72em; color: #4a5568; text-align: center; max-width: 90px; }
.legend-markers { display: flex; flex-wrap: wrap; gap: 8px 16px; }
.legend-marker-item { display: flex; align-items: center; gap: 6px; font-size: .8em; color: #4a5568; }
.marker-badge { width: 14px; height: 14px; border-radius: 50%; flex-shrink: 0; border: 1px solid rgba(0,0,0,.1); }
.legend-hint { font-size: .72em; color: #718096; text-align: center; margin: 10px 0; font-style: italic; }

.highlighted-member {
    filter: drop-shadow(0 0 10px rgba(90, 62, 142, .45));
}
.filtered-member {
    opacity: .35;
}
.focus-dim {
    opacity: .18;
}
.focus-highlight {
    filter: drop-shadow(0 0 8px rgba(90, 62, 142, .3));
}
.branch-dim {
    opacity: .33;
}
.branch-highlight {
    filter: drop-shadow(0 0 10px rgba(56, 161, 105, .28));
}

/* ── Responsive ── */
@media (max-width: 700px) {
    body { padding: 8px; }
    .container { border-radius: 8px; }
    .form-row { flex-direction: column; }
    .toolbar { gap: 4px; }
    .toolbar .btn-secondary, .toolbar .btn-danger, .toolbar .btn-info { padding: 6px 8px; font-size: .76em; }
    .view-filters,
    .layer-filters { width: 100%; justify-content: center; flex-wrap: wrap; }
    .palette-grid { gap: 5px; }
    .pal-item svg { width: 52px !important; height: 60px !important; }
    .members-header { flex-direction: column; align-items: flex-start; }
    .members-header-actions,
    .selection-quick-buttons { width: 100%; }
    .search-input { width: 100%; }
    .templates-grid { grid-template-columns: 1fr 1fr; }
    .events-layout,
    .analysis-grid { grid-template-columns: 1fr; }
    .differentiation-layout { grid-template-columns: 1fr; }
    .focus-tools { flex-direction: column; align-items: stretch; }
    .quick-reference { margin: 0 8px; }
    .workspace-hints,
    .selection-quick-actions,
    .case-cockpit { margin-left: 8px; margin-right: 8px; }
    .selection-quick-builder { width: 100%; }
    .case-cockpit-header { align-items: flex-start; }
    .relation-item,
    .relation-item-header { grid-template-columns: 1fr; }
    .relation-item-header { display: none; }
    .relation-item .btn-remove { justify-self: stretch; width: 100%; }
    .member-actions { justify-content: stretch; width: 100%; }
    .member-actions button { flex: 1 1 70px; width: auto; }
    .toast-stack { left: 8px; right: 8px; bottom: 8px; }
    .toast { min-width: 0; max-width: none; }
    .shortcuts-overlay-grid { grid-template-columns: 1fr; }
    .diff-history-item { grid-template-columns: 1fr; }
    .diff-history-actions { justify-self: start; }
    .diff-score-pill { justify-self: start; }
    .diff-trend-chart { grid-template-columns: repeat(7, minmax(22px, 1fr)); }
}

/* ═══ Canvas mode badge ═══ */
.canvas-container { position: relative; }
.canvas-mode-badge {
    position: absolute;
    top: 10px;
    right: 14px;
    z-index: 20;
    padding: 5px 12px;
    border-radius: 20px;
    font-size: 12px;
    font-weight: 600;
    pointer-events: none;
    box-shadow: 0 2px 8px rgba(0,0,0,0.12);
    letter-spacing: 0.01em;
}
.canvas-mode-place {
    background: #fff8dc;
    border: 1.5px solid #d4a017;
    color: #7a5a00;
}
.canvas-mode-compact {
    background: #e8f5e9;
    border: 1.5px solid #66bb6a;
    color: #2e7d32;
}

/* ═══ Shortcuts overlay ═══ */
.shortcuts-overlay {
    position: fixed;
    inset: 0;
    z-index: 3000;
    background: rgba(30,24,0,0.45);
    display: flex;
    align-items: center;
    justify-content: center;
    backdrop-filter: blur(2px);
}
.shortcuts-overlay-card {
    background: #fffdf0;
    border: 1.5px solid #e6cc4a;
    border-radius: 16px;
    box-shadow: 0 8px 40px rgba(0,0,0,0.22);
    padding: 28px 32px 24px;
    max-width: 820px;
    width: 96vw;
    max-height: 90vh;
    overflow-y: auto;
}
.shortcuts-overlay-header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 20px;
    font-size: 17px;
    font-weight: 700;
    color: #5a4a00;
    border-bottom: 1px solid #e6cc4a;
    padding-bottom: 12px;
}
.shortcuts-overlay-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 0 28px;
}
.so-row {
    display: flex;
    align-items: center;
    gap: 8px;
    padding: 5px 0;
    border-bottom: 1px dashed #f0e8c0;
    font-size: 13px;
    color: #4a3c00;
}
.so-row kbd {
    background: #fff8dc;
    border: 1px solid #d4b012;
    border-radius: 5px;
    padding: 2px 7px;
    font-size: 11px;
    font-family: monospace;
    white-space: nowrap;
    color: #5a4200;
    min-width: 28px;
    text-align: center;
}

/* ════════ Symbol right-click context menu ════════ */
.symbol-context-menu {
    position: fixed;
    z-index: 9999;
    background: #fff;
    border: 1.5px solid #D4A017;
    border-radius: 10px;
    box-shadow: 0 6px 24px rgba(0,0,0,.18);
    padding: 5px 0;
    min-width: 190px;
    font-size: 13.5px;
    color: #2a2a2a;
}
.symbol-context-menu button {
    display: flex;
    align-items: center;
    gap: 8px;
    width: 100%;
    padding: 7px 14px;
    background: none;
    border: none;
    cursor: pointer;
    text-align: left;
    color: inherit;
    font-size: 13.5px;
    border-radius: 0;
    transition: background .12s;
}
.symbol-context-menu button:hover { background: #fffbef; }
.symbol-context-menu button.ctx-danger { color: #c0392b; }
.symbol-context-menu button.ctx-danger:hover { background: #fff0ef; }
.symbol-context-menu .ctx-icon { width: 22px; text-align: center; flex-shrink: 0; }
.symbol-context-menu hr { border: none; border-top: 1px solid #f0e0a0; margin: 4px 0; }

/* ════════ Named save slots ════════ */
.saved-slots-container { display: flex; flex-direction: column; gap: 8px; margin-top: 8px; }
.saved-slot-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    background: #fffde7;
    border: 1px solid #f0c75e;
    border-radius: 8px;
    padding: 8px 12px;
}
.saved-slot-info { display: flex; flex-direction: column; flex: 1; min-width: 0; }
.saved-slot-name { font-weight: 600; color: #3d2e00; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.saved-slot-meta { font-size: 11px; color: #8b7500; margin-top: 2px; }
.saved-slot-actions { display: flex; gap: 4px; flex-shrink: 0; }
.btn-xs { padding: 3px 8px !important; font-size: 11.5px !important; border-radius: 5px !important; }

/* ════════ Print styles ════════ */
@media print {
    body { background: #fff !important; }
    .tabs, .toolbar, .tab-content:not(.active),
    .modal-overlay, .toast-stack, .legend-modal, .shortcuts-overlay,
    .symbol-context-menu, .canvas-mode-badge, .view-preset-bar,
    .autosave-controls, .saved-slots-container,
    .shortcuts-table, .tips-list, .templates-grid,
    .quick-ref-panel, .selection-quick-actions,
    button { display: none !important; }
    .container { width: 100vw !important; max-width: 100vw !important; margin: 0 !important; padding: 0 !important; border-radius: 0 !important; }
    .canvas-container { min-height: 0 !important; }
    .canvas-container svg { width: 100vw !important; height: auto !important; max-height: 95vh !important; display: block !important; }
    header h1 { font-size: 18pt !important; }
    header { padding: 4mm 0 2mm !important; text-align: center !important; }
    @page { margin: 10mm; size: A4 landscape; }
}

/* ══════════════════════════════════════════════════════════════
   MODE SIMPLE / MODE AVANCÉ
   ══════════════════════════════════════════════════════════════ */

/* ── Header mode row ── */
.header-mode-row {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    margin-top: 10px;
    flex-wrap: wrap;
}

.btn-mode-toggle {
    padding: 6px 18px;
    border-radius: 20px;
    border: 2px solid var(--theme-accent);
    background: #fff;
    color: var(--theme-title);
    font-size: .82em;
    font-weight: 700;
    cursor: pointer;
    transition: background .18s, color .18s;
    letter-spacing: .3px;
    white-space: nowrap;
}
.btn-mode-toggle:hover { background: var(--theme-accent); color: #fff; }

/* Active state: in simple mode the button offers "Mode avancé" */
[data-app-mode="simple"] .btn-mode-toggle {
    background: var(--theme-accent);
    color: #fff;
}

.mode-hint {
    font-size: .74em;
    color: var(--theme-subtitle);
    opacity: .75;
}

/* ── SIMPLE MODE: hide advanced elements ── */

/* Tabs: only show Membres */
[data-app-mode="simple"] .tabs .tab[data-tab="relations"],
[data-app-mode="simple"] .tabs .tab[data-tab="events"],
[data-app-mode="simple"] .tabs .tab[data-tab="context"],
[data-app-mode="simple"] .tabs .tab[data-tab="analysis"],
[data-app-mode="simple"] .tabs .tab[data-tab="tools"] {
    display: none !important;
}

/* Simple-only rows: hidden by default, visible only in simple mode */
.simple-only-row { display: none !important; }
[data-app-mode="simple"] .simple-only-row { display: flex !important; }

/* Member form: hide advanced rows in simple mode */
[data-app-mode="simple"] #tab-members .advanced-row { display: none !important; }

/* Edit panel in simple mode: show only the basic fields, hide advanced ones */
[data-app-mode="simple"] #editPanel .advanced-row { display: none !important; }

/* Show only the first form-row (name + gender + generation) in simple mode */
[data-app-mode="simple"] #tab-members .form-row:first-child { display: flex !important; }

/* Toolbar: hide advanced controls */
[data-app-mode="simple"] #undoBtn,
[data-app-mode="simple"] #redoBtn,
[data-app-mode="simple"] #autoLayout,
[data-app-mode="simple"] #addHousehold,
[data-app-mode="simple"] .view-filters,
[data-app-mode="simple"] .layer-filters,
[data-app-mode="simple"] .view-preset-bar,
[data-app-mode="simple"] #exportPDF,
[data-app-mode="simple"] #saveJSON,
[data-app-mode="simple"] #loadJSON,
[data-app-mode="simple"] #showLegend,
[data-app-mode="simple"] #showShortcuts,
[data-app-mode="simple"] #togglePalette,
[data-app-mode="simple"] #clearAll,
[data-app-mode="simple"] .toolbar-sep { display: none !important; }

/* Keep fit view, SVG export and zoom in simple mode */
[data-app-mode="simple"] #fitContent,
[data-app-mode="simple"] #exportSVG { display: inline-flex !important; }

/* Hide analysis / contextual panels */
[data-app-mode="simple"] .quick-reference,
[data-app-mode="simple"] .analysis-panel,
[data-app-mode="simple"] .selection-quick-builder,
[data-app-mode="simple"] .selection-quick-actions .selection-action-advanced { display: none !important; }

/* Simplify member list: hide filter bar and completeness badges */
[data-app-mode="simple"] .member-filter-bar,
[data-app-mode="simple"] .member-completeness-badge,
[data-app-mode="simple"] .member-gen-accent,
[data-app-mode="simple"] .tab-hint { display: none !important; }

/* Simple mode canvas info badge */
[data-app-mode="simple"] .canvas-mode-badge.canvas-mode-place { display: none !important; }

/* Simple mode: palette stays but hide generation selector */
[data-app-mode="simple"] .palette-gen-row { display: none !important; }

/* Role group: hidden by default, only visible in simple mode.
   !important is used here to match the same specificity pattern as the rest
   of the [data-app-mode="simple"] block above, which also relies on !important
   to override nested rules. */
.simple-role-group { display: none !important; }
[data-app-mode="simple"] .simple-role-group { display: flex !important; }
/* Generation group: hidden in simple mode (role replaces it) */
[data-app-mode="simple"] .advanced-gen-group { display: none !important; }

/* Simple mode title hint in member section */
[data-app-mode="simple"] #tab-members::before {
    content: '🌱 Mode simple – entrez un prénom, choisissez le genre et le rôle, puis cliquez sur Ajouter.';
    display: block;
    background: linear-gradient(90deg, rgba(212,160,23,.15), transparent);
    border-left: 3px solid var(--theme-accent);
    padding: 8px 14px;
    margin: 0 0 12px;
    font-size: .83em;
    color: var(--theme-subtitle);
    border-radius: 0 8px 8px 0;
}

/* Simple mode: bigger canvas so there is more room to drag members around */
[data-app-mode="simple"] #canvasContainer {
    min-height: 520px !important;
}

/* Simple mode: larger, cleaner member list cards */
[data-app-mode="simple"] .member-item {
    padding: 11px 16px;
    font-size: .97em;
    gap: 10px;
}
[data-app-mode="simple"] .member-item .member-name {
    font-size: 1.05em;
}
/* Simple mode: bigger "Ajouter" button so it is very easy to spot */
[data-app-mode="simple"] #addMember {
    font-size: 1.05em;
    padding: 14px 20px;
}
/* Simple mode: hide "clear all" confirmation; show a plain clear button */
[data-app-mode="simple"] #clearAll { display: inline-flex !important; }

/* ── Ensure nothing blows up when mode is not yet set (no data-app-mode) ── */
body:not([data-app-mode]) .header-mode-row .mode-hint { display: none; }

/* ── Simple-mode member list: role dot + name + pill badge ── */
.simple-member-card {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    border-radius: 10px;
    background: #fff;
    border: 1.5px solid #e8e0c8;
    margin-bottom: 6px;
    cursor: pointer;
    transition: background .15s, border-color .15s;
}
.simple-member-card:hover { background: #fffde7; border-color: #d4a017; }
.simple-member-card.selected { background: #fff9e0; border-color: #d4a017; box-shadow: 0 0 0 2px #d4a01744; }
.simple-member-dot {
    flex-shrink: 0;
    width: 22px;
    height: 22px;
    border-radius: 50%;
    border: 2.5px solid;
    display: inline-block;
}
.simple-role-pill {
    flex-shrink: 0;
    border: 1.5px solid;
    border-radius: 30px;
    padding: 2px 10px;
    font-size: .78em;
    font-weight: 700;
    color: #fff;
    white-space: nowrap;
    text-shadow: 0 1px 2px rgba(0,0,0,.25);
    letter-spacing: .02em;
}
/* Simple mode canvas: softer background for constellation feel */
[data-app-mode="simple"] #mainSvg {
    background: radial-gradient(ellipse at 60% 40%, #f0f4ff 0%, #e8eaf8 100%);
}
/* Simple mode: hide member count aggregates (too clinical) */
[data-app-mode="simple"] #membersCount { display: none !important; }
/* Simple mode: members list header simpler */
[data-app-mode="simple"] #tab-members .members-header { gap: 8px; }
