:root{--accent: #0a84ff;--accent-soft: color-mix(in srgb, var(--accent) 16%, transparent);--radius: 22px;--radius-sm: 14px;--font: -apple-system, BlinkMacSystemFont, "Segoe UI", "Inter", Roboto, Helvetica, Arial, sans-serif;--ease: cubic-bezier(.22, 1, .36, 1);--shadow: 0 10px 40px -12px rgba(0, 0, 0, .35);--up: #2fd07a;--down: #ff5a5f}:root,[data-theme=dark]{--bg-0: #070b16;--bg-1: #0d1426;--blob-1: #1b6bff;--blob-2: #7a3cff;--blob-3: #00c2c7;--text: #f3f6fc;--text-dim: #9aa7c2;--text-faint: #6b7790;--glass: rgba(255, 255, 255, .06);--glass-2: rgba(255, 255, 255, .09);--glass-border: rgba(255, 255, 255, .12);--glass-hover: rgba(255, 255, 255, .11);--input-bg: rgba(255, 255, 255, .06);--scrim: rgba(4, 7, 14, .6)}[data-theme=light]{--bg-0: #eef2fb;--bg-1: #dfe7f7;--blob-1: #7db4ff;--blob-2: #c2a3ff;--blob-3: #7fe5e8;--text: #0e1426;--text-dim: #4a566f;--text-faint: #8090a8;--glass: rgba(255, 255, 255, .55);--glass-2: rgba(255, 255, 255, .7);--glass-border: rgba(255, 255, 255, .7);--glass-hover: rgba(255, 255, 255, .8);--input-bg: rgba(255, 255, 255, .6);--scrim: rgba(20, 30, 50, .35);--shadow: 0 14px 40px -16px rgba(40, 60, 110, .4)}*{box-sizing:border-box}html,body,#root{height:100%}body{margin:0;font-family:var(--font);color:var(--text);background:var(--bg-0);-webkit-font-smoothing:antialiased;overflow-x:hidden}.bg-aurora{position:fixed;top:0;right:0;bottom:0;left:0;z-index:-1;overflow:hidden;background:linear-gradient(160deg,var(--bg-0),var(--bg-1));transition:background .6s var(--ease)}.bg-aurora:before,.bg-aurora:after,.bg-aurora i{content:"";position:absolute;width:46vw;height:46vw;border-radius:50%;filter:blur(80px);opacity:.55;will-change:transform}.bg-aurora:before{background:var(--blob-1);top:-10%;left:-8%;animation:float1 22s var(--ease) infinite}.bg-aurora:after{background:var(--blob-2);bottom:-15%;right:-10%;animation:float2 26s var(--ease) infinite}.bg-aurora i{background:var(--blob-3);top:30%;left:45%;animation:float3 30s var(--ease) infinite}@keyframes float1{50%{transform:translate(18vw,12vh) scale(1.15)}}@keyframes float2{50%{transform:translate(-16vw,-10vh) scale(1.1)}}@keyframes float3{50%{transform:translate(-12vw,14vh) scale(.9)}}.app{min-height:100%;display:flex;flex-direction:column}.container{width:min(1240px,100%);margin:0 auto;padding:0 22px}.content{flex:1;padding:26px 0 60px}.topbar{position:sticky;top:0;z-index:40;backdrop-filter:blur(20px) saturate(160%);-webkit-backdrop-filter:blur(20px) saturate(160%);background:var(--glass);border-bottom:1px solid var(--glass-border)}.topbar-inner{display:flex;align-items:center;gap:18px;height:64px}.brand{display:flex;align-items:center;gap:12px;font-weight:650;letter-spacing:-.02em}.brand-logo{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:linear-gradient(135deg,var(--blob-1),var(--blob-2));color:#fff;box-shadow:0 6px 18px -6px var(--blob-2)}.brand h1{font-size:16px;margin:0;line-height:1.1}.brand small{color:var(--text-dim);font-size:11.5px;font-weight:500}.nav{display:flex;gap:4px;margin-left:8px}.nav a{text-decoration:none;color:var(--text-dim);font-size:14px;font-weight:550;padding:8px 14px;border-radius:999px;transition:all .2s var(--ease);display:inline-flex;align-items:center;gap:7px}.nav a:hover{color:var(--text);background:var(--glass-2)}.nav a.active{color:var(--text);background:var(--accent-soft);box-shadow:inset 0 0 0 1px var(--glass-border)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:10px}.updated{color:var(--text-faint);font-size:12px;display:flex;align-items:center;gap:6px}.dot-live{width:7px;height:7px;border-radius:50%;background:var(--up);box-shadow:0 0 0 0 var(--up);animation:pulse 2s infinite}@keyframes pulse{0%{box-shadow:0 0 color-mix(in srgb,var(--up) 60%,transparent)}70%{box-shadow:0 0 0 8px transparent}}.glass{background:var(--glass);border:1px solid var(--glass-border);border-radius:var(--radius);backdrop-filter:blur(22px) saturate(150%);-webkit-backdrop-filter:blur(22px) saturate(150%);box-shadow:var(--shadow)}.glass-hover{transition:transform .3s var(--ease),background .3s var(--ease),border-color .3s var(--ease)}.glass-hover:hover{transform:translateY(-3px);background:var(--glass-hover);border-color:color-mix(in srgb,var(--accent) 40%,var(--glass-border))}.section{margin-top:30px}.section-head{display:flex;align-items:center;gap:10px;margin:0 4px 16px}.section-head h2{font-size:19px;margin:0;letter-spacing:-.02em}.section-head .sub{color:var(--text-dim);font-size:13px}.section-head .icon{color:var(--accent);display:grid;place-items:center}.grid-weather{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.grid-markets{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(230px,1fr))}.wcard{padding:20px;cursor:pointer;position:relative;overflow:hidden}.wcard-top{display:flex;justify-content:space-between;align-items:flex-start}.wcard-city{font-size:17px;font-weight:650;letter-spacing:-.01em}.wcard-flag{font-size:13px;color:var(--text-dim)}.wcard-temp{font-size:52px;font-weight:300;letter-spacing:-.03em;line-height:1;margin:6px 0 2px}.wcard-temp sup{font-size:22px;font-weight:400;vertical-align:super}.wcard-desc{color:var(--text-dim);font-size:14px;text-transform:capitalize}.wcard-wico{font-size:44px;line-height:1;filter:drop-shadow(0 4px 10px rgba(0,0,0,.2))}.wcard-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:16px}.wstat{background:var(--glass-2);border-radius:var(--radius-sm);padding:9px 10px;text-align:center}.wstat .v{font-size:14px;font-weight:620}.wstat .l{font-size:10.5px;color:var(--text-faint);margin-top:2px}.wcard-spark{margin-top:14px;height:54px}.mcard{padding:18px;position:relative;overflow:hidden}.mcard-head{display:flex;justify-content:space-between;align-items:center}.mcard-label{font-size:14.5px;font-weight:600}.mcard-cat{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-faint)}.mcard-price{font-size:27px;font-weight:600;letter-spacing:-.02em;margin:10px 0 2px}.mcard-unit{font-size:12px;color:var(--text-faint);font-weight:500}.chip{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;font-weight:650;padding:3px 9px;border-radius:999px}.chip.up{color:var(--up);background:color-mix(in srgb,var(--up) 14%,transparent)}.chip.down{color:var(--down);background:color-mix(in srgb,var(--down) 14%,transparent)}.mcard-spark{margin-top:8px;height:46px}.btn{font-family:inherit;font-size:14px;font-weight:600;cursor:pointer;border:1px solid var(--glass-border);background:var(--glass-2);color:var(--text);padding:9px 16px;border-radius:12px;display:inline-flex;align-items:center;gap:8px;transition:all .2s var(--ease)}.btn:hover{background:var(--glass-hover);transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn.primary{background:var(--accent);border-color:transparent;color:#fff;box-shadow:0 8px 20px -8px var(--accent)}.btn.primary:hover{filter:brightness(1.08)}.btn.ghost{background:transparent}.btn.danger{color:var(--down);border-color:color-mix(in srgb,var(--down) 40%,transparent)}.btn.danger:hover{background:color-mix(in srgb,var(--down) 14%,transparent)}.btn.icon{padding:9px;border-radius:11px}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-sm{padding:6px 12px;font-size:13px}.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}.field label{font-size:13px;font-weight:600;color:var(--text-dim)}.field .hint{font-size:12px;color:var(--text-faint)}.input,.select,textarea.input{font-family:inherit;font-size:14px;color:var(--text);background:var(--input-bg);border:1px solid var(--glass-border);border-radius:12px;padding:10px 13px;width:100%;transition:border-color .2s,box-shadow .2s}.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.input::placeholder{color:var(--text-faint)}.row{display:flex;gap:12px;flex-wrap:wrap}.row>*{flex:1;min-width:120px}.switch{position:relative;width:46px;height:27px;flex:0 0 auto;cursor:pointer}.switch input{display:none}.switch .track{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--input-bg);border:1px solid var(--glass-border);border-radius:999px;transition:all .25s var(--ease)}.switch .thumb{position:absolute;top:3px;left:3px;width:21px;height:21px;border-radius:50%;background:#fff;box-shadow:0 2px 6px #0000004d;transition:all .25s var(--ease)}.switch input:checked+.track{background:var(--accent);border-color:transparent}.switch input:checked+.track+.thumb{transform:translate(19px)}.segmented{display:inline-flex;background:var(--input-bg);border:1px solid var(--glass-border);border-radius:12px;padding:3px;gap:2px}.segmented button{border:none;background:transparent;color:var(--text-dim);font-family:inherit;font-size:13px;font-weight:600;padding:7px 14px;border-radius:9px;cursor:pointer;transition:all .2s var(--ease);display:inline-flex;align-items:center;gap:6px}.segmented button.active{background:var(--glass-2);color:var(--text);box-shadow:var(--shadow)}.settings-tabs{display:flex;gap:6px;margin-bottom:22px;flex-wrap:wrap}.settings-tabs a{text-decoration:none;color:var(--text-dim);font-weight:600;font-size:14px;padding:9px 16px;border-radius:12px;display:inline-flex;align-items:center;gap:8px;transition:all .2s var(--ease)}.settings-tabs a:hover{background:var(--glass-2);color:var(--text)}.settings-tabs a.active{background:var(--accent-soft);color:var(--text);box-shadow:inset 0 0 0 1px var(--glass-border)}.panel{padding:24px;max-width:720px}.panel h3{margin:0 0 4px;font-size:18px;letter-spacing:-.02em}.panel .panel-sub{color:var(--text-dim);font-size:13.5px;margin:0 0 20px}.panel-actions{display:flex;gap:10px;margin-top:18px;padding-top:18px;border-top:1px solid var(--glass-border)}.list-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--glass-2);border:1px solid var(--glass-border);border-radius:var(--radius-sm);margin-bottom:10px;transition:opacity .2s,border-color .2s,transform .15s var(--ease)}.list-row[draggable=true]{cursor:grab}.list-row.dragging{opacity:.45;border-color:var(--accent);cursor:grabbing}.drag-handle{display:inline-flex;color:var(--text-faint);cursor:grab;flex:0 0 auto;touch-action:none}.drag-handle:active{cursor:grabbing}.list-row:hover .drag-handle{color:var(--text-dim)}.list-row .grow{flex:1;min-width:0}.list-row .title{font-weight:600;font-size:14.5px}.list-row .meta{color:var(--text-dim);font-size:12.5px}.scrim{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--scrim);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:60;display:grid;place-items:center;padding:20px}.modal{width:min(680px,100%);max-height:88vh;overflow:auto;padding:26px}.modal-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px}.modal-head h3{margin:0;font-size:22px;letter-spacing:-.02em}.toasts{position:fixed;bottom:22px;right:22px;z-index:80;display:flex;flex-direction:column;gap:10px}.toast{padding:13px 16px;border-radius:14px;font-size:14px;font-weight:550;display:flex;align-items:center;gap:10px;box-shadow:var(--shadow);border:1px solid var(--glass-border);background:var(--glass-2);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.toast.ok{border-color:color-mix(in srgb,var(--up) 50%,transparent)}.toast.err{border-color:color-mix(in srgb,var(--down) 50%,transparent)}.detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px;margin:18px 0}.detail-cell{background:var(--glass-2);border-radius:var(--radius-sm);padding:13px}.detail-cell .l{font-size:11.5px;color:var(--text-faint);display:flex;align-items:center;gap:5px}.detail-cell .v{font-size:19px;font-weight:600;margin-top:5px}.daily-row{display:flex;align-items:center;gap:12px;padding:9px 4px;border-top:1px solid var(--glass-border)}.daily-row .day{width:46px;font-weight:600;font-size:13.5px;text-transform:capitalize}.daily-row .emoji{font-size:22px;width:30px;text-align:center}.daily-row .bar{flex:1;height:6px;border-radius:3px;background:linear-gradient(90deg,#4aa3ff,#ffd166,#ff6b6b);opacity:.5}.daily-row .temps{font-size:13.5px;min-width:90px;text-align:right}.daily-row .temps b{font-weight:650}.daily-row .temps span{color:var(--text-faint)}.muted{color:var(--text-dim)}.empty{text-align:center;padding:50px 20px;color:var(--text-dim)}.empty .emoji{font-size:40px;margin-bottom:10px}.spinner{width:18px;height:18px;border:2px solid var(--glass-border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.skeleton{background:linear-gradient(90deg,var(--glass) 25%,var(--glass-2) 50%,var(--glass) 75%);background-size:200% 100%;animation:shimmer 1.4s infinite;border-radius:var(--radius)}@keyframes shimmer{to{background-position:-200% 0}}.badge-soft{font-size:11px;font-weight:650;padding:3px 9px;border-radius:999px;background:var(--accent-soft);color:var(--accent)}.geo-results{border:1px solid var(--glass-border);border-radius:var(--radius-sm);overflow:hidden;margin-top:-6px}.geo-item{display:flex;justify-content:space-between;padding:10px 13px;cursor:pointer;font-size:14px}.geo-item:hover{background:var(--glass-hover)}.geo-item+.geo-item{border-top:1px solid var(--glass-border)}.sim-slider-wrap{margin:6px 0 18px}input[type=range].sim-slider{width:100%;accent-color:var(--accent);height:6px;cursor:pointer}.sim-slider-labels{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:12.5px;color:var(--text-faint)}.sim-slider-labels .up{color:var(--up);font-weight:700;display:inline-flex;align-items:center;gap:4px}.sim-slider-labels .down{color:var(--down);font-weight:700;display:inline-flex;align-items:center;gap:4px}.sim-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:6px}.sim-cell{background:var(--glass-2);border:1px solid var(--glass-border);border-radius:var(--radius-sm);padding:16px;text-align:center}.sim-cell .l{font-size:12px;color:var(--text-faint)}.sim-cell .v{font-size:25px;font-weight:680;margin-top:5px;letter-spacing:-.02em}@media (max-width: 560px){.sim-grid{grid-template-columns:1fr}}.kiosk{position:fixed;top:0;right:0;bottom:0;left:0;z-index:200;overflow:hidden;background:linear-gradient(160deg,var(--bg-0),var(--bg-1));color:var(--text);display:flex;flex-direction:column}.kiosk-exit{position:absolute;top:2.2vh;right:2vw;z-index:6;opacity:.4;transition:opacity .2s}.kiosk:hover .kiosk-exit{opacity:1}.kiosk-head{display:flex;align-items:flex-start;justify-content:space-between;padding:3.4vh 4vw 0;z-index:2}.kiosk-title{font-size:2.4vw;font-weight:650;letter-spacing:-.02em;line-height:1.1}.kiosk-title small{display:block;color:var(--text-dim);font-size:1.15vw;font-weight:500;margin-top:.3vh}.kiosk-clock{text-align:right}.kiosk-clock .time{font-size:4.6vw;font-weight:250;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}.kiosk-clock .date{color:var(--text-dim);font-size:1.35vw;text-transform:capitalize;margin-top:.4vh}.kiosk-stage{flex:1;display:flex;align-items:center;justify-content:center;padding:1vh 5vw;position:relative;z-index:2}.kiosk-slide{width:100%}.k-loading{font-size:2vw;color:var(--text-dim)}.k-city{display:grid;grid-template-columns:1fr 1.05fr;gap:4vw;align-items:center}.k-city-left{text-align:center}.k-city-emoji{font-size:17vw;line-height:1;filter:drop-shadow(0 1.4vh 3vh rgba(0,0,0,.35))}.k-cityname{font-size:3.2vw;font-weight:650;letter-spacing:-.02em;margin-top:1vh}.k-temp{font-size:11vw;font-weight:200;letter-spacing:-.04em;line-height:.9}.k-temp sup{font-size:3.6vw;font-weight:300;vertical-align:super}.k-desc{font-size:1.8vw;color:var(--text-dim);text-transform:capitalize;margin-top:.5vh}.k-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2vw;margin-top:3vh}.k-stat{background:var(--glass);border:1px solid var(--glass-border);border-radius:1.4vw;padding:1.6vw 1.2vw;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);text-align:center}.k-stat .v{font-size:2.1vw;font-weight:620;letter-spacing:-.01em}.k-stat .l{font-size:1vw;color:var(--text-faint);margin-top:.5vh}.k-markets{display:grid;grid-template-columns:repeat(4,1fr);gap:1.6vw}.k-mtile{background:var(--glass);border:1px solid var(--glass-border);border-radius:1.6vw;padding:1.8vw;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.k-mtile .lbl{font-size:1.4vw;color:var(--text-dim);font-weight:600}.k-mtile .price{font-size:3.2vw;font-weight:600;letter-spacing:-.02em;margin:.6vh 0}.k-mtile .chg{font-size:1.6vw;font-weight:700}.kiosk-dots{position:absolute;bottom:1.2vh;left:50%;transform:translate(-50%);display:flex;gap:.8vw}.kiosk-dots i{width:.85vw;height:.85vw;border-radius:50%;background:var(--glass-border);transition:all .3s var(--ease)}.kiosk-dots i.on{background:var(--accent);width:2.4vw;border-radius:999px}.kiosk-ticker{height:7vh;border-top:1px solid var(--glass-border);background:var(--glass);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);display:flex;align-items:center;overflow:hidden;white-space:nowrap;z-index:2}.ticker-track{display:inline-flex;gap:4vw;padding-left:100%;animation:ticker 38s linear infinite}.ticker-item{font-size:1.7vw;display:inline-flex;gap:.7vw;align-items:center;font-weight:500}.ticker-item b{font-weight:700}@keyframes ticker{to{transform:translate(-100%)}}@media (max-width: 640px){.wcard-temp{font-size:44px}.nav a span.label{display:none}.content{padding-top:18px}}
