*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%;width:100%;overflow:hidden;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#app{position:relative}#map{position:absolute;inset:0}.ws{position:fixed;bottom:0;left:0;right:0;z-index:100;background:#0c0e14ed;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-radius:0;box-shadow:0 -4px 32px #00000073;color:#f0f0f0;max-height:72px;overflow:hidden;transition:max-height .15s ease-out;display:flex;flex-direction:column;padding-bottom:env(safe-area-inset-bottom,0)}.ws--open{max-height:55vh}.ws--open.ws--detail{max-height:88vh}@media(min-width:680px){.ws{left:auto;bottom:16px;right:16px;width:360px;border-radius:0;box-shadow:0 8px 32px #00000080;max-height:72px}.ws--open{max-height:500px}.ws--open.ws--detail{max-height:680px}}.ws__handle{padding:10px 16px;cursor:pointer;flex-shrink:0;user-select:none;-webkit-user-select:none;border-radius:inherit}.ws__handle:hover{background:#ffffff0a}.ws__handle:focus-visible{outline:2px solid #4a90d9;outline-offset:-2px}.ws__pill{width:36px;height:4px;background:#ffffff38;border-radius:2px;margin:0 auto 10px}.ws__header-row{display:flex;align-items:center;gap:8px}.ws__indicator{width:8px;height:8px;border-radius:50%;flex-shrink:0;position:relative}.ws__indicator--none{background:#555}.ws__indicator--active{background:#f40}.ws__indicator--active:after{content:"";position:absolute;inset:0;border-radius:50%;background:#f40;animation:ws-pulse 1.2s ease-out infinite}@keyframes ws-pulse{0%{transform:scale(.9);opacity:.8}to{transform:scale(2.5);opacity:0}}.ws__title{font-size:.875rem;font-weight:600;color:#f0f0f0;flex:1}.ws__chevron{font-size:.55rem;color:#666;transition:transform .15s ease-out}.ws--open .ws__chevron{transform:rotate(180deg)}.ws__content{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain}.ws__empty{padding:28px 16px;text-align:center;color:#666;font-size:.875rem}.ws__list{list-style:none;padding-bottom:8px}.ws__item{padding:11px 16px 11px 14px;border-left:3px solid var(--sev-color, #ff4400);border-bottom:1px solid rgba(255,255,255,.06);cursor:pointer;transition:background .12s}.ws__item:hover{background:#ffffff0f}.ws__item:active{background:#ffffff1a}.ws__item-badge{display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.07em;padding:2px 6px;border-radius:3px;color:#fff;margin-bottom:5px}.ws__item-sender{font-size:.875rem;font-weight:600;color:#f0f0f0;margin-bottom:2px}.ws__item-counties{font-size:.75rem;color:#888;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:3px}.ws__item-expiry{font-size:.75rem;color:#999;font-weight:500}.ws__item-expiry--urgent{color:#ff6b6b}.ws__detail{padding:4px 16px 32px}.ws__back{background:none;border:none;color:#4a9eff;font-size:.8rem;font-family:inherit;cursor:pointer;padding:8px 0 14px;display:block;line-height:1}.ws__back:hover{color:#79baff}.ws__detail-badge{display:inline-block;font-size:.6rem;font-weight:700;letter-spacing:.07em;padding:3px 8px;border-radius:3px;color:#fff;margin-bottom:8px}.ws__detail-sender{font-size:1rem;font-weight:700;color:#f5f5f5;margin-bottom:8px;line-height:1.25}.ws__detail-meta{margin-bottom:16px}.ws__detail-counties{font-size:.8rem;color:#aaa;margin-bottom:3px}.ws__detail-expiry{font-size:.8rem;color:#aaa;font-weight:600;margin-bottom:3px}.ws__detail-expiry--urgent{color:#ff6b6b}.ws__detail-motion{font-size:.75rem;color:#888}.ws__detail-section{border-top:1px solid rgba(255,255,255,.08);padding-top:12px;margin-top:0}.ws__detail-section+.ws__detail-section{margin-top:12px}.ws__detail-section--instr{border-color:#ffc80033}.ws__detail-label{font-size:.6rem;font-weight:700;letter-spacing:.08em;color:#ffc800;margin-bottom:6px}.ws__detail-text{font-family:SF Mono,Courier New,monospace;font-size:.7rem;color:#ccc;white-space:pre-wrap;word-break:break-word;line-height:1.55;margin:0}.ws__detail-section--instr .ws__detail-text{color:#ffe680}.radar-ctrl{background:#0c0e14e0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:4px;overflow:hidden;box-shadow:0 1px 4px #0006;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.radar-ctrl__btn{display:block;width:100%;padding:7px 12px;background:none;border:none;color:#666;font-size:.65rem;font-weight:700;letter-spacing:.1em;cursor:pointer;font-family:inherit;white-space:nowrap;transition:color .12s}.radar-ctrl__btn:hover{color:#aaa}.radar-ctrl__btn--on{color:#4ad9ff}.radar-ctrl__btn--on:hover{color:#7de8ff}.radar-ctrl__btn:focus-visible{outline:2px solid #4a90d9;outline-offset:-2px}.radar-ctrl__slider-row{padding:0 10px 8px}.radar-ctrl__slider{width:100%;accent-color:#4ad9ff;cursor:pointer}.spc{position:fixed;inset:0;z-index:150;background:#000000a6;display:flex;align-items:flex-end;justify-content:center}.spc[hidden]{display:none}.spc__panel{background:#0c0e14f7;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);color:#f0f0f0;width:100%;max-height:88vh;display:flex;flex-direction:column;box-shadow:0 -4px 32px #0009;border-radius:12px 12px 0 0;padding-bottom:env(safe-area-inset-bottom,0)}@media(min-width:680px){.spc{align-items:center;padding:24px}.spc__panel{max-width:700px;max-height:82vh;border-radius:12px}}.spc__header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 16px 12px;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.spc__title{font-size:.9rem;font-weight:700;color:#f0f0f0;margin:0}.spc__header-actions{display:flex;align-items:center;gap:8px}.spc__timestamp{font-size:.65rem;color:#666;white-space:nowrap}.spc__refresh-btn,.spc__close-btn{background:none;border:none;color:#888;font-size:.9rem;cursor:pointer;font-family:inherit;padding:4px 6px;border-radius:4px;line-height:1;transition:color .12s,background .12s}.spc__refresh-btn:hover,.spc__close-btn:hover{color:#f0f0f0;background:#ffffff14}.spc__refresh-btn:focus-visible,.spc__close-btn:focus-visible{outline:2px solid #4a90d9;outline-offset:2px}.spc__body{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;padding:16px;display:flex;flex-direction:column;gap:20px}.spc__section{display:flex;flex-direction:column;gap:8px}.spc__section-label{font-size:.65rem;font-weight:700;letter-spacing:.08em;color:#ffc800;margin:0}.spc__section[data-secondary] .spc__section-label{color:#666;font-weight:600}.spc__img{width:100%;height:auto;display:block;border-radius:4px;background:#ffffff0a;min-height:40px}.spc-ctrl{background:#0c0e14e0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-radius:4px;overflow:hidden;box-shadow:0 1px 4px #0006;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.spc-ctrl__btn{display:block;width:100%;padding:7px 12px;background:none;border:none;color:#888;font-size:.65rem;font-weight:700;letter-spacing:.1em;cursor:pointer;font-family:inherit;white-space:nowrap;transition:color .12s}.spc-ctrl__btn:hover{color:#f0f0f0}.spc-ctrl__btn:focus-visible{outline:2px solid #4a90d9;outline-offset:-2px}#gh-link{position:fixed;bottom:80px;left:8px;z-index:50;color:#ffffff4d;font-size:.6rem;font-weight:700;letter-spacing:.08em;text-decoration:none;background:#0c0e14b8;padding:4px 8px;border-radius:4px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);transition:color .12s;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#gh-link:hover{color:#ffffffbf}.warning-popup{font-size:.875rem;line-height:1.4;color:#1a1a1a}.warning-popup__severity{display:inline-block;font-weight:700;font-size:.7rem;text-transform:uppercase;letter-spacing:.06em;padding:2px 7px;border-radius:3px;margin-bottom:6px}.warning-popup__severity--standard{background:#f40;color:#fff}.warning-popup__severity--observed{background:red;color:#fff}.warning-popup__severity--considerable{background:#8b0000;color:#fff}.warning-popup__severity--catastrophic{background:#ff69b4;color:#000}.warning-popup__sender{font-weight:600;margin-bottom:2px}.warning-popup__counties{color:#555;margin-bottom:4px;font-size:.8rem}.warning-popup__expiry{font-weight:600;margin-bottom:8px;font-size:.8rem}.warning-popup__description{max-height:200px;overflow-y:auto;font-size:.75rem;color:#444;border-top:1px solid #e0e0e0;padding-top:6px;white-space:pre-wrap;word-break:break-word}
