:root {
            --bg-dark: #0a0e0a;
            --bg-panel: #0d1410;
            --green-bright: #00ff88;
            --green-mid: #00cc6a;
            --green-dim: #006633;
            --green-glow: rgba(0, 255, 136, 0.4);
            --text-primary: #00ff88;
            --text-dim: #4a7c59;
            --border: #1a3325;
            --sidebar-width: 280px;
        }

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

        body {
            font-family: 'JetBrains Mono', monospace;
            background: var(--bg-dark);
            color: var(--text-primary);
            overflow: hidden;
            min-height: 100vh;
        }

        body::before {
            content: '';
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            background: repeating-linear-gradient(
                0deg,
                transparent,
                transparent 2px,
                rgba(0, 0, 0, 0.03) 2px,
                rgba(0, 0, 0, 0.03) 4px
            );
            pointer-events: none;
            z-index: 1000;
        }

        /* Nautical design overrides */
        body.design-nautical {
            --bg-dark: #020818;
            --bg-panel: rgba(2, 16, 36, 0.98);
            --green-bright: #38d8ff;
            --green-mid: #27b0db;
            --green-dim: #155c78;
            --green-glow: rgba(56, 216, 255, 0.45);
            --text-primary: #d9f4ff;
            --text-dim: #6aa1c0;
            --border: #0b2942;
            background:
                radial-gradient(circle at 20% 0%, #082443 0%, #020818 45%, #00040b 100%);
        }
        body.design-nautical::before {
            background:
                repeating-linear-gradient(
                    0deg,
                    transparent 0px,
                    transparent 3px,
                    rgba(3, 34, 71, 0.35) 4px
                ),
                radial-gradient(circle at 50% 120%, rgba(39, 176, 219, 0.18), transparent 65%);
        }

        #header {
            position: fixed;
            top: 0;
            left: 0;
            right: 0;
            padding: 12px 16px;
            padding-top: max(12px, env(safe-area-inset-top));
            padding-left: max(16px, env(safe-area-inset-left));
            padding-right: max(16px, env(safe-area-inset-right));
            background: linear-gradient(180deg, var(--bg-dark) 0%, transparent 100%);
            z-index: 500;
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 16px;
        }
        #header .header-spacer { flex: 1; min-width: 40px; }

        #header-auth {
            display: inline-flex;
            align-items: center;
            gap: 8px;
            flex-shrink: 0;
            min-width: 0;
        }
        #header-auth a {
            line-height: 1;
        }

        #menu-toggle {
            display: none;
            background: transparent;
            border: 1px solid var(--border);
            color: var(--green-bright);
            width: 40px;
            height: 40px;
            font-size: 1.2rem;
            cursor: pointer;
            font-family: inherit;
            align-items: center;
            justify-content: center;
            flex-shrink: 0;
        }
        #menu-toggle:hover { background: rgba(0, 255, 136, 0.1); }

        .header-brand {
            display: none;
            flex-direction: column;
            align-items: flex-start;
            gap: 4px;
            min-width: 0;
            margin-left: 0;
        }
        .header-brand .header-logo {
            font-family: 'Orbitron', sans-serif;
            font-size: 0.95rem;
            font-weight: 700;
            letter-spacing: 0.15em;
            color: var(--green-bright);
            text-transform: uppercase;
            text-shadow: 0 0 12px rgba(0, 255, 136, 0.5);
            white-space: nowrap;
        }
        .header-brand .header-tagline {
            font-size: 0.65rem;
            color: var(--text-dim);
            max-width: min(280px, calc(100vw - 140px));
            white-space: normal;
            line-height: 1.35;
        }

        #status {
            font-size: 0.7rem;
            color: var(--text-dim);
            letter-spacing: 0.15em;
            display: inline-flex;
            align-items: center;
            line-height: 1;
            min-width: 0;
        }

        #status.loading::after {
            content: '...';
            animation: blink 0.8s infinite;
        }

        @keyframes blink {
            0%, 50% { opacity: 1; }
            51%, 100% { opacity: 0; }
        }

        /* Side menu */
        #side-menu {
            position: fixed;
            top: 0;
            left: 0;
            width: var(--sidebar-width);
            height: 100vh;
            height: 100dvh;
            z-index: 600;
            background: linear-gradient(180deg, rgba(13, 20, 16, 0.98) 0%, rgba(10, 14, 10, 0.98) 100%);
            border-right: 1px solid var(--border);
            box-shadow: 4px 0 24px rgba(0, 0, 0, 0.4);
            display: flex;
            flex-direction: column;
            padding-top: 0;
            padding-bottom: env(safe-area-inset-bottom);
            transition: transform 0.25s ease, box-shadow 0.25s ease;
        }

        #menu-header {
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            padding: max(12px, env(safe-area-inset-top)) 14px 12px;
            border-bottom: 1px solid var(--border);
            background: rgba(0, 0, 0, 0.2);
        }

        #logo {
            font-family: 'Orbitron', sans-serif;
            font-size: clamp(0.9rem, 2.5vw, 1.2rem);
            font-weight: 700;
            letter-spacing: 0.2em;
            color: #00ff88;
            text-transform: uppercase;
            text-shadow: 0 0 12px rgba(0, 255, 136, 0.8), 0 0 20px rgba(0, 255, 136, 0.4);
        }
        #logo::after {
            content: '';
            display: block;
            height: 2px;
            width: 100%;
            margin-top: 4px;
            background: linear-gradient(90deg, var(--green-bright), transparent 80%);
            opacity: 0.8;
        }

        .logo-and-tagline {
            display: flex;
            flex-direction: column;
            gap: 4px;
            min-width: 0;
        }
        #app-tagline {
            font-size: 0.6rem;
            color: var(--text-dim);
            font-weight: 400;
            letter-spacing: 0.05em;
            line-height: 1.3;
            max-width: 220px;
        }

        #menu-close {
            display: none;
            flex-shrink: 0;
            width: 40px;
            height: 40px;
            align-items: center;
            justify-content: center;
            background: transparent;
            border: 1px solid var(--border);
            color: var(--green-bright);
            font-size: 1.4rem;
            cursor: pointer;
            font-family: inherit;
            line-height: 1;
        }
        #menu-close:hover { background: rgba(0, 255, 136, 0.1); }

        #side-menu::before {
            content: '';
            position: absolute;
            top: 0; left: 0; right: 0;
            height: 2px;
            background: linear-gradient(90deg, transparent, var(--green-bright), transparent);
            opacity: 0.6;
        }

        #side-menu-content {
            flex: 1;
            overflow-y: auto;
            overflow-x: hidden;
            padding: 12px 0;
            -webkit-overflow-scrolling: touch;
        }

        #side-menu-content::-webkit-scrollbar {
            width: 6px;
        }
        #side-menu-content::-webkit-scrollbar-track { background: var(--bg-dark); }
        #side-menu-content::-webkit-scrollbar-thumb { background: var(--border); border-radius: 3px; }

        .menu-section {
            padding: 0 14px 16px;
        }

        .menu-section-title {
            font-family: 'Orbitron', sans-serif;
            font-size: 0.65rem;
            letter-spacing: 0.2em;
            color: var(--text-dim);
            margin-bottom: 10px;
            padding-bottom: 6px;
            border-bottom: 1px solid var(--border);
        }

        .menu-section-content { min-height: 0; }

        #lang-select {
            width: 100%;
            padding: 8px 10px;
            font-family: inherit;
            font-size: 0.75rem;
            background: var(--bg-dark);
            border: 1px solid var(--border);
            color: var(--text-primary);
            cursor: pointer;
            margin-bottom: 4px;
        }
        #lang-select:hover, #lang-select:focus {
            border-color: var(--green-mid);
            outline: none;
        }
        #design-style,
        #map-view-style {
            width: 100%;
            padding: 8px 10px;
            font-family: inherit;
            font-size: 0.75rem;
            background: var(--bg-dark);
            border: 1px solid var(--border);
            color: var(--text-primary);
            cursor: pointer;
        }
        #design-style:hover, #design-style:focus,
        #map-view-style:hover, #map-view-style:focus {
            border-color: var(--green-mid);
            outline: none;
        }

        .menu-pane { display: none; }
        .menu-pane.active { display: block; }

        .source-item {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 8px 0;
            font-size: 0.75rem;
            color: var(--text-primary);
            border-bottom: 1px solid rgba(26, 51, 37, 0.4);
        }
        .source-item:last-child { border-bottom: none; }
        .source-item.map-view-row { flex-direction: column; align-items: stretch; gap: 6px; }
        .source-item input[type="checkbox"] {
            accent-color: var(--green-bright);
            width: 16px;
            height: 16px;
            cursor: pointer;
            flex-shrink: 0;
        }
        .source-item label { cursor: pointer; flex: 1; min-width: 0; }
        .source-item label[data-loading="1"]::after { content: ' Loading…'; color: var(--text-dim); font-weight: normal; }

        .legend-item {
            display: flex;
            align-items: center;
            gap: 10px;
            padding: 8px 0;
            font-size: 0.75rem;
            color: var(--text-dim);
        }
        .legend-dot {
            width: 10px;
            height: 10px;
            border-radius: 50%;
            flex-shrink: 0;
        }
        .legend-dot.good { background: #00ff88; box-shadow: 0 0 8px rgba(0, 255, 136, 0.6); }
        .legend-dot.bad { background: #ff3366; box-shadow: 0 0 8px rgba(255, 51, 102, 0.6); }
        .legend-dot.neutral { background: #6a7c6a; }

        /* Map container - offset when sidebar open */
        #map-wrap {
            position: fixed;
            top: 0;
            left: var(--sidebar-width);
            right: 0;
            bottom: 220px; /* safe default above bottom strip; JS sets to strip height */
            transition: left 0.25s ease;
        }
        #map {
            width: 100%;
            height: 100%;
            background: var(--bg-dark);
        }

        /* CRT overlay – Red Alert / Yuri's Revenge style: green CMD screen + moving sweep line */
        #map-crt-overlay {
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            pointer-events: none;
            z-index: 400;
            overflow: hidden;
        }
        /* Base CRT glitch */
        #map-crt-overlay.crt-on::before {
            /* Greenish CMD/phosphor tint + scanlines */
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: repeating-linear-gradient(
                    0deg,
                    transparent 0px,
                    transparent 1px,
                    rgba(0, 0, 0, 0.12) 1px,
                    rgba(0, 0, 0, 0.12) 2px
                ),
                linear-gradient(
                    180deg,
                    rgba(0, 50, 25, 0.22) 0%,
                    rgba(0, 70, 35, 0.18) 50%,
                    rgba(0, 50, 25, 0.22) 100%
                );
            /* Edge vignette for CRT feel */
            box-shadow: inset 0 0 100px 30px rgba(0, 35, 18, 0.25);
        }
        /* Moving sweep line – slightly greener line scanning down (Red Alert style) */
        #map-crt-overlay.crt-on::after {
            content: '';
            position: absolute;
            left: 0;
            right: 0;
            height: 4px;
            background: linear-gradient(
                180deg,
                transparent 0%,
                rgba(0, 255, 120, 0.08) 20%,
                rgba(0, 255, 140, 0.35) 50%,
                rgba(0, 255, 120, 0.08) 80%,
                transparent 100%
            );
            box-shadow: 0 0 20px 4px rgba(0, 255, 136, 0.25),
                        0 0 40px 8px rgba(0, 200, 100, 0.12);
            animation: crt-sweep 12s linear infinite;
            pointer-events: none;
        }
        @keyframes crt-sweep {
            0% { top: -8px; }
            100% { top: 100%; }
        }

        /* CRT glitch – nautical colors (cyan/teal radar sweep) */
        #map-crt-overlay.crt-nautical-on::before {
            content: '';
            position: absolute;
            top: 0;
            left: 0;
            right: 0;
            bottom: 0;
            background: repeating-linear-gradient(
                    0deg,
                    transparent 0px,
                    transparent 1px,
                    rgba(0, 0, 0, 0.12) 1px,
                    rgba(0, 0, 0, 0.12) 2px
                ),
                linear-gradient(
                    180deg,
                    rgba(8, 40, 56, 0.28) 0%,
                    rgba(12, 60, 82, 0.22) 50%,
                    rgba(8, 40, 56, 0.28) 100%
                );
            box-shadow: inset 0 0 100px 30px rgba(2, 24, 42, 0.35);
        }
        #map-crt-overlay.crt-nautical-on::after {
            content: '';
            position: absolute;
            left: 0;
            right: 0;
            height: 4px;
            background: linear-gradient(
                180deg,
                transparent 0%,
                rgba(56, 216, 255, 0.1) 20%,
                rgba(56, 216, 255, 0.4) 50%,
                rgba(56, 216, 255, 0.1) 80%,
                transparent 100%
            );
            box-shadow: 0 0 20px 4px rgba(56, 216, 255, 0.3),
                        0 0 40px 8px rgba(39, 176, 219, 0.15);
            animation: crt-sweep 12s linear infinite;
            pointer-events: none;
        }

        /* Static noise glitch – cinematic ocean-radar static */
        #map-crt-overlay.static-on::before {
            content: '';
            position: absolute;
            inset: 0;
            background:
                repeating-linear-gradient(
                    0deg,
                    rgba(8, 30, 42, 0.9) 0px,
                    rgba(8, 30, 42, 0.9) 2px,
                    rgba(16, 54, 76, 0.95) 3px,
                    rgba(2, 10, 20, 0.98) 4px
                ),
                radial-gradient(circle at 20% 0%, rgba(64, 196, 255, 0.16), transparent 60%),
                radial-gradient(circle at 80% 100%, rgba(0, 255, 180, 0.12), transparent 60%);
            opacity: 0.7;
            mix-blend-mode: soft-light;
            animation: static-noise-move 3s steps(5) infinite;
        }
        #map-crt-overlay.static-on::after {
            content: '';
            position: absolute;
            inset: -20px;
            background-image: url("data:image/svg+xml,%3Csvg width='160' height='160' viewBox='0 0 160 160' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='1.2' numOctaves='3' stitchTiles='noStitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.35'/%3E%3C/svg%3E");
            opacity: 0.55;
            mix-blend-mode: overlay;
            animation: static-noise-shift 1.8s steps(4) infinite;
        }
        @keyframes static-noise-move {
            0% { background-position: 0 0, 0 0, 0 0; }
            50% { background-position: 0 4px, 4px 0, -4px 0; }
            100% { background-position: 0 0, 0 0, 0 0; }
        }
        @keyframes static-noise-shift {
            0% { transform: translate3d(0, 0, 0); }
            25% { transform: translate3d(-4px, 2px, 0); }
            50% { transform: translate3d(3px, -3px, 0); }
            75% { transform: translate3d(-2px, 1px, 0); }
            100% { transform: translate3d(0, 0, 0); }
        }

        /* VHS-style warp / chromatic aberration – visible banding + RGB fringe */
        #map-crt-overlay.warp-on {
            animation: vhs-warp 4s ease-in-out infinite;
            filter: contrast(1.05) saturate(1.1);
        }
        #map-crt-overlay.warp-on::before,
        #map-crt-overlay.warp-on::after {
            content: '';
            position: absolute;
            inset: -6px;
            pointer-events: none;
            mix-blend-mode: screen;
        }
        /* Cyan/green ghost */
        #map-crt-overlay.warp-on::before {
            background:
                repeating-linear-gradient(
                    0deg,
                    rgba(0, 255, 200, 0.16) 0px,
                    rgba(0, 255, 200, 0.0) 3px
                );
            opacity: 0.45;
            transform: translate3d(2px, 0, 0);
        }
        /* Magenta ghost */
        #map-crt-overlay.warp-on::after {
            background:
                repeating-linear-gradient(
                    0deg,
                    rgba(255, 40, 180, 0.16) 0px,
                    rgba(255, 40, 180, 0.0) 3px
                );
            opacity: 0.4;
            transform: translate3d(-2px, 0, 0);
        }
        @keyframes vhs-warp {
            0%   { transform: translate3d(0, 0, 0) skewX(0deg); }
            20%  { transform: translate3d(-2px, 1px, 0) skewX(-0.7deg); }
            40%  { transform: translate3d(1px, -1px, 0) skewX(0.5deg); }
            60%  { transform: translate3d(-1px, 0, 0) skewX(-0.3deg); }
            80%  { transform: translate3d(2px, -1px, 0) skewX(0.6deg); }
            100% { transform: translate3d(0, 0, 0) skewX(0deg); }
        }

        /* Heavy scanlines – exaggerated CRT look */
        #map-crt-overlay.scanlines-on::before {
            content: '';
            position: absolute;
            inset: 0;
            background:
                repeating-linear-gradient(
                    0deg,
                    rgba(0, 0, 0, 0.9) 0px,
                    rgba(0, 0, 0, 0.8) 2px,
                    rgba(0, 255, 136, 0.25) 3px,
                    rgba(0, 0, 0, 0.9) 4px
                );
            opacity: 0.9;
        }
        #map-crt-overlay.scanlines-on::after {
            content: '';
            position: absolute;
            inset: 0;
            background: radial-gradient(circle at 50% 0%, rgba(0, 255, 136, 0.25), transparent 70%);
            mix-blend-mode: screen;
        }

        .leaflet-tile-pane { opacity: 0.95; }
        .leaflet-container {
            background: var(--bg-dark) !important;
            font-family: 'JetBrains Mono', monospace;
        }

        .leaflet-popup-content-wrapper {
            background: var(--bg-panel);
            border: 1px solid var(--border);
            border-radius: 2px;
            box-shadow: 0 0 20px var(--green-glow), inset 0 0 30px rgba(0, 255, 136, 0.05);
        }
        .leaflet-popup-content {
            margin: 12px 16px;
            color: var(--text-primary);
            font-size: 0.8rem;
            line-height: 1.5;
        }
        .leaflet-popup-content a {
            color: var(--green-bright);
            text-decoration: none;
            border-bottom: 1px solid var(--green-dim);
        }
        .leaflet-popup-content a:hover { text-shadow: 0 0 8px var(--green-glow); }
        .layer-popup { font-size: 0.75rem; line-height: 1.5; }
        .layer-popup .popup-meta { color: var(--text-dim); font-size: 0.7rem; }
        .layer-popup .popup-coords { font-family: 'JetBrains Mono', monospace; letter-spacing: 0.05em; margin-top: 4px; }
        .layer-popup .popup-admin-badge { display: inline-block; font-size: 0.7rem; color: var(--green-bright); margin-bottom: 6px; }
        .layer-popup .popup-body { margin-top: 8px; font-size: 0.7rem; color: var(--text-dim); line-height: 1.4; max-height: 120px; overflow-y: auto; }
        .layer-popup .popup-link { display: inline-block; margin-top: 6px; color: var(--green-bright); }
        .leaflet-popup-tip { background: var(--bg-panel); border: 1px solid var(--border); }
        .popup-date { font-size: 0.65rem; color: var(--text-dim); margin-top: 6px; }
        .popup-article {
            color: var(--green-bright);
            text-decoration: none;
            border-bottom: 1px solid var(--green-dim);
            cursor: pointer;
        }
        .popup-article:hover { text-shadow: 0 0 8px var(--green-glow); }

        .cyber-marker {
            width: 12px;
            height: 12px;
            border-radius: 50%;
            border: 0.5px solid var(--bg-dark);
            animation: pulse 2s ease-in-out infinite;
        }
        .cyber-marker.good { background: #00ff88; box-shadow: 0 0 10px rgba(0, 255, 136, 0.6); }
        .cyber-marker.bad { background: #ff3366; box-shadow: 0 0 10px rgba(255, 51, 102, 0.6); }
        .cyber-marker.neutral { background: #6a7c6a; box-shadow: 0 0 6px rgba(106, 124, 106, 0.4); }
        .cyber-marker-admin-wrap {
            background: transparent !important;
            border: none !important;
            z-index: 999 !important;
        }
        .cyber-marker-admin-wrap.pinned {
            z-index: 1000 !important;
        }
        .cyber-marker-user-wrap {
            background: transparent !important;
            border: none !important;
            z-index: 998 !important;
        }
        .cyber-marker-emoji {
            font-size: 22px;
            line-height: 1;
            display: inline-block;
            filter: drop-shadow(0 1px 2px rgba(0,0,0,0.8));
        }
        .layer-marker-aviation {
            width: 10px; height: 10px;
            border-radius: 50%;
            background: #BF00FF;
            border: 1px solid #9B30FF;
            box-shadow: 0 0 8px rgba(191, 0, 255, 0.8), 0 0 4px rgba(155, 48, 255, 0.5);
        }
        .leaflet-marker-icon.layer-marker-aviation-wrap {
            background: transparent !important;
            border: none !important;
        }
        .layer-marker-earthquake {
            width: 10px; height: 10px;
            border-radius: 50%;
            background: #ff8800;
            border: 1px solid #ff8800;
            box-shadow: 0 0 8px rgba(255, 136, 0, 0.9), 0 0 4px rgba(255, 136, 0, 0.6);
        }
        .leaflet-marker-icon.layer-marker-earthquake-wrap {
            background: transparent !important;
            border: none !important;
        }
        .marker-cluster.layer-marker-earthquake-cluster div {
            background: #ff8800;
            border: 1px solid #ff8800;
            color: #000;
            box-shadow: 0 0 10px rgba(255, 136, 0, 0.9), 0 0 6px rgba(255, 136, 0, 0.7);
        }
        .marker-cluster-small, .marker-cluster-medium, .marker-cluster-large {
            background-color: rgba(191, 0, 255, 0.35);
        }
        .marker-cluster div {
            background-color: rgba(155, 48, 255, 0.9);
            color: #e0c0ff;
            font-weight: 600;
        }
        @keyframes pulse {
            0%, 100% { opacity: 1; transform: scale(1); }
            50% { opacity: 0.85; transform: scale(1.08); }
        }

        /* Cyber music player */
        #music-player-wrap {
            border-bottom: 1px solid var(--border);
            margin-bottom: 8px;
            padding-bottom: 10px;
        }
        .music-section-title {
            font-size: 0.65rem;
            letter-spacing: 0.2em;
            color: var(--text-dim);
            margin-bottom: 8px;
        }
        .music-art-and-controls {
            display: flex;
            gap: 12px;
            align-items: flex-start;
            margin-bottom: 10px;
        }
        .music-art {
            width: 80px;
            height: 80px;
            flex-shrink: 0;
            background: var(--bg-dark);
            border: 1px solid var(--border);
            border-radius: 4px;
            overflow: hidden;
            box-shadow: 0 0 12px rgba(0, 255, 136, 0.15);
        }
        .music-art img {
            width: 100%;
            height: 100%;
            object-fit: cover;
        }
        .music-now-info {
            flex: 1;
            min-width: 0;
        }
        .music-now-title {
            font-size: 0.75rem;
            color: var(--green-bright);
            font-weight: 600;
            margin-bottom: 2px;
        }
        .music-now-artist {
            font-size: 0.65rem;
            color: var(--text-dim);
        }
        .music-controls {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-top: 6px;
        }
        .music-btn {
            width: 32px;
            height: 32px;
            border: 1px solid var(--border);
            background: var(--bg-dark);
            color: var(--green-bright);
            cursor: pointer;
            font-size: 1rem;
            display: flex;
            align-items: center;
            justify-content: center;
            border-radius: 2px;
        }
        .music-btn:hover {
            background: rgba(0, 255, 136, 0.1);
            box-shadow: 0 0 8px var(--green-glow);
        }
        .music-btn.playing { background: rgba(0, 255, 136, 0.2); }
        .music-btn img.music-btn-icon {
            width: 18px;
            height: 18px;
            display: block;
            pointer-events: none;
        }
        .music-btn .music-btn-pause-icon {
            display: none;
            font-size: 1rem;
            line-height: 1;
            pointer-events: none;
        }
        .music-btn.playing img.music-btn-icon { display: none; }
        .music-btn.playing .music-btn-pause-icon { display: block; }
        .music-progress-wrap {
            height: 4px;
            background: var(--bg-dark);
            border-radius: 2px;
            margin-top: 6px;
            cursor: pointer;
            border: 1px solid var(--border);
        }
        .music-progress-fill {
            height: 100%;
            width: 0%;
            background: linear-gradient(90deg, var(--green-dim), var(--green-bright));
            border-radius: 2px;
            transition: width 0.1s linear;
        }
        .music-time {
            font-size: 0.6rem;
            color: var(--text-dim);
            margin-top: 4px;
        }
        .music-volume-wrap {
            display: flex;
            align-items: center;
            gap: 8px;
            margin-top: 8px;
        }
        .music-volume-label {
            font-size: 0.6rem;
            color: var(--text-dim);
            flex-shrink: 0;
        }
        .music-volume {
            flex: 1;
            min-width: 0;
            height: 4px;
            -webkit-appearance: none;
            appearance: none;
            background: var(--bg-dark);
            border-radius: 2px;
            border: 1px solid var(--border);
        }
        .music-volume::-webkit-slider-thumb {
            -webkit-appearance: none;
            width: 12px;
            height: 12px;
            border-radius: 2px;
            background: var(--green-bright);
            border: 1px solid var(--border);
            cursor: pointer;
            box-shadow: 0 0 6px var(--green-glow);
        }
        .music-volume::-moz-range-thumb {
            width: 12px;
            height: 12px;
            border-radius: 2px;
            background: var(--green-bright);
            border: 1px solid var(--border);
            cursor: pointer;
            box-shadow: 0 0 6px var(--green-glow);
        }
        .music-track-list {
            max-height: 220px;
            overflow-y: auto;
            margin-top: 8px;
            /* Cyber scrollbar for track list */
            scrollbar-width: thin;
            scrollbar-color: var(--green-bright) var(--bg-dark);
        }
        .music-track-list::-webkit-scrollbar {
            width: 5px;
        }
        .music-track-list::-webkit-scrollbar-track {
            background: var(--bg-dark);
        }
        .music-track-list::-webkit-scrollbar-thumb {
            background: linear-gradient(180deg, var(--green-dim), var(--green-bright));
            border-radius: 3px;
            box-shadow: 0 0 6px var(--green-glow);
        }
        .music-track-item {
            padding: 6px 8px;
            font-size: 0.7rem;
            border-bottom: 1px solid rgba(26, 51, 37, 0.5);
            cursor: pointer;
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 6px;
        }
        .music-track-item:hover {
            background: rgba(0, 255, 136, 0.06);
        }
        .music-track-item.active {
            background: rgba(0, 255, 136, 0.12);
            color: var(--green-bright);
        }
        .music-track-item .track-dur { font-size: 0.6rem; color: var(--text-dim); }
        .music-track-list-header {
            font-size: 0.65rem;
            letter-spacing: 0.15em;
            color: var(--text-dim);
            margin-top: 10px;
            margin-bottom: 6px;
        }
        .music-track-list-empty {
            font-size: 0.7rem;
            color: var(--text-dim);
            padding: 12px 8px;
            font-style: italic;
        }

        .leaflet-control-attribution {
            background: rgba(10, 14, 10, 0.9) !important;
            color: var(--text-dim) !important;
            font-size: 0.6rem !important;
            padding: 4px 8px !important;
            border: 1px solid var(--border) !important;
        }
        .leaflet-control-attribution a { color: var(--green-dim) !important; }
        .leaflet-control-zoom { border: 1px solid var(--border) !important; }
        .leaflet-control-zoom a {
            background: var(--bg-panel) !important;
            color: var(--green-bright) !important;
            border: none !important;
        }
        .leaflet-control-zoom a:hover { background: var(--green-dim) !important; }

        /* Bottom tickers - inside bottom-strip, follows sidebar */
        #ticker-strip {
            flex-shrink: 0;
            background: linear-gradient(0deg, rgba(10, 14, 10, 0.97) 0%, rgba(13, 20, 16, 0.95) 100%);
            border-top: 1px solid var(--border);
            padding-bottom: env(safe-area-inset-bottom);
            box-shadow: 0 -4px 24px rgba(0, 0, 0, 0.3);
        }
        .ticker-row {
            height: 32px;
            display: flex;
            align-items: center;
            overflow: hidden;
            border-bottom: 1px solid rgba(26, 51, 37, 0.5);
            font-size: 0.7rem;
            letter-spacing: 0.05em;
        }
        .ticker-row:last-child { border-bottom: none; }
        body.tickers-hidden #ticker-strip .ticker-row:not(#cmd-line-wrap) { display: none; }
        .ticker-label {
            flex-shrink: 0;
            padding: 0 12px;
            color: var(--text-dim);
            font-family: 'Orbitron', sans-serif;
            font-size: 0.6rem;
            letter-spacing: 0.15em;
            border-right: 1px solid var(--border);
        }
        .ticker-scroll {
            flex: 1;
            overflow: hidden;
            white-space: nowrap;
        }
        .ticker-scroll-inner {
            display: inline-block;
            animation-timing-function: linear;
            animation-iteration-count: infinite;
        }
        .ticker-scroll-inner.loading { animation: none; }
        .ticker-scroll-inner.finance.has-content { animation-name: ticker-slide-slow; animation-duration: 200s; }
        .ticker-scroll-inner.crypto.has-content { animation-name: ticker-slide-slow; animation-duration: 300s; }
        .ticker-scroll-inner.news.has-content { animation-name: ticker-slide-fast; animation-duration: 1400s; }
        .ticker-scroll-inner.paused { animation-play-state: paused; }
        @keyframes ticker-slide-slow {
            0% { transform: translateX(0); }
            100% { transform: translateX(-50%); }
        }
        @keyframes ticker-slide-fast {
            0% { transform: translateX(0); }
            100% { transform: translateX(-50%); }
        }
        .ticker-scroll-inner span {
            padding-right: 2em;
            color: var(--text-primary);
        }
        .ticker-scroll-inner span.ticker-headline {
            cursor: pointer;
            text-decoration: underline;
            text-underline-offset: 2px;
        }
        .ticker-scroll-inner span.ticker-headline:hover { text-shadow: 0 0 8px var(--green-glow); }
        .ticker-scroll-inner span.ticker-finance-item {
            cursor: pointer;
            padding-right: 2em;
        }
        .ticker-scroll-inner span.ticker-finance-item.up { color: #00ff88; }
        .ticker-scroll-inner span.ticker-finance-item.down { color: #ff4466; }
        .ticker-scroll-inner span.ticker-finance-item.neutral { color: var(--text-dim); }
        .ticker-scroll-inner span.ticker-finance-item:hover { text-decoration: underline; }
        .ticker-scroll-inner .sep { color: var(--text-dim); padding-right: 1em; }

        /* CMD line - above tickers */
        #cmd-line-wrap {
            display: flex;
            align-items: center;
            height: 36px;
            border-bottom: 1px solid rgba(26, 51, 37, 0.5);
            padding: 0 12px;
            gap: 8px;
            background: rgba(0, 0, 0, 0.25);
            pointer-events: auto;
        }
        #cmd-prompt {
            font-family: 'JetBrains Mono', monospace;
            font-size: 0.7rem;
            color: var(--text-dim);
            flex-shrink: 0;
        }
        #cmd-input {
            flex: 1;
            min-width: 80px;
            font-family: 'JetBrains Mono', monospace;
            font-size: 0.75rem;
            color: var(--text-primary);
            background: transparent;
            border: none;
            outline: none;
            pointer-events: auto;
        }
        #cmd-input::placeholder { color: var(--text-dim); opacity: 0.8; }
        #cmd-output {
            font-size: 0.65rem;
            color: var(--text-dim);
            max-width: 240px;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        #cmd-help-panel {
            display: none;
            padding: 10px 12px 12px;
            border-bottom: 1px solid rgba(26, 51, 37, 0.5);
            background: rgba(0, 0, 0, 0.35);
            font-size: 0.65rem;
            font-family: 'JetBrains Mono', monospace;
            color: var(--text-dim);
            line-height: 1.6;
            max-height: 200px;
            overflow-y: auto;
            /* Match music player scrollbar */
            scrollbar-width: thin;
            scrollbar-color: var(--green-bright) var(--bg-dark);
        }
        #cmd-help-panel::-webkit-scrollbar {
            width: 5px;
        }
        #cmd-help-panel::-webkit-scrollbar-track {
            background: var(--bg-dark);
        }
        #cmd-help-panel::-webkit-scrollbar-thumb {
            background: linear-gradient(180deg, var(--green-dim), var(--green-bright));
            border-radius: 3px;
            box-shadow: 0 0 6px var(--green-glow);
        }
        #cmd-help-panel.visible { display: block; }
        #cmd-help-panel .cmd-help-title { color: var(--green-bright); margin-bottom: 6px; }

        /* Article viewer modal */
        #article-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            z-index: 950;
            background: rgba(0, 0, 0, 0.75);
            display: none;
            align-items: center;
            justify-content: center;
            padding: 20px;
            box-sizing: border-box;
        }
        #article-overlay.visible { display: flex; }
        #article-modal {
            background: var(--bg-panel);
            border: 1px solid var(--border);
            box-shadow: 0 0 40px var(--green-glow);
            max-width: 560px;
            width: 100%;
            max-height: 90vh;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }
        #article-modal-header {
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            padding: 12px 16px;
            border-bottom: 1px solid var(--border);
            background: rgba(0, 0, 0, 0.3);
        }
        #article-modal-title-bar {
            flex: 1;
            min-width: 0;
            font-family: 'Orbitron', sans-serif;
            font-size: 0.75rem;
            color: var(--text-dim);
            letter-spacing: 0.1em;
        }
        #article-modal-close {
            flex-shrink: 0;
            width: 36px;
            height: 36px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-size: 1.4rem;
            cursor: pointer;
            line-height: 1;
            font-family: inherit;
        }
        #article-modal-close:hover { background: rgba(0, 255, 136, 0.15); }
        #article-modal-body {
            flex: 1;
            overflow-y: auto;
            padding: 16px;
        }
        #article-modal h2 {
            font-family: 'Orbitron', sans-serif;
            font-size: 1rem;
            color: var(--text-primary);
            margin-bottom: 12px;
            line-height: 1.4;
        }
        #article-modal-image {
            width: 100%;
            max-height: 240px;
            object-fit: cover;
            margin-bottom: 12px;
            border: 1px solid var(--border);
        }
        #article-modal-desc {
            font-size: 0.8rem;
            color: var(--text-dim);
            line-height: 1.6;
            margin-bottom: 16px;
        }
        #article-modal-meta { font-size: 0.65rem; color: var(--text-dim); margin-bottom: 12px; }
        #article-modal-readmore {
            display: inline-block;
            padding: 10px 20px;
            background: transparent;
            border: 1px solid var(--green-bright);
            color: var(--green-bright);
            font-family: inherit;
            font-size: 0.75rem;
            letter-spacing: 0.1em;
            cursor: pointer;
            text-decoration: none;
            transition: background 0.2s, box-shadow 0.2s;
        }
        #article-modal-readmore:hover {
            background: rgba(0, 255, 136, 0.15);
            box-shadow: 0 0 12px var(--green-glow);
        }

        /* Analytics news list modal (clickable hour / sentiment) */
        #analytics-news-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            z-index: 900;
            background: rgba(0, 0, 0, 0.75);
            display: none;
            align-items: center;
            justify-content: center;
            padding: 20px;
            box-sizing: border-box;
        }
        #analytics-news-overlay.visible { display: flex; }
        #analytics-news-modal {
            background: var(--bg-panel);
            border: 1px solid var(--border);
            box-shadow: 0 0 40px var(--green-glow);
            max-width: 560px;
            width: 100%;
            max-height: 85vh;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }
        #analytics-news-modal-header {
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            padding: 12px 16px;
            border-bottom: 1px solid var(--border);
            background: rgba(0, 0, 0, 0.3);
        }
        #analytics-news-modal-title { font-family: 'Orbitron', sans-serif; font-size: 0.75rem; color: var(--text-dim); letter-spacing: 0.08em; }
        #analytics-news-modal-close {
            flex-shrink: 0;
            width: 36px; height: 36px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-size: 1.4rem;
            cursor: pointer;
            font-family: inherit;
        }
        #analytics-news-modal-close:hover { background: rgba(0, 255, 136, 0.15); }
        #analytics-news-list-wrap {
            flex: 1;
            overflow-y: auto;
            padding: 12px;
        }
        .analytics-news-item {
            display: flex;
            gap: 12px;
            padding: 10px 0;
            border-bottom: 1px solid rgba(0, 255, 136, 0.12);
            cursor: pointer;
            text-align: left;
            background: transparent;
            border-left: 3px solid transparent;
            margin-bottom: 0;
            font-family: inherit;
            color: inherit;
            width: 100%;
            box-sizing: border-box;
            transition: background 0.15s, border-color 0.15s;
        }
        .analytics-news-item:hover { background: rgba(0, 255, 136, 0.06); border-left-color: var(--green-bright); }
        .analytics-news-item:last-child { border-bottom: none; }
        .analytics-news-item-img {
            flex-shrink: 0;
            width: 72px;
            height: 56px;
            object-fit: cover;
            border-radius: 2px;
            background: rgba(0, 0, 0, 0.3);
        }
        .analytics-news-item-no-img {
            flex-shrink: 0;
            width: 72px;
            height: 56px;
            border-radius: 2px;
            background: rgba(0, 255, 136, 0.08);
            display: flex;
            align-items: center;
            justify-content: center;
            font-size: 0.6rem;
            color: var(--text-dim);
        }
        .analytics-news-item-body { min-width: 0; flex: 1; }
        .analytics-news-item-title { font-size: 0.8rem; font-weight: 600; color: var(--text-primary); margin-bottom: 4px; line-height: 1.25; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
        .analytics-news-item-desc { font-size: 0.7rem; color: var(--text-dim); line-height: 1.3; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; margin-bottom: 4px; }
        .analytics-news-item-meta { font-size: 0.6rem; color: var(--text-dim); opacity: 0.9; }
        #analytics-news-pagination {
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: center;
            flex-wrap: wrap;
            gap: 6px;
            padding: 10px 16px;
            border-top: 1px solid var(--border);
            background: rgba(0, 0, 0, 0.2);
        }
        #analytics-news-pagination button {
            min-width: 32px;
            height: 28px;
            padding: 0 8px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--text-dim);
            font-size: 0.75rem;
            cursor: pointer;
            font-family: inherit;
        }
        #analytics-news-pagination button:hover:not(:disabled) { background: rgba(0, 255, 136, 0.12); color: var(--green-bright); }
        #analytics-news-pagination button.current { background: rgba(0, 255, 136, 0.2); color: var(--green-bright); border-color: var(--green-bright); }
        #analytics-news-pagination button:disabled { opacity: 0.4; cursor: not-allowed; }
        #analytics-news-loading { text-align: center; padding: 24px; color: var(--text-dim); font-size: 0.8rem; }
        #analytics-hour-chart rect[data-hour], .analytics-hour-bar { cursor: pointer; }
        .sentiment-bar[data-sentiment], #analytics-sentiment-legend span[data-sentiment] { cursor: pointer; }

        /* Chart modal (finance/crypto) */
        #chart-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            z-index: 900;
            background: rgba(0, 0, 0, 0.8);
            display: none;
            align-items: center;
            justify-content: center;
            padding: 20px;
            box-sizing: border-box;
        }
        #chart-overlay.visible { display: flex; }
        #chart-modal {
            background: var(--bg-panel);
            border: 1px solid var(--border);
            box-shadow: 0 0 40px var(--green-glow);
            max-width: 520px;
            width: 100%;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }
        #chart-modal-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 12px 16px;
            border-bottom: 1px solid var(--border);
            background: rgba(0, 0, 0, 0.3);
        }
        #chart-modal-title { font-family: 'Orbitron', sans-serif; font-size: 0.9rem; color: var(--text-primary); }
        #chart-modal-close {
            width: 36px; height: 36px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-size: 1.4rem;
            cursor: pointer;
            font-family: inherit;
        }
        #chart-modal-close:hover { background: rgba(0, 255, 136, 0.15); }
        #chart-modal-body { padding: 16px; }
        #chart-modal-price { font-size: 1.2rem; margin-bottom: 4px; }
        #chart-modal-price.up { color: #00ff88; }
        #chart-modal-price.down { color: #ff4466; }
        #chart-modal-price.neutral { color: var(--text-dim); }
        #chart-modal-meta { font-size: 0.65rem; color: var(--text-dim); margin-bottom: 8px; }
        #chart-range-btns { display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
        #chart-range-btns button {
            padding: 6px 12px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--text-dim);
            font-size: 0.7rem;
            cursor: pointer;
            font-family: inherit;
        }
        #chart-range-btns button:hover { color: var(--text-primary); background: rgba(0, 255, 136, 0.08); }
        #chart-range-btns button.active { border-color: var(--green-bright); color: var(--green-bright); background: rgba(0, 255, 136, 0.12); }
        #chart-canvas-wrap { width: 100%; height: 220px; background: rgba(0,0,0,0.2); border: 1px solid var(--border); margin-top: 8px; }
        #chart-canvas { display: block; width: 100%; height: 100%; }

        /* App loading overlay (initial load) */
        #app-loading-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            z-index: 940;
            background: var(--bg-dark);
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 20px;
            box-sizing: border-box;
            transition: opacity 0.25s ease, visibility 0.25s ease;
        }
        #app-loading-overlay.hidden {
            opacity: 0;
            visibility: hidden;
            pointer-events: none;
        }
        .app-loading-content {
            text-align: center;
        }
        .app-loading-spinner {
            width: 40px;
            height: 40px;
            margin: 0 auto 16px;
            border: 3px solid var(--border);
            border-top-color: var(--green-bright);
            border-radius: 50%;
            animation: app-spin 0.8s linear infinite;
        }
        @keyframes app-spin {
            to { transform: rotate(360deg); }
        }
        .app-loading-text {
            font-family: 'Orbitron', sans-serif;
            font-size: 0.9rem;
            color: var(--text-primary);
            letter-spacing: 0.1em;
            margin-bottom: 4px;
        }
        .app-loading-sub {
            font-size: 0.7rem;
            color: var(--text-dim);
        }

        /* In-app error overlay (no external error pages) */
        #error-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            z-index: 960;
            background: rgba(0, 0, 0, 0.9);
            display: none;
            align-items: center;
            justify-content: center;
            padding: 20px;
            box-sizing: border-box;
        }
        #error-overlay.visible { display: flex; }
        .app-error-modal {
            background: var(--bg-panel);
            border: 1px solid var(--border);
            box-shadow: 0 0 40px var(--green-glow);
            max-width: 420px;
            width: 100%;
            padding: 24px;
        }
        .app-error-modal h3 {
            font-family: 'Orbitron', sans-serif;
            font-size: 0.9rem;
            color: var(--text-primary);
            margin-bottom: 12px;
            letter-spacing: 0.05em;
        }
        .app-error-modal p {
            font-size: 0.8rem;
            color: var(--text-dim);
            line-height: 1.5;
            margin-bottom: 20px;
        }
        .app-error-actions {
            display: flex;
            gap: 12px;
            flex-wrap: wrap;
        }
        .app-error-actions button {
            padding: 10px 16px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-family: inherit;
            font-size: 0.8rem;
            cursor: pointer;
        }
        .app-error-actions button:hover { background: rgba(0, 255, 136, 0.1); }
        .app-error-actions button.primary { background: rgba(0, 255, 136, 0.15); border-color: var(--green-mid); }

        /* Ticker error state (graceful per-feed failure) */
        .ticker-scroll-inner.ticker-error-state { animation: none; }
        .ticker-scroll-inner .ticker-error-msg { color: var(--text-dim); font-size: 0.75rem; }

        /* Single-session warning (multiple tabs) */
        #session-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            z-index: 950;
            background: rgba(0, 0, 0, 0.88);
            display: none;
            align-items: center;
            justify-content: center;
            padding: 20px;
            box-sizing: border-box;
        }
        #session-overlay.visible { display: flex; }
        #session-modal {
            background: var(--bg-panel);
            border: 1px solid var(--border);
            box-shadow: 0 0 40px var(--green-glow);
            max-width: 420px;
            width: 100%;
            padding: 20px;
        }
        #session-modal h3 {
            font-family: 'Orbitron', sans-serif;
            font-size: 0.9rem;
            color: var(--text-primary);
            margin-bottom: 12px;
            letter-spacing: 0.05em;
        }
        #session-modal p {
            font-size: 0.8rem;
            color: var(--text-dim);
            line-height: 1.5;
            margin-bottom: 20px;
        }
        #session-modal-actions {
            display: flex;
            gap: 12px;
            flex-wrap: wrap;
        }
        #session-modal-actions button {
            padding: 10px 16px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-family: inherit;
            font-size: 0.8rem;
            cursor: pointer;
        }
        #session-modal-actions button:hover { background: rgba(0, 255, 136, 0.1); }
        #session-modal-actions button.primary { background: rgba(0, 255, 136, 0.15); border-color: var(--green-mid); }

        /* Game viewer (iddqd) — map in box */
        #game-overlay {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            z-index: 900;
            background: rgba(0, 0, 0, 0.85);
            display: none;
            align-items: center;
            justify-content: center;
            padding: 20px;
            box-sizing: border-box;
        }
        #game-overlay.visible { display: flex; }
        #game-modal {
            background: var(--bg-panel);
            border: 1px solid var(--border);
            box-shadow: 0 0 40px var(--green-glow);
            width: 100%;
            max-width: 960px;
            height: 90vh;
            max-height: 640px;
            overflow: hidden;
            display: flex;
            flex-direction: column;
        }
        #game-modal-header {
            flex-shrink: 0;
            display: flex;
            align-items: center;
            justify-content: space-between;
            padding: 10px 14px;
            border-bottom: 1px solid var(--border);
            background: rgba(0, 0, 0, 0.3);
        }
        #game-modal-title { font-family: 'Orbitron', sans-serif; font-size: 0.85rem; color: var(--text-primary); letter-spacing: 0.1em; }
        #game-modal-close {
            width: 36px; height: 36px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-size: 1.4rem;
            cursor: pointer;
            font-family: inherit;
        }
        #game-modal-close:hover { background: rgba(0, 255, 136, 0.15); }
        #game-modal-body {
            flex: 1;
            min-height: 0;
            background: #000;
        }
        #game-iframe {
            display: block;
            width: 100%;
            height: 100%;
            border: none;
        }

        /* Bottom strip: analytics + CMD/tickers, moves together */
        #bottom-strip {
            position: fixed;
            left: var(--sidebar-width);
            right: 0;
            bottom: 0;
            z-index: 501;
            display: flex;
            flex-direction: column;
            transition: left 0.25s ease;
            pointer-events: auto;
        }
        #bottom-strip > * { pointer-events: auto; }

        /* Analytics panel - full width above CMD, 4 columns */
        #analytics-panel {
            position: relative;
            left: 0;
            right: 0;
            margin-left: 0;
            margin-bottom: 0;
            align-self: stretch;
            z-index: 450;
            width: 100%;
            min-width: 0;
            flex-shrink: 0;
            max-height: min(78vh, 520px);
            min-height: 0;
            background: linear-gradient(180deg, rgba(13, 20, 16, 0.97) 0%, rgba(10, 14, 10, 0.98) 100%);
            border: 1px solid var(--border);
            box-shadow: 0 0 24px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(0, 255, 136, 0.08);
            font-size: 0.7rem;
            display: flex;
            flex-direction: column;
            transition: max-height 0.25s ease, width 0.25s ease;
        }
        #analytics-panel.minimized {
            max-height: 47px;
            overflow: hidden;
        }
        #analytics-panel.minimized #analytics-toggle .analytics-toggle-icon { transform: rotate(-90deg); }
        #analytics-panel:not(.minimized) #analytics-toggle .analytics-toggle-icon { transform: rotate(90deg); }
        #analytics-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            padding: 10px 12px;
            border-bottom: 1px solid var(--border);
            background: rgba(0, 0, 0, 0.25);
            flex-shrink: 0;
            cursor: pointer;
        }
        #analytics-header:hover { background: rgba(0, 255, 136, 0.06); }
        #analytics-title {
            font-family: 'Orbitron', sans-serif;
            font-size: 0.7rem;
            letter-spacing: 0.15em;
            color: var(--green-bright);
        }
        #analytics-toggle {
            width: 28px;
            height: 28px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-size: 0.8rem;
            cursor: pointer;
            font-family: inherit;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: transform 0.2s ease;
            padding: 0;
        }
        #analytics-toggle .analytics-toggle-icon {
            width: 12px;
            height: 12px;
            display: block;
            object-fit: contain;
            transition: transform 0.2s ease;
        }
        #analytics-toggle:hover { background: rgba(0, 255, 136, 0.1); }
        #analytics-refresh {
            width: 28px;
            height: 28px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-size: 0.8rem;
            cursor: pointer;
            font-family: inherit;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 0;
            flex-shrink: 0;
        }
        #analytics-refresh:hover { background: rgba(0, 255, 136, 0.1); }
        #analytics-refresh svg { width: 14px; height: 14px; display: block; }
        #analytics-body {
            position: relative;
            overflow-x: hidden;
            overflow-y: auto;
            padding: 8px 10px;
            flex: 1;
            min-height: 0;
            min-width: 0;
            width: 100%;
            box-sizing: border-box;
            display: grid;
            grid-template-columns: minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
            gap: 10px;
            align-items: start;
        }
        #analytics-body::-webkit-scrollbar { width: 5px; }
        #analytics-body::-webkit-scrollbar-track { background: rgba(0,0,0,0.2); }
        #analytics-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
        #analytics-loading {
            display: none;
            position: absolute;
            inset: 0;
            background: rgba(10, 18, 14, 0.85);
            align-items: center;
            justify-content: center;
            font-size: 0.75rem;
            color: var(--text-dim);
            z-index: 2;
        }
        #analytics-news-col {
            position: relative;
        }
        #analytics-news-col.loading #analytics-loading {
            display: flex;
        }
        #analytics-loading::after {
            content: '';
            width: 18px;
            height: 18px;
            margin-left: 8px;
            border: 2px solid var(--border);
            border-top-color: var(--green-mid);
            border-radius: 50%;
            animation: analytics-spin 0.7s linear infinite;
        }
        @keyframes analytics-spin {
            to { transform: rotate(360deg); }
        }
        .analytics-col {
            min-width: 0;
            overflow: hidden;
            display: flex;
            flex-direction: column;
            gap: 8px;
        }
        .analytics-col .analytics-section {
            margin-bottom: 0;
        }
        .analytics-section {
            margin-bottom: 14px;
            min-width: 0;
        }
        .analytics-section:last-child { margin-bottom: 0; }
        .analytics-section-title {
            font-size: 0.6rem;
            letter-spacing: 0.12em;
            color: var(--text-dim);
            margin-bottom: 6px;
        }
        .analytics-chart {
            position: relative;
            min-height: 80px;
            min-width: 0;
            background: rgba(0, 0, 0, 0.2);
            border: 1px solid var(--border);
            border-radius: 2px;
        }
        #analytics-hour-chart { height: 100px; }
        #analytics-sentiment-chart { height: 28px; display: flex; align-items: stretch; }
        #analytics-sentiment-legend {
            display: flex;
            flex-wrap: wrap;
            gap: 10px 16px;
            margin-top: 6px;
            font-size: 0.65rem;
            color: var(--text-dim);
        }
        #analytics-sentiment-legend span { display: flex; align-items: center; gap: 4px; }
        .analytics-stats #analytics-stats-list {
            display: grid;
            gap: 4px;
            font-size: 0.65rem;
            color: var(--text-dim);
        }
        .analytics-stat-row { display: flex; justify-content: space-between; gap: 12px; }
        .analytics-stat-row strong { color: var(--text-primary); font-weight: 600; }
        .sentiment-bar { display: block; height: 100%; min-width: 2px; transition: width 0.2s ease; }
        .sentiment-bar.good { background: #00ff88; }
        .sentiment-bar.bad { background: #ff3366; }
        .sentiment-bar.neutral { background: #6a7c6a; }
        .analytics-rank-list {
            list-style: none;
            font-size: 0.65rem;
            color: var(--text-dim);
            display: flex;
            flex-direction: column;
            gap: 2px;
        }
        .analytics-rank-list li {
            display: flex;
            justify-content: space-between;
            align-items: center;
            gap: 8px;
            padding: 2px 0;
            cursor: pointer;
        }
        .analytics-rank-list li .name { min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
        .analytics-rank-list li.up { color: #00ff88; }
        .analytics-rank-list li.down { color: #ff4466; }
        .analytics-rank-list li.neutral { color: var(--text-dim); }
        .analytics-24h-chart {
            position: relative;
            height: 56px;
            margin-top: 8px;
            min-width: 0;
            background: rgba(0, 0, 0, 0.2);
            border: 1px solid var(--border);
            border-radius: 2px;
            overflow: hidden;
        }
        .analytics-chart-above {
            margin-top: 0;
            margin-bottom: 8px;
        }
        .analytics-24h-chart.analytics-chart-above {
            margin-bottom: 6px;
        }
        .analytics-24h-chart-wrap {
            position: relative;
        }
        .analytics-24h-chart path.sparkline-path {
            cursor: pointer;
            stroke-width: 1.5;
        }
        .analytics-24h-chart path.sparkline-path:hover {
            stroke-opacity: 1;
        }
        #analytics-asset-tooltip {
            position: fixed;
            z-index: 950;
            display: none;
            min-width: 140px;
            padding: 8px 10px;
            font-size: 0.65rem;
            color: var(--text-primary);
            background: rgba(10, 14, 12, 0.98);
            border: 1px solid var(--border);
            border-radius: 4px;
            box-shadow: 0 4px 12px rgba(0,0,0,0.4);
            pointer-events: none;
        }
        #analytics-asset-tooltip.visible { display: block; }
        #analytics-asset-tooltip .tooltip-name { font-weight: 600; margin-bottom: 2px; }
        #analytics-asset-tooltip .tooltip-symbol { color: var(--text-dim); margin-bottom: 4px; }
        #analytics-asset-tooltip .tooltip-value { margin-bottom: 2px; }
        #analytics-asset-tooltip .tooltip-change.up { color: #00ff88; }
        #analytics-asset-tooltip .tooltip-change.down { color: #ff4466; }
        .analytics-24h-chart svg { display: block; width: 100%; height: 100%; max-width: 100%; }
        @media (max-width: 900px) {
            #analytics-body { grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); }
        }
        @media (max-width: 520px) {
            #analytics-body { grid-template-columns: minmax(0, 1fr); }
        }

        /* Mobile: analytics single column, spacing, scroll */
        @media (max-width: 768px) {
            #analytics-body {
                grid-template-columns: minmax(0, 1fr);
                grid-auto-rows: minmax(min-content, auto);
                gap: 16px;
                padding: 12px 10px;
                padding-left: max(10px, env(safe-area-inset-left));
                padding-right: max(10px, env(safe-area-inset-right));
            }
            #analytics-panel {
                max-height: min(85vh, 520px);
            }
            .analytics-col {
                min-width: 0;
                width: 100%;
            }
            .analytics-section {
                margin-bottom: 16px;
            }
            .analytics-section:last-child { margin-bottom: 0; }
            .analytics-section-title {
                margin-bottom: 8px;
            }
            #analytics-hour-chart { height: 90px; min-height: 70px; }
            #analytics-sentiment-chart { height: 24px; min-height: 24px; }
            #analytics-sentiment-legend {
                gap: 8px 12px;
                margin-top: 8px;
            }
            .analytics-24h-chart {
                height: 48px;
                min-height: 44px;
                margin-top: 6px;
            }
            .analytics-stat-row { flex-wrap: wrap; gap: 4px; }
            .analytics-rank-list li { flex-wrap: wrap; gap: 4px; }
        }
        @media (max-width: 480px) {
            #analytics-body {
                gap: 14px;
                padding: 10px 8px;
                padding-left: max(8px, env(safe-area-inset-left));
                padding-right: max(8px, env(safe-area-inset-right));
            }
            #analytics-header { padding: 8px 10px; }
            #analytics-title { font-size: 0.65rem; }
            .analytics-section-title { font-size: 0.58rem; }
            .analytics-rank-list, .analytics-stats #analytics-stats-list { font-size: 0.6rem; }
            #analytics-hour-chart { height: 80px; min-height: 60px; }
            .analytics-24h-chart { height: 44px; min-height: 40px; }
        }

        /* Breaking News panel - minimizable, same style as analytics (header + toggle) */
        #breaking-news-panel {
            position: relative;
            left: 0;
            right: 0;
            margin-left: 0;
            margin-bottom: 0;
            align-self: stretch;
            z-index: 451;
            width: 100%;
            min-width: 0;
            flex-shrink: 0;
            max-height: min(42vh, 280px);
            min-height: 0;
            background: linear-gradient(180deg, rgba(13, 20, 16, 0.97) 0%, rgba(10, 14, 10, 0.98) 100%);
            border: 1px solid var(--border);
            box-shadow: 0 0 24px rgba(0, 0, 0, 0.4), 0 0 0 1px rgba(0, 255, 136, 0.08);
            font-size: 0.7rem;
            display: flex;
            flex-direction: column;
            transition: max-height 0.25s ease, width 0.25s ease;
        }
        #breaking-news-panel.minimized {
            max-height: 49px;
            overflow: hidden;
        }
        #breaking-news-panel:not(.minimized) {
            min-height: min(42vh, 280px);
        }
        #breaking-news-panel.minimized #breaking-news-toggle .breaking-news-toggle-icon { transform: rotate(-90deg); }
        #breaking-news-panel:not(.minimized) #breaking-news-toggle .breaking-news-toggle-icon { transform: rotate(90deg); }
        #breaking-news-header {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 12px;
            padding: 10px 12px;
            border-bottom: 1px solid var(--border);
            background: rgba(0, 0, 0, 0.25);
            flex-shrink: 0;
            cursor: pointer;
        }
        #breaking-news-header:hover { background: rgba(0, 255, 136, 0.06); }
        #breaking-news-title {
            font-family: 'Orbitron', sans-serif;
            font-size: 0.7rem;
            letter-spacing: 0.15em;
            color: var(--green-bright);
        }
        #breaking-news-toggle {
            width: 28px;
            height: 28px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-size: 0.8rem;
            cursor: pointer;
            font-family: inherit;
            display: flex;
            align-items: center;
            justify-content: center;
            transition: transform 0.2s ease;
            padding: 0;
        }
        #breaking-news-toggle .breaking-news-toggle-icon {
            width: 12px;
            height: 12px;
            display: block;
            object-fit: contain;
            transition: transform 0.2s ease;
        }
        #breaking-news-toggle:hover { background: rgba(0, 255, 136, 0.1); }
        #breaking-news-refresh {
            width: 28px;
            height: 28px;
            border: 1px solid var(--border);
            background: transparent;
            color: var(--green-bright);
            font-size: 0.8rem;
            cursor: pointer;
            font-family: inherit;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 0;
            flex-shrink: 0;
        }
        #breaking-news-refresh:hover { background: rgba(0, 255, 136, 0.1); }
        #breaking-news-refresh svg { width: 14px; height: 14px; display: block; }
        #breaking-news-body {
            overflow-x: hidden;
            overflow-y: auto;
            padding: 6px 10px;
            flex: 1;
            min-height: 0;
            display: flex;
            flex-direction: column;
            gap: 4px;
        }
        #breaking-news-body::-webkit-scrollbar { width: 5px; }
        #breaking-news-body::-webkit-scrollbar-track { background: rgba(0,0,0,0.2); }
        #breaking-news-body::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
        .breaking-news-item {
            display: flex;
            align-items: center;
            gap: 8px;
            padding: 6px 8px;
            border-left: 2px solid var(--border);
            background: rgba(0, 0, 0, 0.2);
            cursor: pointer;
            font-size: 0.7rem;
            color: var(--text-primary);
            transition: background 0.15s ease, border-left-color 0.15s ease;
        }
        .breaking-news-item:hover {
            background: rgba(0, 255, 136, 0.06);
            border-left-color: var(--green-bright);
        }
        .breaking-news-item.bad { border-left-color: #ff3366; }
        .breaking-news-item.bad:hover { border-left-color: #ff5588; }
        .breaking-news-item.breaking-news-admin .breaking-news-admin-emoji { margin-right: 2px; }
        .breaking-news-item.breaking-news-pinned .breaking-news-pinned-badge { margin-right: 2px; }
        .breaking-news-item .breaking-news-dot {
            width: 6px;
            height: 6px;
            border-radius: 50%;
            flex-shrink: 0;
        }
        .breaking-news-item.bad .breaking-news-dot { background: #ff3366; box-shadow: 0 0 6px rgba(255, 51, 102, 0.6); }
        .breaking-news-item.good .breaking-news-dot { background: #00ff88; }
        .breaking-news-item.neutral .breaking-news-dot { background: #6a7c6a; }
        .breaking-news-loading {
            padding: 12px 10px;
            text-align: center;
            font-size: 0.7rem;
            color: var(--text-dim);
        }
        .breaking-news-loading::after {
            content: '...';
            animation: blink 0.8s infinite;
        }
        .breaking-news-item-title {
            min-width: 0;
            display: -webkit-box;
            -webkit-line-clamp: 2;
            -webkit-box-orient: vertical;
            overflow: hidden;
            line-height: 1.25;
        }
        .breaking-news-item-text {
            flex: 1;
            min-width: 0;
        }
        .breaking-news-item-time {
            opacity: 0.75;
            font-size: 0.9em;
            white-space: nowrap;
        }
        .breaking-news-item-body {
            display: block;
            font-size: 0.75em;
            color: var(--text-dim);
            margin-top: 2px;
            overflow: hidden;
            text-overflow: ellipsis;
            white-space: nowrap;
        }
        @media (max-width: 768px) {
            #breaking-news-panel { max-height: min(38vh, 260px); }
            #breaking-news-panel:not(.minimized) { min-height: min(38vh, 260px); }
            #breaking-news-body { padding: 6px 8px; padding-left: max(8px, env(safe-area-inset-left)); padding-right: max(8px, env(safe-area-inset-right)); }
            .breaking-news-item { padding: 8px 6px; font-size: 0.68rem; }
        }
        @media (max-width: 480px) {
            #breaking-news-panel.minimized { max-height: 44px; }
            #breaking-news-header { padding: 8px 10px; }
            #breaking-news-title { font-size: 0.65rem; }
        }

        /* Analytics news modal: mobile friendly */
        @media (max-width: 768px) {
            #analytics-news-overlay { padding: 12px; align-items: flex-end; }
            #analytics-news-modal {
                max-height: 90vh;
                max-height: 90dvh;
                margin: 0;
            }
            #analytics-news-modal-header { padding: 10px 12px; }
            #analytics-news-list-wrap { padding: 8px; }
            .analytics-news-item { padding: 8px 0; gap: 10px; }
            .analytics-news-item-img, .analytics-news-item-no-img {
                width: 56px;
                height: 44px;
            }
        }
        #menu-backdrop {
            position: fixed;
            top: 0; left: 0; right: 0; bottom: 0;
            z-index: 550;
            background: rgba(0, 0, 0, 0.5);
            opacity: 0;
            visibility: hidden;
            transition: opacity 0.25s ease, visibility 0.25s ease;
        }
        #menu-backdrop.visible {
            opacity: 1;
            visibility: visible;
        }

        /* Mobile: sidebar overlay, map full width when menu closed */
        @media (max-width: 768px) {
            :root { --sidebar-width: 0; }

            #menu-toggle { display: flex; }

            #menu-close { display: flex; }

            #side-menu {
                width: min(100vw, 300px);
                transform: translateX(-100%);
                box-shadow: none;
            }
            #side-menu.open {
                transform: translateX(0);
                box-shadow: 4px 0 24px rgba(0, 0, 0, 0.5);
            }

            #map-wrap {
                left: 0;
            }

            #bottom-strip { left: 0; }

            #header { padding-left: 12px; padding-right: 12px; }
            #logo { letter-spacing: 0.2em; }

            /* Mobile header: keep auth left, status right */
            #header { justify-content: flex-start; }
            #header .header-spacer { display: none; }
            #header-auth { max-width: 60vw; }
            #header-auth .header-auth-greeting { display: none; }
            #header-auth .header-auth-sep { display: none; }
            #status {
                margin-left: auto;
                font-size: 0.65rem;
                max-width: 50%;
                text-align: right;
                white-space: nowrap;
                overflow: hidden;
                text-overflow: ellipsis;
            }

            .menu-section { padding: 0 12px 14px; }
            .source-item, .legend-item { padding: 10px 0; min-height: 44px; }
            .source-item input[type="checkbox"] { width: 20px; height: 20px; }
        }

        /* Desktop: fold sidebar so CMD/markets don't overlap; menu toggle visible */
        @media (min-width: 769px) {
            #menu-toggle { display: flex; }
            body.sidebar-folded {
                --sidebar-width: 0;
            }
            body.sidebar-folded #side-menu {
                width: 280px;
                transform: translateX(-100%);
            }
            body.sidebar-folded .header-brand {
                display: flex;
            }
        }

        @media (max-width: 480px) {
            #side-menu { width: 100vw; }
            #map-wrap { bottom: 88px; }
            .ticker-row { height: 28px; font-size: 0.65rem; }
            .ticker-label { padding: 0 8px; font-size: 0.55rem; }
        }