*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f1a;--bg-secondary: #1a1a2e;--bg-tertiary: #252542;--bg-card: #1a2744;--bg-hover: #1f3460;--header-height: 72px;--text-primary: #e8e8e8;--text-secondary: #b8b8c8;--text-muted: #8888a0;--accent-primary: #00d9ff;--accent-secondary: #7b2cbf;--accent-gradient: linear-gradient(135deg, #00d9ff 0%, #7b2cbf 100%);--status-success: #00ff88;--status-warning: #ffaa00;--status-error: #ff4757;--status-info: #00d9ff;--vtec-warning: #ff4757;--vtec-watch: #ff9f43;--vtec-advisory: #feca57;--vtec-statement: #54a0ff;--border-color: #2a2a4a;--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 0 1px var(--accent-primary);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "JetBrains Mono", "Fira Code", monospace;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px}html,body,#root{height:100%}body{font-family:var(--font-family);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;overflow-x:hidden;font-weight:500;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-tertiary);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}.app{display:flex;flex-direction:column;min-height:100vh}.header{background:#1a1a2e;border-bottom:1px solid var(--border-color);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:300;height:var(--header-height)}.header__menu-toggle{background:none;border:none;padding:.5rem;cursor:pointer;display:flex;align-items:center;justify-content:center;margin-right:.75rem;color:var(--text-primary);transition:all var(--transition-fast);border-radius:var(--radius-md);flex-shrink:0}.header__menu-toggle:hover{background:#2a2a4a}.header__menu-toggle:active{transform:scale(.95)}.hamburger{display:flex;flex-direction:column;justify-content:space-between;width:24px;height:18px;position:relative;cursor:pointer}.hamburger span{display:block;width:100%;height:3px;background:var(--text-primary);border-radius:2px;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:center;position:absolute;left:0}.hamburger span:nth-child(1){top:0}.hamburger span:nth-child(2){top:50%;transform:translateY(-50%)}.hamburger span:nth-child(3){bottom:0}.hamburger--open span:nth-child(1){top:50%;transform:translateY(-50%) rotate(45deg)}.hamburger--open span:nth-child(2){opacity:0;transform:translateY(-50%) scaleX(0)}.hamburger--open span:nth-child(3){bottom:auto;top:50%;transform:translateY(-50%) rotate(-45deg)}.header__logo{display:flex;align-items:center;gap:.75rem}.header__logo-icon{width:40px;height:40px;background:var(--accent-gradient);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.header__title{font-size:1.5rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header__location{font-size:1rem;font-weight:600;color:var(--text-primary)}.header__subtitle{font-size:.75rem;color:var(--text-muted)}.header__actions{display:flex;align-items:center;gap:.75rem}.header__status{margin-left:auto;margin-right:1rem}.status-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem .75rem;border-radius:999px;border:1px solid var(--border-color);background:#0c1222;font-size:.75rem;color:var(--text-secondary)}.status-pill--online{border-color:#0f86;color:#9affd0}.status-pill--offline{border-color:#ff475766;color:#ff9aa6}.status-dot{width:8px;height:8px;border-radius:50%;background:var(--status-success)}.status-pill--offline .status-dot{background:var(--status-error)}.header__user{display:flex;align-items:center;gap:.75rem}.header__username{font-size:.875rem;color:var(--text-secondary);font-weight:600}.auth-page{background:var(--bg-primary)}.auth-main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 1rem 4rem}.auth-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2rem;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-card__subtitle{color:var(--text-muted);font-size:.9rem;margin:.5rem 0 1.5rem}.auth-actions{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;margin-top:1rem}.user-list{display:flex;flex-direction:column;gap:.75rem}.user-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.user-item__name{font-weight:600;color:var(--text-primary)}.user-item__meta{font-size:.8rem;color:var(--text-muted)}.user-item__actions{display:flex;gap:.5rem}.header__status{display:flex;align-items:center;gap:1rem}.status-indicator{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.875rem}.status-indicator__dot{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-indicator__dot--connected{background:var(--status-success);box-shadow:0 0 10px var(--status-success)}.status-indicator__dot--disconnected{background:var(--status-error);box-shadow:0 0 10px var(--status-error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.main{display:flex;flex:1;overflow:hidden;position:relative}.sidebar{width:280px;background:#1a1a2e;border-right:1px solid var(--border-color);display:flex;flex-direction:column;overflow-y:auto;transition:transform var(--transition-normal);position:fixed;top:var(--header-height);left:0;height:calc(100vh - var(--header-height));z-index:200;transform:translate(-100%);box-shadow:2px 0 20px #00000080}.sidebar--open{transform:translate(0)}.sidebar-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:150;opacity:0;pointer-events:none;transition:opacity var(--transition-normal)}.main.sidebar-open .sidebar-overlay{opacity:1;pointer-events:auto}@media(max-width:768px){.header__menu-toggle{display:flex}}.sidebar__section{padding:1rem;border-bottom:1px solid var(--border-color)}.sidebar__header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid var(--border-color);position:sticky;top:0;background:#1a1a2e;z-index:1}.sidebar__title-text{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted)}.sidebar__close{background:none;border:none;color:var(--text-muted);font-size:1.25rem;cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:color var(--transition-fast),background var(--transition-fast)}.sidebar__close:hover{color:var(--text-primary);background:#2a2a4a}.sidebar__title{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.75rem}.nav-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);color:var(--text-secondary)}.nav-item:hover{background:var(--bg-hover);color:var(--text-primary)}.nav-item--active{background:var(--accent-gradient);color:#fff}.nav-item__icon{font-size:1.25rem}.nav-item__badge{margin-left:auto;background:var(--status-error);color:#fff;font-size:.75rem;padding:.125rem .5rem;border-radius:999px;font-weight:600}.content{flex:1;padding:1.5rem;overflow-y:auto;background:radial-gradient(circle at top left,rgba(46,64,140,.15),transparent 55%),radial-gradient(circle at top right,rgba(109,60,165,.12),transparent 45%),var(--bg-primary)}.mobile-nav{display:none}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;margin-bottom:1rem;transition:all var(--transition-normal)}.card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-glow)}.card--vtec{border-left:4px solid var(--vtec-warning)}.card--vtec-watch{border-left-color:var(--vtec-watch)}.card--vtec-advisory{border-left-color:var(--vtec-advisory)}.card--vtec-statement{border-left-color:var(--vtec-statement)}.card__header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:.75rem}.card__title{font-size:1rem;font-weight:600;color:var(--text-primary)}.card__subtitle{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.card__badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .75rem;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;text-transform:uppercase}.card__badge--warning{background:#ff475733;color:var(--vtec-warning)}.card__badge--watch{background:#ff9f4333;color:var(--vtec-watch)}.card__badge--advisory{background:#feca5733;color:var(--vtec-advisory)}.card__badge--statement{background:#54a0ff33;color:var(--vtec-statement)}.card__content{font-family:var(--font-mono);font-size:.8rem;line-height:1.5;color:var(--text-secondary);background:var(--bg-secondary);padding:1rem;border-radius:var(--radius-md);white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto}.card__footer{display:flex;align-items:center;justify-content:space-between;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.card__meta{display:flex;align-items:center;gap:1rem;font-size:.75rem;color:var(--text-muted)}.card__actions{display:flex;gap:.5rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast)}.btn--primary{background:var(--accent-gradient);color:#fff}.btn--primary:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.btn--sm{padding:.4rem .75rem;font-size:.8rem}.btn--secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn--secondary:hover{border-color:var(--accent-primary)}.btn--icon{padding:.5rem;aspect-ratio:1}.input-group{margin-bottom:1rem}.input-group__label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:.5rem}.input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #00d9ff33}.input::placeholder{color:var(--text-muted)}.search-bar{display:flex;gap:.5rem;margin-bottom:1.5rem}.search-bar .input{flex:1}.filter-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.filter-chip{padding:.375rem .875rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:999px;font-size:.8rem;cursor:pointer;transition:all var(--transition-fast)}.filter-chip:hover{border-color:var(--accent-primary)}.filter-chip--active{background:var(--accent-gradient);border-color:transparent;color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.25rem;text-align:center}.stat-card__value{font-size:2rem;font-weight:700;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-card__label{font-size:.875rem;color:var(--text-muted);margin-top:.25rem}.alert-toast{position:fixed;bottom:1.5rem;right:1.5rem;background:var(--bg-card);border:1px solid var(--vtec-warning);border-radius:var(--radius-lg);padding:1rem 1.5rem;max-width:400px;box-shadow:var(--shadow-lg);animation:slideIn .3s ease;z-index:1000}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.alert-toast__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.alert-toast__icon{font-size:1.25rem}.alert-toast__title{font-weight:600;color:var(--vtec-warning)}.alert-toast__close{margin-left:auto;background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:1.25rem}.alert-toast__body{font-size:.875rem;color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:90%;max-width:800px;max-height:95vh;overflow:hidden;display:flex;flex-direction:column;animation:scaleIn .2s ease}.auth-modal{max-width:420px}.auth-error{background:#ff47571f;border:1px solid rgba(255,71,87,.35);color:var(--status-error);padding:.5rem .75rem;border-radius:var(--radius-md);font-size:.85rem}.auth-footer{justify-content:space-between}@keyframes scaleIn{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.modal__title{font-size:1.25rem;font-weight:600}.modal__close{background:none;border:none;color:var(--text-muted);font-size:1.5rem;cursor:pointer;transition:color var(--transition-fast)}.modal__close:hover{color:var(--text-primary)}.modal__content{padding:1.5rem;overflow:hidden;flex:1}.modal__subtitle{color:var(--text-secondary);font-size:.9rem;margin-bottom:1rem}.modal__footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color)}.product-text{font-family:var(--font-mono);font-size:.85rem;line-height:1.6;color:#fff;white-space:pre-wrap;word-break:break-word;background:var(--bg-primary);padding:1.25rem;border-radius:var(--radius-md);max-height:calc(95vh - 320px);overflow-y:auto}.vtec-info{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:1rem;margin-bottom:1rem}.vtec-info__row{display:flex;gap:2rem;margin-bottom:.5rem}.vtec-info__times{display:flex;gap:2rem;flex-wrap:wrap}.vtec-info__time{display:flex;flex-direction:column;gap:.25rem}.vtec-info__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted)}.vtec-info__value{font-weight:500;color:var(--text-primary)}.loading{display:flex;align-items:center;justify-content:center;padding:3rem}.spinner{width:40px;height:40px;border:3px solid var(--bg-tertiary);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.empty-state__icon{font-size:3rem;margin-bottom:1rem}.empty-state__title{font-size:1.25rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem}@media(max-width:768px){:root{--header-height: 60px}.header{padding:.75rem 1rem}.header__logo-icon{width:32px;height:32px;font-size:1.2rem}.header__location{font-size:.9rem}.header__subtitle{display:none}.header__menu-toggle{display:flex;padding:.4rem;margin-right:.5rem}.header__actions{gap:.4rem}.header__username{font-size:.75rem;max-width:80px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.header__actions .btn--sm{padding:.3rem .5rem;font-size:.7rem}.header__status{display:none}.header__logo{flex:1}.content{padding:1rem}.stats-grid{grid-template-columns:repeat(2,1fr)}}.watched-list{display:flex;flex-direction:column;gap:.5rem}.settings-card{padding:1rem 1.25rem}.settings-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.settings-row__meta h3{margin:0 0 .25rem}.settings-row__meta p{margin:0;color:var(--text-muted);font-size:.85rem}.settings-row__hint{margin-top:.35rem;color:var(--text-muted);font-size:.75rem}.watched-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md)}.watched-item__pattern{font-family:var(--font-mono);font-weight:600;color:var(--accent-primary)}.watched-item__desc{font-size:.875rem;color:var(--text-muted);margin-left:.5rem}.watched-item__remove{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.25rem;font-size:1.25rem;transition:color var(--transition-fast)}.watched-item__remove:hover{color:var(--status-error)}.weather-story-modal{max-width:900px;width:95%}.weather-story-modal .modal__content{padding:0;display:flex;flex-direction:column;max-height:calc(95vh - 120px);overflow:hidden}.weather-story__tabs{display:flex;gap:.25rem;padding:.75rem 1rem;background:var(--bg-primary);border-bottom:1px solid var(--border-color);overflow-x:auto}.weather-story__tab{padding:.6rem 1.25rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;display:flex;align-items:center;gap:.5rem}.weather-story__tab:hover{border-color:var(--accent-primary);color:var(--text-primary)}.weather-story__tab--active{background:var(--accent-gradient);border-color:transparent;color:#fff}.weather-story__tab--unavailable{opacity:.5;cursor:not-allowed}.weather-story__tab--inactive{opacity:.7;border-style:dashed;background:#ffc1071a}.weather-story__tab--inactive:hover{border-color:#ffc107}.weather-story__tab--inactive.weather-story__tab--active{background:linear-gradient(135deg,#ff9800,#ff5722);opacity:1;border-style:solid}.weather-story__tab-archive{font-size:.7rem;margin-left:.25rem}.weather-story__outdated-banner{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem 1rem;background:#ff980026;border-bottom:1px solid rgba(255,152,0,.3);color:#ffb74d;font-size:.85rem;text-align:center}.weather-story__outdated-icon{font-size:1rem}.weather-story__tab-number{display:inline-flex;align-items:center;justify-content:center;width:1.5rem;height:1.5rem;background:#ffffff26;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600}.weather-story__tab--active .weather-story__tab-number{background:#0003}.weather-story__content{flex:1;display:flex;flex-direction:column;overflow:hidden}.weather-story__image-container{flex:1;padding:1rem;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);overflow:hidden;min-height:300px}.weather-story__image{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius-md);box-shadow:var(--shadow-lg);animation:fadeIn .3s ease}.weather-story__loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;color:var(--text-muted)}.weather-story__unavailable{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;color:var(--text-muted);text-align:center;padding:2rem}.weather-story__unavailable-icon{font-size:3rem;opacity:.5}.weather-story__title{padding:.75rem 1.25rem;background:var(--bg-secondary);border-bottom:1px solid var(--border-color)}.weather-story__title h3{margin:0;font-size:1.1rem;font-weight:600;color:var(--text-primary);text-align:center}.weather-story__description{padding:1rem 1.25rem;background:var(--bg-tertiary);border-top:1px solid var(--border-color)}.weather-story__description p{margin:0;font-size:.9rem;line-height:1.5;color:var(--text-secondary);text-align:center}.weather-story__meta{padding:1rem 1.25rem;background:var(--bg-secondary);border-top:1px solid var(--border-color)}.weather-story__meta-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem}.weather-story__meta-item{display:flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--text-muted)}.weather-story__meta-label{color:var(--text-secondary)}.weather-story__meta-value{color:var(--accent-primary);font-weight:500}.weather-story__actions{display:flex;gap:.5rem}.weather-story__link{display:inline-flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8rem;text-decoration:none;cursor:pointer;transition:all var(--transition-fast)}.weather-story__link:hover{border-color:var(--accent-primary);color:var(--accent-primary)}.weather-story-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1rem;background:linear-gradient(135deg,#ff9f43,#ff6b6b);border:none;border-radius:var(--radius-md);color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all var(--transition-fast);box-shadow:0 2px 8px #ff6b6b4d}.weather-story-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #ff6b6b66}.weather-story-btn__icon{font-size:1.1rem}.weather-story-btn__badge{background:#ffffff40;padding:.1rem .4rem;border-radius:var(--radius-sm);font-size:.7rem;font-weight:600}@media(max-width:768px){.weather-story-modal{width:100%;max-height:100vh;border-radius:0}.weather-story__tabs{padding:.5rem;gap:.35rem}.weather-story__tab{padding:.5rem .75rem;font-size:.8rem}.weather-story__tab-number{width:1.25rem;height:1.25rem;font-size:.65rem}.weather-story__image-container{min-height:200px}.weather-story__meta-row{flex-direction:column;align-items:flex-start}}.zoomed-image-container{position:relative;max-width:95vw;max-height:95vh;display:flex;align-items:center;justify-content:center;animation:scaleIn .2s ease}.zoomed-image{max-width:100%;max-height:95vh;object-fit:contain;border-radius:var(--radius-md);box-shadow:var(--shadow-xl)}.zoomed-image-close{position:absolute;top:-40px;right:0;color:#fff;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:#00000080;border-radius:50%;border:1px solid rgba(255,255,255,.2);font-size:1.2rem;cursor:pointer;z-index:10}.zoomed-image-close:hover{background:#000c;color:#fff}.switch{position:relative;display:inline-block;width:48px;height:24px;flex-shrink:0}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);transition:.4s;border-radius:24px;border:1px solid var(--border-color)}.slider:before{position:absolute;content:"";height:18px;width:18px;left:2px;bottom:2px;background-color:var(--text-muted);transition:.4s;border-radius:50%}input:checked+.slider{background-color:var(--accent-primary);border-color:var(--accent-primary)}input:checked+.slider:before{transform:translate(24px);background-color:#fff}.dashboard-shell{display:flex;flex-direction:column;gap:1.5rem}.dashboard-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.dashboard-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:1rem}.stat-pill{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.75rem 1rem;display:flex;flex-direction:column;align-items:center;transition:transform var(--transition-fast)}.stat-pill:hover{transform:translateY(-2px);border-color:var(--accent-primary)}.stat-pill__value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.stat-pill__label{font-size:.75rem;color:var(--text-muted);text-transform:uppercase}.dashboard-row__label{font-size:.875rem;font-weight:600;color:var(--text-muted)}.dashboard-row__chips{display:flex;gap:.5rem;flex-wrap:wrap}.filter-pill{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);padding:.4rem .8rem;border-radius:999px;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast)}.filter-pill:hover{background:var(--bg-hover)}.filter-pill--active{background:var(--accent-primary);color:var(--bg-primary);border-color:var(--accent-primary);font-weight:600}.alert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem}.alert-card{background:var(--bg-card);border:1px solid var(--border-color);border-left:4px solid var(--vtec-warning);border-radius:var(--radius-lg);padding:1.25rem;cursor:pointer;transition:all var(--transition-normal)}.alert-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0006;border-color:var(--accent-primary)}.alert-card__header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.75rem}.alert-card__headline{font-size:1.1rem;font-weight:700;color:var(--text-primary);line-height:1.3}.alert-card__emoji{font-size:1.5rem}.alert-card__counties{font-size:.85rem;color:var(--text-muted);margin-bottom:1rem}.alert-card__footer{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid rgba(255,255,255,.05);padding-top:.75rem}.alert-card__times{display:flex;flex-direction:column;gap:.2rem;font-size:.75rem;color:var(--text-secondary)}.alert-card__wfo{font-size:.7rem;color:var(--text-muted);background:var(--bg-tertiary);padding:.1rem .4rem;border-radius:4px}.forecast-tabs{display:flex;gap:.5rem;margin-bottom:1rem;overflow-x:auto;padding-bottom:.5rem}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1rem}.forecast-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:1rem;cursor:pointer;transition:all .2s}.forecast-card:hover{background:var(--bg-hover);border-color:var(--accent-primary)}.forecast-card__header{display:flex;justify-content:space-between;margin-bottom:.5rem;font-size:.75rem;color:var(--text-muted)}.forecast-card__tag{color:var(--accent-primary);font-weight:700}.forecast-card__office{text-transform:uppercase}.forecast-card__time{margin-left:auto}.forecast-card__title{font-size:.95rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.forecast-card__body{font-size:.85rem;color:var(--text-secondary);line-height:1.4}.auth-page{background:var(--bg-primary);min-height:100vh;display:flex;flex-direction:column}.auth-main{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:480px;box-shadow:var(--shadow-lg)}.auth-card h2{margin-bottom:.5rem;color:var(--text-primary)}.auth-card__subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem}.card__badge{padding:.25rem .6rem;border-radius:999px;font-size:.7rem;font-weight:700;text-transform:uppercase}.card__badge--warning{background:#ff475733;color:#ff4757}.card__badge--watch{background:#ff9f4333;color:#ff9f43}.card__badge--advisory{background:#feca5733;color:#feca57}.card__badge--statement{background:#54a0ff33;color:#54a0ff}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.card{animation:fadeInUp .3s ease}.dashboard-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1.5rem;margin-bottom:1.5rem}.dashboard-shell{display:flex;flex-direction:column;gap:1.25rem}.dashboard-row{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:var(--radius-lg);background:linear-gradient(135deg,#1a1a2e,#282c4a);border:1px solid var(--border-color);box-shadow:var(--shadow-sm)}.dashboard-row__label{color:var(--text-secondary);font-size:.85rem;font-weight:600}.dashboard-row__chips{display:flex;flex-wrap:wrap;gap:.5rem}.stat-pill{background:#0a0f1e;border:1px solid var(--border-color);border-radius:var(--radius-md);padding:.5rem .75rem;min-width:88px;text-align:center;position:relative;overflow:hidden}.stat-pill:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-gradient);opacity:.7}.stat-pill__value{font-size:1.1rem;font-weight:700;color:var(--accent-primary)}.stat-pill__label{font-size:.7rem;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-muted)}.filter-pill{padding:.35rem .75rem;border-radius:999px;border:1px solid var(--border-color);background:#252542;color:var(--text-secondary);cursor:pointer;font-size:.75rem;transition:all var(--transition-fast)}.filter-pill--active{background:var(--accent-gradient);color:#fff;border-color:transparent}.dashboard-section{background:linear-gradient(135deg,#141830,#262c54);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1rem;box-shadow:var(--shadow-sm);position:relative;overflow:hidden}.dashboard-section:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--accent-gradient);opacity:.7}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.section-header h3{font-weight:700;font-size:1.1rem;position:relative;padding-bottom:.25rem}.section-header h3:after{content:"";position:absolute;left:0;bottom:0;width:40px;height:2px;background:var(--accent-gradient);opacity:.8}.alert-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,360px));gap:1rem}.alert-card{background:linear-gradient(135deg,#0d1220,#111833);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.75rem 1rem;cursor:pointer;transition:all var(--transition-fast);display:flex;flex-direction:column;min-height:130px;box-shadow:var(--shadow-sm)}.alert-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.alert-card__header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.5rem}.alert-card__headline{font-weight:700;font-size:.95rem}.alert-card__badge{font-size:.7rem;padding:.2rem .5rem;border-radius:999px;background:#ff9f4333;color:var(--vtec-watch)}.alert-card__emoji{font-size:1.5rem;flex-shrink:0}.alert-card__counties{font-size:.8rem;color:var(--text-secondary);margin-bottom:.5rem;font-weight:500;line-height:1.4}.alert-card__meta{display:flex;font-weight:500;gap:1rem;color:var(--text-muted);font-size:.75rem}.alert-card__footer{margin-top:auto;padding-top:.5rem;font-size:.8rem;font-weight:500;color:var(--text-secondary);display:flex;justify-content:space-between;align-items:flex-end;gap:.75rem}.alert-card__times{display:flex;flex-direction:column;gap:.15rem}.alert-card__wfo{font-weight:600;color:var(--text-muted);font-size:.75rem}.forecast-tabs{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.forecast-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,400px));gap:1rem}.forecast-card{background:linear-gradient(135deg,#0d1220,#111833);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.75rem 1rem;cursor:pointer;transition:all var(--transition-fast);box-shadow:var(--shadow-sm)}.forecast-card:hover{border-color:var(--accent-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.forecast-card__header{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem}.forecast-card__tag{background:#00d9ff33;color:var(--accent-primary);border-radius:999px;padding:.15rem .5rem;font-size:.7rem;font-weight:600}.forecast-card__office{font-size:.7rem;color:var(--text-muted)}.forecast-card__time{margin-left:auto;font-size:.7rem;color:var(--text-muted)}.forecast-card__title{font-weight:600;font-size:.85rem;margin-bottom:.35rem}.forecast-card__body{font-size:.75rem;color:var(--text-secondary)}.dashboard-title{font-size:1.5rem;color:var(--text-primary);margin-bottom:.25rem}.dashboard-subtitle{color:var(--text-muted);font-size:.9rem}.dashboard-actions{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.quick-lookup{display:flex;gap:.5rem;align-items:center;width:100%;margin-bottom:.75rem}.quick-lookup .input{flex:1}.dashboard-grid{display:grid;grid-template-columns:minmax(0,2fr) minmax(0,1fr);gap:1.5rem}.dashboard-column{display:flex;flex-direction:column;gap:1.5rem}.dashboard-panel{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1rem 1.25rem}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.75rem}.panel-pill{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:999px;padding:.125rem .5rem;font-size:.75rem}.panel-subtitle{color:var(--text-muted);font-size:.8rem;margin-bottom:1rem}.live-indicator{display:flex;align-items:center;gap:.5rem}.live-indicator:before{content:"";width:8px;height:8px;background:#ff4757;border-radius:50%;animation:pulse 1.5s infinite}table{width:100%}table th{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em}table tr:hover{background:var(--bg-hover)}.card--watched{border:1px solid var(--accent-primary);box-shadow:var(--shadow-glow)}.alert-toast:nth-child(2){bottom:5.5rem}.alert-toast:nth-child(3){bottom:9.5rem}.alert-toast:nth-child(n+4){display:none}.modal__subtitle--desktop-only{display:block}.modal__section-title{margin-bottom:.5rem;color:var(--text-secondary);font-size:.9rem}@media(max-width:768px){.modal__section-title{display:none}.modal{width:96%;max-height:92vh;border-radius:var(--radius-md)}.modal__header{padding:.75rem 1rem}.modal__title{font-size:1.1rem}.modal__content{padding:.75rem}.modal__subtitle--desktop-only{display:none}.vtec-info{padding:.6rem;margin-bottom:.75rem}.vtec-info__times{gap:.75rem;justify-content:space-between}.vtec-info__time{flex:1}.vtec-info__label{font-size:.6rem}.vtec-info__value{font-size:.8rem}.modal__footer{padding:.5rem .75rem}.modal__footer .btn{padding:.35rem .6rem;font-size:.7rem}.product-text{font-size:.7rem;padding:.6rem;max-height:calc(92vh - 180px);color:#fff!important}.dashboard-header{flex-direction:column}.dashboard-grid{grid-template-columns:1fr}.quick-lookup,.quick-lookup .input{width:100%}.alert-toast{left:1rem;right:1rem;max-width:none}.dashboard-stats,.dashboard-filters{display:none!important}.dashboard-section{padding:.7rem}.alert-grid,.forecast-grid{grid-template-columns:1fr}.alert-card,.forecast-card{min-height:auto;padding:.6rem .75rem}.alert-card__headline{font-size:.9rem}.alert-card__emoji{font-size:1.2rem}.alert-card__counties{font-size:.75rem;margin-bottom:.3rem}.alert-card__footer{font-size:.75rem;padding-top:.4rem}.forecast-card__title{font-size:.8rem}.forecast-card__body{font-size:.7rem}}.card--vtec:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--vtec-warning),var(--vtec-watch));border-radius:var(--radius-lg) var(--radius-lg) 0 0}.content>*{animation:fadeInUp .4s ease}.filter-chip{position:relative;overflow:hidden}.filter-chip:before{content:"";position:absolute;inset:0;background:var(--accent-gradient);opacity:0;transition:opacity var(--transition-fast)}.filter-chip:hover:before{opacity:.1}.filter-chip--active:before{opacity:1}.card:hover{transform:translateY(-2px)}.stat-card__value{text-shadow:0 0 30px rgba(0,217,255,.5)}.modal-overlay{background:#000c}.product-text{color:#fff}.vtec-info{background:linear-gradient(135deg,var(--bg-tertiary),var(--bg-secondary));border-left:3px solid var(--accent-primary)}.status-indicator__dot--connected{animation:connectedPulse 2s ease-in-out infinite}@keyframes connectedPulse{0%,to{box-shadow:0 0 5px var(--status-success)}50%{box-shadow:0 0 15px var(--status-success),0 0 30px var(--status-success)}}.empty-state__icon{animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}
