.material-symbols-rounded { font-display: block; }
    html.fonts-loading .material-symbols-rounded {
      visibility: hidden;
      width: 24px;
      display: inline-block;
    }

:root {
      --ms-blue: #f97316;
      --ms-blue-light: rgba(249,115,22,0.12);
      --bg-app: #f8fafc;
      --bg-surface: #ffffff;
      --bg-glass: rgba(255,255,255,0.92);
      --text-main: #1e293b;
      --text-mute: #64748b;
      --border: #e2e8f0;
      --shadow-sm: 0 1px 4px rgba(0,0,0,0.08);
      --shadow-md: 0 4px 16px rgba(0,0,0,0.1);
      --radius-sm: 8px;
      --radius-lg: 16px;
      --radius-pill: 99px;
      --charcoal: #3a3a3a;
      --charcoal-dark: #2a2a2a;
    }

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

    body, html {
      height: 100%; width: 100vw; max-width: 100%;
      font-family: 'Inter', system-ui, sans-serif;
      background-color: var(--bg-app); color: var(--text-main);
      overflow-x: hidden; -webkit-font-smoothing: antialiased;
    }

    /* Base Utilities */
    .text-mute { color: var(--text-mute); }
    .text-warning { color: #D13438; }
    .badge { background: #D13438; color: white; font-size: 0.7rem; font-weight: 700; padding: 2px 8px; border-radius: 99px; margin-left: auto; }
    .badge-subtle { background: rgba(249,115,22,0.15); color: #f97316; padding: 4px 10px; border-radius: var(--radius-pill); font-size: 0.75rem; font-weight: 600; }

    .brand { display: flex; align-items: center; gap: 8px; }
    .brand-icon { background: var(--ms-blue); border-radius: 8px; width: 36px; height: 36px; display: flex; align-items: center; justify-content: center; position: relative; overflow: visible; }
    .brand-icon::before { content: ''; position: absolute; inset: 0; border-radius: 8px; box-shadow: 0 0 0 0 rgba(249,115,22,0.6); animation: brand-pulse 2.5s ease-in-out infinite; }
    @keyframes brand-pulse { 0% { box-shadow: 0 0 0 0 rgba(249,115,22,0.6); } 70% { box-shadow: 0 0 0 8px rgba(249,115,22,0); } 100% { box-shadow: 0 0 0 0 rgba(249,115,22,0); } }
    .brand-text { font-size: 1.25rem; font-weight: 800; letter-spacing: -0.04em; color: #1e293b; }

    .search-pill { display: flex; align-items: center; gap: 8px; background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.1); border-radius: var(--radius-pill); padding: 8px 14px; transition: 0.2s; min-width: 0; }
    .search-pill input { border: none; background: transparent; width: 100%; outline: none; font-family: inherit; font-size: 0.9rem; font-weight: 500; min-width: 0; color: #fff; }

    /* Layout Containers */
    .desktop-sidebar { display: none; }
    .mobile-header { 
      display: flex; flex-direction: row; align-items: center; justify-content: space-between; gap: 12px; 
      background: #3a3a3a; border-bottom: 1px solid #2a2a2a;
      padding: 10px 16px; position: fixed; top: 0; left: 0; width: 100%; z-index: 50; height: 64px;
    }
    .mobile-header .search-pill { padding: 8px 12px; flex: 1; background:rgba(255,255,255,0.1); border:1px solid rgba(255,255,255,0.15); border-radius:var(--radius-pill); }
    .mobile-header .search-pill input { color:#ffffff; }
    .mobile-header .search-pill .material-symbols-rounded { color:rgba(255,255,255,0.5); }

    .app-layout { 
      display: flex; height: 100dvh; padding-top: 64px; 
      padding-bottom: calc(62px + env(safe-area-inset-bottom)); 
      width: 100%; max-width: 100%; 
    }

    .main-content { flex: 1; display: flex; flex-direction: column; position: relative; padding: 0; min-width: 0; width: 100%; height: 100%; }

    .global-title-bar { background-color: #3a3a3a; border-bottom: 1px solid #2a2a2a; color: rgba(255,255,255,0.65); padding: 6px 20px; font-size: 0.75rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase; z-index: 40; flex-shrink: 0; }

    .page-view { display: none; flex: 1; overflow-y: auto; overflow-x: hidden; padding: 20px; animation: fadeUp 0.3s ease; overscroll-behavior: contain; }
    .page-view.active { display: block; }
    .page-view.flush-view.active { display: flex; overflow: hidden; overscroll-behavior: none; touch-action: none; }
    .flush-view { padding: 0 !important; margin: 0; height: 100%; width: 100%; overflow: hidden; position: relative; touch-action: none; }
    .flush-view iframe { width: 100%; height: 100%; border: none; display: block; touch-action: none; }
    #view-radar { -webkit-overflow-scrolling: auto; }
    #view-outlooks.active { display: flex; }
    #view-meso.active { display: flex; }
    .meso-badge { display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:0.68rem;font-weight:700; }
    .meso-badge-concern { background:rgba(249,115,22,0.15);color:#f97316;border:1px solid rgba(249,115,22,0.35); }
    .meso-badge-area { background:rgba(255,255,255,0.07);color:rgba(255,255,255,0.6);border:1px solid rgba(255,255,255,0.12); }
    .meso-badge-expire { background:rgba(245,158,11,0.12);color:#fbbf24;border:1px solid rgba(245,158,11,0.3); }
    .meso-badge .material-symbols-rounded { font-size:12px; }
    .meso-sum-section { margin-bottom:14px; }
    .meso-sum-label { font-size:0.6rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:#f97316;margin-bottom:5px;display:flex;align-items:center;gap:5px; }
    .meso-sum-label .material-symbols-rounded { font-size:13px; }
    .meso-sum-text { font-size:0.84rem;line-height:1.7;color:rgba(255,255,255,0.75); }
    .meso-err { font-size:0.8rem;color:#f87171;padding:8px 0; }

    /* Widgets & Grid */
    .home-two-column { display: flex; flex-direction: column; gap: 20px; width: 100%; }
    .column-left, .column-right { display: flex; flex-direction: column; gap: 20px; width: 100%; }

    .widget { background: var(--bg-surface); border-radius: var(--radius-lg); box-shadow: var(--shadow-sm); padding: 20px; border: 1px solid var(--border); width: 100%; }
    .widget-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; }
    .widget-header h3 { font-size: 1.1rem; font-weight: 600; }

    .current-compact { display: flex; flex-direction: column; background: #3a3a3a; color: white; padding: 20px; gap: 0; }
    .current-main { display: flex; align-items: center; gap: 16px; margin: 16px 0 18px; }
    .current-icon { font-size: 56px; }
    .temp-large { font-size: 3rem; font-weight: 300; line-height: 1; }
    .temp-desc { font-size: 1rem; opacity: 0.9; font-weight: 600; margin-top: 4px; }
    .current-stats { display: flex; justify-content: space-between; border-top: 1px solid rgba(255,255,255,0.2); padding-top: 14px; font-size: 0.82rem; opacity: 0.9; }

    .alert-widget { border-left: 4px solid #f97316; }
    .alert-item { background: var(--bg-app); padding: 12px 16px; border-radius: var(--radius-sm); font-size: 0.9rem; border: 1px solid var(--border); margin-bottom: 8px; }
    .alert-severe { border-color: rgba(249,115,22,0.3); background: rgba(249,115,22,0.07); }

    .radar-widget-mini { padding: 0; overflow: hidden; display: flex; flex-direction: column; border: 1px solid var(--border); }
    .radar-widget-mini .widget-header { padding: 10px 14px; margin-bottom: 0; }
    .iframe-container { width: 100%; height: 250px; position: relative; margin-top: 0; }
    .iframe-container iframe { width: 100%; height: 100%; border: none; }

    .forecast-widget { display: flex; flex-direction: column; height: 100%; border: 1px solid var(--border); background: var(--bg-surface); border-radius: var(--radius-lg); }
    .forecast-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:8px; }
    .forecast-header h3 { font-size:0.6rem; font-weight:800; text-transform:uppercase; letter-spacing:0.12em; color:var(--text-mute); margin:0; }
    .segmented-control { display:flex; background:var(--bg-app); border-radius:var(--radius-pill); padding:3px; border:1px solid var(--border); }
    .segment { background:transparent; border:none; padding:4px 12px; border-radius:var(--radius-pill); font-size:0.72rem; font-weight:700; color:var(--text-mute); cursor:pointer; transition:all .15s; white-space:nowrap; }
    .segment.active { background:#f97316; color:#fff; box-shadow:0 1px 4px rgba(249,115,22,0.3); }
    .forecast-list { display: none; flex-direction: column; gap: 8px; margin-top: 20px; }
    .forecast-list.active { display: flex; }
    .forecast-row { display: flex; justify-content: space-between; align-items: center; padding: 16px; background: var(--bg-app); border-radius: var(--radius-sm); border: 1px solid var(--border); }

    /* Nav Bars */
    .mobile-bottom-nav { display: flex; justify-content: space-around; align-items: center; background: #3a3a3a; border-top: 1px solid #2a2a2a; position: fixed; bottom: 0; left: 0; width: 100%; padding: 8px 16px calc(10px + env(safe-area-inset-bottom)) 16px; z-index: 50; }
    .mobile-tab { display: flex; flex-direction: column; align-items: center; gap: 2px; font-size: 0.7rem; font-weight: 600; color: rgba(255,255,255,0.5); cursor: pointer; }
    .mobile-tab.active { color: #f97316; }
    .mobile-tab .material-symbols-rounded { font-size: 24px; }
    .icon-badge-wrap { position: relative; display: flex; align-items: center; justify-content: center; }
    .mini-badge { display: none; position: absolute; top: -2px; right: -4px; width: 10px; height: 10px; background: #D13438; border: 2px solid #3a3a3a; border-radius: 50%; }

    .mobile-severe-menu { display: none; position: fixed; bottom: 0; left: 0; width: 100%; background: #3a3a3a; border-radius: 24px 24px 0 0; padding: 24px 24px calc(40px + env(safe-area-inset-bottom)) 24px; box-shadow: 0 -8px 40px rgba(0,0,0,0.4); z-index: 600; border-top: 1px solid #2a2a2a; }
    .mobile-severe-menu.open { display: block; }
    .sheet-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 20px; }
    .sheet-header h3 { color: #ffffff; font-size: 1.1rem; font-weight: 800; letter-spacing: -0.02em; }
    .sheet-close-btn { background: rgba(255,255,255,0.1); border: none; width: 32px; height: 32px; border-radius: 50%; display: flex; align-items: center; justify-content: center; cursor: pointer; color: rgba(255,255,255,0.7); }
    .sheet-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
    .sheet-list-item { display:flex;align-items:center;gap:14px;padding:14px 16px;background:rgba(255,255,255,0.08);border:1px solid rgba(255,255,255,0.12);border-radius:12px;cursor:pointer;color:#ffffff;font-size:0.9rem;font-weight:600;transition:background .15s;-webkit-tap-highlight-color:transparent; }
    .sheet-list-item:active { background:rgba(255,255,255,0.15); }
    .sheet-list-icon { font-size:20px;color:rgba(255,255,255,0.6);flex-shrink:0; }
    .sheet-icon { width: 32px; height: 32px; border-radius: 8px; background: rgba(249,115,22,0.15); display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
    .sheet-icon .material-symbols-rounded { font-size: 18px; color: #f97316; }
    .menu-overlay { display: none; position: fixed; inset: 0; z-index: 599; background: rgba(0,0,0,0.3); }
    .menu-overlay.open { display: block; }

    @media (min-width: 1024px) {
      .mobile-header, .mobile-bottom-nav { display: none !important; }
      #app-chip, #pwa-banner { display: none !important; }
      .app-layout { padding-top: 0; padding-bottom: 0; height: 100vh; }
      .desktop-sidebar { display: flex; flex-direction: column; width: 280px; background: #ffffff; border-right: 1px solid #e2e8f0; padding: 0; justify-content: flex-start; color: #ffffff; }
      .desktop-sidebar button { color: #ffffff !important; }
      .desktop-sidebar button:not(.nav-item.active) { color: rgba(255,255,255,0.85) !important; }
      .desktop-sidebar p { color: rgba(255,255,255,0.6) !important; }
      .nav-item { display: flex; align-items: center; gap: 12px; padding: 10px 12px; border-radius: var(--radius-sm); font-size: 0.9rem; font-weight: 600; cursor: pointer; background: transparent; border: none; width: 100%; text-align: left; font-family: inherit; color: #ffffff !important; }
      .nav-item .material-symbols-rounded { color: rgba(255,255,255,0.7) !important; }
      .nav-item:hover { background: rgba(255,255,255,0.1); color: #ffffff !important; }
      .nav-item:hover .material-symbols-rounded { color: #ffffff !important; }
      .nav-item.active { background: #f97316; color: #ffffff; }
      .nav-item.active .material-symbols-rounded { color: #ffffff; }
      .nav-label { font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; color: rgba(255,255,255,0.6) !important; margin: 16px 0 8px 12px; }
      .global-title-bar { padding: 8px 48px; font-size: 0.8rem; }
      .page-view { padding: 32px 48px; }
      .page-view.flush-view { padding: 0 !important; }
      .home-two-column { display: grid; grid-template-columns: 400px 1fr; gap: 28px; align-items: start; }
      .forecast-row-jw { display:grid; grid-template-columns: 64px 28px 1fr auto; align-items:center; gap:0 10px; padding:10px 0; border-bottom:1px solid var(--border); font-size:0.85rem; }
      .forecast-row-jw:last-child { border-bottom:none; }
      .forecast-row-jw .fr-day  { font-weight:600; color:var(--text-main); }
      .forecast-row-jw .fr-desc { color:var(--text-mute); font-size:0.78rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
      .forecast-row-jw .fr-temp { font-weight:700; color:var(--text-main); text-align:right; }
      .fr-detail-stat { display:flex;align-items:center;gap:4px;font-size:0.75rem;color:var(--text-mute);font-weight:600; }
      .forecast-row-jw:hover { background:var(--bg-app); border-radius:8px; }
      .hr-row-jw { display:grid; grid-template-columns: 48px 24px 1fr 36px 36px; align-items:center; gap:0 10px; padding:8px 0; border-bottom:1px solid var(--border); font-size:0.82rem; }
      .hr-row-jw:last-child { border-bottom:none; }
      .hr-row-jw .hr-time  { font-weight:600; color:var(--text-mute); font-size:0.75rem; }
      .hr-row-jw .hr-desc  { color:var(--text-mute); font-size:0.75rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
      .hr-row-jw .hr-precip{ font-size:0.7rem; color:#60a5fa; text-align:right; }
      .hr-row-jw .hr-temp  { font-weight:700; color:var(--text-main); text-align:right; }
    }

    .desktop-sidebar input::placeholder { color: rgba(255,255,255,0.35); }
    #search-input-mobile::placeholder { color: rgba(255,255,255,0.35); }
    .mobile-header .brand-text { color: #ffffff; }
    .sug-item { display:flex;align-items:center;gap:8px;padding:10px 14px;font-size:0.85rem;cursor:pointer;transition:background .1s; }
    .sug-item:hover, .sug-item.hover { background:#f8fafc; }
    .sug-item .material-symbols-rounded { font-size:16px;color:#94a3b8;flex-shrink:0; }
    #suggestions-desktop .sug-item { color:#1e293b; }
    #suggestions-desktop .sug-item:hover { background:#f1f5f9; }
    #suggestions-desktop .sug-item .material-symbols-rounded { color:#94a3b8; }
    .sug-section { font-size:0.6rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--text-mute);padding:8px 14px 4px; }
    #suggestions-desktop .sug-section { color:#94a3b8; }
    .forecast-row-jw { display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);font-size:0.85rem; }
    .forecast-row-jw:last-child { border-bottom:none; }
    .forecast-row-jw .fr-day { width:64px;font-weight:600;color:var(--text-main);flex-shrink:0; }
    .forecast-row-jw .fr-desc { flex:1;color:var(--text-mute);font-size:0.78rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
    .forecast-row-jw .fr-temp { font-weight:700;color:var(--text-main);flex-shrink:0; }
    .hr-row-jw { display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border);font-size:0.82rem; }
    .hr-row-jw:last-child { border-bottom:none; }
    .hr-row-jw .hr-time { width:52px;font-weight:600;color:var(--text-mute);flex-shrink:0;font-size:0.75rem; }
    .hr-row-jw .hr-desc { flex:1;color:var(--text-mute);font-size:0.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis; }
    .hr-row-jw .hr-temp { font-weight:700;color:var(--text-main);flex-shrink:0; }
    .hr-row-jw .hr-precip { font-size:0.7rem;color:#60a5fa;flex-shrink:0;min-width:30px;text-align:right; }

    @media (max-width: 1023px) {
      /* Daily forecast rows — single line */
      .forecast-row-jw { flex-wrap:nowrap; align-items:center; row-gap:0; padding:10px 0; }
      .forecast-row-jw .fr-day      { order:1; width:72px; flex-shrink:0; font-size:0.82rem; }
      .forecast-row-jw img          { order:2; flex-shrink:0; }
      .forecast-row-jw .fr-desc     { order:3; flex:1; font-size:0.75rem; color:var(--text-mute); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; padding:0 8px; }
      .forecast-row-jw .fr-temp-wrap{ order:4; flex-shrink:0; }
      .forecast-row-jw .fr-chevron  { order:5; flex-shrink:0; color:var(--text-mute); font-size:16px; }
      .fr-expand { margin-top:6px !important; }

      /* Hourly rows */
      .hr-row-jw { flex-wrap:nowrap; align-items:center; row-gap:0; padding:8px 0; }
      .hr-row-jw .hr-time   { order:1; width:56px; flex-shrink:0; font-size:0.78rem; font-weight:600; color:var(--text-mute); }
      .hr-row-jw img        { order:2; flex-shrink:0; }
      .hr-row-jw .hr-desc   { order:3; flex:1; font-size:0.75rem; color:var(--text-mute); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; padding:0 8px; }
      .hr-row-jw .hr-precip { order:4; font-size:0.7rem; color:#60a5fa; flex-shrink:0; min-width:32px; text-align:right; }
      .hr-row-jw .hr-temp   { order:5; font-weight:700; color:var(--text-main); flex-shrink:0; margin-left:8px; }
    }
    #wx-video { pointer-events: none; }
    @keyframes watches-bar-slide { from{left:0} to{left:calc(160px - 50px)} }
    @keyframes slideUp { from{transform:translateY(100%);opacity:0} to{transform:translateY(0);opacity:1} }
    @keyframes fadeInScale { from{opacity:0;transform:scale(0.96)} to{opacity:1;transform:scale(1)} }
    /* MapLibre dark theme overrides */
    .maplibregl-ctrl-group { background:#ffffff !important; border:1px solid #e2e8f0 !important; }
    .maplibregl-ctrl-group button { background:#ffffff !important; color:#1e293b !important; border-bottom:1px solid #e2e8f0 !important; }
    .maplibregl-ctrl-group button:hover { background:#f8fafc !important; }
    .maplibregl-ctrl-group button .maplibregl-ctrl-icon { filter:none; }
    .maplibregl-ctrl-attrib { background:rgba(255,255,255,0.85) !important; color:#64748b !important; }
    .maplibregl-ctrl-attrib a { color:#64748b !important; }
    .maplibregl-popup-tip { border-top-color:#3a3a3a !important; border-bottom-color:#3a3a3a !important; }
    @keyframes spin-anim { to{transform:rotate(360deg)} }

    /* Layer toggle buttons */
    .alyr-btn { display:flex;align-items:center;background:transparent;border:none;border-radius:6px;cursor:pointer;width:100%;height:32px;transition:background .15s;-webkit-tap-highlight-color:transparent;font-family:inherit;padding:0 6px;gap:10px; }
    .alyr-btn .material-symbols-rounded { font-size:16px;color:rgba(255,255,255,0.45);flex-shrink:0;transition:color .15s; }
    .alyr-btn .alyr-label { color:rgba(255,255,255,0.45); }
    .alyr-btn:hover { background:rgba(255,255,255,0.07); }
    .alyr-btn:hover .material-symbols-rounded { color:rgba(255,255,255,0.8); }
    .alyr-btn:hover .alyr-label { color:rgba(255,255,255,0.8); }
    .alyr-btn.active .material-symbols-rounded { color:#fff; }
    .alyr-btn.active .alyr-label { color:#fff; }
    .alyr-btn.active.alyr-warn  .material-symbols-rounded { color:#f87171; }
    .alyr-btn.active.alyr-warn  .alyr-label { color:#f87171; }
    .alyr-btn.active.alyr-watch .material-symbols-rounded { color:#fbbf24; }
    .alyr-btn.active.alyr-watch .alyr-label { color:#fbbf24; }
    .alyr-btn.active.alyr-flood .material-symbols-rounded { color:#34d399; }
    .alyr-btn.active.alyr-flood .alyr-label { color:#34d399; }
    .alyr-btn.active.alyr-radar .material-symbols-rounded { color:#60a5fa; }
    .alyr-btn.active.alyr-radar .alyr-label { color:#60a5fa; }
    .alyr-btn:not(.active) { opacity:0.6; }
    .alyr-label { font-size:0.78rem;font-weight:600;white-space:nowrap;overflow:hidden;opacity:0;transition:opacity .15s .05s; }
    #alerts-layer-bar:hover .alyr-label { opacity:1; }
    #alerts-layer-bar .alyr-btn { width:100%;height:34px; }

    /* Legend items */
    .wl-item { display:flex;align-items:center;gap:6px;font-size:0.65rem;color:rgba(255,255,255,0.9);padding:2px 0; }
    .wl-swatch { width:10px;height:10px;border-radius:2px;flex-shrink:0; }

    /* Watch modal spinner */
    .wm-spin { width:16px;height:16px;border:2px solid rgba(255,255,255,0.1);border-top-color:#60a5fa;border-radius:50%;animation:spin-anim .65s linear infinite;flex-shrink:0; }

    /* Badge chip */
    .wm-badge { display:inline-flex;padding:3px 9px;background:rgba(255,255,255,0.07);border:1px solid rgba(255,255,255,0.12);border-radius:99px;font-size:0.68rem;font-weight:500;color:rgba(255,255,255,0.65);margin:2px; }

    /* Pulse keyframes — applied via JS to MapLibre source features */
    @keyframes pulse-pill { 0%,100%{opacity:1} 50%{opacity:0.5} }
    /* Weather 101 */
    .g101-card { background:var(--bg-surface);border-radius:20px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,0.06);border:1px solid var(--border); }
    .g101-card-header { background:linear-gradient(135deg,var(--g1),var(--g2));padding:20px 20px; }
    .g101-card-header-inner { display:flex;align-items:center;gap:14px; }
    .g101-icon-wrap { width:40px;height:40px;border-radius:12px;background:rgba(255,255,255,0.12);display:flex;align-items:center;justify-content:center;flex-shrink:0; }
    .g101-icon-wrap .material-symbols-rounded { font-size:22px;color:#fff; }
    .g101-title { font-size:1.05rem;font-weight:800;color:#fff;letter-spacing:-0.02em; }
    .g101-sub { font-size:0.7rem;color:rgba(255,255,255,0.5);margin-top:2px; }
    .g101-body { padding:18px 20px; }
    .g101-alert-row { display:flex;align-items:flex-start;gap:10px;padding:8px 12px;border-radius:8px;font-size:0.8rem;line-height:1.55;color:var(--text-main);background:rgba(0,0,0,0.04);margin-bottom:4px; }
    .g101-pip { width:6px;height:6px;border-radius:50%;background:var(--c);flex-shrink:0;margin-top:5px; }
    .g101-divider { height:1px;background:var(--border);margin:14px 0; }
    .g101-scale-title { font-size:0.58rem;font-weight:800;letter-spacing:0.14em;text-transform:uppercase;color:var(--text-mute);margin-bottom:8px; }
    .g101-scale-list { display:flex;flex-direction:column;gap:3px;margin-bottom:4px; }
    .g101-scale-item { display:grid;grid-template-columns:90px 80px 1fr;gap:8px;align-items:center;padding:7px 10px;border-radius:8px;background:rgba(0,0,0,0.03);border-left:2.5px solid var(--sc); }
    .g101-scale-item span:nth-child(1) { font-size:0.78rem;font-weight:800;color:var(--sc); }
    .g101-scale-item span:nth-child(2) { font-size:0.68rem;font-weight:700;color:var(--text-mute); }
    .g101-scale-item span:nth-child(3) { font-size:0.75rem;color:var(--text-main);line-height:1.45; }
    .g101-tips { display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-top:4px; }
    .g101-tip { display:flex;align-items:flex-start;gap:9px;padding:10px 12px;background:var(--bg-app);border-radius:10px;font-size:0.78rem;line-height:1.55;color:var(--text-main); }
    .g101-tip .material-symbols-rounded { font-size:16px;color:var(--ms-blue);flex-shrink:0;margin-top:1px; }
    @media (max-width:600px) {
      .g101-tips { grid-template-columns:1fr; }
      .g101-scale-item { grid-template-columns:72px 70px 1fr; }
    }

@keyframes slideUpSheet { from { transform: translateY(100%); opacity:0.6; } to { transform: translateY(0); opacity:1; } }
    @media (min-width:1024px) {
      #watch-modal-box {
        bottom: 24px !important; right: 24px !important; left: auto !important;
        width: 380px !important; max-height: calc(100vh - 48px) !important;
        border-radius: 16px !important;
        animation: fadeInScale .2s ease !important;
      }
    }
    /* Alert detail panel rows — matching reference screenshot */
    .wm-table { width:100%; border-collapse:collapse; }
    .wm-table td { padding:10px 0; border-bottom:1px solid rgba(255,255,255,0.07); vertical-align:middle; }
    .wm-table tr:last-child td { border-bottom:none; }
    .wm-label-cell { width:90px; padding-right:8px; }
    .wm-label-text { font-size:0.72rem; color:rgba(255,255,255,0.45); font-weight:500; white-space:nowrap; }
    .wm-val-main { font-size:0.82rem; font-weight:700; color:#fff; }
    .wm-val-impact { font-size:0.82rem; font-weight:800; color:#fff; letter-spacing:0.01em; }
    .wm-icon-label { display:flex; flex-direction:column; align-items:flex-start; gap:3px; }
    .wm-icon-label .material-symbols-rounded { font-size:18px; color:rgba(255,255,255,0.5); }
    .wm-icon-label span.lbl { font-size:0.62rem; font-weight:700; text-transform:uppercase; letter-spacing:0.05em; color:rgba(255,255,255,0.4); line-height:1.2; }
    .wm-special-val { font-size:0.85rem; font-weight:900; letter-spacing:0.02em; }
    /* Segmented bar */
    .wm-seg-bar { display:flex; gap:2px; margin-top:6px; }
    .wm-seg { flex:1; text-align:center; padding:3px 0; font-size:0.55rem; font-weight:700; text-transform:uppercase; letter-spacing:0.03em; border-radius:3px; }
    /* Scale bar */
    .wm-scale-wrap { margin-top:8px; position:relative; }
    .wm-scale-track { height:6px; border-radius:3px; background:rgba(255,255,255,0.12); position:relative; overflow:visible; }
    .wm-scale-fill { position:absolute; left:0; top:0; height:100%; border-radius:3px; }
    .wm-scale-pip { position:absolute; top:50%; transform:translate(-50%,-50%); width:3px; height:14px; border-radius:2px; }
    .wm-scale-labels { display:flex; justify-content:space-between; margin-top:7px; gap:2px; }
    .wm-scale-lbl { font-size:0.6rem; font-weight:600; color:rgba(255,255,255,0.35); text-transform:uppercase; letter-spacing:0.03em; text-align:center; flex:1; }
    .wm-scale-lbl.active { color:#fff; font-weight:800; }
    .wm-counties { display:flex; flex-wrap:wrap; gap:4px; margin-top:2px; }
    .wm-county { background:rgba(255,255,255,0.07); border:1px solid rgba(255,255,255,0.1); border-radius:99px; padding:2px 8px; font-size:0.7rem; color:rgba(255,255,255,0.75); font-weight:500; }

/* Outlook controls panel */
    .ol-controls-panel { flex-shrink:0; background:#3a3a3a; border-top:1px solid rgba(255,255,255,0.12); padding-bottom:env(safe-area-inset-bottom); z-index:10; }
    .ol-day-tabs-row { display:flex; border-bottom:1px solid rgba(255,255,255,0.08); }
    .ol-day-tab { flex:1; padding:9px 4px 0; background:none; border:none; cursor:pointer; font-family:inherit; font-size:0.62rem; font-weight:700; color:rgba(255,255,255,0.35); text-transform:uppercase; letter-spacing:0.06em; border-bottom:2px solid transparent; margin-bottom:-1px; display:flex; flex-direction:column; align-items:center; gap:3px; -webkit-tap-highlight-color:transparent; transition:color .15s; }
    .ol-day-tab .label { padding-bottom:5px; }
    .ol-threat-bar { display:block; width:60%; height:3px; border-radius:2px; background:rgba(255,255,255,0.1); transition:background .3s; }
    .ol-day-tab.active { color:#fb923c; border-bottom-color:#fb923c; }
    .ol-mode-row { display:flex; gap:6px; padding:8px 10px; overflow-x:auto; scrollbar-width:none; justify-content:center; flex-shrink:0; }
    .ol-mode-row::-webkit-scrollbar { display:none; }
    .ol-mode-btn { display:flex; align-items:center; gap:5px; padding:6px 14px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); border-radius:20px; cursor:pointer; font-family:inherit; font-size:0.72rem; font-weight:600; color:rgba(255,255,255,0.45); white-space:nowrap; flex-shrink:0; -webkit-tap-highlight-color:transparent; transition:all .15s; }
    .ol-mode-btn.active { background:rgba(249,115,22,0.2); border-color:rgba(249,115,22,0.5); color:#fb923c; }
    .ol-mode-btn .material-symbols-rounded { font-size:14px; }
    .ol-loop-row { display:flex; gap:6px; padding:8px 10px; justify-content:center; flex-shrink:0; }
    .ol-loop-btn { flex:1; max-width:64px; padding:6px 4px; background:rgba(255,255,255,0.06); border:1px solid rgba(255,255,255,0.1); border-radius:20px; cursor:pointer; font-family:inherit; font-size:0.72rem; font-weight:600; color:rgba(255,255,255,0.45); text-align:center; -webkit-tap-highlight-color:transparent; transition:all .15s; }
    .ol-loop-btn.active { background:rgba(249,115,22,0.2); border-color:rgba(249,115,22,0.5); color:#fb923c; }
    .ol-disc-row { padding:4px 10px 10px; }
    .ol-disc-btn { width:100%; display:flex; align-items:center; justify-content:center; gap:6px; padding:10px; background:#f97316; border:none; border-radius:var(--radius-sm); cursor:pointer; font-family:inherit; font-size:0.78rem; font-weight:700; color:#fff; -webkit-tap-highlight-color:transparent; transition:background .15s; }
    .ol-disc-btn:hover { background:#ea6c0a; }
    .ol-disc-btn .material-symbols-rounded { font-size:15px; }
    .ol-legend-item { display:flex; align-items:center; gap:6px; font-size:0.65rem; font-weight:500; color:rgba(255,255,255,0.9); padding:2px 0; white-space:nowrap; }
    .ol-legend-swatch { width:10px; height:10px; border-radius:2px; flex-shrink:0; }
    #ol-legend:empty { display:none !important; }
    .ol-warn-triangle { width:14px; height:14px; flex-shrink:0; display:inline-flex; align-items:center; justify-content:center; margin-left:2px; }
    .ol-warn-triangle svg { width:14px; height:14px; display:block; }
    /* Discussion modal */
    #disc-modal.open { display:flex; }
    .disc-section { margin-bottom:16px; }
    .disc-section-label { font-size:0.62rem;font-weight:800;text-transform:uppercase;letter-spacing:0.1em;color:#f97316;margin-bottom:5px;display:flex;align-items:center;gap:5px; }
    .disc-section-label .material-symbols-rounded { font-size:14px; }
    .disc-section-text { font-size:0.85rem;line-height:1.7;color:rgba(255,255,255,0.75); }
    .disc-threat-pill { display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:20px;font-size:0.68rem;font-weight:700;border:1px solid; }
    .disc-loading { display:flex;align-items:center;gap:10px;color:rgba(255,255,255,0.4);font-size:0.82rem;padding:10px 0; }
    .disc-err { font-size:0.82rem;color:#f87171;padding:8px 0; }
    .spin-ring { width:16px;height:16px;border:2px solid rgba(255,255,255,0.1);border-top-color:#60a5fa;border-radius:50%;animation:spin-anim .65s linear infinite;flex-shrink:0; }
    /* MapLibre popup */
    .maplibregl-popup-content { padding:0 !important;border-radius:10px !important;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,0.3) !important;background:#3a3a3a !important; }
    .popup-inner { padding:12px 14px; }
    .popup-header { display:flex;align-items:center;gap:10px;margin-bottom:2px; }
    .popup-swatch { width:14px;height:14px;border-radius:3px;flex-shrink:0;border-width:1.5px;border-style:solid; }
    .popup-risk { font-size:0.9rem;font-weight:800;color:#fff; }
    .popup-sub { font-size:0.7rem;color:rgba(255,255,255,0.4); }
    .popup-divider { height:1px;background:rgba(255,255,255,0.08);margin:8px 0; }
    .popup-desc { font-size:0.78rem;color:rgba(255,255,255,0.7);line-height:1.55; }

@keyframes discSlideIn { from { transform: translateX(100%); } to { transform: translateX(0); } }
    @keyframes discSlideOut { from { transform: translateX(0); } to { transform: translateX(100%); } }
    @media (min-width: 1024px) {
      #disc-modal { align-items: stretch !important; justify-content: flex-end !important; padding: 0 !important; background: rgba(0,0,0,.45) !important; }
      #disc-modal-panel { border-radius: 0 !important; max-width: 420px !important; max-height: 100% !important; height: 100% !important; box-shadow: -8px 0 40px rgba(0,0,0,.5) !important; animation: discSlideIn .28s cubic-bezier(.4,0,.2,1) !important; }
      #disc-modal-panel.closing { animation: discSlideOut .22s cubic-bezier(.4,0,.2,1) forwards !important; }
      #home-alert-modal { align-items: stretch !important; justify-content: flex-end !important; padding: 0 !important; pointer-events: all !important; }
      #home-alert-modal-panel { border-radius: 0 !important; max-width: 560px !important; max-height: 100% !important; height: 100% !important; box-shadow: -8px 0 40px rgba(0,0,0,.5) !important; animation: discSlideIn .28s cubic-bezier(.4,0,.2,1) !important; }
      #home-alert-modal-panel.closing { animation: discSlideOut .22s cubic-bezier(.4,0,.2,1) forwards !important; }
      #meso-modal { align-items: stretch !important; justify-content: flex-end !important; padding: 0 !important; background: rgba(0,0,0,.45) !important; pointer-events: all !important; }
      #meso-modal-panel { border-radius: 0 !important; max-width: 420px !important; max-height: 100% !important; height: 100% !important; box-shadow: -8px 0 40px rgba(0,0,0,.5) !important; animation: discSlideIn .28s cubic-bezier(.4,0,.2,1) !important; }
      #meso-modal-panel.closing { animation: discSlideOut .22s cubic-bezier(.4,0,.2,1) forwards !important; }
    }