html,body,#root{color:#1e293b;background:#f0f4f8;width:100%;height:100%;margin:0;padding:0;font-family:Segoe UI,Roboto,Helvetica,Arial,sans-serif;overflow:hidden}*{box-sizing:border-box}.app-shell{flex-direction:column;width:100%;height:100%;display:flex;overflow:hidden}.app-topbar{z-index:5;border-top:none;border-left:none;border-right:none;border-radius:0;flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:8px 16px;display:flex}.app-topbar__brand{align-items:center;gap:10px;display:flex}.app-topbar__title{color:#0284c7;letter-spacing:.3px;font-weight:700}.app-topbar__nav{gap:6px;display:flex}.app-topbar__tab{padding:6px 14px;font-size:13px}.app-main{flex:auto;min-height:0;position:relative;overflow:hidden}.glass{-webkit-backdrop-filter:blur(12px);background:#ffffffe0;border:1px solid #94a3b840;border-radius:12px;box-shadow:0 8px 32px #0000001f}.neon-text{text-shadow:none}.control-btn{color:#334155;cursor:pointer;background:#ffffffb3;border:1px solid #94a3b859;border-radius:8px;padding:8px 14px;font-size:13px;font-weight:500;transition:all .2s}.control-btn:hover{background:#38bdf81f;border-color:#38bdf880}.control-btn.active{color:#0284c7;background:#38bdf833;border-color:#38bdf8cc}.bottom-sheet-backdrop{z-index:1000;background:#0006;animation:.2s ease-out fadeIn;position:fixed;inset:0}.bottom-sheet{-webkit-backdrop-filter:blur(12px);z-index:1001;background:#fffffff2;border-top:1px solid #94a3b840;border-radius:20px 20px 0 0;max-height:80vh;padding:16px;animation:.3s cubic-bezier(.16,1,.3,1) slideUp;position:fixed;bottom:0;left:0;right:0;overflow-y:auto;box-shadow:0 -8px 32px #00000026}.bottom-sheet-header{border-bottom:1px solid #94a3b833;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;display:flex}.bottom-sheet-title{color:#0f172a;font-size:16px;font-weight:600}.bottom-sheet-close{color:#64748b;cursor:pointer;background:0 0;border:none;padding:0 4px;font-size:24px;line-height:1}.mobile-fab{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#334155;cursor:pointer;background:#ffffffe6;border:1px solid #94a3b859;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;transition:all .2s;display:flex;box-shadow:0 4px 12px #0000001a}.mobile-fab:active{background:#f0f4f8;transform:scale(.95)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.variable-row{text-align:left;color:#334155;background:0 0;border:none;border-bottom:1px solid #94a3b826;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:15px;display:flex}.variable-row:active{background:#0284c714}.variable-row.active{color:#0284c7;background:#0284c70d;font-weight:600}.dashboard-page{background:#f0f4f8;width:100%;height:100%;overflow:hidden auto}.dashboard-controls{border-radius:12px;flex-wrap:wrap;align-items:flex-end;gap:16px;margin:16px 20px 0;padding:16px 20px;display:flex}.dashboard-heading{flex-direction:column;gap:2px;margin-right:auto;display:flex}.dashboard-title{color:#0f172a;margin:0;font-size:20px;font-weight:700}.dashboard-subtitle{color:#64748b;margin:0;font-size:13px}.dashboard-control{flex-direction:column;gap:6px;min-width:160px;display:flex}.visualizer-control__label{text-transform:uppercase;letter-spacing:1px;color:#64748b;font-size:11px;font-weight:600}.visualizer-control__input{color:#1e293b;background:#ffffffd9;border:1px solid #94a3b866;border-radius:8px;outline:none;min-width:140px;padding:8px 10px;font-size:14px}.visualizer-control__input:focus{border-color:#0284c799;box-shadow:0 0 0 3px #0284c71f}.dashboard-updated-at{color:#64748b;align-self:flex-end;padding-bottom:8px;font-size:12px}.dashboard-refresh{align-self:flex-end}.dashboard-content{flex-direction:column;gap:16px;padding:16px 20px 32px;display:flex}.dashboard-error{color:#b91c1c;background:#dc262614;border:1px solid #dc26264d;border-radius:10px;flex-direction:column;align-items:flex-start;gap:10px;margin:16px 20px 0;padding:14px 16px;font-size:13px;display:flex}.dashboard-status-strip{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.metric-card{background:#fff;border:1px solid #e2e8f0;border-radius:12px;flex-direction:column;gap:4px;padding:14px 16px;display:flex;box-shadow:0 1px 2px #0f172a0a}.metric-card__label{text-transform:uppercase;letter-spacing:.8px;color:#64748b;font-size:11px;font-weight:600}.metric-card__value{color:#0f172a;font-size:22px;font-weight:700;line-height:1.2}.metric-card__helper{color:#64748b;font-size:12px}.dashboard-sparkline-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px;display:grid}.dashboard-spark-card{background:#fff;border:1px solid #e2e8f0;border-left-width:4px;border-radius:10px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.dashboard-spark-card--high{border-left-color:#b91c1c}.dashboard-spark-card--medium{border-left-color:#f59e0b}.dashboard-spark-card--normal{border-left-color:#94a3b8}.dashboard-spark-card__body{flex-direction:column;gap:2px;display:flex}.dashboard-spark-card__label{text-transform:uppercase;letter-spacing:.7px;color:#64748b;font-size:11px;font-weight:600}.dashboard-spark-card__value{color:#0f172a;font-size:18px;font-weight:700}.dashboard-spark-card__helper{color:#64748b;font-size:11px}.dashboard-spark-card__graph{align-items:stretch;height:60px;display:flex}.dashboard-spark-card__svg{width:100%;height:100%;display:block}.dashboard-spark-card__empty{color:#94a3b8;align-self:center;margin:auto;font-size:11px}.dashboard-signal-panel{background:#ffffffeb;border:1px solid #94a3b840;border-radius:12px;flex-direction:column;gap:12px;padding:16px 18px;display:flex;box-shadow:0 2px 10px #0f172a0d}.dashboard-signal-panel__header{flex-direction:column;gap:2px;display:flex}.dashboard-signal-panel__title{color:#0f172a;margin:0;font-size:16px;font-weight:700}.dashboard-signal-panel__subtitle{color:#64748b;margin:0;font-size:12px}.metric-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:10px;display:grid}.dashboard-signal-panel__tables{grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:14px;display:grid}.dashboard-phenomena-grid{grid-template-columns:1fr;gap:16px;display:grid}.panorama-table__wrapper{background:#fff;border:1px solid #e2e8f0;border-radius:10px;flex-direction:column;gap:8px;padding:12px 14px;display:flex}.panorama-table__header{justify-content:space-between;align-items:baseline;gap:8px;display:flex}.panorama-table__title{color:#102a43;margin:0;font-size:14px;font-weight:700}.panorama-table__meta{color:#64748b;font-size:11px}.panorama-table__scroll{overflow-x:auto}.panorama-table__element{border-collapse:separate;border-spacing:0 6px;color:#334e68;width:100%;font-size:13px}.panorama-table__element thead th{letter-spacing:1px;text-transform:uppercase;color:#52606d;text-align:left;border-bottom:1px solid #d9e2ec;padding:6px 10px;font-size:11px;font-weight:700}.panorama-table__element tbody td{vertical-align:middle;background:#fff;border-top:1px solid #e2e8f0;border-bottom:1px solid #e2e8f0;padding:10px 12px}.panorama-table__element tbody td:first-child{border-left:1px solid #e2e8f0;border-top-left-radius:8px;border-bottom-left-radius:8px}.panorama-table__element tbody td:last-child{border-right:1px solid #e2e8f0;border-top-right-radius:8px;border-bottom-right-radius:8px}.panorama-table__col-rank{color:#102a43;width:46px;font-size:16px;font-weight:700}.panorama-table__col-station{color:#102a43;min-width:160px;font-weight:600}.panorama-table__station-name{font-weight:700}.panorama-table__station-province{color:#64748b;font-size:11px;font-weight:400}.panorama-table__col-value{width:170px;font-weight:700}.panorama-table__col-updated{color:#64748b;width:170px;font-size:12px}.station-map-link{color:#005fbd;font-size:12px;font-weight:700;text-decoration:none}.station-map-link:hover{text-decoration:underline}.dashboard-empty{text-align:center;padding:18px 14px}.dashboard-empty__title{color:#475569;margin:0 0 4px;font-size:14px;font-weight:700}.dashboard-empty__description{color:#94a3b8;margin:0;font-size:12px}@media (width<=768px){.dashboard-controls{gap:12px;margin:12px 12px 0;padding:12px 14px}.dashboard-heading{width:100%;margin-right:0}.dashboard-control{width:100%;min-width:0}.visualizer-control__input{width:100%}.dashboard-updated-at,.dashboard-refresh{align-self:stretch}.dashboard-content{padding:12px 12px 24px}.dashboard-status-strip{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.dashboard-signal-panel__tables{grid-template-columns:1fr}.app-topbar__tab{padding:6px 10px;font-size:12px}}
