        * {
            margin: 0;
            padding: 0;
            box-sizing: border-box;
            -webkit-tap-highlight-color: transparent;
            -webkit-touch-callout: none;
        }
        @media (prefers-reduced-motion: reduce) {
            *, *::before, *::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
        }
        :focus { outline: 2px solid var(--text-primary); outline-offset: 2px; }
        :focus:not(:focus-visible) { outline: none; }
        :focus-visible { outline: 2px solid var(--text-primary); outline-offset: 2px; }
        .import-drop-zone.drag-over { border-color: var(--text-primary); background: var(--hover); }
        .graph-wrapper { position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 1; }
        .btn-map-legend {
            flex-shrink: 0; width: 32px; height: 32px; min-width: 44px; min-height: 44px; padding: 0;
            border-radius: 50%; border: 1px solid var(--border); background: var(--bg-secondary);
            color: var(--text-primary); font-size: 16px; font-weight: 600; cursor: pointer;
            display: flex; align-items: center; justify-content: center;
        }
        .btn-map-legend:hover { background: var(--hover); }
        .map-legend-panel {
            position: absolute; top: 100%; left: 50%; transform: translateX(-50%); margin-top: 8px;
            max-width: min(400px, 90vw); max-height: 70vh; overflow-y: auto;
            background: var(--bg-primary); border: 1px solid var(--border); border-radius: var(--radius);
            box-shadow: 0 8px 24px rgba(0,0,0,0.15); z-index: 900; padding: 16px;
        }
        .map-legend-panel[hidden] { display: none !important; }
        .map-legend-title { font-size: 18px; margin-bottom: 8px; color: var(--text-primary); }
        .map-legend-summary { font-size: 13px; color: var(--text-secondary); margin-bottom: 12px; line-height: 1.4; }
        .map-legend-h3 { font-size: 14px; margin: 12px 0 6px; color: var(--text-primary); }
        .map-legend-list { font-size: 12px; color: var(--text-secondary); margin-left: 16px; line-height: 1.5; }
        .btn-legend-close { margin-top: 12px; padding: 8px 16px; background: var(--text-primary); color: var(--bg-primary); border: none; border-radius: var(--radius); cursor: pointer; font-size: 13px; min-height: 44px; }
        .map-first-visit-overlay {
            position: absolute; top: 0; left: 0; right: 0; bottom: 0; z-index: 3;
            display: flex; align-items: center; justify-content: center; background: rgba(0,0,0,0.4); padding: 24px;
        }
        .map-first-visit-overlay[hidden] { display: none !important; }
        .map-first-visit-inner { background: var(--bg-primary); padding: 24px; border-radius: var(--radius); max-width: 320px; text-align: center; border: 1px solid var(--border); }
        .map-first-visit-inner p { margin-bottom: 16px; font-size: 14px; color: var(--text-primary); line-height: 1.5; }
        .map-first-visit-dismiss { min-height: 44px; padding: 10px 20px; }
        .map-emphasis-banner {
            position: absolute; top: 12px; left: 50%; transform: translateX(-50%); z-index: 4;
            display: flex; align-items: center; gap: 12px; padding: 8px 14px; background: var(--bg-primary); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: 0 2px 12px rgba(0,0,0,0.1);
        }
        .map-emphasis-banner[hidden] { display: none !important; }
        .btn-map-see-all { padding: 6px 12px; font-size: 12px; background: var(--accent); color: var(--bg-primary); border: none; border-radius: var(--radius); cursor: pointer; min-height: 44px; }
        .btn-map-see-all:hover { opacity: 0.9; }
        .welcome-overlay {
            position: absolute; top: 0; left: 0; right: 0; bottom: 0;
            display: flex; align-items: center; justify-content: center;
            background: var(--bg-primary);
            opacity: 0.97;
            z-index: 2;
            padding: 24px;
            box-sizing: border-box;
        }
        .welcome-overlay.hidden { display: none; }
        .welcome-overlay-inner { text-align: center; max-width: 320px; }
        .welcome-overlay h2 { font-size: 20px; font-weight: 600; margin-bottom: 8px; color: var(--text-primary); }
        .welcome-overlay p { font-size: 14px; color: var(--text-secondary); margin-bottom: 20px; line-height: 1.5; }
        .welcome-overlay .btn-cta {
            display: inline-block; padding: 12px 24px; background: var(--text-primary); color: var(--bg-primary);
            border: none; font-size: 14px; font-weight: 500; cursor: pointer; transition: opacity 0.2s;
        }
        .welcome-overlay .btn-cta:hover { opacity: 0.9; }
        .welcome-overlay .btn-cta { border-radius: var(--radius); }
        .welcome-overlay-dismiss { margin-top: 16px; font-size: 12px; color: var(--text-secondary); }
        .welcome-overlay-dismiss button { background: none; border: none; color: var(--text-secondary); cursor: pointer; text-decoration: underline; }
        /* Bloc marque header */
        .header-brand { display: flex; flex-direction: column; gap: 0; margin-right: auto; min-width: 0; overflow: hidden; flex: 1; max-width: 100%; }
        .header-brand-name { font-size: 16px; font-weight: 600; color: var(--text-primary); letter-spacing: -0.02em; font-family: Georgia, "Times New Roman", serif; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        .header-tagline { font-size: 11px; color: var(--text-secondary); margin-top: 1px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        .welcome-title { font-family: Georgia, "Times New Roman", serif; }
        .header-licence { font-size: 10px; color: var(--text-secondary); margin-top: 2px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        @media (max-width: 480px) {
            .header-tagline, .header-licence { display: none; }
        }
        .header-save-indicator { font-size: 10px; margin-top: 1px; }
        .header-btn svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
        .reminder-bell-badge { position: absolute; top: 4px; right: 4px; min-width: 16px; height: 16px; padding: 0 4px; font-size: 10px; font-weight: 600; background: var(--accent); color: var(--bg-primary); border-radius: 8px; display: flex; align-items: center; justify-content: center; }
        .souls-header-badge { position: absolute; top: 4px; right: 4px; min-width: 16px; height: 16px; padding: 0 4px; font-size: 10px; font-weight: 600; background: var(--accent); color: var(--bg-primary); border-radius: 8px; display: flex; align-items: center; justify-content: center; }
        .nav-btn-icon svg { width: 20px; height: 20px; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

        body {
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, 'Helvetica Neue', sans-serif;
            background: var(--bg-primary);
            color: var(--text-primary);
            height: 100vh;
            overflow: hidden;
            position: fixed;
            width: 100%;
            -webkit-font-smoothing: antialiased;
        }

        /* Thème Noir & Blanc + accent (Phase 2) */
        :root {
            --bg-primary: #fafafa;
            --bg-secondary: #f0f0f0;
            --bg-tertiary: #000000;
            --text-primary: #000000;
            --text-secondary: #444444;
            --border: #e0e0e0;
            --border-dark: #000000;
            --hover: #eeeeee;
            --active: #000000;
            --accent: #2563eb;
            --radius: 6px;
            --radius-card: 8px;
        }

        [data-theme="dark"] {
            --bg-primary: #0a0a0f;
            --bg-secondary: #14141a;
            --bg-tertiary: #ffffff;
            --text-primary: #ffffff;
            --text-secondary: #999999;
            --border: #333333;
            --border-dark: #ffffff;
            --hover: #1a1a22;
            --active: #ffffff;
            --accent: #60a5fa;
        }

        /* App Container */
        #app {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: var(--bg-primary);
            transition: background 0.3s ease;
        }
        #app.app-loading .graph-wrapper::after {
            content: 'Chargement…';
            position: absolute; top: 0; left: 0; right: 0; bottom: 0;
            background: var(--bg-primary);
            display: flex; align-items: center; justify-content: center;
            font-size: 14px; color: var(--text-secondary);
            z-index: 5;
        }

        /* Header Mobile - Minimaliste */
        .header {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            height: 56px;
            padding-top: env(safe-area-inset-top);
            padding-left: max(16px, env(safe-area-inset-left));
            padding-right: max(16px, env(safe-area-inset-right));
            background: var(--bg-primary);
            border-bottom: 1px solid var(--border);
            display: flex;
            align-items: center;
            z-index: 1000;
            gap: 8px;
            min-height: calc(56px + env(safe-area-inset-top));
        }

        .header-title {
            font-size: 16px;
            font-weight: 500;
            color: var(--text-primary);
            margin-right: auto;
            letter-spacing: -0.3px;
        }
        .header-licence {
            display: block;
            font-size: 12px;
            font-weight: 400;
            color: var(--text-secondary);
            margin-top: 2px;
        }
        .header-save-indicator {
            display: block;
            font-size: 11px;
            color: var(--text-secondary);
            opacity: 0;
            transition: opacity 0.3s ease;
            margin-top: 2px;
        }
        .header-save-indicator.save-indicator-visible {
            opacity: 1;
        }

        .header-btn {
            width: 44px;
            height: 44px;
            min-width: 44px;
            min-height: 44px;
            border-radius: 0;
            background: transparent;
            color: var(--text-primary);
            border: none;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 18px;
            cursor: pointer;
            transition: all 0.15s ease;
            touch-action: manipulation;
            -webkit-tap-highlight-color: transparent;
        }

        .header-btn:active {
            background: var(--hover);
        }

        .header-btn:hover {
            background: var(--hover);
            transform: scale(1.03);
        }
        .header-btn:focus-visible { outline-offset: 2px; }

        .header-menu {
            position: relative;
        }

        .header-menu-dropdown {
            position: absolute;
            top: 100%;
            right: 0;
            margin-top: 4px;
            min-width: 200px;
            background: var(--bg-primary);
            border: 1px solid var(--border);
            border-radius: 0;
            box-shadow: 0 4px 12px rgba(0,0,0,0.15);
            z-index: 1100;
            display: none;
            padding: 4px 0;
        }

        .header-menu-dropdown.show {
            display: block;
        }

        .header-menu-dropdown button {
            width: 100%;
            text-align: left;
            padding: 10px 16px;
            border: none;
            background: none;
            color: var(--text-primary);
            font-size: 13px;
            cursor: pointer;
            transition: background 0.15s ease;
        }

        .header-menu-dropdown button:hover {
            background: var(--hover);
        }

        .header-menu-dropdown button.danger {
            color: var(--text-primary);
        }

        .header-menu-dropdown button.danger:hover {
            background: var(--bg-secondary);
        }

        /* Mode Drag - Minimaliste */
        .drag-mode {
            position: absolute;
            top: 56px;
            left: 0;
            right: 0;
            padding: 12px 16px;
            background: var(--bg-primary);
            border-bottom: 1px solid var(--border);
            display: flex;
            align-items: center;
            gap: 12px;
            z-index: 950;
        }

        .drag-info {
            flex: 1;
            font-size: 13px;
            color: var(--text-secondary);
            font-weight: 400;
        }

        .drag-cancel {
            background: var(--bg-secondary);
            color: var(--text-primary);
            border: 1px solid var(--border-dark);
            padding: 6px 12px;
            border-radius: var(--radius);
            cursor: pointer;
            font-size: 13px;
            transition: all 0.15s ease;
        }

        .drag-cancel:hover {
            background: var(--text-primary);
            color: var(--bg-primary);
        }

        /* Liste des Âmes - Sidebar Minimaliste (mobile-first) */
        .souls-sidebar {
            position: absolute;
            left: 0;
            top: calc(56px + env(safe-area-inset-top));
            bottom: calc(64px + env(safe-area-inset-bottom));
            width: 320px;
            max-width: 85vw;
            background: var(--bg-primary);
            border-right: 1px solid var(--border);
            padding: 0;
            display: flex;
            flex-direction: column;
            overflow: hidden;
            transform: translateX(-100%);
            transition: transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);
            z-index: 900;
        }

        .souls-sidebar.show {
            transform: translateX(0);
        }

        /* E2: Pleine largeur sur mobile */
        @media (max-width: 480px) {
            .souls-sidebar {
                width: 100%;
                max-width: 100%;
                box-shadow: 4px 0 20px rgba(0,0,0,0.15);
            }
        }

        /* A3: Backdrop semi-transparent quand sidebar ouverte */
        .souls-sidebar-backdrop {
            display: none;
            position: fixed;
            inset: 0;
            background: rgba(0,0,0,0.3);
            z-index: 899;
            opacity: 0;
            transition: opacity 0.25s ease;
            pointer-events: none;
        }

        .souls-sidebar-backdrop.show {
            display: block;
            opacity: 1;
            pointer-events: auto;
        }

        @media (min-width: 769px) {
            .souls-sidebar-backdrop { display: none !important; }
        }

        .filter-chip-badge {
            margin-left: 4px;
            padding: 2px 6px;
            font-size: 10px;
            border-radius: 10px;
            background: var(--accent, #64dfdf);
            color: var(--bg-primary);
        }

        .souls-progression-count {
            font-size: 11px;
            color: var(--text-secondary);
        }

        /* Aide - Sidebar */
        .help-sidebar {
            position: fixed;
            right: 0;
            top: calc(56px + env(safe-area-inset-top));
            bottom: calc(64px + env(safe-area-inset-bottom));
            width: 360px;
            max-width: 92vw;
            background: var(--bg-primary);
            border-left: 1px solid var(--border);
            padding: 16px;
            padding-right: max(16px, env(safe-area-inset-right));
            overflow-y: auto;
            overflow-x: hidden;
            -webkit-overflow-scrolling: touch;
            transform: translateX(100%);
            transition: transform 0.3s ease;
            z-index: 1010; /* Au-dessus du nav-bottom (1000) */
        }
        .help-sidebar.show {
            transform: translateX(0);
        }
        /* Cockpit sidebar : flex layout pour contenu scrollable */
        .cockpit-sidebar {
            display: flex;
            flex-direction: column;
            padding: 0;
        }
        .cockpit-sidebar .help-header {
            padding: 16px 16px 0;
            flex-shrink: 0;
        }
        .cockpit-sidebar .cockpit-tabs {
            flex-shrink: 0;
        }
        .cockpit-sidebar .cockpit-content {
            flex: 1;
            min-height: 0;
        }
        .cockpit-header-text { flex: 1; min-width: 0; }
        .cockpit-subtitle {
            font-size: 11px;
            color: var(--text-secondary);
            margin: 4px 0 0;
            line-height: 1.35;
        }
        .cockpit-first-banner {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
            padding: 10px 12px;
            margin: 8px 12px;
            background: var(--bg-secondary);
            border: 1px solid var(--accent);
            border-radius: 8px;
            font-size: 12px;
            color: var(--text-primary);
        }
        .cockpit-first-banner span { flex: 1; }
        .cockpit-banner-dismiss {
            flex-shrink: 0;
            width: 28px;
            height: 28px;
            padding: 0;
            border: none;
            background: transparent;
            color: var(--text-secondary);
            cursor: pointer;
            border-radius: 4px;
            font-size: 14px;
        }
        .cockpit-banner-dismiss:hover { background: var(--hover); color: var(--text-primary); }
        .mandala-empty-hint {
            font-size: 11px;
            color: var(--text-secondary);
            margin: 8px 0 0;
            line-height: 1.35;
        }
        .cockpit-tabs--always { border-bottom: 1px solid var(--border); margin-bottom: 0; }
        .inbox-input-hint {
            font-size: 11px;
            color: var(--text-secondary);
            margin: 6px 0 0;
            line-height: 1.4;
            opacity: 1;
            visibility: visible;
        }
        .inbox-input-hint code {
            background: var(--bg-secondary);
            padding: 2px 5px;
            border-radius: 4px;
            font-size: 10px;
            color: var(--text-primary);
        }
        /* Mandala magique : résonance sélection (roue 5 segments + runes) */
        .cockpit-mandala {
            flex-shrink: 0;
            padding: 12px;
            border-bottom: 1px solid var(--border);
            margin-bottom: 8px;
            background: var(--bg-primary);
        }
        .mandala-center {
            display: flex;
            gap: 10px;
            align-items: flex-start;
            justify-content: space-between;
        }
        .mandala-title {
            font-size: 12px;
            font-weight: 600;
            color: var(--text-primary);
        }
        .mandala-chips {
            display: flex;
            gap: 6px;
            flex-wrap: wrap;
            margin-top: 4px;
        }
        .mandala-chips .chip {
            font-size: 11px;
            padding: 4px 10px;
            border-radius: 999px;
            border: 1px solid var(--border);
            background: var(--bg-secondary);
            color: var(--text-primary);
        }
        .mandala-chips .chip:focus-visible {
            outline: none;
            box-shadow: 0 0 0 2px var(--accent);
        }
        .mandala-center-actions {
            display: flex;
            gap: 6px;
        }
        .micon {
            width: 32px;
            height: 32px;
            min-width: 32px;
            min-height: 32px;
            border-radius: var(--radius-card);
            border: 1px solid var(--border);
            background: var(--bg-secondary);
            cursor: pointer;
            color: var(--text-primary);
            font-size: 18px;
            line-height: 1;
            padding: 0;
            display: flex;
            align-items: center;
            justify-content: center;
            font-family: system-ui, "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
            overflow: visible;
        }
        .micon:hover {
            transform: translateY(-1px);
        }
        .micon:active {
            transform: translateY(0) scale(.98);
        }
        .micon:focus-visible {
            outline: 2px solid var(--text-primary);
            outline-offset: 2px;
        }
        @media (max-width: 768px) {
            .cockpit-mandala .micon {
                min-width: 44px;
                min-height: 44px;
                width: 44px;
                height: 44px;
            }
        }
        .mandala-runes {
            display: flex;
            gap: 8px;
            flex-wrap: wrap;
            margin: 10px 0 8px;
        }
        .mandala-rune {
            display: flex;
            align-items: center;
            gap: 6px;
            padding: 6px 10px;
            border-radius: 999px;
            border: 1px solid var(--border);
            background: var(--bg-secondary);
            cursor: default;
            color: var(--text-primary);
            animation: runeReveal 0.3s ease-out;
        }
        @media (prefers-reduced-motion: reduce) {
            .mandala-rune {
                animation: none;
            }
        }
        @keyframes runeReveal {
            from { opacity: 0; transform: scale(0.96); }
            to { opacity: 1; transform: scale(1); }
        }
        .mandala-rune .rune-dot {
            width: 10px;
            height: 10px;
            min-width: 10px;
            min-height: 10px;
            border-radius: 999px;
            background: var(--accent);
            opacity: 0.95;
            flex-shrink: 0;
        }
        /* Tension : losange (tension_time, appel, érosion, surcharge) */
        .mandala-rune.rune--tension .rune-dot {
            border-radius: 2px;
            transform: rotate(45deg);
        }
        /* Calme : cercle (repos, promesse latente) — défaut déjà cercle */
        .mandala-rune.rune--calme .rune-dot {
            border-radius: 999px;
        }
        .mandala-rune .rune-label {
            font-size: 12px;
        }
        .mandala-rune .rune-hint {
            font-size: 11px;
            margin-left: 6px;
            color: var(--text-secondary);
        }
        /* Wrapper porte couleur et variables pour héritage SVG (fix contraste thèmes) */
        .mandala-wheel-wrap {
            position: relative;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 8px;
            color: var(--text-primary);
            --mandala-arc-fill: var(--bg-secondary);
            --mandala-arc-stroke: var(--border);
            --mandala-arc-hover: var(--hover);
            --mandala-center-fill: var(--bg-secondary);
            --mandala-center-stroke: var(--border);
        }
        /* Profondeur : dégradé radial discret derrière le mandala */
        .mandala-wheel-wrap::before {
            content: '';
            position: absolute;
            left: 50%;
            top: 50%;
            width: 240px;
            height: 240px;
            margin-left: -120px;
            margin-top: -120px;
            border-radius: 50%;
            background: radial-gradient(circle at center, var(--bg-secondary) 0%, transparent 70%);
            opacity: 0.5;
            pointer-events: none;
            z-index: 0;
        }
        .mandala-wheel-wrap > .mandala-wheel,
        .mandala-wheel-wrap > .mandala-hintline {
            position: relative;
            z-index: 1;
        }
        .mandala-wheel {
            width: 100%;
            max-width: 280px;
            height: auto;
            min-height: 200px;
            aspect-ratio: 1;
            user-select: none;
            color: inherit;
        }
        /* Anneaux décoratifs (multi-anneau type mandala) */
        .mandala-ring {
            fill: none;
            stroke: var(--mandala-arc-stroke);
            stroke-width: 0.8;
            opacity: 0.6;
        }
        .mandala-ring-outer {
            stroke-width: 1;
            opacity: 0.5;
        }
        .mandala-ring-mid {
            stroke-width: 0.6;
            opacity: 0.7;
        }
        /* Anneau pointillé : frontière du « monde » */
        .mandala-ring-dashed {
            stroke-dasharray: 4 3;
            stroke-width: 0.6;
            opacity: 0.4;
        }
        .seg {
            cursor: pointer;
            outline: none;
        }
        .seg .seg-arc,
        .seg .seg-icon,
        .seg .seg-label {
            pointer-events: none;
        }
        .seg .seg-hit {
            pointer-events: all;
        }
        .seg-arc {
            fill: var(--mandala-arc-fill);
            stroke: var(--mandala-arc-stroke);
            stroke-width: 1.5;
            pointer-events: none;
        }
        .seg-icon,
        .seg-label {
            pointer-events: none;
        }
        .seg-hit {
            cursor: pointer;
        }
        .seg:hover .seg-arc {
            fill: var(--mandala-arc-hover);
        }
        .seg:active .seg-arc {
            fill: var(--mandala-arc-hover);
        }
        .seg.seg-disabled .seg-arc {
            fill: var(--bg-secondary, #2a2a2a);
            opacity: 0.6;
        }
        .seg.seg-disabled:hover .seg-arc {
            fill: var(--bg-secondary, #2a2a2a);
        }
        .seg.seg-disabled {
            cursor: default;
            pointer-events: none;
        }
        .seg.seg-dominant .seg-arc {
            fill: var(--accent, #64dfdf);
            opacity: 0.35;
        }
        .seg.seg-dominant:hover .seg-arc {
            fill: var(--accent, #64dfdf);
            opacity: 0.5;
        }
        .seg.seg-dominant .seg-icon,
        .seg.seg-dominant .seg-label {
            fill: var(--accent, #64dfdf);
        }
        .seg.seg-dominant {
            cursor: pointer;
            transform-origin: 110px 110px;
            transform: scale(1.08);
        }
        .seg.seg-dominant.pulse-dominant .seg-arc {
            animation: segPulse 1.2s ease-in-out;
        }
        @keyframes segPulse {
            0%, 100% { opacity: 0.35; }
            50% { opacity: 0.6; }
        }
        .seg.seg-attenuated .seg-arc {
            fill: var(--bg-secondary, #2a2a2a);
            opacity: 0.25;
        }
        .seg.seg-attenuated .seg-icon {
            font-size: 14px;
            opacity: 0.85;
        }
        .seg.seg-attenuated .seg-label {
            display: none;
        }
        .seg.seg-attenuated {
            cursor: default;
        }
        .seg-label {
            font-size: 11px;
            fill: currentColor;
            dominant-baseline: middle;
        }
        .seg-icon {
            font-size: 16px;
            fill: currentColor;
            dominant-baseline: middle;
            font-family: system-ui, "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
        }
        .seg:focus .seg-arc,
        .mandala-centerbtn:focus circle {
            stroke: currentColor;
            stroke-width: 2;
        }
        .mandala-centerbtn {
            cursor: pointer;
            outline: none;
        }
        .mandala-centerbtn circle {
            fill: var(--mandala-center-fill);
            stroke: var(--mandala-center-stroke);
            stroke-width: 1;
        }
        .mandala-centerbtn:hover circle {
            fill: var(--mandala-arc-hover);
        }
        .mandala-centerbtn .mandala-centerbtn-icon {
            font-size: 16px;
            fill: currentColor;
            dominant-baseline: middle;
            pointer-events: none;
            font-family: system-ui, "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
        }
        .mandala-center-icon {
            cursor: pointer;
            outline: none;
        }
        .mandala-center-icon circle {
            stroke: var(--mandala-arc-stroke);
            stroke-width: 1;
        }
        .mandala-center-icon-soul {
            fill: var(--mandala-arc-fill);
        }
        .mandala-center-icon-bubble {
            fill: var(--mandala-arc-fill);
            stroke-width: 1.5;
        }
        .mandala-center-icon:hover circle {
            fill: var(--mandala-arc-hover);
        }
        .mandala-center-icon-label {
            fill: currentColor;
            pointer-events: none;
            font-size: 9px;
        }
        .mandala-center-empty {
            fill: var(--text-secondary);
            pointer-events: none;
        }
        /* Entity state ring (anneau 1) — couleurs par état */
        .mandala-center-icon.es-neutral circle { fill: var(--mandala-arc-fill); stroke: var(--mandala-arc-stroke); }
        .mandala-center-icon.es-warm circle { fill: #f4a261; stroke: #e76f51; }
        .mandala-center-icon.es-hot circle { fill: #e76f51; stroke: #e63946; }
        .mandala-center-icon.es-muted circle { fill: var(--bg-secondary, #2a2a2a); stroke: var(--text-secondary); opacity: 0.8; }
        .mandala-center-icon.es-warm:hover circle { fill: #e76f51; }
        .mandala-center-icon.es-hot:hover circle { fill: #e63946; }
        .mandala-center-icon.es-muted:hover circle { opacity: 1; }
        .intention-seg.rune-focused .intention-arc { fill: var(--accent, #64dfdf); opacity: 0.5; }
        .mandala-rune.rune-focused .rune-dot { background: var(--accent, #64dfdf); }
        .intention-seg {
            cursor: pointer;
            outline: none;
        }
        .intention-arc {
            fill: var(--mandala-arc-fill);
            stroke: var(--mandala-arc-stroke);
            stroke-width: 1;
            pointer-events: none;
        }
        .intention-seg:hover .intention-arc {
            fill: var(--mandala-arc-hover);
        }
        .intention-seg.intention-active .intention-arc {
            fill: var(--mandala-arc-hover);
            stroke: var(--accent);
            stroke-width: 1.5;
        }
        .intention-hit {
            pointer-events: all;
        }
        .intention-icon {
            fill: currentColor;
            pointer-events: none;
            font-family: system-ui, "Apple Color Emoji", "Segoe UI Emoji", "Noto Color Emoji", sans-serif;
        }
        .mandala-hintline {
            font-size: 11px;
            min-height: 16px;
            text-align: center;
            color: var(--text-secondary);
        }
        .mandala-why-hint {
            font-size: 10px;
            text-align: center;
            color: var(--text-tertiary, var(--text-secondary));
            margin: 4px 0 0;
            min-height: 14px;
        }
        .mandala-runes-row {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
            margin-bottom: 4px;
        }
        .mandala-runes-row .mandala-runes {
            flex: 1;
            min-width: 0;
        }
        .mandala-runes-row [data-action="openRunesEditorModal"] {
            flex-shrink: 0;
            font-size: 12px;
            padding: 4px 8px;
        }
        .mandala-runes-editor-dialog label {
            display: block;
            margin-top: 4px;
        }
        .mandala-runes-editor-dialog input[type="text"],
        .mandala-runes-editor-dialog input[type="number"] {
            width: 100%;
            box-sizing: border-box;
        }
        .cockpit-context-panel {
            margin-top: 8px;
            padding: 8px 0;
            border-top: 1px solid var(--border);
            max-height: 200px;
            overflow-y: auto;
        }
        .cockpit-context-panel-inner {
            font-size: 12px;
        }
        .cockpit-fragments-title {
            font-weight: 600;
            margin-bottom: 6px;
            color: var(--text-primary);
        }
        .cockpit-fragment-section {
            margin-bottom: 10px;
        }
        .cockpit-fragment-section-head {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 4px;
            font-size: 11px;
            color: var(--text-secondary);
        }
        .cockpit-fragment-voir-tout {
            background: none;
            border: none;
            color: var(--accent);
            cursor: pointer;
            font-size: 10px;
            padding: 0 4px;
        }
        .cockpit-fragment-voir-tout:hover {
            text-decoration: underline;
        }
        .cockpit-fragment-list {
            list-style: none;
            margin: 0;
            padding: 0;
        }
        .cockpit-fragment-item {
            display: flex;
            align-items: center;
            gap: 6px;
            padding: 4px 0;
            border-bottom: 1px solid var(--border);
        }
        .cockpit-fragment-item:last-child {
            border-bottom: none;
        }
        .cockpit-fragment-label {
            flex: 1;
            min-width: 0;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .cockpit-fragment-label.cockpit-fragment-late {
            color: var(--accent-warning, #ffb347);
        }
        .cockpit-fragment-btn {
            flex-shrink: 0;
            padding: 2px 6px;
            font-size: 10px;
            border-radius: 4px;
            border: 1px solid var(--border);
            background: var(--bg-secondary);
            color: var(--text-primary);
            cursor: pointer;
        }
        .cockpit-fragment-btn:hover {
            background: var(--bg-tertiary);
        }
        .cockpit-fragment-btn-primary {
            border-color: var(--accent);
            color: var(--accent);
        }
        .cockpit-fragments-empty {
            font-size: 11px;
            color: var(--text-secondary);
            margin: 0;
        }
        .mandala-wheel.pulse {
            animation: mandalaPulse 240ms ease-out;
        }
        @media (prefers-reduced-motion: reduce) {
            .mandala-wheel.pulse {
                animation: none;
            }
        }
        @keyframes mandalaPulse {
            0% { transform: scale(1); }
            45% { transform: scale(1.03); }
            100% { transform: scale(1); }
        }
        .mandala-tools {
            margin-top: 10px;
        }
        .mandala-tools summary {
            cursor: pointer;
            font-size: 12px;
            font-weight: 500;
            color: var(--text-secondary);
            list-style: none;
        }
        .mandala-tools summary::-webkit-details-marker {
            display: none;
        }
        .mandala-tools summary::after {
            content: ' ▸';
            font-size: 10px;
        }
        .mandala-tools[open] summary {
            color: var(--text-primary);
        }
        .mandala-tools[open] summary::after {
            content: ' ▾';
        }
        .mandala-tools-content {
            margin-top: 8px;
        }
        .help-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            margin-bottom: 12px;
        }
        .help-title {
            font-size: 16px;
            font-weight: 600;
        }
        .help-close {
            background: var(--bg-secondary);
            border: 1px solid var(--border-dark);
            width: 32px;
            height: 32px;
            cursor: pointer;
            color: var(--text-primary);
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.15s ease;
        }
        
        .help-close:hover {
            background: var(--text-primary);
            color: var(--bg-primary);
        }
        .help-section {
            margin-top: 12px;
            padding-top: 8px;
            border-top: 1px solid var(--border);
        }
        .help-section summary {
            display: flex;
            align-items: center;
            justify-content: space-between;
            font-size: 13px;
            text-transform: uppercase;
            letter-spacing: 0.08em;
            color: var(--text-secondary);
            cursor: pointer;
            list-style: none;
            padding: 6px 0;
        }
        .help-section summary::-webkit-details-marker {
            display: none;
        }
        .help-section summary::after {
            content: '▸';
            font-size: 12px;
            color: var(--text-secondary);
            transition: transform 0.2s ease;
        }
        .help-section[open] summary::after {
            transform: rotate(90deg);
        }
        .help-content {
            padding: 6px 0 4px 0;
        }
        .help-content p,
        .help-content li {
            font-size: 13px;
            color: var(--text-primary);
            line-height: 1.5;
        }
        .help-content ul {
            padding-left: 18px;
        }
        .help-link {
            color: var(--accent);
            text-decoration: underline;
        }
        .help-link:hover { color: var(--text-primary); }

        /* Onglets d'aide */
        .help-tabs {
            display: flex;
            gap: 4px;
            margin-bottom: 16px;
            border-bottom: 2px solid var(--border-dark);
            padding-bottom: 8px;
        }

        .help-tab {
            flex: 1;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 4px;
            padding: 8px 4px;
            background: transparent;
            border: none;
            border-bottom: 2px solid transparent;
            color: var(--text-secondary);
            cursor: pointer;
            transition: all 0.2s ease;
            font-size: 11px;
        }

        .help-tab:hover {
            color: var(--text-primary);
            background: var(--bg-secondary);
        }

        .help-tab.active {
            color: var(--text-primary);
            border-bottom-color: var(--text-primary);
            font-weight: 600;
        }

        .tab-icon {
            font-size: 18px;
        }

        .tab-label {
            font-size: 11px;
            text-align: center;
        }

        /* Contenu des onglets */
        .help-content-wrapper {
            position: relative;
        }

        .help-tab-content {
            display: none;
            animation: fadeIn 0.3s ease;
        }

        .help-tab-content.active {
            display: block;
        }

        /* Page d'accueil / Onboarding */
        .help-welcome {
            padding: 8px 0;
        }

        .welcome-hero {
            text-align: center;
            margin-bottom: 24px;
            padding-bottom: 20px;
            border-bottom: 2px solid var(--border-dark);
        }

        .welcome-title {
            font-size: 22px;
            font-weight: 700;
            color: var(--text-primary);
            margin: 0 0 8px 0;
        }

        .welcome-subtitle {
            font-size: 14px;
            color: var(--text-secondary);
            margin: 0;
        }

        .welcome-section {
            margin-bottom: 24px;
        }

        .section-heading {
            font-size: 16px;
            font-weight: 600;
            color: var(--text-primary);
            margin: 0 0 12px 0;
        }

        .section-text {
            font-size: 13px;
            color: var(--text-primary);
            line-height: 1.6;
            margin-bottom: 12px;
        }

        .feature-list {
            list-style: none;
            padding-left: 0;
            margin: 12px 0;
        }

        .feature-list li {
            padding: 8px 0;
            padding-left: 24px;
            position: relative;
            font-size: 13px;
            line-height: 1.6;
        }

        .feature-list li::before {
            content: "✓";
            position: absolute;
            left: 0;
            color: var(--text-primary);
            font-weight: bold;
        }

        .quick-start-steps {
            display: flex;
            flex-direction: column;
            gap: 16px;
            margin-top: 16px;
        }

        .step-item {
            display: flex;
            gap: 12px;
            align-items: flex-start;
        }

        .step-number {
            width: 32px;
            height: 32px;
            border-radius: 50%;
            background: var(--text-primary);
            color: var(--bg-primary);
            display: flex;
            align-items: center;
            justify-content: center;
            font-weight: 700;
            font-size: 14px;
            flex-shrink: 0;
        }

        .step-content {
            flex: 1;
        }

        .step-content strong {
            display: block;
            margin-bottom: 4px;
            color: var(--text-primary);
            font-size: 13px;
        }

        .step-content p {
            margin: 0;
            font-size: 12px;
            color: var(--text-secondary);
            line-height: 1.5;
        }

        .inline-icon {
            font-size: 16px;
            vertical-align: middle;
        }

        .welcome-actions {
            display: flex;
            gap: 12px;
            margin-top: 16px;
        }

        .welcome-btn {
            flex: 1;
            padding: 10px 16px;
            background: var(--bg-secondary);
            border: 1px solid var(--border-dark);
            border-radius: 6px;
            color: var(--text-primary);
            cursor: pointer;
            transition: all 0.2s ease;
            font-size: 13px;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 6px;
        }

        .welcome-btn:hover {
            background: var(--hover);
            border-color: var(--text-primary);
            transform: translateY(-1px);
        }

        .welcome-footer {
            margin-top: 32px;
            padding-top: 20px;
            border-top: 1px solid var(--border-dark);
            text-align: center;
        }

        .footer-text {
            font-size: 12px;
            color: var(--text-secondary);
            margin: 0;
        }
        
        /* Astuces */
        .help-tips {
            padding: 8px 0;
        }

        .tab-title {
            font-size: 18px;
            font-weight: 600;
            color: var(--text-primary);
            margin: 0 0 20px 0;
        }

        .tip-card {
            display: flex;
            gap: 12px;
            padding: 16px;
            margin-bottom: 16px;
            background: var(--bg-secondary);
            border: 1px solid var(--border-dark);
            border-radius: 8px;
            transition: all 0.2s ease;
        }

        .tip-card:hover {
            border-color: var(--text-primary);
            transform: translateX(2px);
        }

        .tip-icon {
            font-size: 24px;
            flex-shrink: 0;
        }

        .tip-content {
            flex: 1;
        }

        .tip-title {
            font-size: 14px;
            font-weight: 600;
            color: var(--text-primary);
            margin: 0 0 6px 0;
        }

        .tip-content p {
            font-size: 13px;
            color: var(--text-primary);
            line-height: 1.6;
            margin: 0;
        }

        /* FAQ */
        .help-faq {
            padding: 8px 0;
        }

        .faq-item {
            margin-bottom: 12px;
            border: 1px solid var(--border-dark);
            border-radius: 6px;
            overflow: hidden;
            transition: all 0.2s ease;
        }

        .faq-item:hover {
            border-color: var(--text-primary);
        }

        .faq-question {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 12px 16px;
            background: var(--bg-secondary);
            cursor: pointer;
            font-size: 13px;
            font-weight: 500;
            color: var(--text-primary);
            list-style: none;
            transition: background 0.2s ease;
        }

        .faq-question:hover {
            background: var(--hover);
        }

        .faq-question::-webkit-details-marker {
            display: none;
        }

        .faq-question::after {
            content: '▾';
            margin-left: auto;
            font-size: 12px;
            color: var(--text-secondary);
            transition: transform 0.2s ease;
        }

        .faq-item[open] .faq-question::after {
            transform: rotate(180deg);
        }

        .faq-icon {
            font-size: 18px;
        }

        .faq-answer {
            padding: 12px 16px 16px 48px;
            background: var(--bg-primary);
            font-size: 13px;
            color: var(--text-primary);
            line-height: 1.6;
        }

        .faq-answer ul {
            margin: 8px 0;
            padding-left: 20px;
        }

        .faq-answer li {
            margin: 4px 0;
        }

        /* Guide */
        .help-guide {
            padding: 8px 0;
        }

        .section-summary {
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .section-icon {
            font-size: 16px;
        }

        .help-list {
            list-style: none;
            padding-left: 0;
            margin: 12px 0;
        }

        .help-list li {
            padding: 6px 0;
            padding-left: 20px;
            position: relative;
            font-size: 13px;
            line-height: 1.6;
        }

        .help-list li::before {
            content: "•";
            position: absolute;
            left: 8px;
            color: var(--text-secondary);
        }

        .content-subtitle {
            font-size: 14px;
            font-weight: 600;
            color: var(--text-primary);
            margin: 16px 0 8px 0;
        }

        /* Sidebar d'édition de bulle */
        .bubble-edit-sidebar {
            position: absolute;
            right: 0;
            top: 56px;
            bottom: 64px;
            width: 320px;
            background: var(--bg-primary);
            border-left: 1px solid var(--border);
            padding: 16px;
            overflow-y: auto;
            -webkit-overflow-scrolling: touch;
            transform: translateX(100%);
            transition: transform 0.3s ease;
            z-index: 10001;
        }

        .bubble-edit-sidebar.show {
            transform: translateX(0);
        }
        /* Soul Edit Sidebar — Redesign complet */
        .soul-edit-sidebar { width: min(380px, 100vw); }
        @media (max-width: 480px) {
            .soul-edit-sidebar { width: 100%; max-width: 100%; right: 0; left: 0; }
            .bubble-edit-sidebar.soul-edit-sidebar { width: 100%; }
        }
        .soul-edit-sidebar .soul-edit-hero { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 16px; padding-bottom: 14px; border-bottom: 1px solid var(--border); }
        .soul-edit-sidebar .soul-edit-hero-symbol { width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 28px; flex-shrink: 0; cursor: pointer; transition: transform 0.15s, box-shadow 0.15s; }
        .soul-edit-sidebar .soul-edit-hero-symbol:hover { transform: scale(1.08); box-shadow: 0 0 0 3px var(--accent); }
        .soul-edit-sidebar .soul-edit-hero-info { flex: 1; min-width: 0; }
        .soul-edit-sidebar .soul-edit-hero-name { font-size: 18px; font-weight: 600; color: var(--text-primary); margin-bottom: 4px; word-break: break-word; }
        .soul-edit-sidebar .soul-edit-hero-meta { display: flex; flex-wrap: wrap; gap: 10px; font-size: 11px; color: var(--text-secondary); margin-bottom: 8px; }
        .soul-edit-sidebar .soul-edit-graph-btn { padding: 6px 10px; font-size: 11px; border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text-primary); border-radius: 6px; cursor: pointer; }
        .soul-edit-sidebar .soul-edit-graph-btn:hover { background: var(--hover); }
        
        .soul-edit-quick-actions { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 16px; }
        .soul-edit-quick-btn { width: 44px; height: 44px; border: 1px solid var(--border); background: var(--bg-secondary); border-radius: 8px; font-size: 16px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
        .soul-edit-quick-btn:hover { background: var(--accent); color: var(--bg-primary); border-color: var(--accent); }
        
        .soul-edit-stats-bar { display: flex; justify-content: space-around; background: var(--bg-secondary); border-radius: 8px; padding: 12px 8px; margin-bottom: 16px; }
        .soul-edit-stat { text-align: center; flex: 1; }
        .soul-edit-stat-value { display: block; font-size: 18px; font-weight: 600; color: var(--text-primary); }
        .soul-edit-stat-label { font-size: 10px; color: var(--text-secondary); text-transform: uppercase; }
        
        .soul-edit-sidebar details.soul-section { border: 1px solid var(--border); border-radius: 8px; margin-bottom: 10px; overflow: hidden; }
        .soul-edit-sidebar details.soul-section summary { padding: 12px; cursor: pointer; list-style: none; display: flex; align-items: center; gap: 8px; min-height: 44px; font-size: 13px; user-select: none; background: var(--bg-secondary); }
        .soul-edit-sidebar details.soul-section summary::-webkit-details-marker { display: none; }
        .soul-edit-sidebar details.soul-section summary::before { content: '▶'; font-size: 10px; transition: transform 0.2s; color: var(--text-secondary); }
        .soul-edit-sidebar details.soul-section[open] summary::before { transform: rotate(90deg); }
        .soul-edit-sidebar details.soul-section .soul-section-body { padding: 12px; }
        
        .soul-edit-contact-item { display: flex; align-items: center; gap: 10px; padding: 10px; border: 1px solid var(--border); border-radius: 6px; margin-bottom: 8px; background: var(--bg-primary); }
        .soul-edit-contact-icon { font-size: 18px; flex-shrink: 0; }
        .soul-edit-contact-main { flex: 1; min-width: 0; }
        .soul-edit-contact-type { display: block; font-size: 10px; color: var(--text-secondary); text-transform: uppercase; }
        .soul-edit-contact-value { display: block; font-size: 13px; color: var(--text-primary); word-break: break-all; }
        .soul-edit-contact-actions { display: flex; gap: 4px; flex-shrink: 0; }
        .soul-edit-contact-action-btn { width: 32px; height: 32px; border: 1px solid var(--border); background: var(--bg-secondary); border-radius: 6px; cursor: pointer; font-size: 12px; display: flex; align-items: center; justify-content: center; }
        .soul-edit-contact-action-btn:hover { background: var(--hover); }
        .soul-edit-contact-action-btn.danger:hover { background: #fecaca; border-color: #ef4444; }
        
        .soul-edit-add-btn { display: block; width: 100%; padding: 10px; margin-top: 8px; border: 1px dashed var(--border); background: transparent; color: var(--text-secondary); border-radius: 6px; font-size: 12px; cursor: pointer; text-align: center; transition: all 0.15s; }
        .soul-edit-add-btn:hover { border-color: var(--accent); color: var(--accent); background: var(--bg-secondary); }
        
        .soul-edit-pact-item { display: flex; align-items: center; gap: 10px; padding: 10px; border: 1px solid var(--border); border-radius: 6px; margin-bottom: 8px; background: var(--bg-primary); }
        .soul-edit-pact-text { flex: 1; font-size: 12px; color: var(--text-primary); min-width: 0; }
        .soul-edit-pact-meta { font-size: 10px; color: var(--text-secondary); flex-shrink: 0; }
        .soul-edit-pact-btn { width: 32px; height: 32px; border: 1px solid var(--border); background: var(--bg-secondary); border-radius: 6px; cursor: pointer; font-size: 14px; }
        .soul-edit-pact-btn:hover { background: var(--accent); color: var(--bg-primary); }
        
        .soul-edit-bubbles-grid { display: flex; flex-wrap: wrap; gap: 6px; }
        .soul-edit-bubble-chip { padding: 8px 12px; border: 1px solid var(--border); background: var(--bg-primary); border-radius: 6px; font-size: 12px; cursor: pointer; }
        .soul-edit-bubble-chip:hover { background: var(--hover); border-color: var(--accent); }
        
        .soul-edit-journal { max-height: 180px; overflow-y: auto; }
        .soul-edit-journal-item { display: flex; gap: 8px; padding: 8px 0; border-bottom: 1px solid var(--border); font-size: 11px; }
        .soul-edit-journal-item:last-child { border-bottom: none; }
        .soul-edit-journal-date { color: var(--text-secondary); flex-shrink: 0; min-width: 100px; }
        .soul-edit-journal-text { color: var(--text-primary); }
        
        .soul-edit-items-grid { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }
        .soul-edit-item-chip { padding: 6px 10px; background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 6px; font-size: 11px; }
        
        .soul-edit-empty { font-size: 12px; color: var(--text-secondary); padding: 8px 0; }
        
        .soul-edit-danger-zone { margin-top: 20px; padding-top: 16px; border-top: 1px solid var(--border); display: flex; gap: 8px; flex-wrap: wrap; }
        .soul-edit-danger-btn { padding: 10px 14px; border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text-primary); border-radius: 6px; font-size: 12px; cursor: pointer; }
        .soul-edit-danger-btn:hover { background: var(--hover); }
        .soul-edit-danger-btn.danger { color: #ef4444; }
        .soul-edit-danger-btn.danger:hover { background: #fecaca; border-color: #ef4444; }
        
        .soul-edit-bubble-select { width: 100%; padding: 10px; border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text-primary); border-radius: 6px; font-size: 13px; }
        
        .soul-edit-relations { display: flex; flex-direction: column; gap: 8px; }
        .soul-edit-relation-item { display: flex; align-items: center; gap: 10px; padding: 10px; border: 1px solid var(--border); border-radius: 6px; background: var(--bg-primary); cursor: pointer; transition: all 0.15s; }
        .soul-edit-relation-item:hover { background: var(--hover); border-color: var(--accent); }
        .soul-edit-relation-symbol { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 18px; flex-shrink: 0; }
        .soul-edit-relation-info { flex: 1; min-width: 0; }
        .soul-edit-relation-name { display: block; font-size: 13px; font-weight: 500; color: var(--text-primary); }
        .soul-edit-relation-count { display: block; font-size: 10px; color: var(--text-secondary); margin-top: 2px; }
        .soul-edit-relation-arrow { font-size: 14px; color: var(--text-secondary); flex-shrink: 0; }

        .bubble-edit-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 20px;
            padding-bottom: 12px;
            border-bottom: 1px solid var(--border);
        }

        .bubble-edit-title {
            font-size: 16px;
            font-weight: 500;
            color: var(--text-primary);
        }

        .bubble-edit-close {
            width: 44px;
            height: 44px;
            min-width: 44px;
            min-height: 44px;
            border: 1px solid var(--border-dark);
            background: transparent;
            color: var(--text-primary);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.15s ease;
        }

        .bubble-edit-close:hover {
            background: var(--text-primary);
            color: var(--bg-primary);
        }

        .bubble-edit-section {
            margin-bottom: 24px;
        }

        .bubble-edit-section-title {
            font-size: 12px;
            font-weight: 500;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            margin-bottom: 12px;
        }

        .bubble-edit-quick-add {
            display: flex;
            gap: 8px;
            margin-bottom: 12px;
        }

        .bubble-edit-quick-add input {
            flex: 1;
            padding: 8px;
            border: 1px solid var(--border-dark);
            font-size: 13px;
        }

        .bubble-edit-quick-add button {
            padding: 8px 12px;
            border: 1px solid var(--border-dark);
            background: var(--text-primary);
            color: var(--bg-primary);
            cursor: pointer;
            font-size: 13px;
        }

        .bubble-edit-soul-item {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 8px;
            border: 1px solid var(--border);
            margin-bottom: 4px;
        }

        .bubble-edit-soul-info {
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .bubble-edit-soul-symbol {
            font-size: 18px;
        }

        .bubble-edit-soul-name {
            font-size: 13px;
            color: var(--text-primary);
        }

        .bubble-edit-remove {
            width: 24px;
            height: 24px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            color: var(--text-primary);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 12px;
            transition: all 0.15s ease;
        }

        .bubble-edit-remove:hover {
            background: var(--ghibli-coral);
            border-color: var(--ghibli-coral);
            color: #ffffff;
        }

        .souls-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 12px;
            padding-bottom: 10px;
            border-bottom: 1px solid var(--border);
        }

        .souls-title {
            font-size: 13px;
            font-weight: 600;
            color: var(--text-primary);
            letter-spacing: -0.02px;
        }

        .add-soul-btn {
            min-width: 32px;
            height: 36px;
            padding: 0 12px;
            border-radius: var(--radius);
            background: var(--bg-secondary);
            color: var(--text-primary);
            border: 1px solid var(--border-dark);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 18px;
            transition: all 0.15s ease;
        }

        .add-soul-btn:hover {
            background: var(--text-primary);
            color: var(--bg-primary);
        }

        .souls-header-actions {
            display: flex;
            align-items: center;
            gap: 6px;
        }

        .souls-search-bar {
            margin-bottom: 12px;
        }

        .souls-search-row {
            display: flex;
            gap: 8px;
            align-items: center;
            flex-wrap: wrap;
        }

        .souls-search-row-l2 {
            display: flex;
            gap: 8px;
            align-items: center;
            flex-wrap: wrap;
        }

        @media (min-width: 481px) {
            .souls-search-row-l2 { margin-top: 0; margin-left: 0; }
        }

        @media (max-width: 480px) {
            .souls-search-row { flex-direction: column; align-items: stretch; }
            .souls-search-row .souls-search-input { width: 100%; }
            .souls-search-row-l2 { margin-top: 8px; }
        }

        .souls-search-input {
            flex: 1;
            min-width: 0;
            padding: 8px 12px;
            font-size: 13px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            color: var(--text-primary);
            border-radius: var(--radius);
            outline: none;
            box-sizing: border-box;
        }

        .souls-pills-dropdown-wrap {
            position: relative;
        }

        .souls-pills-btn {
            padding: 8px 10px;
            font-size: 12px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            color: var(--text-primary);
            cursor: pointer;
            border-radius: 0;
            white-space: nowrap;
        }

        .souls-pills-btn:hover {
            background: var(--border);
        }

        .souls-pills-dropdown {
            display: none;
            position: absolute;
            top: 100%;
            right: 0;
            margin-top: 4px;
            padding: 8px;
            background: var(--bg-primary);
            border: 1px solid var(--border);
            box-shadow: 0 4px 12px rgba(0,0,0,0.2);
            z-index: 1000;
            min-width: 140px;
        }

        .souls-pills-dropdown.show {
            display: block;
        }

        .souls-pill-option {
            display: block;
            padding: 6px 8px;
            cursor: pointer;
            font-size: 13px;
            color: var(--text-primary);
        }

        .souls-pill-option:hover {
            background: var(--bg-secondary);
        }

        .souls-pills-label {
            font-size: 11px;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            margin: 8px 0 4px 0;
        }

        .souls-pills-label:first-child {
            margin-top: 0;
        }

        .souls-pills-section {
            margin-bottom: 8px;
        }

        .souls-pill {
            display: inline-block;
            padding: 4px 10px;
            margin: 2px 4px 2px 0;
            font-size: 12px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            color: var(--text-primary);
            cursor: pointer;
            border-radius: 4px;
            transition: all 0.15s ease;
        }

        .souls-pill:hover {
            background: var(--border);
        }

        .souls-pill.active {
            background: var(--text-primary);
            color: var(--bg-primary);
            border-color: var(--text-primary);
        }

        .souls-search-input::placeholder {
            color: var(--text-secondary);
        }

        .souls-search-input:focus {
            border-color: var(--text-secondary);
        }

        .import-contacts-btn {
            width: 32px;
            height: 32px;
            border-radius: 0;
            background: var(--bg-secondary);
            color: var(--text-primary);
            border: 1px solid var(--border-dark);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 16px;
            transition: all 0.15s ease;
        }

        .import-contacts-btn:hover {
            background: var(--text-primary);
            color: var(--bg-primary);
        }

        /* ===== SIDEBAR ÂMES — Cards organiques ===== */
        .souls-sidebar-header { padding: 12px; border-bottom: 1px solid var(--border); flex-shrink: 0; }
        .souls-search-input { width: 100%; padding: 10px 12px; font-size: 13px; border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text-primary); border-radius: var(--radius); margin-bottom: 10px; box-sizing: border-box; }
        .souls-header-row { display: flex; gap: 8px; align-items: center; }
        .souls-header-row select { flex: 1; min-width: 0; padding: 8px 10px; font-size: 12px; border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text-primary); border-radius: var(--radius); }
        .souls-header-btn { width: 36px; height: 36px; padding: 0; border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text-primary); border-radius: var(--radius); cursor: pointer; font-size: 14px; }
        .souls-header-actions { display: flex; gap: 6px; align-items: center; position: relative; }
        .souls-settings-btn { width: 36px; height: 36px; padding: 0; border: 1px solid var(--border); background: var(--bg-secondary); color: var(--text-primary); border-radius: var(--radius); cursor: pointer; font-size: 16px; display: flex; align-items: center; justify-content: center; }
        .souls-settings-btn:hover { background: var(--hover); }
        .souls-settings-menu { display: none; position: absolute; top: 100%; right: 0; margin-top: 4px; background: var(--bg-primary); border: 1px solid var(--border); border-radius: var(--radius); box-shadow: 0 4px 12px rgba(0,0,0,0.15); z-index: 1000; min-width: 220px; padding: 6px 0; }
        .souls-settings-menu.show { display: block; }
        .souls-settings-menu button { display: block; width: 100%; padding: 10px 14px; border: none; background: none; color: var(--text-primary); font-size: 13px; text-align: left; cursor: pointer; }
        .souls-settings-menu button:hover { background: var(--hover); }
        .souls-scroll-area { flex: 1; overflow-y: auto; padding: 12px; padding-left: max(12px, env(safe-area-inset-left)); -webkit-overflow-scrolling: touch; }
        .souls-section { margin-bottom: 20px; }
        .souls-section-title { font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.8px; color: var(--text-secondary); margin-bottom: 10px; padding-bottom: 4px; }
        .soul-card { position: relative; background: var(--bg-secondary); border: 1px solid var(--border); border-radius: 8px; margin-bottom: 8px; overflow: hidden; transition: border-color 0.2s, box-shadow 0.2s; }
        .soul-card::before { content: ''; position: absolute; inset: 0; border-radius: 8px; opacity: 0; pointer-events: none; transition: opacity 0.2s; }
        .soul-card.heat-1::before { opacity: 0.2; background: linear-gradient(135deg, transparent 50%, rgba(74,222,128,0.4) 100%); }
        .soul-card.heat-75::before { opacity: 0.15; background: linear-gradient(135deg, transparent 50%, rgba(74,222,128,0.3) 100%); }
        .soul-card.heat-5::before { opacity: 0.1; background: linear-gradient(135deg, transparent 50%, rgba(234,179,8,0.2) 100%); }
        .soul-card.heat-25::before { opacity: 0.08; background: linear-gradient(135deg, transparent 50%, rgba(248,113,113,0.2) 100%); }
        .soul-card.selected-in-graph { border-color: var(--accent); box-shadow: 0 0 0 2px rgba(37,99,235,0.3); }
        .soul-card .soul-card-body { padding: 10px 12px; overflow: visible; min-height: auto; }
        .soul-card-line1 { display: flex; align-items: center; gap: 8px; margin-bottom: 6px; }
        .soul-card-name { font-size: 14px; font-weight: 600; color: var(--text-primary); word-break: break-word; white-space: normal; }
        .soul-card-type-badge { font-size: 10px; padding: 2px 6px; border-radius: 4px; background: var(--border); color: var(--text-secondary); flex-shrink: 0; }
        .soul-card-line2 { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 6px; min-height: 20px; }
        .soul-card-bubble-chip { font-size: 10px; padding: 2px 6px; border-radius: 4px; background: var(--bg-primary); border: 1px solid var(--border); color: var(--text-secondary); max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        .soul-card-line3 { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
        .soul-card-badge { font-size: 10px; color: var(--text-secondary); }
        .soul-card-badge.late { color: #ef4444; }
        .soul-card-actions { display: flex; gap: 4px; margin-left: auto; flex-shrink: 0; }
        .soul-card-btn { width: 32px; height: 32px; padding: 0; border: none; background: var(--bg-primary); border-radius: 6px; cursor: pointer; font-size: 14px; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
        .soul-card-btn:hover { background: var(--hover); }
        .soul-card-btn.primary { background: var(--accent); color: var(--bg-primary); }
        .soul-card-avatar { width: 36px; height: 36px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 16px; flex-shrink: 0; cursor: grab; }
        .soul-card-avatar:active { cursor: grabbing; }

        /* Legacy soul-item (reused for cards) */
        .soul-item {
            --soul-card-radius: 10px;
            --soul-card-glow: rgba(100, 200, 255, 0.2);
            position: relative;
            background: var(--bg-secondary);
            border: 1px solid var(--border);
            border-radius: var(--soul-card-radius);
            margin-bottom: 8px;
            user-select: none;
            overflow: hidden;
            transition: border-color 0.25s ease, box-shadow 0.25s ease, transform 0.2s ease;
        }
        .soul-item:hover { transform: translateY(-1px); }
        .soul-item.expanded { transform: none; }
        .soul-item::before {
            content: '';
            position: absolute;
            inset: -1px;
            border-radius: calc(var(--soul-card-radius) + 2px);
            padding: 2px;
            background: linear-gradient(135deg, var(--border) 0%, transparent 40%, var(--accent) 100%);
            -webkit-mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
            mask: linear-gradient(#fff 0 0) content-box, linear-gradient(#fff 0 0);
            -webkit-mask-composite: xor;
            mask-composite: exclude;
            opacity: 0.4;
            pointer-events: none;
            transition: opacity 0.25s ease;
        }
        .soul-item.expanded::before { opacity: 0.9; }
        .soul-item.selected-in-graph { border-color: var(--accent); box-shadow: 0 0 16px var(--soul-card-glow); }
        .soul-item.heat-1::after { content: ''; position: absolute; inset: 0; border-radius: var(--soul-card-radius); opacity: 0.2; background: linear-gradient(135deg, transparent 50%, rgba(74,222,128,0.4) 100%); pointer-events: none; }
        .soul-item.heat-75::after { content: ''; position: absolute; inset: 0; border-radius: var(--soul-card-radius); opacity: 0.15; background: linear-gradient(135deg, transparent 50%, rgba(74,222,128,0.3) 100%); pointer-events: none; }
        .soul-item.heat-5::after { content: ''; position: absolute; inset: 0; border-radius: var(--soul-card-radius); opacity: 0.1; background: linear-gradient(135deg, transparent 50%, rgba(234,179,8,0.2) 100%); pointer-events: none; }
        .soul-item.heat-25::after { content: ''; position: absolute; inset: 0; border-radius: var(--soul-card-radius); opacity: 0.08; background: linear-gradient(135deg, transparent 50%, rgba(248,113,113,0.2) 100%); pointer-events: none; }
        .soul-item.soul-hidden { opacity: 0.45; }
        .soul-item.soul-hidden .soul-card-header { text-decoration: line-through; }
        
        /* Header compact — style liste contacts */
        .soul-card-header {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 10px 12px;
            cursor: pointer;
            min-height: 52px;
            transition: background 0.15s ease;
            -webkit-user-drag: element;
        }
        .soul-card-header:hover { background: var(--hover); }
        .soul-card-header:active { background: var(--border); }
        
        .soul-card-avatar {
            width: 40px;
            height: 40px;
            min-width: 40px;
            min-height: 40px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 18px;
            flex-shrink: 0;
            cursor: grab;
            transition: transform 0.15s ease;
        }
        .soul-card-avatar:active { cursor: grabbing; transform: scale(1.05); }
        
        .soul-card-main {
            flex: 1;
            min-width: 0;
        }
        .soul-card-contact-row { margin-top: 8px; }
        .soul-card-contact-btns { display: flex; gap: 6px; flex-wrap: wrap; }
        .soul-card-contact-btn { width: 32px; height: 32px; padding: 0; border: 1px solid var(--border); background: var(--bg-primary); border-radius: 6px; font-size: 12px; cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
        .soul-card-contact-btn:hover { background: var(--hover); border-color: var(--accent); }
        .soul-card-avatar.selected { box-shadow: 0 0 0 2px var(--accent); }
        .soul-card-name {
            font-size: 15px;
            font-weight: 500;
            color: var(--text-primary);
            word-break: break-word;
            white-space: normal;
        }
        .soul-card-meta {
            font-size: 11px;
            color: var(--text-secondary);
            margin-top: 2px;
            display: flex;
            gap: 6px;
            flex-wrap: wrap;
        }
        .soul-card-meta span { white-space: nowrap; }
        
        .soul-card-badges {
            display: flex;
            align-items: center;
            gap: 6px;
            flex-shrink: 0;
        }
        .soul-card-badge {
            font-size: 11px;
            padding: 2px 8px;
            border-radius: 10px;
            background: var(--border);
            color: var(--text-secondary);
        }
        .soul-card-select, .soul-card-pin {
            width: 28px;
            height: 28px;
            min-width: 28px;
            min-height: 28px;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: 6px;
            color: var(--text-secondary);
            transition: all 0.15s ease;
            cursor: pointer;
            user-select: none;
        }
        .soul-card-select:hover, .soul-card-pin:hover {
            background: var(--hover);
            color: var(--text-primary);
        }
        .soul-item.selected-in-graph .soul-card-select { color: var(--accent); }
        .soul-card-expand {
            width: 32px;
            height: 32px;
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: center;
            color: var(--text-secondary);
            transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
        }
        .soul-item.expanded .soul-card-expand { transform: rotate(180deg); }
        
        /* Corps étendu — HUD jeu vidéo (uniquement .soul-item expandable) */
        .soul-item .soul-card-body {
            overflow: hidden;
            max-height: 0;
            transition: max-height 0.35s cubic-bezier(0.4, 0, 0.2, 1);
        }
        .soul-item.expanded .soul-card-body { max-height: 600px; }
        
        .soul-card-inner {
            padding: 8px 10px 10px;
            border-top: 1px solid var(--border);
        }
        
        /* Fiche expanded — compacte, clic-ton-action */
        .soul-expand-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: 10px;
        }
        .soul-expand-btn {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 4px;
            padding: 6px 10px;
            font-size: 11px;
            border: 1px solid var(--border);
            background: var(--bg-primary);
            color: var(--text-primary);
            border-radius: 6px;
            cursor: pointer;
            transition: all 0.15s ease;
            white-space: nowrap;
        }
        .soul-expand-btn:hover { background: var(--hover); border-color: var(--text-secondary); }
        .soul-expand-btn.primary { background: var(--accent); color: var(--bg-primary); border-color: var(--accent); }
        .soul-expand-btn.primary:hover { opacity: 0.9; }
        .soul-expand-btn.danger:hover { border-color: #ef4444; color: #ef4444; }
        .soul-expand-btn.icon-only { padding: 6px; min-width: 28px; }
        
        .soul-expand-row {
            display: flex;
            align-items: center;
            flex-wrap: wrap;
            gap: 6px;
            margin-bottom: 8px;
            font-size: 11px;
        }
        .soul-expand-row:last-child { margin-bottom: 0; }
        .soul-expand-row-label { color: var(--text-secondary); flex-shrink: 0; min-width: 48px; }
        .soul-expand-chip { display: inline-flex; align-items: center; gap: 4px; padding: 3px 6px; background: var(--bg-primary); border: 1px solid var(--border); border-radius: 4px; font-size: 10px; }
        .soul-expand-muted { color: var(--text-secondary); font-size: 11px; }
        
        .soul-freshness-bar {
            height: 3px;
            background: var(--border);
            border-radius: 2px;
            overflow: hidden;
            margin-bottom: 8px;
        }
        .soul-freshness-fill {
            height: 100%;
            border-radius: 2px;
            background: linear-gradient(90deg, var(--accent), #4ade80);
            transition: width 0.4s ease;
        }
        
        /* Legacy fallbacks */
        .soul-card-section { padding: 8px 0; border-bottom: 1px solid var(--border); }
        .soul-card-section:last-child { border-bottom: none; }
        .soul-card-section-title { font-size: 10px; font-weight: 600; color: var(--text-secondary); margin-bottom: 6px; }
        .soul-card-actions { display: flex; flex-wrap: wrap; gap: 6px; }
        .soul-card-btn { display: flex; align-items: center; justify-content: center; gap: 4px; padding: 6px 10px; font-size: 11px; border: 1px solid var(--border); background: var(--bg-primary); color: var(--text-primary); border-radius: 6px; cursor: pointer; transition: all 0.15s ease; }
        .soul-card-btn:hover { background: var(--hover); border-color: var(--text-secondary); }
        .soul-card-btn.primary { background: var(--accent); color: var(--bg-primary); border-color: var(--accent); }
        .soul-card-btn.danger:hover { border-color: #ef4444; color: #ef4444; }
        
        .soul-contacts-grid { display: flex; flex-wrap: wrap; gap: 4px; }
        .soul-contact-chip {
            display: inline-flex;
            align-items: center;
            gap: 4px;
            padding: 4px 8px;
            background: var(--bg-primary);
            border: 1px solid var(--border);
            border-radius: 4px;
            font-size: 11px;
            cursor: pointer;
            transition: all 0.15s ease;
            max-width: 140px;
            min-width: 0;
        }
        .soul-contact-chip:hover { border-color: var(--accent); }
        .soul-contact-chip-icon { font-size: 12px; flex-shrink: 0; }
        .soul-contact-chip-value { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        
        /* Menu radial pour âmes (dans les bulles) */
        .soul-menu-group {
            pointer-events: all;
        }
        .soul-menu-backdrop {
            cursor: pointer;
            touch-action: none;
        }
        .soul-menu-btn {
            cursor: pointer;
            touch-action: manipulation;
            -webkit-tap-highlight-color: transparent;
        }
        .soul-menu-btn:hover circle {
            fill: var(--hover);
        }
        
        /* Liens éphémères (proximité/trace) */
        .link-ephemeral {
            stroke-dasharray: 6, 4;
            opacity: 0.4;
        }
        .link-trace {
            stroke: var(--accent, #64dfdf);
            stroke-dasharray: 3, 3;
            opacity: 0.6;
        }
        
        /* Filtres chips - Phase 2: repliables */
        .souls-filter-chips {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            padding: 8px 12px;
            border-bottom: 1px solid var(--border);
        }
        .souls-filter-primary { display: flex; flex-wrap: wrap; gap: 6px; align-items: center; }
        .souls-filter-details { flex: 0 0 auto; }
        .souls-filter-summary {
            padding: 6px 10px; font-size: 11px; color: var(--text-secondary); cursor: pointer; list-style: none;
            display: inline-flex; align-items: center; border: 1px solid var(--border); border-radius: var(--radius);
            background: var(--bg-secondary); min-height: 36px; user-select: none;
        }
        .souls-filter-summary::-webkit-details-marker { display: none; }
        .souls-filter-summary::before { content: '▶'; font-size: 10px; margin-right: 6px; transition: transform 0.2s; }
        .souls-filter-details[open] .souls-filter-summary::before { transform: rotate(90deg); }
        .souls-filter-secondary { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 8px; padding-top: 8px; border-top: 1px solid var(--border); }
        .souls-search-details { border-bottom: 1px solid var(--border); }
        .souls-search-summary {
            padding: 8px 12px; font-size: 11px; color: var(--text-secondary); cursor: pointer; list-style: none;
            display: flex; align-items: center; min-height: 44px; user-select: none;
        }
        .souls-search-summary::-webkit-details-marker { display: none; }
        .souls-search-summary::before { content: '▶'; font-size: 10px; margin-right: 8px; transition: transform 0.2s; }
        .souls-search-details[open] .souls-search-summary::before { transform: rotate(90deg); }
        .souls-search-details .souls-search-bar { padding: 0 12px 12px; }
        .souls-legend-hint {
            font-size: 10px; color: var(--text-secondary); padding: 8px 12px; margin-bottom: 10px;
            background: var(--bg-secondary); border-radius: 8px; border: 1px solid var(--border);
        }
        .filter-chip {
            padding: 10px 14px;
            min-height: 44px;
            min-width: 44px;
            box-sizing: border-box;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            border-radius: 12px;
            font-size: 11px;
            border: 1px solid var(--border);
            background: var(--bg-secondary);
            cursor: pointer;
            transition: all 0.15s;
            white-space: nowrap;
        }
        .filter-chip:hover {
            background: var(--hover);
        }
        .filter-chip.active {
            background: var(--accent-light, rgba(100, 150, 255, 0.25));
            border-color: var(--accent, #64dfdf);
            color: var(--text-primary);
        }
        .filter-chip-reset {
            background: transparent;
            border: none;
            font-size: 12px;
            padding: 10px 12px;
            min-width: 44px;
            min-height: 44px;
            box-sizing: border-box;
            cursor: pointer;
            opacity: 0.6;
        }
        .filter-chip-reset:hover {
            opacity: 1;
        }

        /* Inbox minimaliste D3-driven */
        .inbox-input-wrap { position: relative; margin-bottom: 10px; }
        .inbox-input-wrap .inbox-input { width: 100%; padding: 10px 12px; font-size: 14px; box-sizing: border-box; }
        .inbox-completion-dropdown { display: none; position: absolute; left: 0; right: 0; top: 100%; z-index: 100; max-height: 180px; overflow-y: auto; background: var(--bg-primary); border: 1px solid var(--border); border-radius: 6px; margin-top: 4px; box-shadow: 0 4px 12px rgba(0,0,0,0.15); }
        .inbox-bar { display: flex; align-items: center; gap: 10px; margin-bottom: 12px; flex-wrap: wrap; }
        .inbox-segment { display: flex; gap: 4px; }
        .inbox-segment-dot { width: 28px; height: 28px; padding: 0; border: none; background: transparent; color: var(--text-secondary); font-size: 14px; cursor: pointer; border-radius: 6px; transition: color 0.15s, background 0.15s; display: flex; align-items: center; justify-content: center; }
        .inbox-segment-dot:hover { color: var(--text-primary); background: var(--hover); }
        .inbox-segment-dot.active { color: var(--accent); }
        .inbox-search { flex: 1; min-width: 100px; padding: 6px 10px; font-size: 12px; }
        .inbox-list { display: flex; flex-direction: column; gap: 2px; }
        .inbox-item { display: flex; align-items: flex-start; gap: 8px; padding: 8px 10px; border-radius: 6px; background: transparent; transition: background 0.15s, opacity 0.15s; border-left: 3px solid transparent; }
        .inbox-item:hover { background: var(--hover); }
        .inbox-item:hover .inbox-item-actions { opacity: 1; }
        .inbox-item--new { border-left-color: var(--accent); }
        .inbox-item--triaged { border-left-color: var(--text-secondary); }
        .inbox-item-dot { flex-shrink: 0; width: 8px; height: 8px; margin-top: 6px; border-radius: 50%; }
        .inbox-item--new .inbox-item-dot { background: var(--accent); }
        .inbox-item--triaged .inbox-item-dot { background: var(--text-secondary); }
        .inbox-item-body { flex: 1; min-width: 0; }
        .inbox-item-text { font-size: 13px; color: var(--text-primary); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; cursor: pointer; }
        .inbox-item-chips { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px; font-size: 11px; }
        .inbox-item-chip { padding: 2px 6px; border-radius: 4px; background: var(--bg-secondary); color: var(--text-secondary); cursor: pointer; }
        .inbox-item-chip--link { color: var(--accent); }
        .inbox-item-chip--link:hover { text-decoration: underline; }
        .inbox-item-actions { display: flex; gap: 4px; flex-wrap: wrap; opacity: 0; transition: opacity 0.15s; flex-shrink: 0; }
        @media (hover: none) { .inbox-item-actions { opacity: 1; } }
        .inbox-item-btn { padding: 4px 8px; font-size: 11px; border: none; background: var(--bg-secondary); color: var(--text-primary); border-radius: 4px; cursor: pointer; }
        .inbox-item-btn:hover { background: var(--border); }
        .inbox-empty { color: var(--text-secondary); font-size: 12px; padding: 20px 0; text-align: center; }
        
        /* Legacy alias for soul-item-details (body) */
        .soul-item-details { display: contents; }
        
        .soul-contact-fields {
            padding: 12px;
        }
        
        .soul-contact-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(48px, 1fr));
            gap: 6px;
            margin-bottom: 12px;
        }
        
        .soul-contact-cell {
            position: relative;
            padding: 8px;
            border: 1px solid var(--border);
            border-radius: 6px;
            background: var(--bg-primary);
            cursor: pointer;
            transition: all 0.2s ease;
            overflow: hidden;
            display: flex;
            align-items: center;
            justify-content: center;
            min-height: 48px;
        }
        
        .soul-contact-cell:hover {
            border-color: var(--ghibli-sky);
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }
        
        .soul-contact-cell.expanded {
            grid-column: 1 / -1;
            border-color: var(--border-dark);
            box-shadow: 0 4px 12px rgba(0,0,0,0.1);
            justify-content: flex-start;
            padding: 16px;
            min-height: auto;
            flex-direction: column;
            align-items: stretch;
        }
        
        .soul-contact-cell-header {
            display: flex;
            align-items: center;
            gap: 12px;
            width: 100%;
            margin-bottom: 12px;
        }
        
        .soul-contact-cell.expanded .soul-contact-cell-header {
            margin-bottom: 16px;
            padding-bottom: 12px;
            border-bottom: 1px solid var(--border);
        }
        
        .soul-contact-icon {
            font-size: 20px;
            width: 32px;
            height: 32px;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 6px;
            flex-shrink: 0;
        }
        
        .soul-contact-cell.expanded .soul-contact-icon {
            width: 48px;
            height: 48px;
            font-size: 28px;
        }
        
        .soul-contact-info {
            flex: 1;
            min-width: 0;
            display: none;
            width: 100%;
        }
        
        .soul-contact-cell.expanded .soul-contact-info {
            display: block;
            width: 100%;
        }
        
        .soul-contact-type {
            font-size: 11px;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.8px;
            margin-bottom: 8px;
            font-weight: 600;
            display: block;
            width: 100%;
        }
        
        .soul-contact-value {
            font-size: 14px;
            color: var(--text-primary);
            font-weight: 500;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            cursor: text;
            padding: 10px 12px;
            border-radius: 4px;
            transition: all 0.15s ease;
            border: 1px solid var(--border);
            background: var(--bg-secondary);
            width: 100%;
            box-sizing: border-box;
            line-height: 1.4;
        }
        
        .soul-contact-value:hover {
            background: var(--hover);
            border-color: var(--border-dark);
        }
        
        .soul-contact-value.editing {
            background: var(--bg-primary);
            border: 2px solid var(--border-dark);
            outline: none;
            white-space: normal;
            word-break: break-all;
            min-height: 44px;
            padding: 10px 12px;
        }
        
        .soul-contact-cell.expanded .soul-contact-value {
            white-space: normal;
            word-break: break-all;
            min-height: auto;
        }
        
        .soul-contact-actions {
            display: none;
            margin-top: 16px;
            padding-top: 16px;
            border-top: 1px solid var(--border);
            gap: 8px;
            flex-wrap: wrap;
            width: 100%;
        }
        
        .soul-contact-cell.expanded .soul-contact-actions {
            display: flex;
        }
        
        .soul-contact-action-btn {
            padding: 8px 12px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            color: var(--text-primary);
            cursor: pointer;
            font-size: 12px;
            font-weight: 500;
            border-radius: 4px;
            transition: all 0.15s ease;
            display: flex;
            align-items: center;
            gap: 6px;
            min-height: 36px;
        }
        
        .soul-contact-action-btn:hover {
            background: var(--ghibli-sky);
            border-color: var(--ghibli-sky);
            color: #ffffff;
            transform: translateY(-1px);
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }
        
        .soul-contact-action-btn:active {
            transform: translateY(0);
        }
        
        .soul-contact-action-btn.primary {
            background: var(--ghibli-sky);
            border-color: var(--ghibli-sky);
            color: #ffffff;
        }
        
        .soul-contact-action-btn.primary:hover {
            background: var(--ghibli-sky);
            opacity: 0.9;
            color: #ffffff;
            box-shadow: 0 2px 6px rgba(0,0,0,0.15);
        }
        
        .soul-contact-action-btn.danger {
            background: var(--bg-secondary);
            color: var(--text-primary);
            border-color: var(--border-dark);
        }
        
        .soul-contact-action-btn.danger:hover {
            background: var(--ghibli-coral);
            border-color: var(--ghibli-coral);
            color: #ffffff;
            box-shadow: 0 2px 4px rgba(0,0,0,0.1);
        }
        
        .soul-contact-field {
            display: none;
        }
        
        .soul-contact-add {
            padding: 8px 12px;
            margin: 8px 12px;
            background: var(--bg-primary);
            border: 1px solid var(--border-dark);
            color: var(--text-primary);
            font-size: 11px;
            cursor: pointer;
            transition: all 0.15s ease;
        }
        
        .soul-contact-add:hover {
            background: var(--hover);
        }

        .soul-symbol, .soul-card-avatar {
            width: 40px;
            height: 40px;
            border-radius: 50%;
            background: transparent;
            color: var(--text-primary);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            margin-right: 12px;
            font-weight: 400;
            border: 1px solid var(--border-dark);
        }

        .soul-info {
            flex: 1;
        }

        .soul-name {
            font-weight: 400;
            margin-bottom: 2px;
            font-size: 14px;
            color: var(--text-primary);
        }

        .soul-meta {
            font-size: 12px;
            color: var(--text-secondary);
        }

        .souls-list-empty {
            padding: 24px 16px;
            text-align: center;
            color: var(--text-secondary);
            font-size: 13px;
            line-height: 1.5;
        }

        .souls-list-selected-title {
            font-size: 11px;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.5px;
            margin: 0 0 8px 0;
            padding-bottom: 4px;
            border-bottom: 2px solid var(--accent, #64dfdf);
            font-weight: 600;
        }
        .souls-list-title-other {
            margin-top: 16px;
            padding-top: 4px;
            border-top: 1px solid var(--border);
        }

        .soul-item.selected-in-graph {
            border-color: var(--accent, #64dfdf);
            background: var(--hover);
            animation: soul-selected-pulse 2s ease-in-out infinite;
        }

        .soul-item.selected-in-graph .soul-item-header {
            background: transparent;
        }

        @keyframes soul-selected-pulse {
            0%, 100% { box-shadow: 0 0 0 0 rgba(100, 223, 223, 0.3); }
            50% { box-shadow: 0 0 0 4px rgba(100, 223, 223, 0); }
        }

        .soul-item {
            scroll-margin-top: 80px;
        }
        @media (max-width: 480px) {
            .souls-sidebar .soul-card-header { padding: 8px 10px; min-height: 48px; }
            .souls-sidebar .soul-card-avatar { width: 36px; height: 36px; min-width: 36px; min-height: 36px; font-size: 16px; }
            .souls-sidebar .soul-expand-actions { gap: 4px; }
            .souls-sidebar .soul-expand-btn { padding: 5px 8px; font-size: 10px; }
        }

        .souls-title-wrap {
            display: flex;
            flex-direction: column;
            gap: 2px;
        }
        .souls-selection-count {
            font-size: 11px;
            color: var(--text-secondary);
        }
        .souls-selection-bar {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px 12px;
            flex-shrink: 0;
            border-bottom: 1px solid var(--border);
            background: var(--hover);
            border-bottom: 1px solid var(--border);
            flex-wrap: wrap;
        }
        .souls-selection-bar-label {
            font-size: 12px;
            color: var(--text-secondary);
            flex: 1;
            min-width: 0;
        }
        .souls-selection-bar-btn {
            padding: 10px 14px;
            min-width: 44px;
            min-height: 44px;
            box-sizing: border-box;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            font-size: 11px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            color: var(--text-primary);
            cursor: pointer;
            border-radius: 0;
            transition: all 0.15s ease;
        }
        .souls-selection-bar-btn:hover {
            background: var(--ghibli-sky);
        }
        .souls-selection-bar-btn.souls-selection-clear {
            padding: 6px 8px;
        }

        /* Navigation Bottom - Minimaliste */
        .nav-bottom {
            position: absolute;
            bottom: 0;
            left: 0;
            right: 0;
            height: 64px;
            background: var(--bg-primary);
            border-top: 1px solid var(--border);
            display: flex;
            justify-content: space-around;
            align-items: center;
            padding-bottom: env(safe-area-inset-bottom);
            z-index: 1000;
        }

        .nav-btn {
            width: 48px;
            height: 48px;
            border-radius: var(--radius);
            background: transparent;
            border: none;
            color: var(--text-secondary);
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            font-size: 12px;
            gap: 2px;
            cursor: pointer;
            transition: all 0.15s ease;
        }

        .nav-btn:hover {
            background: var(--hover);
            transform: scale(1.03);
        }
        .nav-btn:active {
            background: var(--hover);
        }

        .nav-btn-icon {
            font-size: 18px;
        }
        .icon {
            font-variant-emoji: text;
            color: var(--text-primary);
            line-height: 1;
        }

        .nav-btn.active {
            color: var(--text-primary);
            background: var(--hover);
        }

        .nav-modes-dropdown {
            position: absolute;
            bottom: 100%;
            left: 50%;
            transform: translateX(-50%);
            margin-bottom: 4px;
            min-width: 140px;
            background: var(--bg-primary);
            border: 1px solid var(--border);
            border-radius: var(--radius);
            box-shadow: 0 -4px 12px rgba(0,0,0,0.15);
            z-index: 1100;
            display: none;
            padding: 4px 0;
        }
        .nav-modes-dropdown.show {
            display: block;
        }
        .nav-modes-dropdown button {
            width: 100%;
            padding: 10px 14px;
            text-align: left;
            background: none;
            border: none;
            color: var(--text-primary);
            font-size: 13px;
            cursor: pointer;
            display: block;
        }
        .nav-modes-dropdown button:hover {
            background: var(--hover);
        }

        /* B7: Overlay sidebar tap-to-close */
        .sidebar-overlay {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: rgba(0, 0, 0, 0.3);
            opacity: 0;
            pointer-events: none;
            transition: opacity 0.3s ease;
            z-index: 880; /* C: Sous sidebars (>=900) mais au-dessus du graph */
        }
        .sidebar-overlay.show {
            opacity: 1;
            pointer-events: all;
        }
        [data-theme="dark"] .sidebar-overlay {
            background: rgba(255, 255, 255, 0.1);
        }

        /* Overlay & Modals - Minimaliste (au-dessus du graphe et des bulles) */
        .overlay {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            height: 100%;
            background: rgba(0, 0, 0, 0.3);
            z-index: 99998;
            display: none;
            opacity: 0;
            transition: opacity 0.2s;
        }

        .overlay.show {
            display: block;
            opacity: 1;
        }

        .modal {
            position: fixed;
            bottom: 0;
            left: 0;
            right: 0;
            background: var(--bg-primary);
            border-radius: 0;
            padding: 24px 20px;
            max-height: 85vh;
            overflow-y: auto;
            transform: translateY(100%);
            transition: transform 0.3s ease;
            z-index: 99999;
            touch-action: pan-y;
            border-top: 1px solid var(--border);
            isolation: isolate;
        }
        .modal .btn-primary,
        .modal .btn-secondary,
        .modal button:not(.modal-close) {
            position: relative;
            z-index: 1;
        }

        .modal.show {
            transform: translateY(0);
        }

        .modal-header {
            display: flex;
            justify-content: space-between;
            align-items: center;
            margin-bottom: 24px;
            padding-bottom: 16px;
            border-bottom: 1px solid var(--border);
        }

        .modal-title {
            font-size: 18px;
            font-weight: 500;
            color: var(--text-primary);
            letter-spacing: -0.3px;
        }

        .modal-close {
            width: 32px;
            height: 32px;
            border-radius: 0;
            background: var(--bg-secondary);
            border: 1px solid var(--border-dark);
            color: var(--text-primary);
            cursor: pointer;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: all 0.15s ease;
        }

        .modal-close:hover {
            background: var(--text-primary);
            color: var(--bg-primary);
        }

        /* Form Elements - Minimaliste */
        .form-group {
            margin-bottom: 20px;
        }

        .form-label {
            display: block;
            font-size: 13px;
            color: var(--text-secondary);
            margin-bottom: 8px;
            font-weight: 400;
        }

        .form-input {
            width: 100%;
            padding: 12px;
            border: 1px solid var(--border-dark);
            border-radius: 0;
            font-size: 14px;
            background: var(--bg-primary);
            color: var(--text-primary);
            transition: all 0.15s ease;
        }

        .form-input:focus {
            outline: none;
            border-color: var(--text-primary);
        }

        .form-input.has-error {
            border-color: #ff0000;
        }

        .form-input[type="textarea"],
        textarea.form-input {
            resize: vertical;
            min-height: 80px;
            font-family: inherit;
        }

        .validation-error {
            color: #ff0000;
            font-size: 12px;
            margin-top: 4px;
        }

        .btn-primary {
            width: 100%;
            padding: 14px;
            background: var(--text-primary);
            color: var(--bg-primary);
            border: 1px solid var(--border-dark);
            border-radius: 0;
            font-size: 14px;
            font-weight: 400;
            cursor: pointer;
            transition: all 0.15s ease;
        }

        /* Boutons en groupe flex - même taille */
        .form-group[style*="display: flex"] .btn-primary,
        .form-group[style*="display: flex"] .btn-secondary {
            width: auto;
            flex: 1;
        }

        .btn-primary:active {
            background: var(--text-secondary);
        }

        .btn-primary:hover {
            background: var(--text-secondary);
        }

        .btn-secondary {
            width: 100%;
            padding: 14px;
            background: var(--bg-secondary);
            color: var(--text-primary);
            border: 1px solid var(--border-dark);
            border-radius: 0;
            font-size: 14px;
            font-weight: 400;
            cursor: pointer;
            transition: all 0.15s ease;
        }

        .btn-secondary:active {
            background: var(--hover);
        }

        .btn-secondary:hover {
            background: var(--hover);
        }

        /* Color Palette - Minimaliste */
        .color-palette {
            display: grid;
            grid-template-columns: repeat(5, 1fr);
            gap: 8px;
            margin: 16px 0;
        }

        /* En-tête info bulle */
        .bubble-info-header {
            margin-bottom: 24px;
            padding-bottom: 20px;
            border-bottom: 2px solid var(--border-dark);
        }

        .bubble-info-title {
            font-size: 24px;
            font-weight: 600;
            color: var(--text-primary);
            margin-bottom: 12px;
        }

        .bubble-info-stats {
            display: flex;
            gap: 20px;
            flex-wrap: wrap;
        }

        .stat-item {
            display: flex;
            align-items: center;
            gap: 6px;
            font-size: 13px;
            color: var(--text-secondary);
        }

        .stat-icon {
            font-size: 16px;
        }

        .stat-value {
            font-weight: 600;
            color: var(--text-primary);
        }

        .stat-label {
            color: var(--text-secondary);
        }

        /* Section édition */
        .bubble-info-edit-section {
            background: var(--bg-secondary);
            border: 1px solid var(--border-dark);
            border-radius: 8px;
            padding: 20px;
            margin-bottom: 24px;
        }

        .section-title {
            font-size: 14px;
            font-weight: 600;
            color: var(--text-primary);
            margin-bottom: 16px;
            display: flex;
            align-items: center;
            gap: 6px;
        }

        .edit-controls-grid {
            display: grid;
            grid-template-columns: 1fr 1fr;
            gap: 20px;
        }

        .edit-control {
            display: flex;
            flex-direction: column;
            gap: 10px;
        }

        .edit-label {
            font-size: 12px;
            font-weight: 500;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.5px;
        }

        .color-picker-input {
            width: 100%;
            height: 50px;
            border: 2px solid var(--border-dark);
            border-radius: 6px;
            cursor: pointer;
        }

        .color-palette-compact {
            display: grid;
            grid-template-columns: repeat(5, 1fr);
            gap: 8px;
            margin: 12px 0;
        }

        .color-palette-compact .color-option {
            aspect-ratio: 1;
            border-radius: 6px;
            cursor: pointer;
            transition: all 0.15s ease;
            border: 2px solid var(--border-dark);
        }

        .color-palette-compact .color-option:hover {
            transform: scale(1.1);
            border-color: var(--text-primary);
        }

        .size-value {
            color: var(--text-primary);
            font-weight: 600;
        }

        .size-slider {
            width: 100%;
            margin-top: 8px;
        }

        /* Sections générales */
        .bubble-info-section {
            margin-bottom: 24px;
            padding-bottom: 20px;
            border-bottom: 1px solid var(--border);
        }

        .bubble-info-details-section {
            border-bottom: none;
            padding-bottom: 0;
        }

        .bubble-info-details {
            display: flex;
            flex-direction: column;
            gap: 10px;
            margin-top: 12px;
        }

        .detail-row {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 8px 0;
            font-size: 13px;
        }

        .detail-label {
            color: var(--text-secondary);
            font-weight: 500;
        }

        .detail-value {
            color: var(--text-primary);
            display: flex;
            align-items: center;
            gap: 8px;
        }

        .color-preview {
            width: 20px;
            height: 20px;
            border: 1px solid var(--border-dark);
            border-radius: 4px;
            display: inline-block;
        }

        /* Footer */
        .bubble-info-footer {
            display: flex;
            gap: 10px;
            justify-content: flex-end;
            margin-top: 24px;
            padding-top: 20px;
            border-top: 1px solid var(--border-dark);
        }

        .color-option {
            width: 100%;
            aspect-ratio: 1;
            border-radius: 0;
            border: 1px solid var(--border-dark);
            cursor: pointer;
            transition: all 0.15s ease;
        }

        .color-option:hover {
            border-width: 2px;
        }

        .color-option.selected {
            border-width: 3px;
        }

        /* Symbol Grid - Minimaliste */
        .symbol-grid {
            display: grid;
            grid-template-columns: repeat(8, 1fr);
            gap: 8px;
            margin: 16px 0;
        }

        .symbol-option {
            width: 100%;
            aspect-ratio: 1;
            border-radius: 0;
            background: transparent;
            border: 1px solid var(--border-dark);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            cursor: pointer;
            transition: all 0.15s ease;
            color: var(--text-primary);
        }

        .symbol-option:hover {
            background: var(--hover);
        }

        .symbol-option.selected {
            background: var(--text-primary);
            color: var(--bg-primary);
        }

        /* Grille de types de contacts */
        .contact-types-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
            gap: 10px;
            margin: 16px 0;
        }

        .contact-type-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 12px 8px;
            border: 1px solid var(--border-dark);
            background: var(--bg-primary);
            color: var(--text-primary);
            border-radius: 4px;
            cursor: pointer;
            transition: all 0.15s ease;
            min-height: 80px;
        }

        .contact-type-btn:hover {
            background: var(--hover);
            transform: translateY(-2px);
        }

        .contact-type-btn.selected {
            background: var(--text-primary);
            color: var(--bg-primary);
            border-color: var(--text-primary);
        }

        .contact-type-icon {
            font-size: 24px;
            margin-bottom: 6px;
        }

        .contact-type-label {
            font-size: 12px;
            text-align: center;
            line-height: 1.2;
        }

        /* Conteneur scrollable pour la liste d'âmes (ajout à une bulle) */
        .souls-selection-list-wrapper {
            max-height: 280px;
            overflow-y: auto;
            overflow-x: hidden;
            margin: 0 0 16px 0;
            padding-right: 4px;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: var(--bg-secondary);
        }
        .souls-selection-list-wrapper::-webkit-scrollbar { width: 8px; }
        .souls-selection-list-wrapper::-webkit-scrollbar-track { background: var(--bg-primary); border-radius: 4px; }
        .souls-selection-list-wrapper::-webkit-scrollbar-thumb { background: var(--border-dark); border-radius: 4px; }

        /* Grille de sélection d'âmes */
        .souls-selection-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
            gap: 12px;
            margin: 12px;
            padding: 0;
        }

        .soul-selection-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 16px 12px;
            border: 1px solid var(--border-dark);
            background: var(--bg-primary);
            color: var(--text-primary);
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.2s ease;
            min-height: 100px;
        }

        .soul-selection-btn:hover {
            background: var(--hover);
            transform: translateY(-2px);
            border-color: var(--text-primary);
        }

        .soul-selection-btn.selected {
            border-color: var(--text-primary);
            border-width: 2px;
            background: var(--hover);
            box-shadow: 0 0 0 2px var(--text-primary);
        }

        .add-soul-selected-list {
            display: flex;
            flex-direction: column;
            gap: 10px;
            max-height: 200px;
            overflow-y: auto;
            padding-right: 4px;
        }
        .add-soul-selected-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 10px 12px;
            border: 1px solid var(--border);
            border-radius: 8px;
            background: var(--bg-secondary);
        }
        .add-soul-selected-item-name {
            flex: 0 0 120px;
            font-weight: 500;
            color: var(--text-primary);
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        .add-soul-symbol-picker {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
            flex: 1;
            min-width: 0;
        }
        .add-soul-symbol-picker button {
            width: 32px;
            height: 32px;
            padding: 0;
            border: 1px solid var(--border-dark);
            background: var(--bg-primary);
            color: var(--text-primary);
            border-radius: 6px;
            cursor: pointer;
            font-size: 16px;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: border-color 0.15s, box-shadow 0.15s;
        }
        .add-soul-symbol-picker button:hover {
            border-color: var(--text-primary);
        }
        .add-soul-symbol-picker button.selected-symbol {
            border-color: var(--text-primary);
            box-shadow: 0 0 0 2px var(--text-primary);
        }

        /* Icônes âmes dans les bulles du graph : pas de clipping, centrage vertical */
        .soul-symbol-group,
        .soul-symbol-inner {
            overflow: visible;
        }
        .soul-symbol-group .soul-symbol-text {
            line-height: 1;
            overflow: visible;
        }

        .soul-selection-symbol {
            width: 48px;
            height: 48px;
            border-radius: 50%;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 24px;
            margin-bottom: 8px;
            border: 2px solid var(--border-dark);
        }

        .soul-selection-name {
            font-size: 13px;
            text-align: center;
            font-weight: 500;
            line-height: 1.3;
        }

        /* Grille de sélection de types de bulle (cases plus petites) */
        .bubble-types-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(70px, 1fr));
            gap: 8px;
            margin: 16px 0;
        }

        .bubble-type-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 10px 6px;
            border: 1px solid var(--border-dark);
            background: var(--bg-primary);
            color: var(--text-primary);
            border-radius: 6px;
            cursor: pointer;
            transition: all 0.2s ease;
            min-height: 70px;
        }

        .bubble-type-btn:hover {
            background: var(--hover);
            transform: translateY(-2px);
            border-color: var(--text-primary);
        }

        .bubble-type-btn.selected {
            background: var(--text-primary);
            color: var(--bg-primary);
            border-color: var(--text-primary);
        }

        .bubble-type-icon {
            font-size: 24px;
            margin-bottom: 4px;
        }

        .bubble-type-label {
            font-size: 11px;
            text-align: center;
            font-weight: 500;
            line-height: 1.2;
            word-break: break-word;
        }

        /* Sélecteur d'emoji compact en slider */
        .emoji-slider-container {
            position: relative;
            margin: 16px 0;
        }

        .emoji-slider {
            display: flex;
            overflow-x: auto;
            overflow-y: hidden;
            gap: 6px;
            padding: 8px;
            scroll-behavior: smooth;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: thin;
            scrollbar-color: var(--border-dark) transparent;
        }

        .emoji-slider::-webkit-scrollbar {
            height: 6px;
        }

        .emoji-slider::-webkit-scrollbar-track {
            background: transparent;
        }

        .emoji-slider::-webkit-scrollbar-thumb {
            background: var(--border-dark);
            border-radius: 3px;
        }

        .emoji-option {
            flex-shrink: 0;
            width: 40px;
            height: 40px;
            border: 1px solid var(--border-dark);
            background: var(--bg-primary);
            border-radius: 6px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            cursor: pointer;
            transition: all 0.15s ease;
        }

        .emoji-option:hover {
            background: var(--hover);
            transform: scale(1.1);
            border-color: var(--text-primary);
        }

        .emoji-option.selected {
            background: var(--text-primary);
            color: var(--bg-primary);
            border-color: var(--text-primary);
            transform: scale(1.15);
        }

        .emoji-preview {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px;
            border: 1px solid var(--border-dark);
            border-radius: 6px;
            background: var(--bg-secondary);
            margin-top: 12px;
        }

        .emoji-preview-icon {
            font-size: 32px;
        }

        .emoji-preview-label {
            font-size: 13px;
            color: var(--text-secondary);
        }

        /* Grille d'actions rapides pour info bulle (plus compacte) */
        .bubble-info-actions-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(70px, 1fr));
            gap: 8px;
            margin: 16px 0;
        }

        .bubble-info-action-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 8px 6px;
            border: 1px solid var(--border-dark);
            background: var(--bg-primary);
            color: var(--text-primary);
            border-radius: 6px;
            cursor: pointer;
            transition: all 0.2s ease;
            min-height: 60px;
        }

        .bubble-info-action-btn:hover {
            background: var(--hover);
            transform: translateY(-2px);
            border-color: var(--text-primary);
        }

        .bubble-info-action-btn .action-icon {
            font-size: 20px;
            margin-bottom: 4px;
        }

        .bubble-info-action-btn .action-label {
            font-size: 10px;
            text-align: center;
            line-height: 1.2;
        }

        /* Slider de taille */
        input[type="range"] {
            -webkit-appearance: none;
            appearance: none;
            height: 6px;
            background: var(--bg-secondary);
            border-radius: 3px;
            outline: none;
        }

        input[type="range"]::-webkit-slider-thumb {
            -webkit-appearance: none;
            appearance: none;
            width: 18px;
            height: 18px;
            background: var(--text-primary);
            border-radius: 50%;
            cursor: pointer;
        }

        input[type="range"]::-moz-range-thumb {
            width: 18px;
            height: 18px;
            background: var(--text-primary);
            border-radius: 50%;
            cursor: pointer;
            border: none;
        }

        /* Types dans info bulle */
        .bubble-info-types {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
            margin-top: 12px;
        }

        .bubble-info-type-tag {
            display: inline-flex;
            align-items: center;
            gap: 6px;
            padding: 8px 14px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            border-radius: 6px;
            font-size: 13px;
            transition: all 0.15s ease;
        }

        .bubble-info-type-tag:hover {
            background: var(--hover);
            border-color: var(--text-primary);
        }

        /* Âmes dans info bulle */
        .bubble-info-souls {
            display: flex;
            flex-direction: column;
            gap: 10px;
            margin-top: 12px;
        }

        .bubble-info-soul-item {
            display: flex;
            align-items: center;
            gap: 12px;
            padding: 12px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.15s ease;
        }

        .bubble-info-soul-item:hover {
            background: var(--hover);
            border-color: var(--text-primary);
            transform: translateX(2px);
        }

        .bubble-info-soul-symbol {
            width: 40px;
            height: 40px;
            border-radius: 6px;
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            border: 2px solid var(--border-dark);
            flex-shrink: 0;
        }

        .bubble-info-soul-name {
            flex: 1;
            font-size: 14px;
            font-weight: 500;
            color: var(--text-primary);
        }

        .bubble-info-soul-legend {
            font-size: 12px;
            color: var(--text-secondary);
            font-style: italic;
            margin-left: auto;
        }

        /* Grille de familles de contacts */
        .contact-families-grid {
            display: grid;
            grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
            gap: 12px;
            margin: 16px 0;
        }

        .contact-family-btn {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            padding: 16px 12px;
            border: 2px solid var(--border-dark);
            background: var(--bg-primary);
            color: var(--text-primary);
            border-radius: 8px;
            cursor: pointer;
            transition: all 0.2s ease;
            min-height: 100px;
            position: relative;
        }

        .contact-family-btn:hover {
            background: var(--hover);
            transform: translateY(-3px);
            border-color: var(--text-primary);
        }

        .contact-family-icon {
            font-size: 32px;
            margin-bottom: 8px;
        }

        .contact-family-label {
            font-size: 14px;
            font-weight: 500;
            text-align: center;
            line-height: 1.3;
            margin-bottom: 4px;
        }

        .contact-family-count {
            font-size: 11px;
            color: var(--text-secondary);
            opacity: 0.7;
        }

        /* Bouton retour */
        .btn-back {
            padding: 8px 12px;
            border: 1px solid var(--border-dark);
            background: var(--bg-secondary);
            color: var(--text-primary);
            border-radius: 4px;
            cursor: pointer;
            font-size: 13px;
            transition: all 0.15s ease;
        }

        .btn-back:hover {
            background: var(--hover);
        }

        /* Icônes de marques */
        .contact-type-icon.brand {
            font-weight: bold;
            font-size: 20px;
            font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
        }

        .brand-icon {
            display: inline-block;
            width: 32px;
            height: 32px;
            line-height: 32px;
            border-radius: 6px;
            font-weight: bold;
            font-size: 14px;
            text-align: center;
            transition: all 0.2s ease;
        }

        .contact-type-btn.selected .brand-icon {
            opacity: 0.8;
            transform: scale(0.95);
        }

        .contact-type-btn:hover .brand-icon {
            transform: scale(1.1);
        }

        /* Bubble Legend Editor */
        .legend-editor {
            background: var(--ghibli-cloud);
            border-radius: 12px;
            padding: 16px;
            margin: 16px 0;
        }

        .legend-item {
            display: flex;
            align-items: center;
            margin-bottom: 12px;
        }

        .legend-symbol {
            width: 40px;
            height: 40px;
            border-radius: 10px;
            background: var(--bg-secondary);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 20px;
            margin-right: 12px;
            font-weight: bold;
        }

        .legend-input {
            flex: 1;
            padding: 10px 12px;
            border: 1px solid var(--ghibli-cloud);
            border-radius: 8px;
            background: var(--bg-primary);
            color: var(--text-primary);
        }

        /* Types Grid - Minimaliste */
        .types-grid {
            display: grid;
            grid-template-columns: repeat(3, 1fr);
            gap: 8px;
            margin: 16px 0;
        }

        .type-option {
            padding: 12px;
            background: transparent;
            border: 1px solid var(--border-dark);
            border-radius: 0;
            text-align: center;
            cursor: pointer;
            transition: all 0.15s ease;
            color: var(--text-primary);
            font-size: 13px;
        }

        .type-option:hover {
            background: var(--hover);
        }

        .type-option.selected {
            background: var(--text-primary);
            color: var(--bg-primary);
        }

        /* Stats + Filtres graphe — une ligne stats + bouton légende, puis filtres collapsible */
        .graph-top-bars {
            position: absolute;
            top: calc(56px + env(safe-area-inset-top));
            left: 0;
            right: 0;
            display: flex;
            flex-direction: column;
            z-index: 850;
        }
        .graph-top-row {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 8px max(12px, env(safe-area-inset-left)) 8px max(12px, env(safe-area-inset-right));
            background: var(--bg-primary);
            border-bottom: 1px solid var(--border);
            position: relative;
            flex-shrink: 0;
            box-sizing: border-box;
        }
        .graph-top-row .stats-bar {
            flex: 1;
            min-width: 0;
            border-bottom: none;
            padding: 0;
        }
        .stats-bar {
            flex-shrink: 0;
            left: 0;
            right: 0;
            padding: 8px max(12px, env(safe-area-inset-left)) 8px max(12px, env(safe-area-inset-right));
            background: var(--bg-primary);
            border-bottom: 1px solid var(--border);
            display: flex;
            justify-content: space-around;
            align-items: stretch;
            gap: 8px;
            overflow-x: hidden;
            overflow-y: visible;
            transition: max-height 0.3s ease;
            max-height: 72px;
            box-sizing: border-box;
        }

        .stats-bar.expanded {
            max-height: 400px;
            overflow-y: visible;
        }

        .graph-filter-bar {
            flex-shrink: 0;
            background: var(--bg-secondary);
            border-bottom: 1px solid var(--border);
            z-index: 849;
            font-size: 12px;
        }
        .graph-filter-bar summary {
            list-style: none;
        }
        .graph-filter-bar summary::-webkit-details-marker { display: none; }
        .graph-filter-summary {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 6px 12px;
            cursor: pointer;
            user-select: none;
        }
        .graph-filter-summary:hover { background: var(--hover); }
        .graph-filter-label { color: var(--text-secondary); font-size: 12px; }
        .graph-filter-toggle {
            font-size: 10px;
            color: var(--text-secondary);
            transition: transform 0.2s ease;
        }
        .graph-filter-bar[open] .graph-filter-toggle { transform: rotate(180deg); }
        .graph-filter-content {
            display: flex;
            align-items: center;
            gap: 8px;
            flex-wrap: wrap;
            padding: 6px 12px 10px;
            padding-left: max(12px, env(safe-area-inset-left));
            padding-right: max(12px, env(safe-area-inset-right));
        }
        .graph-filter-chips { display: flex; gap: 6px; flex-wrap: wrap; flex: 1; min-width: 0; }
        .graph-filter-chip { padding: 4px 10px; font-size: 11px; border-radius: 6px; border: 1px solid var(--border); background: var(--bg-primary); cursor: pointer; }
        .graph-filter-chip.active { background: var(--accent); color: var(--bg-primary); border-color: var(--accent); }

        @media (max-width: 768px) {
            .graph-top-row {
                padding: 6px 8px;
                gap: 4px;
            }
            .stats-bar {
                padding: 6px 8px;
                gap: 4px;
                max-height: 64px;
            }
            
            .stats-bar.expanded {
                max-height: 500px;
            }
            
            .stat-item {
                padding: 3px 4px;
            }
            
            .stat-icon {
                font-size: 12px;
            }
            
            .stat-value {
                font-size: 13px;
            }
            
            .stat-label {
                font-size: 8px;
            }
            
            .stat-indicator {
                max-width: 24px;
            }
            
            .stat-details {
                padding: 12px;
            }
            
            .soul-contact-grid {
                grid-template-columns: repeat(auto-fill, minmax(44px, 1fr));
                gap: 4px;
            }
            
            .soul-contact-cell {
                padding: 6px;
                min-height: 44px;
            }
            
            .soul-contact-cell.expanded {
                padding: 12px;
            }
            
            .soul-contact-cell.expanded .soul-contact-cell-header {
                margin-bottom: 12px;
                padding-bottom: 10px;
            }
            
            .soul-contact-icon {
                font-size: 18px;
                width: 28px;
                height: 28px;
            }
            
            .soul-contact-cell.expanded .soul-contact-icon {
                width: 40px;
                height: 40px;
                font-size: 24px;
            }
            
            .soul-contact-type {
                font-size: 10px;
            }
            
            .soul-contact-value {
                font-size: 13px;
                padding: 6px 8px;
            }
            
            .soul-contact-action-btn {
                padding: 6px 10px;
                font-size: 11px;
                min-height: 32px;
            }
        }

        .stat-item {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            flex: 1;
            min-width: 0;
            max-width: 100%;
            padding: 4px 6px;
            border-radius: 6px;
            cursor: pointer;
            transition: all 0.2s ease;
            position: relative;
            box-sizing: border-box;
        }

        .stat-item:hover {
            background: var(--hover);
        }

        .stat-item.active {
            background: var(--ghibli-sky);
            box-shadow: 0 2px 8px rgba(0,0,0,0.1);
        }

        .stat-item-header {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 2px;
            width: 100%;
            min-width: 0;
        }

        .stat-icon {
            font-size: 14px;
            line-height: 1;
            margin-bottom: 1px;
            flex-shrink: 0;
        }

        .stat-value {
            font-size: 14px;
            font-weight: 600;
            color: var(--text-primary);
            line-height: 1.2;
            white-space: nowrap;
        }

        .stat-label {
            font-size: 9px;
            color: var(--text-secondary);
            text-transform: uppercase;
            letter-spacing: 0.3px;
            text-align: center;
            line-height: 1.1;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            max-width: 100%;
        }

        .stat-indicator {
            width: 100%;
            max-width: 28px;
            height: 2px;
            background: var(--border);
            border-radius: 2px;
            margin-top: 3px;
            overflow: hidden;
            flex-shrink: 0;
        }

        .stat-indicator-bar {
            height: 100%;
            background: var(--ghibli-sky);
            border-radius: 2px;
            transition: width 0.3s ease;
        }

        .stat-details {
            display: none;
            position: fixed;
            top: auto;
            left: 0;
            right: 0;
            margin-top: 8px;
            padding: 16px;
            padding-left: max(16px, env(safe-area-inset-left));
            padding-right: max(16px, env(safe-area-inset-right));
            border-top: 1px solid var(--border);
            background: var(--bg-primary);
            box-shadow: 0 4px 12px rgba(0,0,0,0.1);
            z-index: 1000;
            width: 100%;
            max-width: 100vw;
            box-sizing: border-box;
            overflow-x: hidden;
        }

        .stat-item.active .stat-details {
            display: block;
        }

        .stat-detail-item {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 6px 0;
            font-size: 13px;
        }

        .stat-detail-label {
            color: var(--text-secondary);
        }

        .stat-detail-value {
            font-weight: 500;
            color: var(--text-primary);
        }

        .stat-detail-list {
            margin-top: 8px;
            max-height: 150px;
            overflow-y: auto;
        }

        .stat-detail-list-item {
            padding: 4px 8px;
            margin: 2px 0;
            background: var(--hover);
            border-radius: 4px;
            font-size: 12px;
            display: flex;
            justify-content: space-between;
        }
        .help-link:focus-visible,
        .header-btn:focus-visible,
        .nav-btn:focus-visible,
        .modal-close:focus-visible,
        .btn-primary:focus-visible,
        .btn-secondary:focus-visible,
        .form-input:focus-visible,
        .help-section summary:focus-visible {
            outline: 2px solid var(--text-primary);
            outline-offset: 2px;
        }

        /* Tablette et Desktop */
        @media (min-width: 769px) and (max-width: 1024px) {
            /* Optimisations pour tablettes */
            .header-btn {
                width: 44px;
                height: 44px;
            }
            
            .nav-btn {
                width: 52px;
                height: 52px;
            }
            
            .souls-sidebar {
                width: 360px;
            }
            
            .help-sidebar {
                width: 400px;
            }
        }

        /* Responsive */
        @media (min-width: 768px) {
            .souls-sidebar {
                width: 380px;
            }
            
            .modal {
                max-width: 480px;
                left: 50%;
                transform: translate(-50%, 100%);
                border-radius: 24px;
            }
            
            .modal.show {
                transform: translate(-50%, 0);
            }
        }

        /* Animation */
        @keyframes pulse {
            0%, 100% { opacity: 1; }
            50% { opacity: 0.7; }
        }

        @keyframes fadeIn {
            from { opacity: 0; transform: translateY(10px); }
            to { opacity: 1; transform: translateY(0); }
        }

        @keyframes scaleIn {
            from { transform: scale(0.8); opacity: 0; }
            to { transform: scale(1); opacity: 1; }
        }

        @keyframes slideUp {
            from { transform: translateY(20px); opacity: 0; }
            to { transform: translateY(0); opacity: 1; }
        }

        .pulse {
            animation: pulse 2s ease-in-out infinite;
        }

        /* Flat Design Improvements */
        .bubble-group {
            transition: transform 0.2s cubic-bezier(0.4, 0, 0.2, 1);
            cursor: move;
            overflow: visible;
        }
        .bubble-group .soul-symbol-group {
            pointer-events: all;
        }

        /* B4: Retirer transform scale sur hover - remplacé par effet visuel sur cercle */
        .bubble-group:hover circle {
            filter: drop-shadow(0 0 8px rgba(0, 0, 0, 0.3));
            stroke-width: 3;
        }
        [data-theme="dark"] .bubble-group:hover circle {
            filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.3));
        }

        .bubble-group.dragging {
            cursor: grabbing;
            opacity: 0.9;
        }

        /* Bubble Quick Menu (Menu Radial) */
        .bubble-menu-group {
            pointer-events: all;
        }

        .bubble-menu-backdrop {
            cursor: pointer;
            touch-action: none;
        }

        .bubble-menu-close {
            cursor: pointer;
            transition: opacity 0.15s ease;
            touch-action: manipulation;
            -webkit-tap-highlight-color: transparent;
        }

        .bubble-menu-close:hover circle {
            fill: var(--hover);
        }
        
        .bubble-menu-btn {
            cursor: pointer;
            touch-action: manipulation;
            -webkit-tap-highlight-color: transparent;
            min-width: 44px;
            min-height: 44px;
        }
        
        .bubble-menu-resize-handle {
            cursor: ns-resize;
            touch-action: none;
            -webkit-tap-highlight-color: transparent;
            min-width: 44px;
            min-height: 44px;
        }

        /* Mobile Touch Improvements */
        @media (max-width: 768px) {
            .header {
                height: 56px;
                padding: 0 max(12px, env(safe-area-inset-left)) 0 max(12px, env(safe-area-inset-right));
                padding-top: env(safe-area-inset-top);
                min-height: calc(56px + env(safe-area-inset-top));
            }

            .header-title {
                font-size: 16px;
            }

            .header-btn {
                width: 44px;
                height: 44px;
                min-width: 44px;
                min-height: 44px;
                font-size: 18px;
            }

            .nav-bottom {
                height: 64px;
                padding: 8px max(8px, env(safe-area-inset-left)) max(8px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-right));
                min-height: calc(64px + env(safe-area-inset-bottom));
            }

            .nav-btn {
                width: 48px;
                height: 48px;
                min-width: 48px;
                min-height: 48px;
                font-size: 11px;
            }

            .stats-bar {
                padding: 10px max(12px, env(safe-area-inset-left)) 10px max(12px, env(safe-area-inset-right));
            }
            
            .souls-sidebar {
                top: calc(56px + env(safe-area-inset-top));
                bottom: calc(64px + env(safe-area-inset-bottom));
            }
            
            .help-sidebar {
                top: calc(56px + env(safe-area-inset-top));
                bottom: calc(64px + env(safe-area-inset-bottom));
            }
        }
