body {
            margin: 0;
            background: #000;
            overflow: hidden;
            font-family: 'Noto Sans', 'Segoe UI', 'Trebuchet MS', Verdana, Arial, sans-serif;
            font-weight: 600;
            --ui-main: #002147;
            --accent-blue: #002147;
            --accent-red: #BB133E;
            --cat-top: #BB133E;
            --cat-top-glow: rgba(187, 19, 62, 0.58);
            --cat-us: #0057B8;
            --cat-us-glow: rgba(0, 87, 184, 0.58);
            --cat-world: #FFFFFF;
            --cat-world-glow: rgba(255, 255, 255, 0.62);
            --cat-politics: #7B2CBF;
            --cat-politics-glow: rgba(123, 44, 191, 0.58);
            --cat-business: #F28C28;
            --cat-business-glow: rgba(242, 140, 40, 0.58);
            --cat-sports: #14B8A6;
            --cat-sports-glow: rgba(20, 184, 166, 0.56);
            --cat-technology: #2E9F3D;
            --cat-technology-glow: rgba(46, 159, 61, 0.58);
            --cat-science: #4A90E2;
            --cat-science-glow: rgba(74, 144, 226, 0.58);
            --cat-environment: #7FAF2A;
            --cat-environment-glow: rgba(127, 175, 42, 0.56);
            --cat-entertainment: #D81B8A;
            --cat-entertainment-glow: rgba(216, 27, 138, 0.58);
            --cat-health: #C6CCD0;
            --cat-health-glow: rgba(198, 204, 208, 0.54);
            --text-contrast: #C6CCD0;
            --text-muted: rgba(198, 204, 208, 0.82);
            --maplibre-br-clearance: 28px;
            --gaia-status-height: 40px;
            --gaia-top-panel-top: 20px;
            --gaia-top-panel-height: 118px;
            --gaia-top-panel-bottom: 138px;
            --gaia-breaking-ticker-height: 32px;
            --gaia-market-ticker-height: 32px;
            --gaia-ui-gap: 10px;
            --gaia-side-panel-width: 420px;
            --gaia-breaking-panel-height: 520px;
            --gaia-factcheck-topic-list-height: 96px;
            --gaia-factcheck-bottom-reserve: 118px;
            --top-panel-scale: 1;
            --side-panel-bottom-gap: calc(var(--maplibre-br-clearance, 28px) + 14px);
            --left-pill-width: 283px;
        }
        #map {
            position: absolute;
            top: 0;
            bottom: 0;
            width: 100%;
            height: 100vh;
            background-color: #000000;
            background-image: none;
        }
        #status-shell {
            position: absolute;
            left: 14px;
            right: auto;
            bottom: var(--gaia-ui-gap, 10px);
            z-index: 109;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            gap: 0;
            height: 22px;
            min-height: 22px;
            min-width: 22px;
            max-width: 22px;
            padding: 0;
            border: 1px solid rgba(0, 0, 0, 0.18);
            border-radius: 50%;
            background: #ffffff;
            overflow: visible;
            visibility: visible;
            pointer-events: auto;
            font-family: 'Noto Sans', 'Segoe UI', 'Trebuchet MS', Verdana, Arial, sans-serif;
            font-size: 12px;
            font-weight: 350;
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.5), 0 0 10px rgba(187, 19, 62, 0.5), 0 0 18px rgba(187, 19, 62, 0.32);
            transition: max-width 180ms ease, padding 180ms ease, border-radius 180ms ease;
        }

        #status-shell.open {
            justify-content: flex-start;
            min-width: 0;
            max-width: min(62vw, 520px);
            padding: 0 10px 0 4px;
            border-radius: 999px;
            overflow: hidden;
            box-shadow: none;
        }

        #status-toggle {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            flex: 0 0 auto;
            width: 14px;
            min-width: 14px;
            height: 14px;
            padding: 0;
            margin: 0;
            border: 0;
            border-radius: 50%;
            background: #111111;
            color: #FFFFFF;
            font: inherit;
            font-size: 10px;
            font-weight: 800;
            line-height: 1;
            cursor: pointer;
        }

        #status-toggle:hover {
            background: #111111;
        }

        #status {
            position: static;
            display: inline-flex;
            align-items: center;
            z-index: auto;
            margin: 0;
            margin-left: 0;
            min-height: 22px;
            max-width: 0;
            opacity: 0;
            padding: 0;
            border-radius: 0;
            overflow: hidden;
            white-space: nowrap;
            font: inherit;
            color: inherit;
            letter-spacing: inherit;
            text-transform: inherit;
            pointer-events: none;
            background: transparent !important;
            border: 0 !important;
            box-shadow: none !important;
            transition: max-width 180ms ease, opacity 160ms linear;
        }

        #status-shell.open #status {
            max-width: min(58vw, 460px);
            opacity: 1;
            padding: 0;
            margin-left: 4px;
        }

        #breaking-news {
            position: absolute;
            left: 20px;
            right: auto;
            top: calc(var(--gaia-top-panel-top, 20px) + 84px);
            bottom: auto;
            width: var(--gaia-side-panel-width, clamp(320px, 42vw, 500px));
            height: var(--gaia-breaking-panel-height, min(56vh, 560px));
            max-height: calc(100vh - (var(--gaia-top-panel-top, 20px) + 84px) - var(--side-panel-bottom-gap));
            background: rgba(0, 33, 71, 0.75);
            border: 2px solid var(--accent-red);
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.2), 0 0 12px rgba(187, 19, 62, 0.28), 0 0 4px rgba(187, 19, 62, 0.52);
            color: var(--text-contrast);
            z-index: 108;
            display: flex;
            flex-direction: column;
            border-radius: 20px;
            overflow: hidden;
            transition: border-radius 160ms ease, background-color 160ms ease;
        }

        #breaking-news-header {
            position: relative;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
            padding: 7px 12px;
            border-bottom: 1px solid var(--accent-blue);
            font-size: 11px;
            letter-spacing: 0.4px;
            text-transform: uppercase;
            cursor: pointer;
            transition: padding 150ms ease, gap 150ms ease, border-color 150ms ease;
        }

        #breaking-news-header > span {
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            font-size: 18px;
            font-weight: 800;
            letter-spacing: 0.2px;
            text-transform: none;
            text-align: center;
            width: max-content;
            max-width: calc(100% - 72px);
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            pointer-events: none;
        }

        .panel-actions {
            display: flex;
            align-items: center;
            gap: 6px;
            margin-left: auto;
            flex: 0 0 auto;
            position: relative;
            z-index: 1;
        }

        #breaking-news-header .panel-actions {
            margin-left: 0;
            margin-right: auto;
        }

        .panel-close {
            border: 1px solid var(--accent-blue);
            background: transparent;
            color: var(--text-contrast);
            width: 20px;
            height: 20px;
            line-height: 16px;
            font-size: 14px;
            font-weight: 700;
            cursor: pointer;
            padding: 0;
        }

        .panel-close:hover {
            box-shadow: inset 0 0 0 2px var(--accent-red);
        }

        #breaking-news-list {
            flex: 1 1 auto;
            min-height: 0;
            overflow-y: auto;
            padding: 8px;
            max-height: 2000px;
            opacity: 1;
            transition: opacity 140ms linear;
            will-change: opacity;
        }

        .breaking-note {
            color: var(--text-muted);
            font-size: 11px;
            line-height: 1.35;
            margin: 2px 0 8px;
        }

        .breaking-item {
            background: transparent;
            border: 0;
            border-top: 1px solid var(--accent-red);
            padding: 14px 14px 12px;
            margin-bottom: 12px;
            cursor: pointer;
        }

        .breaking-title-row {
            display: flex;
            align-items: flex-start;
            gap: 10px;
            margin-bottom: 10px;
        }

        .breaking-rank {
            font-size: 44px;
            line-height: 0.95;
            font-weight: 800;
            color: #f0f0f0;
            flex: 0 0 auto;
        }

        .breaking-rank-divider {
            width: 1px;
            height: 42px;
            background: var(--accent-red);
            flex: 0 0 auto;
        }

        .breaking-source-count {
            color: #D8D8D8;
            font-size: 16px;
            font-weight: 600;
            line-height: 1;
            margin-left: auto;
            text-align: right;
        }

        .breaking-thumb {
            width: 100%;
            height: auto;
            max-height: 330px;
            min-height: 160px;
            border: 1px solid rgba(255, 255, 255, 0.18);
            background: rgba(255, 255, 255, 0.08);
            object-fit: cover;
            display: block;
            margin: 0 0 10px;
        }

        .breaking-thumb-placeholder {
            width: 100%;
            height: 180px;
            border: 1px solid rgba(255, 255, 255, 0.18);
            background: rgba(255, 255, 255, 0.08);
            color: #cfd3d5;
            font-size: 12px;
            display: flex;
            align-items: center;
            justify-content: center;
            text-transform: uppercase;
            letter-spacing: 0.3px;
            margin: 0 0 10px;
        }

        .breaking-meta {
            color: #b8bec2;
            font-size: 11px;
            text-transform: uppercase;
            margin-bottom: 6px;
            letter-spacing: 0.2px;
        }

        .breaking-title {
            color: #f3f3f3;
            font-size: 26px;
            line-height: 1.12;
            margin: 0;
            font-weight: 700;
            letter-spacing: -0.2px;
            flex: 1 1 auto;
        }

        .breaking-summary {
            color: #e1e4e6;
            font-size: 18px;
            line-height: 1.28;
            margin: 0 0 10px;
        }

        .breaking-link {
            color: #e9ecef;
            text-decoration: none;
            font-size: 11px;
            border-bottom: 1px dashed rgba(233, 236, 239, 0.75);
        }

        .breaking-link:hover {
            border-bottom-style: solid;
        }

        .breaking-foot-row {
            display: flex;
            align-items: flex-end;
            justify-content: space-between;
            gap: 8px;
            margin-top: 8px;
        }

        .breaking-foot-actions {
            display: flex;
            align-items: center;
            flex-wrap: wrap;
            gap: 8px;
            min-width: 0;
        }

        .breaking-source-hide-btn {
            border: 1px solid rgba(244, 196, 48, 0.42);
            background: rgba(187, 19, 62, 0.18);
            color: #F4C430;
            border-radius: 999px;
            padding: 4px 8px;
            font-size: 9px;
            font-weight: 800;
            letter-spacing: 0.24px;
            text-transform: uppercase;
            cursor: pointer;
        }

        .breaking-source-hide-btn:hover {
            background: rgba(187, 19, 62, 0.28);
        }

        .followed-sources-shell {
            display: flex;
            flex-direction: column;
            gap: 7px;
            margin: 0;
            padding: 10px 12px;
            border: 1px solid rgba(244, 196, 48, 0.26);
            border-radius: 14px;
            background: rgba(0, 33, 71, 0.18);
        }

        .followed-sources-title {
            color: #ffffff;
            font-size: 10px;
            font-weight: 800;
            letter-spacing: 0.32px;
            text-transform: uppercase;
        }

        .followed-sources-note {
            color: var(--text-muted);
            font-size: 9px;
            line-height: 1.35;
        }

        .followed-sources-list {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
        }

        .follow-source-chip {
            border: 1px solid rgba(198, 204, 208, 0.2);
            background: rgba(255, 255, 255, 0.06);
            color: #dfe4e8;
            border-radius: 999px;
            padding: 4px 9px;
            font-size: 9px;
            font-weight: 700;
            letter-spacing: 0.18px;
            cursor: pointer;
        }

        .follow-source-chip:hover {
            border-color: rgba(244, 196, 48, 0.38);
            color: #ffffff;
        }

        .follow-source-chip.is-active,
        .follow-source-chip[aria-pressed="true"] {
            border-color: rgba(244, 196, 48, 0.5);
            background: rgba(244, 196, 48, 0.14);
            color: #F4C430;
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.12);
        }

        .muted-sources-shell {
            display: flex;
            flex-direction: column;
            gap: 8px;
            margin: 0;
            padding: 10px 12px;
            border: 1px dashed rgba(244, 196, 48, 0.36);
            border-radius: 14px;
            background: rgba(0, 33, 71, 0.2);
        }

        .muted-sources-title {
            color: #F4C430;
            font-size: 10px;
            font-weight: 800;
            letter-spacing: 0.32px;
            text-transform: uppercase;
        }

        .muted-sources-list {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
        }

        .muted-source-chip {
            border: 1px solid rgba(198, 204, 208, 0.22);
            background: rgba(255, 255, 255, 0.08);
            color: #ffffff;
            border-radius: 999px;
            padding: 4px 9px;
            font-size: 9px;
            font-weight: 700;
            letter-spacing: 0.18px;
            cursor: pointer;
        }

        .muted-source-chip:hover {
            border-color: rgba(244, 196, 48, 0.42);
            color: #F4C430;
        }

        .breaking-ad-preview {
            border: 1px dashed rgba(244, 196, 48, 0.46);
            background: rgba(0, 33, 71, 0.22);
            padding: 12px 14px;
            margin: 4px 0 12px;
            border-radius: 14px;
        }

        .breaking-ad-preview-label {
            margin: 0 0 6px;
            color: #F4C430;
            font-size: 9px;
            font-weight: 800;
            letter-spacing: 0.24px;
            text-transform: uppercase;
        }

        .breaking-ad-preview-box {
            display: flex;
            flex-direction: column;
            gap: 4px;
            padding: 10px 12px;
            border: 1px solid rgba(198, 204, 208, 0.2);
            border-radius: 10px;
            background: linear-gradient(135deg, rgba(0, 33, 71, 0.56), rgba(187, 19, 62, 0.12));
            color: #ffffff;
        }

        .breaking-ad-preview-box strong {
            font-size: 11px;
            line-height: 1.2;
        }

        .breaking-ad-preview-box span {
            font-size: 9px;
            line-height: 1.35;
            color: var(--text-muted);
        }

        #factcheck-service {
            position: absolute;
            right: 20px;
            left: auto;
            top: var(--gaia-top-panel-top, 20px);
            bottom: calc(var(--side-panel-bottom-gap) + var(--gaia-factcheck-bottom-reserve, 118px));
            width: var(--gaia-side-panel-width, clamp(320px, 42vw, 500px));
            height: auto;
            max-height: none;
            min-height: 180px;
            border: 2px solid var(--accent-red);
            display: flex;
            flex-direction: column;
            border-radius: 20px;
            background: rgba(0, 33, 71, 0.75);
            color: var(--text-contrast);
            z-index: 107;
            overflow: hidden;
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.2), 0 0 12px rgba(187, 19, 62, 0.28), 0 0 4px rgba(187, 19, 62, 0.52);
            transition: border-radius 160ms ease, background-color 160ms ease;
        }

        #factcheck-service-header {
            position: relative;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
            padding: 7px 12px;
            border-bottom: 1px solid rgba(198, 204, 208, 0.2);
            font-size: 10px;
            letter-spacing: 0.45px;
            text-transform: uppercase;
            color: #F4C430;
            font-weight: 800;
        }

        #factcheck-service-title {
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            display: inline-block;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            color: #ffffff;
            text-align: center;
            width: max-content;
            max-width: calc(100% - 72px);
            pointer-events: none;
        }

        #factcheck-topic-list {
            padding: 8px 10px 6px;
            max-height: var(--gaia-factcheck-topic-list-height, 96px);
            overflow-y: auto;
            border-bottom: 1px solid rgba(198, 204, 208, 0.16);
            flex: 0 0 auto;
        }

        #factcheck-topic-detail {
            padding: 8px 10px 10px;
            flex: 1 1 auto;
            min-height: 110px;
            overflow-y: auto;
        }

        #adsense-preview-slot {
            flex: 0 0 auto;
            margin: 0 10px 10px;
            padding: 10px;
            min-height: 96px;
            border: 1px dashed rgba(244, 196, 48, 0.58);
            border-radius: 14px;
            background: rgba(0, 33, 71, 0.32);
        }

        .adsense-preview-label {
            margin: 0 0 6px;
            font-size: 9px;
            font-weight: 800;
            letter-spacing: 0.28px;
            text-transform: uppercase;
            color: #F4C430;
        }

        .adsense-preview-box {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: center;
            gap: 6px;
            min-height: 68px;
            border: 1px solid rgba(198, 204, 208, 0.24);
            border-radius: 10px;
            background:
                linear-gradient(135deg, rgba(0, 33, 71, 0.62), rgba(187, 19, 62, 0.14));
            text-align: center;
            color: #ffffff;
        }

        .adsense-preview-box strong {
            display: block;
            font-size: 11px;
            line-height: 1.2;
            letter-spacing: 0.15px;
        }

        .adsense-preview-box span {
            display: block;
            font-size: 9px;
            line-height: 1.35;
            color: var(--text-muted);
        }

        .factcheck-note {
            margin: 2px 0 6px;
            font-size: 10px;
            line-height: 1.38;
            color: var(--text-muted);
        }

        .factcheck-topic-card {
            border: 1px solid rgba(198, 204, 208, 0.4);
            background: rgba(0, 33, 71, 0.28);
            padding: 8px;
            margin-bottom: 8px;
        }

        .factcheck-topic-card.active {
            border-color: #F4C430;
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.45);
        }

        .factcheck-topic-title {
            font-size: 11px;
            line-height: 1.32;
            color: #ffffff;
            margin: 0 0 5px;
            font-weight: 700;
        }

        .factcheck-topic-meta {
            font-size: 9px;
            letter-spacing: 0.2px;
            color: var(--text-muted);
            margin: 0 0 7px;
            text-transform: uppercase;
        }

        .factcheck-more-btn {
            width: 100%;
            border: 1px solid #F4C430;
            background: #F4C430;
            color: #002147;
            font-size: 10px;
            font-weight: 800;
            text-transform: uppercase;
            cursor: pointer;
            padding: 7px 9px;
            line-height: 1.1;
        }

        .factcheck-more-btn:hover {
            box-shadow: inset 0 0 0 1px #002147;
        }

        .factcheck-topic-heading {
            margin: 0 0 6px;
            font-size: 11px;
            font-weight: 800;
            color: #ffffff;
            line-height: 1.34;
        }

        .factcheck-topic-submeta {
            margin: 0 0 8px;
            font-size: 10px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.2px;
        }

        .factcheck-article {
            border: 1px solid rgba(198, 204, 208, 0.38);
            background: rgba(0, 33, 71, 0.28);
            padding: 8px;
            margin-bottom: 9px;
        }

        .factcheck-article.active {
            border-color: #F4C430;
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.44);
        }

        .factcheck-article-title {
            margin: 0 0 6px;
            font-size: 11px;
            line-height: 1.34;
            color: #ffffff;
            font-weight: 700;
        }

        .factcheck-article-meta {
            margin: 6px 0 7px;
            font-size: 9px;
            color: var(--text-muted);
            text-transform: uppercase;
            letter-spacing: 0.15px;
        }

        .factcheck-score-row {
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
            margin-bottom: 4px;
        }

        .factcheck-score-label {
            font-size: 9px;
            color: #C6CCD0;
            text-transform: uppercase;
            letter-spacing: 0.15px;
        }

        .factcheck-score-value {
            font-size: 11px;
            font-weight: 800;
            color: #ffffff;
        }

        .factcheck-score-chart {
            width: 100%;
            height: 7px;
            border-radius: 999px;
            background: rgba(198, 204, 208, 0.23);
            overflow: hidden;
        }

        .factcheck-score-fill {
            display: block;
            height: 100%;
            border-radius: 999px;
            background: #2E9F3D;
        }

        .factcheck-score-fill.medium {
            background: #F4C430;
        }

        .factcheck-score-fill.low {
            background: #BB133E;
        }

        .factcheck-issues {
            margin: 7px 0 0;
            padding-left: 14px;
            color: #F4C430;
            font-size: 10px;
            line-height: 1.34;
        }

        .factcheck-issues li {
            margin: 0 0 3px;
        }

        .factcheck-pass {
            margin: 7px 0 0;
            font-size: 10px;
            color: #9ED7A4;
            line-height: 1.3;
        }

        .factcheck-focus-meta {
            margin: 0;
            font-size: 10px;
            color: var(--text-muted);
            letter-spacing: 0.2px;
            text-transform: uppercase;
        }

        .factcheck-selected-article {
            cursor: default;
            border-top: 1px solid var(--accent-red);
        }

        .factcheck-selected-article .breaking-title {
            font-size: 24px;
            line-height: 1.16;
        }

        .factcheck-selected-summary {
            margin-bottom: 10px;
            max-height: 32em;
            overflow-y: auto;
            overflow-x: hidden;
            white-space: normal;
            word-break: break-word;
            padding-right: 3px;
        }

        .factcheck-related-actions {
            margin: 10px 0 8px;
        }

        .factcheck-related-btn {
            width: 100%;
            border: 1px solid var(--accent-red);
            background: var(--accent-red);
            color: #ffffff;
            font-size: 11px;
            font-weight: 800;
            text-transform: uppercase;
            cursor: pointer;
            padding: 8px 10px;
            line-height: 1.2;
        }

        .factcheck-related-btn:hover {
            box-shadow: inset 0 0 0 1px #002147;
        }

        .factcheck-related-list {
            margin-top: 6px;
        }

        .factcheck-related-item {
            margin-bottom: 10px;
            padding: 10px;
        }

        .factcheck-related-item .breaking-rank {
            font-size: 28px;
            line-height: 1;
        }

        .factcheck-related-item .breaking-rank-divider {
            height: 28px;
        }

        .factcheck-related-item .breaking-title {
            font-size: 19px;
            line-height: 1.18;
        }

        .factcheck-related-item .breaking-summary {
            font-size: 14px;
            line-height: 1.3;
        }

        .factcheck-related-item .breaking-thumb {
            max-height: 220px;
            min-height: 110px;
        }

        .factcheck-factuality-row {
            display: flex;
            align-items: center;
            justify-content: flex-start;
            gap: 6px;
            margin: 4px 0 8px;
        }

        .factcheck-factuality-link {
            border: 0;
            background: transparent;
            color: #F4C430;
            text-transform: uppercase;
            font-size: 10px;
            letter-spacing: 0.2px;
            padding: 0;
            cursor: pointer;
            text-decoration: underline;
            text-underline-offset: 2px;
        }

        .factcheck-factuality-link:hover {
            color: #ffe07d;
        }

        .factcheck-factuality-value {
            color: #ffffff;
            font-size: 11px;
            font-weight: 800;
        }

        .factcheck-keyfacts {
            margin-top: 10px;
            padding-top: 10px;
            border-top: 1px solid var(--accent-red);
        }

        .factcheck-keyfacts-title {
            margin: 0 0 6px;
            color: #ffffff;
            font-size: 12px;
            font-weight: 800;
            text-transform: uppercase;
            letter-spacing: 0.25px;
        }

        .factcheck-keyfacts ul {
            margin: 0;
            padding-left: 16px;
            color: #e6eaed;
            font-size: 12px;
            line-height: 1.32;
        }

        .factcheck-keyfacts li {
            margin: 0 0 5px;
        }

        .factcheck-explain {
            margin-top: 10px;
            padding: 10px;
            border: 1px solid rgba(198, 204, 208, 0.38);
            background: rgba(0, 33, 71, 0.28);
        }

        .factcheck-explain-title {
            margin: 0 0 6px;
            color: #ffffff;
            font-size: 12px;
            font-weight: 800;
        }

        .factcheck-explain-submeta {
            margin: 0 0 8px;
            color: var(--text-muted);
            font-size: 10px;
            text-transform: uppercase;
            letter-spacing: 0.2px;
        }

        .factcheck-explain-label {
            margin: 0 0 4px;
            color: #C6CCD0;
            font-size: 10px;
            text-transform: uppercase;
            letter-spacing: 0.2px;
        }

        .factcheck-explain-band {
            margin: 8px 0 0;
            color: #dbe1e5;
            font-size: 11px;
            line-height: 1.3;
        }

        #controls-ui {
            position: absolute;
            bottom: calc(var(--gaia-breaking-ticker-height, 32px) + 82px);
            left: 50%;
            right: auto;
            transform: translate(-50%, 0);
            z-index: 101;
            display: flex;
            align-items: center;
            justify-content: center;
            width: max-content;
            gap: 0;
            border: 0;
            border-radius: 0;
            background: transparent;
            padding: 0;
            box-shadow: none;
            overflow: visible;
            isolation: isolate;
        }
        #controls-ui > * {
            margin: 0;
        }
        #controls-ui > .btn {
            border-radius: 999px;
            border: 1px solid var(--accent-blue);
            min-width: 96px;
            padding: 8px 16px;
            position: relative;
            z-index: 1;
        }
        #controls-ui > #top-panel-logo-slot {
            display: flex;
            align-items: center;
            justify-content: center;
            flex: 0 0 auto;
            width: 112px;
            min-width: 112px;
            height: 112px;
            min-height: 112px;
            padding: 0;
            border: 1px solid var(--accent-blue);
            border-radius: 50%;
            background: color-mix(in srgb, var(--ui-main) 88%, transparent);
            box-shadow: 0 0 0 2px var(--accent-red), 0 0 12px rgba(187, 19, 62, 0.24), 0 0 4px rgba(187, 19, 62, 0.46);
            box-sizing: border-box;
            overflow: hidden;
            position: relative;
            z-index: 2;
        }
        #controls-ui > #top-panel-logo-slot > #top-panel-logo {
            width: 100%;
            height: 100%;
            max-width: none;
            max-height: none;
            object-fit: cover;
            object-position: center;
            display: block;
        }
        #controls-ui > #home-btn {
            border-radius: 999px 0 0 999px;
            margin-right: -10px;
            padding-right: 20px;
            border-color: var(--accent-red);
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.94), 0 0 10px rgba(187, 19, 62, 0.26), 0 0 4px rgba(187, 19, 62, 0.44);
        }
        #controls-ui > #sync-btn {
            border-radius: 0 999px 999px 0;
            margin-left: -10px;
            padding-left: 20px;
            border-color: var(--accent-red);
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.94), 0 0 10px rgba(187, 19, 62, 0.26), 0 0 4px rgba(187, 19, 62, 0.44);
        }
        body.no-ambient-glow #status-shell {
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.5) !important;
        }
        body.no-ambient-glow #status-shell.open {
            box-shadow: none !important;
        }
        body.no-ambient-glow #breaking-news,
        body.no-ambient-glow #factcheck-service {
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.2) !important;
        }
        body.no-ambient-glow #category-panel {
            box-shadow: 0 0 0 1px rgba(74, 144, 226, 0.24) !important;
        }
        body.no-ambient-glow #forecast-panel {
            box-shadow: 0 0 0 1px rgba(244, 196, 48, 0.22) !important;
        }
        body.no-ambient-glow #market-ticker-shell {
            box-shadow: 0 0 0 1px rgba(123, 44, 191, 0.16) !important;
        }
        body.no-ambient-glow #breaking-ticker-shell {
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.14) !important;
        }
        body.no-ambient-glow #news-keyword-search-shell {
            box-shadow: 0 0 0 1px rgba(74, 144, 226, 0.12) !important;
        }
        body.no-ambient-glow #top-panel-logo-slot {
            box-shadow: 0 0 0 2px var(--accent-red) !important;
        }
        body.no-ambient-glow #controls-ui > #home-btn,
        body.no-ambient-glow #controls-ui > #sync-btn {
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.94) !important;
        }
        body.no-ambient-glow .trending-topic-btn {
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04) !important;
        }
        body.no-ambient-glow .trending-topic-btn:hover {
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08) !important;
        }
        body.no-ambient-glow .trending-topic-btn.active,
        body.no-ambient-glow .trending-topic-btn[aria-pressed="true"] {
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 0 1px var(--trend-color, #4A90E2) !important;
        }
        body.no-ambient-glow .trending-topic-marker,
        body.no-ambient-glow .trending-topic-marker::before,
        body.no-ambient-glow .trending-topic-marker-pyramid::before {
            filter: none !important;
        }
        .btn {
            background: var(--accent-blue);
            color: var(--text-contrast);
            border: 1px solid var(--accent-blue);
            padding: 8px 18px;
            cursor: pointer;
            font-family: inherit;
            font-weight: 800;
            text-transform: uppercase;
            transition: 0.25s;
        }
        .btn.accent-red,
        .btn.accent-blue {
            background: var(--accent-blue);
            border-color: var(--accent-blue);
            color: var(--text-contrast);
        }
        .btn:hover {
            transform: translateY(-1px);
            box-shadow: inset 0 0 0 2px var(--accent-red);
            filter: none;
        }
        .btn.active:hover,
        .btn.selected:hover,
        .btn[aria-selected="true"]:hover,
        .btn[aria-pressed="true"]:hover {
            box-shadow: inset 0 0 0 1px var(--accent-blue);
        }
        .btn:active,
        .btn.active,
        .btn.selected,
        .btn[aria-selected="true"],
        .btn[aria-pressed="true"] {
            background: var(--accent-red);
            border-color: var(--accent-blue);
            color: #ffffff;
        }

        #market-ticker-shell {
            position: absolute;
            top: 0;
            left: 50%;
            right: auto;
            transform: translateX(-50%);
            z-index: 112;
            width: min(65vw, calc(100vw - 32px));
            max-width: calc(100vw - 32px);
            height: var(--gaia-market-ticker-height, 32px);
            border: 1px solid rgba(123, 44, 191, 0.42);
            border-top: 0;
            border-radius: 0 0 16px 16px;
            background: rgba(0, 33, 71, 0.75);
            box-shadow: 0 0 0 1px rgba(123, 44, 191, 0.16), 0 0 12px rgba(123, 44, 191, 0.24);
            overflow: visible;
            pointer-events: auto;
            cursor: pointer;
            outline: none;
            transition: box-shadow 160ms ease, background-color 160ms ease;
        }
        #market-ticker-shell:hover,
        #market-ticker-shell:focus-visible,
        #market-ticker-shell.menu-open {
            box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 16px rgba(123, 44, 191, 0.34);
        }

        #market-ticker-shell.menu-open {
            z-index: 120;
        }

        #market-ticker-viewport {
            position: relative;
            z-index: 1;
            display: flex;
            align-items: center;
            width: 100%;
            height: 100%;
            overflow: hidden;
            border-radius: inherit;
            pointer-events: none;
        }

        #market-ticker-track {
            display: inline-flex;
            align-items: center;
            gap: 42px;
            width: max-content;
            min-width: 100%;
            padding: 0 18px;
            white-space: nowrap;
            will-change: transform;
            animation: market-ticker-scroll var(--market-ticker-duration, 42s) linear infinite;
        }

        #market-ticker-shell[data-ready="false"] #market-ticker-track {
            animation: none;
            justify-content: center;
        }

        #breaking-ticker-shell {
            position: absolute;
            left: 50%;
            right: auto;
            top: auto;
            bottom: 0;
            transform: translateX(-50%);
            z-index: 100;
            width: min(65vw, calc(100vw - 32px));
            max-width: calc(100vw - 32px);
            height: var(--gaia-breaking-ticker-height, 32px);
            border: 1px solid rgba(187, 19, 62, 0.48);
            border-bottom: 0;
            border-radius: 16px 16px 0 0;
            background: rgba(0, 33, 71, 0.75);
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.14), 0 0 12px rgba(187, 19, 62, 0.22);
            overflow: hidden;
            pointer-events: none;
        }

        #breaking-ticker-viewport {
            display: flex;
            align-items: center;
            width: 100%;
            height: 100%;
            overflow: hidden;
        }

        #breaking-ticker-track {
            display: inline-flex;
            align-items: center;
            gap: 42px;
            width: max-content;
            min-width: 100%;
            padding: 0 18px;
            white-space: nowrap;
            will-change: transform;
            animation: breaking-ticker-scroll var(--breaking-ticker-duration, 54s) linear infinite;
        }

        #breaking-ticker-shell[data-ready="false"] #breaking-ticker-track {
            animation: none;
            justify-content: center;
        }

        .maplibregl-ctrl-bottom-right {
            right: 0 !important;
            bottom: var(--gaia-ui-gap, 10px) !important;
        }

        .maplibregl-ctrl-bottom-right .maplibregl-ctrl {
            margin: 0 var(--gaia-ui-gap, 10px) 0 0 !important;
        }

        .market-ticker-segment {
            display: inline-flex;
            align-items: center;
            gap: 32px;
            white-space: nowrap;
        }

        .market-ticker-label {
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.6px;
            text-transform: uppercase;
            color: rgba(198, 204, 208, 0.82);
        }

        .market-ticker-item {
            display: inline-flex;
            align-items: baseline;
            gap: 7px;
            font-size: 12px;
            line-height: 1;
            color: var(--text-contrast);
        }

        .market-ticker-headline {
            display: inline-flex;
            align-items: baseline;
            gap: 7px;
            font-size: 11px;
            line-height: 1;
            color: var(--text-contrast);
        }

        .market-ticker-symbol {
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.4px;
            text-transform: uppercase;
            color: rgba(198, 204, 208, 0.86);
        }

        .market-ticker-headline-source {
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.35px;
            text-transform: uppercase;
            color: rgba(198, 204, 208, 0.82);
        }

        .market-ticker-headline-text {
            font-weight: 600;
            color: #ffffff;
        }

        .market-ticker-price {
            font-weight: 700;
            color: #ffffff;
        }

        .market-ticker-change {
            font-size: 10px;
            font-weight: 700;
        }

        .market-ticker-item.up .market-ticker-change {
            color: #0A8F3F;
        }

        .market-ticker-item.down .market-ticker-change {
            color: #BB133E;
        }

        .market-ticker-item.flat .market-ticker-change {
            color: rgba(198, 204, 208, 0.9);
        }

        .market-ticker-note {
            font-size: 11px;
            font-weight: 700;
            letter-spacing: 0.35px;
            color: rgba(198, 204, 208, 0.88);
        }

        #market-watchlist-menu {
            position: absolute;
            top: calc(100% + 10px);
            left: 50%;
            transform: translateX(-50%);
            z-index: 118;
            width: min(760px, calc(100vw - 24px));
            max-width: calc(100vw - 24px);
            padding: 12px;
            border: 1px solid rgba(123, 44, 191, 0.4);
            border-radius: 18px;
            background: rgba(0, 16, 38, 0.94);
            box-shadow: 0 20px 38px rgba(0, 0, 0, 0.42), 0 0 0 1px rgba(187, 19, 62, 0.1);
            cursor: default;
        }

        #market-watchlist-title {
            margin-bottom: 4px;
            color: #ffffff;
            font-size: 11px;
            font-weight: 800;
            letter-spacing: 0.45px;
            text-transform: uppercase;
            text-align: center;
        }

        #market-watchlist-note {
            margin-bottom: 10px;
            color: rgba(198, 204, 208, 0.78);
            font-size: 8px;
            font-weight: 700;
            letter-spacing: 0.28px;
            line-height: 1.2;
            text-transform: uppercase;
            text-align: center;
        }

        #market-watchlist-options {
            display: flex;
            flex-direction: column;
            gap: 12px;
            align-items: stretch;
        }

        .market-watchlist-section {
            display: flex;
            flex-direction: column;
            gap: 8px;
        }

        .market-watchlist-section-title {
            padding: 0 2px;
            color: #ffffff;
            font-size: 9px;
            font-weight: 800;
            letter-spacing: 0.36px;
            line-height: 1.2;
            text-transform: uppercase;
        }

        .market-watchlist-section-groups {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(86px, 1fr));
            gap: 10px 6px;
            align-items: start;
        }

        .market-watchlist-group {
            display: flex;
            flex-direction: column;
            gap: 6px;
            min-width: 0;
        }

        .market-watchlist-group-title {
            padding: 0 4px;
            color: rgba(198, 204, 208, 0.78);
            font-size: 8px;
            font-weight: 800;
            letter-spacing: 0.34px;
            line-height: 1.2;
            text-transform: uppercase;
        }

        .market-watchlist-group-list {
            display: flex;
            flex-direction: column;
            gap: 6px;
            align-items: center;
        }

        .market-watchlist-option {
            display: inline-flex;
            align-items: center;
            justify-content: center;
            width: 86px;
            min-width: 86px;
            max-width: 86px;
            min-height: 0;
            padding: 4px 10px;
            border: 1px solid rgba(198, 204, 208, 0.24);
            border-radius: 999px;
            background: rgba(0, 33, 71, 0.96);
            color: #ffffff;
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04), 0 0 10px rgba(74, 144, 226, 0.18);
            font-family: inherit;
            font-size: 8.3px;
            font-weight: 700;
            letter-spacing: 0.32px;
            line-height: 1.1;
            text-transform: uppercase;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            cursor: pointer;
            transition: transform 140ms ease, box-shadow 140ms ease, background-color 140ms ease, border-color 140ms ease;
        }

        .market-watchlist-option:hover {
            transform: translateY(-1px);
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 14px rgba(74, 144, 226, 0.24);
        }

        .market-watchlist-option:focus-visible {
            outline: none;
            border-color: rgba(255, 255, 255, 0.18);
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 0 1px rgba(74, 144, 226, 0.32), 0 0 16px rgba(74, 144, 226, 0.28);
        }

        .market-watchlist-option[aria-pressed="true"] {
            background: rgba(8, 54, 102, 0.98);
            color: #ffffff;
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 0 1px rgba(74, 144, 226, 0.36), 0 0 16px rgba(74, 144, 226, 0.32);
        }

        #trending-topics-shell {
            position: absolute;
            top: calc(var(--gaia-market-ticker-height, 32px) + 28px);
            left: 50%;
            transform: translateX(-50%);
            z-index: 112;
            width: min(1120px, calc(100vw - 24px));
            max-width: calc(100vw - 24px);
            padding: 4px 0;
            border: 0;
            border-radius: 999px;
            background: transparent;
            box-shadow: none;
            pointer-events: auto;
            overflow: visible;
        }

        #trending-topics-list {
            display: flex;
            flex-wrap: nowrap;
            gap: 6px;
            justify-content: center;
            align-items: center;
            width: 100%;
            overflow-x: visible;
            overflow-y: visible;
            scrollbar-width: none;
        }

        #trending-topics-list::-webkit-scrollbar {
            display: none;
        }

        .trending-topic-note {
            display: inline-flex;
            align-items: center;
            justify-content: flex-start;
            min-width: max-content;
            min-height: 29px;
            padding: 0 6px;
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.35px;
            text-transform: uppercase;
            color: rgba(198, 204, 208, 0.84);
        }

        .trending-topic-btn {
            flex: 0 0 auto;
            min-width: 86px;
            border: 1px solid var(--trend-color, #4A90E2);
            border-radius: 999px;
            background: rgba(0, 33, 71, 0.96);
            color: #ffffff;
            padding: 6px 10px;
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.04), 0 0 10px var(--trend-glow, rgba(74, 144, 226, 0.18));
            font-family: inherit;
            font-size: 8.3px;
            font-weight: 700;
            letter-spacing: 0.32px;
            line-height: 1.1;
            text-transform: uppercase;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            cursor: pointer;
            transition: transform 140ms ease, box-shadow 140ms ease, background-color 140ms ease, border-color 140ms ease;
        }

        .trending-topic-btn:hover {
            transform: translateY(-1px);
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 14px var(--trend-glow, rgba(74, 144, 226, 0.24));
        }

        .trending-topic-btn.active,
        .trending-topic-btn[aria-pressed="true"] {
            background: rgba(8, 54, 102, 0.98);
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08), 0 0 0 1px var(--trend-color, #4A90E2), 0 0 16px var(--trend-glow, rgba(74, 144, 226, 0.32));
        }

        #news-keyword-search-shell {
            position: absolute;
            top: 124px;
            left: 50%;
            transform: translateX(-50%);
            z-index: 112;
            width: min(540px, calc(100vw - 44px));
            border: 1px solid rgba(74, 144, 226, 0.42);
            border-radius: 999px;
            background: rgba(0, 33, 71, 0.86);
            box-shadow: 0 0 0 1px rgba(74, 144, 226, 0.12), 0 0 12px rgba(74, 144, 226, 0.12);
            pointer-events: auto;
            overflow: hidden;
        }

        #news-keyword-search-form {
            display: flex;
            align-items: center;
            gap: 0;
            width: 100%;
            min-width: 0;
        }

        #news-keyword-search-input {
            flex: 1 1 auto;
            min-width: 0;
            border: 0;
            background: transparent;
            color: var(--text-contrast);
            padding: 9px 14px;
            font-family: inherit;
            font-size: 11px;
            font-weight: 600;
            outline: none;
        }

        #news-keyword-search-input::placeholder {
            color: rgba(198, 204, 208, 0.72);
        }

        #news-keyword-search-submit,
        #news-keyword-search-clear {
            border: 0;
            border-left: 1px solid rgba(74, 144, 226, 0.24);
            background: transparent;
            color: var(--text-contrast);
            padding: 9px 12px;
            font-family: inherit;
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.35px;
            text-transform: uppercase;
            cursor: pointer;
            flex: 0 0 auto;
            transition: background-color 140ms ease, color 140ms ease;
        }

        #news-keyword-search-submit:hover,
        #news-keyword-search-clear:hover {
            background: rgba(74, 144, 226, 0.12);
        }

        #news-keyword-search-clear[hidden] {
            display: none;
        }

        .trending-topic-marker {
            position: relative;
            width: 34px;
            height: 24px;
            pointer-events: none;
            filter: drop-shadow(0 0 6px var(--trend-glow, rgba(74, 144, 226, 0.34)));
        }

        .trending-topic-marker::before {
            content: '';
            position: absolute;
            left: 50%;
            top: 50%;
            width: 8px;
            height: 8px;
            transform: translate(-50%, -50%);
            border-radius: 50%;
            background: var(--trend-glow, rgba(74, 144, 226, 0.24));
            filter: blur(2px);
            opacity: 0.82;
        }

        .trending-topic-marker-visual {
            position: absolute;
            inset: 0;
            transform: rotateZ(var(--trend-angle, 0deg));
            transform-origin: 50% 50%;
        }

        .trending-topic-marker-tail {
            position: absolute;
            left: 4px;
            top: 50%;
            width: 10px;
            height: 2px;
            transform: translateY(-50%);
            border-radius: 999px;
            background: linear-gradient(90deg, rgba(255, 255, 255, 0.12), rgba(255, 255, 255, 0.9) 42%, var(--trend-color, #4A90E2) 100%);
            opacity: 0.92;
        }

        .trending-topic-marker-pyramid {
            position: absolute;
            right: 3px;
            top: 50%;
            width: 16px;
            height: 16px;
            transform: translateY(-50%);
            transform-origin: 50% 50%;
            animation: trending-lightning-flicker 1.35s steps(2, end) infinite alternate;
            animation-delay: var(--trend-delay, 0ms);
        }

        .trending-topic-marker-pyramid::before,
        .trending-topic-marker-pyramid::after {
            content: '';
            position: absolute;
            inset: 0;
            clip-path: polygon(16% 6%, 66% 6%, 48% 38%, 86% 38%, 38% 100%, 50% 60%, 14% 60%, 34% 28%);
        }

        .trending-topic-marker-pyramid::before {
            background: linear-gradient(135deg, rgba(255, 255, 255, 0.98) 0%, rgba(255, 255, 255, 0.76) 18%, var(--trend-color, #4A90E2) 62%, rgba(0, 12, 34, 0.22) 100%);
            filter: drop-shadow(0 0 4px var(--trend-glow, rgba(74, 144, 226, 0.3)));
        }

        .trending-topic-marker-pyramid::after {
            transform: scale(0.82) translate(8%, -2%);
            transform-origin: 50% 50%;
            background: linear-gradient(135deg, rgba(255, 255, 255, 0.34) 0%, rgba(255, 255, 255, 0) 42%, rgba(0, 0, 0, 0.18) 100%);
            opacity: 0.9;
        }

        .trending-topic-marker-face {
            position: absolute;
            inset: 0;
            display: none;
        }

        .trending-topic-marker-face-top {
            clip-path: polygon(0 18%, 60% 18%, 100% 50%, 46% 50%);
            background: linear-gradient(90deg, rgba(255, 255, 255, 0.94) 0%, rgba(255, 255, 255, 0.3) 30%, var(--trend-color, #4A90E2) 100%);
        }

        .trending-topic-marker-face-bottom {
            clip-path: polygon(46% 50%, 100% 50%, 60% 82%, 0 82%);
            background: linear-gradient(90deg, rgba(255, 255, 255, 0.18) 0%, var(--trend-color, #4A90E2) 56%, rgba(0, 9, 28, 0.34) 100%);
        }

        .trending-topic-marker-face-side {
            clip-path: polygon(0 18%, 46% 50%, 0 82%, 14% 50%);
            background: linear-gradient(180deg, rgba(255, 255, 255, 0.28) 0%, rgba(0, 9, 28, 0.28) 100%);
            opacity: 0.9;
        }

        @keyframes market-ticker-scroll {
            from {
                transform: translateX(0);
            }
            to {
                transform: translateX(calc(-1 * var(--market-ticker-shift, 0px)));
            }
        }

        @keyframes breaking-ticker-scroll {
            from {
                transform: translateX(0);
            }
            to {
                transform: translateX(calc(-1 * var(--breaking-ticker-shift, 0px)));
            }
        }

        @keyframes trending-lightning-flicker {
            from {
                opacity: 0.78;
                filter: brightness(0.96);
            }
            to {
                opacity: 1;
                filter: brightness(1.16);
            }
        }

        @keyframes trending-pyramid-spin {
            from {
                transform: translateY(-50%) perspective(120px) rotateY(0deg);
            }
            to {
                transform: translateY(-50%) perspective(120px) rotateY(360deg);
            }
        }

        #top-panel {
            position: absolute;
            top: 20px;
            left: 50%;
            right: auto;
            transform: translate(-50%, 0) scale(var(--top-panel-scale, 1));
            transform-origin: top center;
            z-index: 111;
            width: max-content;
            max-width: 94vw;
            min-width: 0;
            border: 0;
            background: transparent;
            pointer-events: auto;
            padding: 0;
            display: flex;
            flex-direction: column;
            align-items: center;
            gap: 10px;
            transition: transform 160ms ease, top 160ms ease;
        }

        #map-style-bar {
            display: flex;
            align-items: center;
            justify-content: flex-start;
            gap: 0;
            width: max-content;
            max-width: calc(100vw - 48px);
            border: 1px solid var(--accent-blue);
            border-radius: 999px;
            background: color-mix(in srgb, var(--ui-main) 84%, transparent);
            overflow-x: auto;
            overflow-y: hidden;
            -webkit-overflow-scrolling: touch;
            box-shadow: 0 0 0 1px rgba(198, 204, 208, 0.08);
        }

        #map-style-bar::-webkit-scrollbar {
            display: none;
        }

        .map-style-btn {
            border: 0;
            border-left: 1px solid rgba(255, 255, 255, 0.18);
            background: transparent;
            color: var(--text-contrast);
            min-height: 34px;
            padding: 8px 12px;
            font-size: 10px;
            font-weight: 700;
            letter-spacing: 0.25px;
            text-transform: uppercase;
            white-space: nowrap;
            cursor: pointer;
            flex: 0 0 auto;
            font-family: inherit;
            transition: background-color 120ms ease, color 120ms ease, box-shadow 120ms ease;
        }

        .map-style-btn:first-child {
            border-left: 0;
            border-radius: 999px 0 0 999px;
        }

        .map-style-btn:last-child {
            border-radius: 0 999px 999px 0;
        }

        .map-style-btn:hover {
            box-shadow: inset 0 0 0 1px var(--accent-red);
        }

        .map-style-btn.active,
        .map-style-btn[aria-pressed="true"] {
            background: var(--accent-red);
            color: #ffffff;
        }

        #top-panel-header {
            position: fixed;
            top: 20px;
            right: 20px;
            left: auto;
            z-index: 112;
            width: var(--left-pill-width);
            max-width: calc(100vw - 40px);
            display: flex;
            align-items: center;
            justify-content: center;
            min-height: 42px;
            border: 2px solid var(--accent-red);
            border-radius: 999px;
            background: var(--ui-main);
            box-shadow: 0 0 0 1px var(--accent-blue);
            padding: 6px 12px;
            margin: 0;
            overflow: hidden;
            pointer-events: none;
            transition: width 160ms ease, right 160ms ease, top 160ms ease;
        }

        #top-panel-toolbar {
            position: relative;
            z-index: 112;
            display: flex;
            align-items: center;
            justify-content: center;
            gap: 10px;
            width: max-content;
            max-width: min(96vw, 1320px);
        }

        #top-panel-logo-slot {
            display: flex;
            align-items: center;
            justify-content: center;
            flex: 0 0 564px;
            width: 564px;
            min-width: 564px;
            min-height: 102px;
            padding: 8px 18px;
            border: 1px solid var(--accent-blue);
            border-radius: 999px;
            background: color-mix(in srgb, var(--ui-main) 84%, transparent);
            box-shadow: 0 0 0 1px rgba(198, 204, 208, 0.08);
            box-sizing: border-box;
        }

        #top-panel-logo {
            width: min(570px, 100%);
            height: auto;
            max-height: 102px;
            object-fit: contain;
            object-position: center;
            display: block;
        }

        #top-panel-tabs {
            display: flex;
            flex-wrap: wrap;
            gap: 6px;
        }

        .top-menu-tab {
            border: 1px solid var(--accent-blue);
            background: var(--accent-blue);
            color: var(--text-contrast);
            padding: 7px 10px;
            cursor: pointer;
            font-size: 10px;
            font-weight: 700;
            text-transform: uppercase;
            letter-spacing: 0.3px;
            flex: 0 1 auto;
            font-family: inherit;
        }

        .top-menu-tab.active {
            border-color: var(--accent-blue);
            background: var(--accent-red);
            color: #ffffff;
        }

        .top-menu-tab:hover {
            box-shadow: inset 0 0 0 2px var(--accent-red);
            filter: none;
        }
        .top-menu-tab.active:hover,
        .top-menu-tab[aria-selected="true"]:hover {
            box-shadow: inset 0 0 0 1px var(--accent-blue);
        }

        #top-panel-menus {
            min-height: 0;
        }

        .top-menu-panel {
            display: none;
            border: 1px solid var(--accent-blue);
            background: rgba(0, 33, 71, 0.14);
            padding: 10px;
        }

        .top-menu-panel.active {
            display: block;
        }

        .menu-note {
            margin: 0 0 8px;
            color: var(--text-muted);
            font-size: 10px;
            text-transform: uppercase;
            letter-spacing: 0.2px;
            line-height: 1.35;
        }

        .menu-actions {
            display: flex;
            flex-wrap: wrap;
            gap: 8px;
        }

        .menu-actions .btn {
            padding: 8px 10px;
            font-size: 10px;
            flex: 1 1 160px;
        }

        #news-categories {
            display: flex;
            flex-wrap: nowrap;
            justify-content: flex-start;
            gap: 0;
            margin: 0 auto;
            width: max-content;
            max-width: calc(100vw - 48px);
            border: 0;
            border-radius: 999px;
            background: var(--ui-main);
            padding: 3px;
            box-shadow: 0 0 0 2px var(--accent-red);
            overflow-x: auto;
            overflow-y: hidden;
            -webkit-overflow-scrolling: touch;
            scrollbar-width: none;
        }

        #news-categories::-webkit-scrollbar {
            display: none;
        }

        #category-panel {
            position: absolute;
            left: 20px;
            top: var(--gaia-top-panel-top, 20px);
            bottom: auto;
            width: var(--gaia-side-panel-width, clamp(320px, 42vw, 500px));
            min-height: 0;
            max-height: calc(100vh - var(--gaia-top-panel-top, 20px) - var(--side-panel-bottom-gap));
            z-index: 105;
            border: 2px solid #4A90E2;
            box-shadow: 0 0 0 1px rgba(74, 144, 226, 0.24), 0 0 12px rgba(74, 144, 226, 0.28), 0 0 4px rgba(74, 144, 226, 0.52);
            background: rgba(0, 33, 71, 0.75);
            display: flex;
            flex-direction: column;
            border-radius: 20px;
            pointer-events: auto;
            overflow: hidden;
            transition: border-radius 160ms ease, background-color 160ms ease;
        }

        #category-panel-header {
            position: relative;
            color: var(--text-contrast);
            font-size: 12px;
            text-transform: uppercase;
            border-bottom: 1px solid var(--accent-blue);
            padding: 7px 12px;
            background: transparent;
            letter-spacing: 0.4px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
            cursor: pointer;
            transition: padding 150ms ease, gap 150ms ease, border-color 150ms ease;
        }

        #category-panel-title {
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            display: inline-block;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            text-align: center;
            width: max-content;
            max-width: calc(100% - 96px);
            pointer-events: none;
        }

        #category-panel-actions {
            display: flex;
            align-items: center;
            gap: 6px;
            flex: 0 0 auto;
            margin-left: 0;
            margin-right: auto;
        }

        #category-panel-body {
            position: relative;
            flex: 0 1 auto;
            min-height: 0;
            overflow-x: hidden;
            overflow-y: auto;
            display: flex;
            flex-direction: column;
            gap: 8px;
            padding: 8px;
            max-height: 2000px;
            opacity: 1;
            transition: opacity 140ms linear;
            will-change: opacity;
        }

        #account-service-shell {
            display: flex;
            flex-direction: column;
            gap: 8px;
            width: 100%;
            padding: 10px 12px;
            border: 1px solid rgba(74, 144, 226, 0.26);
            border-radius: 14px;
            background: rgba(0, 33, 71, 0.18);
        }

        #account-service-title {
            color: #ffffff;
            font-size: 10px;
            font-weight: 800;
            letter-spacing: 0.32px;
            text-transform: uppercase;
        }

        #account-service-status {
            color: var(--text-muted);
            font-size: 9px;
            line-height: 1.35;
        }

        #account-service-status.is-error {
            color: #F4C430;
        }

        #account-launch-actions {
            display: flex;
            gap: 6px;
            width: 100%;
        }

        #account-launch-actions > .btn {
            flex: 1 1 0;
            min-width: 0;
        }

        #account-preferences-shell {
            display: flex;
            flex-direction: column;
            gap: 6px;
            width: 100%;
            padding-top: 8px;
            border-top: 1px solid rgba(74, 144, 226, 0.2);
        }

        #account-preferences-title {
            color: rgba(198, 204, 208, 0.84);
            font-size: 9px;
            font-weight: 700;
            letter-spacing: 0.5px;
            text-transform: uppercase;
        }

        #account-preferences-note {
            color: var(--text-muted);
            font-size: 8.8px;
            line-height: 1.35;
        }

        #account-preferences-grid {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 6px;
            width: 100%;
        }

        #account-preferences-grid > .btn {
            min-width: 0;
        }

        #account-preferences-grid > .btn[aria-pressed="true"] {
            border-color: rgba(244, 196, 48, 0.5);
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.22);
        }

        #account-auth-modal {
            position: fixed;
            inset: 0;
            z-index: 1400;
            display: flex;
            align-items: center;
            justify-content: center;
            padding: 18px;
            background: rgba(0, 0, 0, 0.56);
        }

        #account-auth-modal[hidden] {
            display: none;
        }

        #account-auth-modal-dialog {
            position: relative;
            width: min(420px, calc(100vw - 36px));
            padding: 18px 16px 16px;
            border: 1px solid rgba(244, 196, 48, 0.34);
            border-radius: 18px;
            background: rgba(0, 16, 38, 0.96);
            box-shadow: 0 18px 34px rgba(0, 0, 0, 0.48);
        }

        #account-auth-modal-close {
            position: absolute;
            top: 10px;
            right: 10px;
            min-width: 28px;
            width: 28px;
            height: 28px;
            padding: 0;
            border-radius: 50%;
            line-height: 1;
        }

        #account-auth-modal-title {
            color: #ffffff;
            font-size: 12px;
            font-weight: 800;
            letter-spacing: 0.34px;
            text-transform: uppercase;
            text-align: center;
        }

        #account-auth-modal-note {
            margin-top: 6px;
            color: var(--text-muted);
            font-size: 9px;
            line-height: 1.4;
            text-align: center;
        }

        #account-auth-fields {
            display: flex;
            flex-direction: column;
            gap: 6px;
            margin-top: 12px;
        }

        #account-auth-fields[hidden] {
            display: none;
        }

        #account-reset-code-input[hidden] {
            display: none;
        }

        #account-email-input,
        #account-password-input,
        #account-reset-code-input {
            width: 100%;
            min-width: 0;
            border: 1px solid rgba(74, 144, 226, 0.34);
            border-radius: 999px;
            background: rgba(0, 33, 71, 0.2);
            color: var(--text-contrast);
            padding: 6px 10px;
            font: inherit;
            font-size: 10px;
            line-height: 1.2;
            outline: none;
        }

        #account-email-input::placeholder,
        #account-password-input::placeholder,
        #account-reset-code-input::placeholder {
            color: rgba(198, 204, 208, 0.68);
        }

        #account-email-input:focus,
        #account-password-input:focus,
        #account-reset-code-input:focus {
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.34);
        }

        #account-auth-provider-actions,
        #account-auth-actions,
        #account-auth-reset-actions,
        #account-auth-secondary-actions {
            display: flex;
            gap: 6px;
            width: 100%;
        }

        #account-auth-provider-actions[hidden],
        #account-auth-actions[hidden],
        #account-auth-reset-actions[hidden],
        #account-auth-secondary-actions[hidden] {
            display: none;
        }

        #account-auth-provider-actions {
            margin-top: 8px;
        }

        #account-auth-provider-actions > .btn,
        #account-auth-actions > .btn,
        #account-auth-reset-actions > .btn,
        #account-auth-secondary-actions > .btn {
            flex: 1 1 0;
            min-width: 0;
        }

        #account-auth-actions {
            margin-top: 8px;
        }

        #account-auth-reset-actions {
            margin-top: 8px;
        }

        #account-auth-secondary-actions {
            margin-top: 8px;
        }

        #source-preferences-shell {
            display: flex;
            flex-direction: column;
            gap: 10px;
            width: 100%;
            margin-top: 2px;
        }

        #source-preferences-shell[hidden] {
            display: none;
        }

        #newsdata-filter-shell {
            display: flex;
            flex-direction: column;
            gap: 8px;
            width: 100%;
            margin-top: 2px;
            padding-top: 8px;
            border-top: 1px solid rgba(74, 144, 226, 0.24);
        }

        #newsdata-filter-title {
            color: rgba(198, 204, 208, 0.84);
            font-size: 9px;
            font-weight: 700;
            letter-spacing: 0.5px;
            text-transform: uppercase;
        }

        #newsdata-filter-grid {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(132px, 1fr));
            gap: 8px;
            width: 100%;
        }

        #newsdata-filter-shell > #glow-fx-btn,
        #newsdata-filter-shell > #auto-rotate-btn {
            width: 100%;
            min-width: 0;
            margin-top: 2px;
            border-color: var(--accent-red);
        }

        .newsdata-filter-field {
            display: flex;
            flex-direction: column;
            gap: 4px;
            min-width: 0;
        }

        .newsdata-filter-field > span {
            color: rgba(198, 204, 208, 0.78);
            font-size: 8px;
            font-weight: 700;
            letter-spacing: 0.42px;
            text-transform: uppercase;
            padding-left: 2px;
        }

        .newsdata-filter-field > select {
            width: 100%;
            min-width: 0;
            border: 1px solid rgba(74, 144, 226, 0.38);
            border-radius: 999px;
            background: rgba(0, 33, 71, 0.92);
            color: var(--text-contrast);
            padding: 7px 10px;
            font-family: inherit;
            font-size: 10px;
            font-weight: 600;
            line-height: 1.1;
            outline: none;
            cursor: pointer;
            appearance: none;
            box-sizing: border-box;
            transition: border-color 140ms ease, box-shadow 140ms ease, background-color 140ms ease;
        }

        .newsdata-filter-field > select:hover {
            border-color: rgba(74, 144, 226, 0.6);
        }

        .newsdata-filter-field > select:focus {
            border-color: var(--accent-red);
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.22);
        }

        .category-btn {
            border: 0;
            border-radius: 0;
            background: var(--accent-blue);
            color: var(--text-contrast);
            padding: 5px 10px;
            min-width: 72px;
            font-size: 6.9px;
            font-weight: 800;
            text-transform: uppercase;
            cursor: pointer;
            font-family: inherit;
            flex: 0 0 auto;
            text-align: center;
            white-space: nowrap;
            position: relative;
            transition: 0.25s;
            box-sizing: border-box;
        }

        #category-panel #news-categories {
            display: grid;
            grid-template-columns: repeat(auto-fit, minmax(96px, 1fr));
            gap: 6px;
            justify-content: stretch;
            align-content: start;
            margin: 0;
            width: 100%;
            max-width: 100%;
            border: 0;
            border-radius: 0;
            background: transparent;
            padding: 0;
            box-shadow: none;
            overflow: visible;
        }

        #category-panel #news-categories .category-btn {
            width: 100% !important;
            min-width: 0 !important;
            flex: 1 1 auto !important;
            border-radius: 999px;
            padding: 5px 8px;
            box-shadow: inset 0 0 0 1px var(--category-color, var(--accent-red));
        }

        #category-panel #news-categories .category-btn + .category-btn {
            border-left: 0;
        }

        #category-panel #news-categories .category-btn:first-child,
        #category-panel #news-categories .category-btn:last-child {
            border-radius: 999px;
        }

        #category-panel #news-categories .category-btn:hover {
            box-shadow: inset 0 0 0 2px var(--category-color, var(--accent-red));
        }

        #category-panel #news-categories .category-btn.active,
        #category-panel #news-categories .category-btn[aria-selected="true"],
        #category-panel #news-categories .category-btn[aria-pressed="true"] {
            box-shadow: inset 0 0 0 1px var(--category-dot-ring, var(--category-color, var(--accent-red)));
        }

        #category-panel #news-categories .category-btn.active:hover,
        #category-panel #news-categories .category-btn.selected:hover,
        #category-panel #news-categories .category-btn[aria-selected="true"]:hover,
        #category-panel #news-categories .category-btn[aria-pressed="true"]:hover {
            box-shadow: inset 0 0 0 1px var(--category-dot-ring, var(--category-color, var(--accent-red)));
        }

        .category-btn + .category-btn {
            border-left: 1px solid rgba(255, 255, 255, 0.18);
        }

        .category-btn:first-child {
            border-radius: 999px 0 0 999px;
        }

        .category-btn:last-child {
            border-radius: 0 999px 999px 0;
        }

        .category-btn::after {
            content: none;
        }

        .category-btn.active {
            border-color: transparent;
            background: var(--category-active-fill, var(--category-color, var(--accent-red)));
            color: var(--category-active-text, #ffffff);
        }

        .category-btn.active::after {
            opacity: 1;
        }

        .category-btn:hover {
            transform: translateY(-1px);
            box-shadow: inset 0 0 0 2px var(--category-color, var(--accent-red));
            filter: none;
        }
        .category-btn.active:hover,
        .category-btn.selected:hover,
        .category-btn[aria-selected="true"]:hover,
        .category-btn[aria-pressed="true"]:hover {
            box-shadow: inset 0 0 0 1px var(--category-dot-ring, var(--category-color, var(--accent-red)));
        }
        .category-btn:active,
        .category-btn.active,
        .category-btn[aria-selected="true"],
        .category-btn[aria-pressed="true"] {
            background: var(--category-active-fill, var(--category-color, var(--accent-red)));
            border-color: transparent;
            color: var(--category-active-text, #ffffff);
        }

        #forecast-panel {
            position: absolute;
            left: 20px;
            top: calc(var(--gaia-top-panel-top, 20px) + 168px);
            bottom: auto;
            width: var(--gaia-side-panel-width, clamp(320px, 42vw, 500px));
            min-height: 0;
            max-height: calc(100vh - (var(--gaia-top-panel-top, 20px) + 168px) - var(--side-panel-bottom-gap));
            z-index: 104;
            border: 2px solid #F4C430;
            box-shadow: 0 0 0 1px rgba(244, 196, 48, 0.22), 0 0 12px rgba(244, 196, 48, 0.26), 0 0 4px rgba(244, 196, 48, 0.46);
            background: rgba(0, 33, 71, 0.75);
            display: flex;
            flex-direction: column;
            border-radius: 20px;
            pointer-events: auto;
            overflow: hidden;
            transition: border-radius 160ms ease, background-color 160ms ease;
        }

        #forecast-panel-header {
            position: relative;
            color: var(--text-contrast);
            font-size: 12px;
            text-transform: uppercase;
            border-bottom: 1px solid var(--accent-blue);
            padding: 7px 12px;
            background: transparent;
            letter-spacing: 0.4px;
            display: flex;
            align-items: center;
            justify-content: space-between;
            gap: 8px;
            cursor: pointer;
            transition: padding 150ms ease, gap 150ms ease, border-color 150ms ease;
        }

        #forecast-panel-title {
            position: absolute;
            left: 50%;
            transform: translateX(-50%);
            display: inline-block;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
            text-align: center;
            width: max-content;
            max-width: calc(100% - 96px);
            pointer-events: none;
        }

        #forecast-panel-actions {
            display: flex;
            align-items: center;
            gap: 6px;
            flex: 0 0 auto;
            margin-left: 0;
            margin-right: auto;
        }

        #forecast-panel-handle-btn {
            font-size: 10px;
            padding: 5px 8px;
            line-height: 1.1;
            flex: 0 0 auto;
        }

        #forecast-panel-body {
            position: relative;
            flex: 1 1 auto;
            min-height: 0;
            overflow: hidden;
            display: flex;
            flex-direction: column;
            gap: 8px;
            padding: 8px;
            max-height: 2000px;
            opacity: 1;
            transition: opacity 140ms linear;
            will-change: opacity;
        }

        .weather-search-form {
            display: flex;
            align-items: center;
            justify-content: center;
            align-self: center;
            gap: 0;
            flex-wrap: nowrap;
            margin: 0;
        }

        #weather-search-input {
            min-width: 0;
            width: 153px;
            flex: 0 0 153px;
            max-width: 100%;
            margin-left: 0;
            border: 1px solid #F4C430;
            border-right: 1px solid #F4C430;
            border-radius: 999px 0 0 999px;
            background: rgba(0, 33, 71, 0.2);
            color: var(--text-contrast);
            padding: 6px 10px 7px;
            font: inherit;
            font-size: 11px;
            line-height: 1.2;
            outline: none;
        }

        #weather-search-input::placeholder {
            color: var(--text-muted);
        }

        #weather-search-input:focus {
            box-shadow: inset 0 0 0 1px #F4C430;
        }

        .weather-right-pill {
            display: inline-flex;
            align-items: center;
            border: 5px solid var(--accent-blue);
            border-radius: 0 999px 999px 0;
            overflow: hidden;
            flex: 0 0 auto;
            background: var(--accent-blue);
            padding: 0 2px 0 0;
            gap: 0;
        }

        #weather-search-btn {
            min-width: 86px;
            padding: 9px 10px;
            font-size: 10px;
            line-height: 1;
            background: #F4C430;
            border: 0;
            color: #002147;
            border-radius: 0;
            display: inline-flex;
            align-items: center;
            justify-content: center;
        }

        #weather-search-btn:hover,
        #weather-search-btn:active,
        #weather-search-btn.active,
        #weather-search-btn[aria-pressed="true"] {
            background: #F4C430;
            border-color: #F4C430;
            color: #002147;
            box-shadow: inset 0 0 0 1px #F4C430;
        }

        .weather-right-pill > * + * {
            border-left: 1px solid var(--accent-blue);
        }

        .weather-unit-btn {
            border: 0;
            background: #111111;
            color: #ffffff;
            min-width: 44px;
            padding: 9px 10px;
            font-family: inherit;
            font-size: 10px;
            font-weight: 800;
            line-height: 1.1;
            cursor: pointer;
            transition: 0.2s;
            display: inline-flex;
            align-items: center;
            justify-content: center;
            box-shadow: inset 0 0 0 1px #F4C430;
        }

        #weather-unit-c-btn {
            min-width: 48px;
            padding-right: 14px;
            border-top-right-radius: 999px;
            border-bottom-right-radius: 999px;
        }

        .weather-unit-btn:hover {
            box-shadow: inset 0 0 0 1px #F4C430;
        }

        .weather-unit-btn[aria-pressed="true"] {
            background: #111111;
            color: #ffffff;
        }

        #weather-unit-c-btn[aria-pressed="true"] {
            background: linear-gradient(180deg, rgba(47, 122, 246, 0.96), rgba(22, 74, 184, 0.96));
            color: #ffffff;
            box-shadow: inset 0 0 0 1px rgba(156, 206, 255, 0.38);
        }

        #weather-unit-f-btn[aria-pressed="true"] {
            background: linear-gradient(180deg, rgba(233, 66, 158, 0.96), rgba(181, 28, 133, 0.96));
            color: #ffffff;
            box-shadow: inset 0 0 0 1px rgba(255, 178, 232, 0.34);
        }

        .weather-unit-btn[aria-pressed="true"]:hover { box-shadow: none; }

        #weather-unit-c-btn[aria-pressed="true"]:hover,
        #weather-unit-f-btn[aria-pressed="true"]:hover {
            box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.14);
        }

        #forecast-panel.collapsed {
            bottom: auto;
            min-height: 0;
            height: auto;
            right: auto;
            width: var(--left-pill-width);
            min-width: var(--left-pill-width);
            max-width: calc(100vw - 40px);
            border-radius: 999px;
            overflow: hidden;
        }

        #forecast-panel.collapsed #forecast-panel-header {
            border-bottom: 0;
            border-radius: 999px;
            justify-content: space-between;
            gap: 8px;
            padding: 8px 12px;
        }

        #forecast-panel.collapsed #forecast-panel-body {
            display: none;
            max-height: 0;
            opacity: 0;
            pointer-events: none;
            padding-left: 0;
            padding-right: 0;
            padding-top: 0;
            padding-bottom: 0;
        }

        #category-panel.collapsed {
            bottom: auto;
            min-height: 0;
            height: auto;
            right: auto;
            width: var(--left-pill-width);
            min-width: var(--left-pill-width);
            max-width: calc(100vw - 40px);
            border-radius: 999px;
            overflow: hidden;
        }

        #category-panel.collapsed #category-panel-header {
            border-bottom: 0;
            border-radius: 999px;
            justify-content: space-between;
            gap: 8px;
            padding: 8px 12px;
        }

        #category-panel.collapsed #category-panel-body {
            display: none;
            max-height: 0;
            opacity: 0;
            pointer-events: none;
            padding-left: 0;
            padding-right: 0;
            padding-top: 0;
            padding-bottom: 0;
        }

        #breaking-news.collapsed {
            bottom: auto;
            min-height: 0;
            height: auto;
            max-height: none;
            width: var(--left-pill-width);
            min-width: var(--left-pill-width);
            max-width: calc(100vw - 40px);
            border-radius: 999px;
            border: 2px solid var(--accent-red);
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.2), 0 0 12px rgba(187, 19, 62, 0.28), 0 0 4px rgba(187, 19, 62, 0.52);
            overflow: visible;
        }

        #breaking-news.collapsed #breaking-news-header {
            border-bottom: 0;
            border-radius: 999px;
            justify-content: space-between;
            gap: 8px;
            padding: 8px 12px;
            font-size: 12px;
            letter-spacing: 0.4px;
        }

        #breaking-news.collapsed #breaking-news-header > span {
            font-size: 12px;
            text-transform: uppercase;
        }

        #breaking-news.collapsed #breaking-news-list {
            display: none;
            max-height: 0;
            opacity: 0;
            padding-left: 0;
            padding-right: 0;
            padding-top: 0;
            padding-bottom: 0;
            pointer-events: none;
        }

        #factcheck-service.collapsed {
            bottom: auto;
            min-height: 0;
            height: auto;
            max-height: none;
            width: var(--left-pill-width);
            min-width: var(--left-pill-width);
            max-width: calc(100vw - 40px);
            border-radius: 999px;
            border: 2px solid var(--accent-red);
            box-shadow: 0 0 0 1px rgba(187, 19, 62, 0.2), 0 0 12px rgba(187, 19, 62, 0.28), 0 0 4px rgba(187, 19, 62, 0.52);
            overflow: hidden;
        }

        #factcheck-service.collapsed #factcheck-service-header {
            border-bottom: 0;
            border-radius: 999px;
            justify-content: space-between;
            gap: 8px;
            padding: 8px 12px;
            font-size: 12px;
            letter-spacing: 0.4px;
        }

        #factcheck-service.collapsed #factcheck-topic-list,
        #factcheck-service.collapsed #factcheck-topic-detail,
        #factcheck-service.collapsed #adsense-preview-slot {
            display: none;
            max-height: 0;
            opacity: 0;
            pointer-events: none;
            padding-top: 0;
            padding-bottom: 0;
            border: 0;
        }

        #forecast-panel-list {
            position: relative;
            flex: 1 1 auto;
            min-height: 0;
            overflow-x: hidden;
            overflow-y: auto;
            padding: 2px;
            max-height: none;
            scrollbar-gutter: stable;
            scrollbar-width: auto;
            scrollbar-color: #F4C430 rgba(0, 33, 71, 0.35);
        }

        #forecast-panel-list::-webkit-scrollbar {
            width: 10px;
        }

        #forecast-panel-list::-webkit-scrollbar-track {
            background: rgba(0, 33, 71, 0.35);
        }

        #forecast-panel-list::-webkit-scrollbar-thumb {
            background: #F4C430;
            border-radius: 999px;
        }

        #forecast-adsense-slot {
            flex: 0 0 auto;
            padding: 8px;
            border: 1px dashed rgba(244, 196, 48, 0.5);
            border-radius: 14px;
            background: rgba(0, 33, 71, 0.24);
        }

        #forecast-adsense-slot .adsense-preview-label {
            margin-bottom: 5px;
        }

        #forecast-adsense-slot .adsense-preview-box {
            min-height: 58px;
        }

        #left-stack {
            position: absolute;
            left: 20px;
            top: var(--gaia-top-panel-top, 20px);
            bottom: var(--side-panel-bottom-gap);
            width: var(--gaia-side-panel-width, clamp(320px, 42vw, 500px));
            display: flex;
            flex-direction: column;
            gap: var(--gaia-ui-gap, 10px);
            z-index: 108;
            pointer-events: none;
        }

        #left-stack > #category-panel,
        #left-stack > #breaking-news,
        #left-stack > #forecast-panel {
            position: relative;
            left: auto;
            right: auto;
            top: auto;
            bottom: auto;
            width: 100%;
            min-width: 0;
            max-width: none;
            height: auto;
            max-height: none;
            margin: 0;
            pointer-events: auto;
            flex: 0 0 auto;
        }

        #left-stack > #category-panel {
            flex: 0 0 auto;
        }

        #left-stack > #breaking-news:not(.collapsed),
        #left-stack > #forecast-panel:not(.collapsed) {
            flex: 1 1 0;
            min-height: 0;
            align-self: stretch;
        }

        #left-stack > #category-panel:not(.collapsed) {
            align-self: stretch;
        }

        #left-stack > #category-panel.collapsed,
        #left-stack > #breaking-news.collapsed,
        #left-stack > #forecast-panel.collapsed {
            width: var(--left-pill-width);
            min-width: var(--left-pill-width);
            max-width: calc(100vw - 40px);
            align-self: flex-start;
        }

        @media (max-width: 900px) {
            #left-stack {
                left: 10px;
                right: 10px;
                width: auto;
            }

            #left-stack > #category-panel.collapsed,
            #left-stack > #breaking-news.collapsed,
            #left-stack > #forecast-panel.collapsed {
                max-width: calc(100vw - 20px);
            }
        }

        .weather-feed-note {
            color: var(--text-muted);
            font-size: 11px;
            line-height: 1.4;
            margin: 4px 0 8px;
        }

        .weather-feed-error {
            color: #ffffff;
            border: 1px solid var(--accent-blue);
            background: rgba(187, 19, 62, 0.9);
            padding: 8px 10px;
            font-size: 11px;
            line-height: 1.35;
        }

        .weather-result-card {
            border: 1px solid var(--accent-blue);
            background: rgba(0, 33, 71, 0.24);
            padding: 8px;
        }

        .weather-result-header {
            display: flex;
            align-items: baseline;
            justify-content: space-between;
            gap: 8px;
            margin-bottom: 6px;
        }

        .weather-location {
            color: var(--text-contrast);
            font-size: 12px;
            font-weight: 700;
            line-height: 1.3;
        }

        .weather-updated {
            color: var(--text-muted);
            font-size: 10px;
            text-transform: uppercase;
        }

        .weather-kpis {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 5px;
        }

        .weather-kpis + .weather-kpis {
            margin-top: 6px;
        }

        .weather-kpi {
            border: 1px solid rgba(244, 196, 48, 0.38);
            background: rgba(0, 33, 71, 0.3);
            padding: 5px 6px;
            text-align: center;
            min-height: 0;
            border-radius: 8px;
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.08);
        }

        .weather-kpi-label {
            color: var(--text-muted);
            font-size: 8px;
            line-height: 1.2;
            text-transform: uppercase;
            margin-bottom: 3px;
        }

        .weather-kpi-value {
            color: var(--text-contrast);
            font-size: 11px;
            font-weight: 700;
            line-height: 1.2;
            word-break: break-word;
        }

        .weather-summary {
            margin-top: 7px;
            border-top: 1px solid rgba(198, 204, 208, 0.2);
            padding-top: 7px;
            color: var(--text-contrast);
            font-size: 10px;
            line-height: 1.35;
            text-align: center;
        }

        .weather-weekly {
            margin-top: 10px;
            border-top: 1px solid rgba(198, 204, 208, 0.2);
            padding-top: 8px;
        }

        .weather-weekly-title {
            color: var(--text-muted);
            font-size: 10px;
            text-transform: uppercase;
            margin-bottom: 8px;
            text-align: center;
        }

        .weather-weekly-list {
            --forecast-gap: 6px;
            display: flex;
            flex-wrap: wrap;
            gap: var(--forecast-gap);
            overflow: visible;
            padding-bottom: 2px;
            padding-right: 0;
            align-items: stretch;
            justify-content: center;
            scrollbar-gutter: auto;
            -webkit-overflow-scrolling: touch;
        }

        .weather-weekly-list .weather-day + .weather-day::before {
            display: none;
        }

        .weather-weekly-list::-webkit-scrollbar {
            height: 8px;
        }

        .weather-weekly-list::-webkit-scrollbar-track {
            background: rgba(0, 33, 71, 0.35);
        }

        .weather-weekly-list::-webkit-scrollbar-thumb {
            background: #F4C430;
        }

        .weather-day {
            position: relative;
            border: 1px solid var(--accent-blue);
            background: rgba(0, 33, 71, 0.3);
            padding: 2px;
            flex: 0 0 80px;
            min-width: 80px;
            min-height: 88px;
            display: flex;
            flex-direction: column;
            align-items: center;
            text-align: center;
            appearance: none;
            cursor: pointer;
            font: inherit;
            color: inherit;
            transition: transform 0.16s ease, border-color 0.16s ease, background 0.16s ease, box-shadow 0.16s ease;
        }

        .weather-day:hover {
            border-color: #F4C430;
            transform: translateY(-1px);
        }

        .weather-day:focus-visible {
            outline: 2px solid #F4C430;
            outline-offset: 2px;
            border-color: #F4C430;
        }

        .weather-day.is-selected {
            border-color: #F4C430;
            background: rgba(244, 196, 48, 0.12);
            box-shadow: 0 0 0 1px rgba(244, 196, 48, 0.35);
        }

        .weather-day + .weather-day::before {
            content: '';
            position: absolute;
            top: 8px;
            bottom: 8px;
            left: calc((var(--forecast-gap) * -1) / 2);
            width: 1px;
            background: #F4C430;
            pointer-events: none;
        }

        .weather-day-head {
            display: flex;
            flex-direction: column;
            align-items: center;
            justify-content: flex-start;
            gap: 2px;
            margin-bottom: 2px;
            width: 100%;
        }

        .weather-day-icon {
            color: #F4C430;
            font-size: 12px;
            line-height: 1;
            display: inline-block;
        }

        .weather-day-name {
            color: var(--text-contrast);
            font-size: 9px;
            font-weight: 700;
        }

        .weather-day-range {
            color: var(--text-contrast);
            font-size: 9px;
            margin-bottom: 2px;
            width: 100%;
        }

        .weather-day-meta {
            color: var(--text-muted);
            font-size: 8px;
            line-height: 1.25;
            width: 100%;
        }

        .weather-day-detail {
            margin-top: 10px;
            border-top: 1px solid rgba(198, 204, 208, 0.2);
            padding-top: 10px;
        }

        .weather-day-detail-head {
            display: flex;
            align-items: baseline;
            justify-content: space-between;
            gap: 8px;
            margin-bottom: 8px;
            flex-wrap: wrap;
        }

        .weather-day-detail-title {
            color: var(--text-contrast);
            font-size: 12px;
            font-weight: 700;
        }

        .weather-day-detail-subtitle {
            color: var(--text-muted);
            font-size: 10px;
            text-transform: uppercase;
        }

        .weather-detail-section + .weather-detail-section {
            margin-top: 10px;
        }

        .weather-detail-section-title {
            color: var(--text-muted);
            font-size: 10px;
            text-transform: uppercase;
            margin-bottom: 6px;
        }

        .weather-detail-kpis {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 6px;
        }

        .weather-detail-kpi {
            border: 1px solid rgba(198, 204, 208, 0.2);
            background: rgba(0, 33, 71, 0.22);
            padding: 6px;
        }

        .weather-detail-label {
            color: var(--text-muted);
            font-size: 9px;
            text-transform: uppercase;
            margin-bottom: 2px;
        }

        .weather-detail-value {
            color: var(--text-contrast);
            font-size: 12px;
            font-weight: 700;
        }

        .weather-detail-note {
            color: var(--text-muted);
            font-size: 8px;
            line-height: 1.35;
            margin-top: 4px;
        }

        .weather-kpi.weather-kpi-secondary {
            background: rgba(0, 33, 71, 0.22);
            border-color: rgba(244, 196, 48, 0.38);
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.08);
        }

        .weather-kpis.weather-kpis-solar {
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 6px;
            padding-top: 2px;
        }

        .weather-kpi.weather-kpi-solar {
            background: rgba(244, 196, 48, 0.08);
            border-color: rgba(244, 196, 48, 0.38);
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.08);
        }

        .weather-kpi.weather-kpi-solar.weather-kpi-sunrise {
            background: linear-gradient(180deg, rgba(255, 182, 54, 0.28), rgba(244, 196, 48, 0.14));
            border-color: rgba(255, 187, 64, 0.62);
            box-shadow: inset 0 0 0 1px rgba(255, 200, 84, 0.14);
        }

        .weather-kpi.weather-kpi-solar.weather-kpi-sunset {
            background: linear-gradient(180deg, rgba(78, 76, 184, 0.28), rgba(122, 64, 184, 0.14));
            border-color: rgba(126, 102, 226, 0.54);
            box-shadow: inset 0 0 0 1px rgba(124, 90, 214, 0.14);
        }

        .weather-hourly-title {
            color: var(--text-muted);
            font-size: 10px;
            text-transform: uppercase;
            margin-top: 10px;
            margin-bottom: 6px;
        }

        .weather-hourly-summary {
            margin-bottom: 6px;
        }

        .weather-hourly-summary .weather-detail-kpi {
            max-width: 170px;
            padding: 5px 6px;
        }

        .weather-hourly-list {
            display: flex;
            gap: 6px;
            overflow-x: scroll;
            overflow-y: hidden;
            padding-bottom: 4px;
            scrollbar-gutter: stable;
            scrollbar-width: auto;
            scrollbar-color: #F4C430 rgba(0, 33, 71, 0.35);
            -webkit-overflow-scrolling: touch;
        }

        .weather-hourly-list::-webkit-scrollbar {
            height: 10px;
        }

        .weather-hourly-list::-webkit-scrollbar-track {
            background: rgba(0, 33, 71, 0.35);
        }

        .weather-hourly-list::-webkit-scrollbar-thumb {
            background: #F4C430;
            border-radius: 999px;
        }

        .weather-hourly-item {
            flex: 0 0 220px;
            border: 1px solid rgba(198, 204, 208, 0.2);
            background: rgba(0, 33, 71, 0.22);
            padding: 7px;
        }

        .weather-hourly-item.is-current {
            border-color: rgba(244, 196, 48, 0.72);
            background: linear-gradient(180deg, rgba(244, 196, 48, 0.22), rgba(244, 196, 48, 0.12));
            box-shadow: inset 0 0 0 1px rgba(244, 196, 48, 0.18);
        }

        .weather-hourly-time {
            color: #F4C430;
            font-size: 10px;
            font-weight: 700;
            margin-bottom: 4px;
        }

        .weather-hourly-condition {
            color: var(--text-contrast);
            font-size: 9px;
            line-height: 1.3;
            min-height: 24px;
        }

        .weather-hourly-temp {
            color: var(--text-contrast);
            font-size: 11px;
            font-weight: 700;
            margin-top: 4px;
        }

        .weather-hourly-temp span {
            color: var(--text-muted);
            font-size: 9px;
            font-weight: 400;
        }

        .weather-hourly-grid {
            display: grid;
            grid-template-columns: repeat(2, minmax(0, 1fr));
            gap: 5px;
            margin-top: 6px;
        }

        .weather-hourly-stat {
            border: 1px solid rgba(198, 204, 208, 0.14);
            background: rgba(0, 33, 71, 0.18);
            padding: 4px;
            min-height: 38px;
        }

        .weather-hourly-stat span {
            display: block;
            color: var(--text-muted);
            font-size: 7px;
            line-height: 1.2;
            text-transform: uppercase;
            margin-bottom: 2px;
        }

        .weather-hourly-stat strong {
            display: block;
            color: var(--text-contrast);
            font-size: 9px;
            line-height: 1.25;
            font-weight: 700;
            word-break: break-word;
        }

        .weather-hourly-meta {
            color: var(--text-muted);
            font-size: 8px;
            line-height: 1.35;
            margin-top: 5px;
        }


        @media (max-width: 640px) {
            .weather-search-form {
                align-items: stretch;
                flex-wrap: wrap;
                gap: 8px;
                align-self: stretch;
            }

            #weather-search-input,
            .weather-right-pill {
                width: 100%;
            }

            #weather-search-input {
                flex: 1 1 100%;
                border-right: 1px solid #F4C430;
                border-radius: 999px;
            }

            .weather-right-pill {
                border-radius: 999px;
            }

            .weather-unit-btn {
                flex: 1 1 50%;
            }

            .weather-kpis {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }

            .weather-kpis.weather-kpis-solar {
                grid-template-columns: repeat(2, minmax(0, 1fr));
            }

            .weather-detail-kpis {
                grid-template-columns: 1fr;
            }

            .weather-hourly-item {
                flex-basis: 236px;
            }
        }

        @media (max-width: 900px) {
            body {
                --gaia-top-panel-top: 14px;
                --gaia-breaking-ticker-height: 28px;
                --gaia-market-ticker-height: 28px;
                --gaia-ui-gap: 8px;
                --gaia-factcheck-bottom-reserve: 118px;
            }

            #market-ticker-shell {
                top: 0;
                width: min(65vw, calc(100vw - 20px));
                max-width: calc(100vw - 20px);
                height: var(--gaia-market-ticker-height, 28px);
                border-radius: 0 0 14px 14px;
            }

            #market-watchlist-menu {
                top: calc(100% + 8px);
                width: calc(100vw - 20px);
                max-width: calc(100vw - 20px);
                padding: 10px;
            }

            #market-watchlist-title {
                margin-bottom: 3px;
                font-size: 10px;
            }

            #market-watchlist-note {
                margin-bottom: 8px;
                font-size: 7px;
            }

            #market-watchlist-options {
                gap: 10px;
            }

            .market-watchlist-section {
                gap: 7px;
            }

            .market-watchlist-section-title {
                font-size: 8px;
            }

            .market-watchlist-section-groups {
                grid-template-columns: repeat(auto-fit, minmax(86px, 1fr));
                gap: 8px 6px;
            }

            .market-watchlist-group {
                gap: 5px;
            }

            .market-watchlist-group-title {
                padding: 0 2px;
                font-size: 7px;
            }

            .market-watchlist-option {
                width: 86px;
                min-width: 86px;
                max-width: 86px;
                min-height: 0;
                padding: 4px 10px;
                font-size: 7.4px;
            }

            #trending-topics-shell {
                top: calc(var(--gaia-market-ticker-height, 28px) + 12px);
                width: calc(100vw - 20px);
                max-width: calc(100vw - 20px);
                padding: 4px 0;
                border: 0;
                border-radius: 999px;
                background: transparent;
                box-shadow: none;
            }

            #trending-topics-list {
                display: flex;
                flex-wrap: nowrap;
                gap: 6px;
                justify-content: flex-start;
                overflow-x: auto;
                overflow-y: hidden;
                -webkit-overflow-scrolling: touch;
                padding-bottom: 0;
            }

            .trending-topic-note {
                min-width: max-content;
                font-size: 9px;
                justify-content: flex-start;
            }

            .trending-topic-btn {
                flex: 0 0 auto;
                min-height: 29px;
                min-width: 86px;
                padding: 6px 10px;
                font-size: 7.4px;
            }

            #news-keyword-search-shell {
                top: 82px;
                width: calc(100vw - 20px);
            }

            #breaking-ticker-shell {
                width: min(65vw, calc(100vw - 20px));
                max-width: calc(100vw - 20px);
                border-radius: 14px 14px 0 0;
            }

            #breaking-ticker-track {
                gap: 28px;
                padding: 0 14px;
            }

            #market-ticker-track {
                gap: 28px;
                padding: 0 14px;
            }

            .market-ticker-segment {
                gap: 24px;
            }

            .market-ticker-item {
                font-size: 11px;
                gap: 6px;
            }

            .market-ticker-symbol,
            .market-ticker-change,
            .market-ticker-label {
                font-size: 9px;
            }

            #top-panel {
                left: 50%;
                right: auto;
                transform: translate(-50%, 0);
                width: max-content;
                max-width: 96vw;
                top: 14px;
                padding: 0;
                gap: 6px;
            }

            #top-panel-toolbar {
                gap: 6px;
                max-width: calc(100vw - 24px);
            }

            #top-panel-logo-slot {
                width: min(72vw, 450px);
                min-width: min(72vw, 450px);
                padding: 7px 12px;
            }

            #top-panel-logo {
                width: min(450px, 100%);
                max-height: 84px;
            }

            #map-style-bar {
                max-width: calc(100vw - 24px);
            }

            .map-style-btn {
                min-height: 32px;
                padding: 7px 10px;
                font-size: 9px;
            }

            #news-categories {
                width: max-content;
                max-width: calc(100vw - 24px);
                justify-content: flex-start;
                flex-wrap: nowrap;
                overflow-x: auto;
                -webkit-overflow-scrolling: touch;
                padding-bottom: 0;
            }

            .category-btn {
                min-height: 24px;
                font-size: 6.2px;
                padding: 5px 8px;
            }

            .top-menu-tab {
                flex: 1 1 calc(50% - 6px);
                text-align: center;
            }

            #category-panel {
                left: 10px;
                right: 10px;
                top: var(--gaia-top-panel-top, 14px);
                width: auto;
                bottom: auto;
                height: auto;
                max-height: calc(100vh - var(--gaia-top-panel-top, 14px) - var(--side-panel-bottom-gap));
            }

            #category-panel.collapsed {
                right: auto;
                max-width: calc(100vw - 20px);
            }

            #forecast-panel {
                left: 10px;
                right: 10px;
                top: calc(var(--gaia-top-panel-top, 14px) + 168px);
                width: auto;
                bottom: auto;
                height: auto;
                max-height: calc(100vh - (var(--gaia-top-panel-top, 14px) + 168px) - var(--side-panel-bottom-gap));
            }

            #forecast-panel.collapsed {
                right: auto;
                max-width: calc(100vw - 20px);
            }

            #breaking-news {
                left: 10px;
                right: auto;
                top: calc(var(--gaia-top-panel-top, 14px) + 84px);
                width: min(300px, 44vw);
                bottom: auto;
                height: min(58vh, 520px);
                max-height: calc(100vh - (var(--gaia-top-panel-top, 14px) + 84px) - var(--side-panel-bottom-gap));
            }

            #factcheck-service {
                right: 10px;
                left: auto;
                top: var(--gaia-top-panel-top, 14px);
                width: min(300px, 44vw);
                bottom: calc(var(--side-panel-bottom-gap) + var(--gaia-factcheck-bottom-reserve, 118px));
                height: auto;
                max-height: none;
            }

            #factcheck-topic-list {
                max-height: var(--gaia-factcheck-topic-list-height, 104px);
            }

            #breaking-news.collapsed {
                max-width: calc(100vw - 20px);
            }

            #weather-options-pill.open {
                max-width: min(78vw, 560px);
            }
        }

        .marker { background: var(--accent-blue); width: 10px; height: 10px; border-radius: 50%; border: 1px solid var(--text-contrast); cursor: pointer; transition: 0.3s; }
        .marker:hover { transform: scale(1.5); background: var(--accent-red); }

        .maplibregl-popup-content { background: var(--ui-main) !important; color: var(--text-contrast) !important; border: 1px solid var(--accent-blue); font-family: inherit; font-size: 11px; padding: 0 !important; overflow: hidden; }
        .maplibregl-popup-tip { border-top-color: var(--ui-main) !important; }
        .maplibregl-popup-content a { color: var(--text-contrast); text-decoration: none; border-bottom: 1px dashed var(--accent-red); font-weight: 700; }
        .maplibregl-popup-content a:hover { border-bottom-style: solid; }
        .maplibregl-popup-close-button { color: var(--accent-red) !important; font-weight: 700; }
        .maplibregl-popup-close-button:hover { color: #ffffff !important; background: rgba(187, 19, 62, 0.18); }
        .news-popup-card {
            border: 0;
            border-radius: 0;
            background: transparent;
            padding: 0;
            min-width: 210px;
            max-width: min(55vw, 300px);
        }
        .news-popup-breaking {
            margin: 0;
            border: 1px solid rgba(198, 204, 208, 0.35);
            border-top-width: 2px;
            padding: 8px;
            cursor: default;
        }
        .news-popup-breaking .breaking-title {
            font-size: 14px;
            line-height: 1.18;
        }
        .news-popup-breaking .breaking-summary {
            font-size: 10px;
            line-height: 1.3;
            margin-bottom: 6px;
        }
        .news-popup-breaking .breaking-meta {
            font-size: 8px;
            margin-bottom: 5px;
        }
        .news-popup-breaking .breaking-thumb {
            max-height: 120px;
            min-height: 68px;
            margin-bottom: 6px;
        }
        .news-popup-breaking .breaking-thumb-placeholder {
            height: 78px;
            margin-bottom: 6px;
            font-size: 9px;
        }
        .news-popup-description {
            margin: 0 0 8px;
            line-height: 1.28;
            max-height: 32em; /* 25 lines at ~1.28 line-height */
            overflow-y: auto;
            overflow-x: hidden;
            word-break: break-word;
            white-space: normal;
            padding-right: 4px;
        }
        .news-popup-description::-webkit-scrollbar {
            width: 6px;
        }
        .news-popup-description::-webkit-scrollbar-track {
            background: rgba(0, 33, 71, 0.35);
            border-radius: 999px;
        }
        .news-popup-description::-webkit-scrollbar-thumb {
            background: #F4C430;
            border-radius: 999px;
        }
