@import "https://fonts.googleapis.com/css2?family=Ubuntu:wght@300;400;500;700&display=swap";:root{--accent:#35c9ff;--accent-lt:#73d8ff;--bg-panel:#040c12ad;--border:#ffffff14;--text-muted:#ffffffad;--radius-sm:12px;--radius-md:18px;--radius-lg:24px;--font-system:"Ubuntu", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif}body{font-family:var(--font-system);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;background:#071018;margin:0;overflow:hidden}*{box-sizing:border-box;font-family:inherit}button,input,textarea,select{font:inherit}#app{width:100vw;height:100vh}#preloader{z-index:999999;background:radial-gradient(circle at top,#10263b 0%,#08111c 45%,#03070c 100%);flex-direction:column;justify-content:center;align-items:center;gap:24px;transition:opacity 1s,visibility 1s;display:flex;position:fixed;inset:0}#preloader.hidden{opacity:0;visibility:hidden;pointer-events:none}.preloader-logo{object-fit:contain;filter:brightness(0)invert()drop-shadow(0 0 14px #78c8ff73)drop-shadow(0 0 30px #78c8ff33);width:190px;height:190px;animation:4s ease-in-out infinite logoGlow}.preloader-text{color:#ffffffe0;letter-spacing:.45em;font-size:14px;font-weight:700}@keyframes logoGlow{0%{opacity:.7}50%{opacity:1}to{opacity:.7}}.weather-box{z-index:10;scrollbar-width:none;-ms-overflow-style:none;border-radius:var(--radius-lg);color:#fff;background:var(--bg-panel);border:1px solid var(--border);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);width:292px;max-height:calc(100vh - 44px);padding:18px;transition:opacity .25s,transform .25s,filter .25s,background .35s,max-height .35s;position:fixed;top:22px;left:22px;overflow:hidden auto;box-shadow:0 24px 70px #0000006b,inset 0 1px #ffffff0a}.weather-box::-webkit-scrollbar{width:6px}.weather-box::-webkit-scrollbar-thumb{background:#35c9ff59;border-radius:999px}.weather-box.is-changing{opacity:.35;filter:blur(4px);transform:translateY(8px)scale(.985)}.weather-box.is-collapsed{max-height:72px;padding-bottom:12px}body[data-phase=night] .weather-box{background:#020712d1}body[data-phase=sunrise] .weather-box,body[data-phase=sunset] .weather-box{background:#231612b8}body[data-phase=day] .weather-box{background:#040c12a3}.weather-panel-header{color:#fff;cursor:pointer;text-align:center;letter-spacing:.24em;background:0 0;border:none;border-bottom:1px solid #ffffff14;justify-content:center;align-items:center;width:100%;margin:0 0 14px;padding:0 0 12px;font-size:18px;font-weight:700;transition:opacity .25s,transform .25s;display:flex}.weather-panel-header:hover{opacity:.8}.weather-panel-content{transition:max-height .35s,opacity .25s,transform .25s;overflow:hidden}.weather-box:not(.is-collapsed) .weather-panel-content{opacity:1;max-height:1200px;transform:translateY(0)}.weather-box.is-collapsed .weather-panel-content{opacity:0;pointer-events:none;max-height:0;transform:translateY(-8px)}.weather-search-wrap{position:relative}.weather-search{gap:8px;margin:10px 0 16px;display:flex}.weather-search input{border-radius:var(--radius-sm);color:#fff;background:#001428ad;border:1px solid #ffffff1f;outline:none;flex:1;min-width:0;padding:10px 12px;transition:border-color .25s,background .25s}.weather-search input:focus{background:#001830d1;border-color:#73d8ff73}.weather-search input::placeholder{color:#ffffff80}.weather-search button{border-radius:var(--radius-sm);background:var(--accent);color:#001018;cursor:pointer;border:none;padding:10px 14px;font-weight:700;transition:transform .2s,background .2s,box-shadow .2s}.weather-search button:hover{background:var(--accent-lt);transform:translateY(-1px);box-shadow:0 8px 22px #35c9ff40}.city-suggestions{z-index:50;border-radius:var(--radius-md);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:linear-gradient(#081622f5,#030910f5);border:1px solid #78dcff2e;display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden;box-shadow:0 18px 45px #0000006b,inset 0 1px #ffffff0f}.city-suggestions.is-visible{display:grid}.city-suggestion{color:#fff;text-align:left;cursor:pointer;background:0 0;border:none;border-bottom:1px solid #ffffff0f;gap:3px;width:100%;padding:11px 13px;display:grid}.city-suggestion:last-child{border-bottom:none}.city-suggestion:hover{background:#35c9ff1f}.city-suggestion span{font-size:13px;font-weight:700}.city-suggestion small{color:#ffffff94;font-size:11px}.compact-weather-card{border-radius:var(--radius-md);background:linear-gradient(#ffffff13,#ffffff09);border:1px solid #ffffff0f;justify-content:space-between;align-items:center;gap:14px;margin:4px 0 14px;padding:14px;display:flex}.compact-location{min-width:0}.compact-kicker{color:#ffffff85;letter-spacing:.12em;text-transform:uppercase;margin-bottom:4px;font-size:10px;font-weight:700;display:block}.compact-location h2{color:#fff;white-space:nowrap;text-overflow:ellipsis;margin:0;font-size:20px;line-height:1.1;overflow:hidden}.compact-temperature{color:var(--accent);letter-spacing:-.08em;flex-shrink:0;font-size:34px;font-weight:700}.compact-temperature span{letter-spacing:0;margin-left:2px;font-size:16px;font-weight:500}.compact-grid{grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px;display:grid}.compact-stat{border-radius:var(--radius-sm);background:#ffffff0b;border:1px solid #ffffff0b;min-width:0;padding:11px 12px}.compact-stat span{color:#ffffff8a;letter-spacing:.11em;text-transform:uppercase;margin-bottom:5px;font-size:10px;font-weight:700;display:block}.compact-stat strong{color:var(--accent);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:700;display:block;overflow:hidden}.panel-loading-content{text-align:center;place-items:center;gap:12px;padding:22px 0;display:grid}.panel-loading-content p{color:#ffffffc2;margin:0}.loading-orb{border:3px solid #73d8ff33;border-top-color:var(--accent-lt);border-radius:50%;width:38px;height:38px;animation:.9s linear infinite spin;box-shadow:0 0 20px #73d8ff59}@keyframes spin{to{transform:rotate(360deg)}}.weather-row{color:var(--text-muted);justify-content:space-between;align-items:center;gap:10px;margin:8px 0;font-size:13px;display:flex}.weather-row strong{color:var(--accent);text-align:right}.sea-state{border-radius:var(--radius-md);background:#ffffff0d;border:1px solid #ffffff0a;align-items:center;gap:12px;margin:14px 0 12px;padding:13px;display:flex}.wave-icon{font-size:34px}.sea-state h3{margin:0 0 4px;font-size:16px}.sea-state p{color:var(--text-muted);margin:0;font-size:12px;line-height:1.35}.sea-state.calm h3{color:#4aa3ff}.sea-state.light h3{color:#61d394}.sea-state.strong h3{color:#ff9f43}.sea-state.storm h3{color:#ff4d4d}.bar{background:#ffffff14;border-radius:999px;width:100%;height:8px;margin-bottom:12px;overflow:hidden}.bar div{background:linear-gradient(90deg, var(--accent), #ff9f43, #ff4d4d);border-radius:999px;height:100%;transition:width .45s}.details-toggle{border-radius:var(--radius-sm);color:#fff;cursor:pointer;background:#35c9ff12;border:1px solid #73d8ff24;justify-content:space-between;align-items:center;width:100%;margin:10px 0 0;padding:11px 13px;display:flex}.details-toggle span{color:#fffc;letter-spacing:.12em;text-transform:uppercase;font-size:12px;font-weight:700}.details-toggle strong{color:var(--accent);font-size:18px;line-height:1}.details-toggle:hover{background:#35c9ff1f}.weather-details{opacity:0;max-height:0;margin-top:0;transition:max-height .35s,opacity .25s,margin-top .25s;overflow:hidden}.weather-details.is-open{opacity:1;max-height:420px;margin-top:12px}.floating-compass-hud{z-index:9;color:#fff;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);pointer-events:none;background:linear-gradient(#081622ad,#030910d1);border:1px solid #78dcff2e;border-radius:28px;place-items:center;padding:16px 16px 14px;display:grid;position:fixed;bottom:24px;right:24px;box-shadow:0 22px 70px #0000006b,inset 0 1px #ffffff14}.compass-title{text-transform:uppercase;letter-spacing:.12em;color:#ffffff9e;margin-bottom:10px;font-size:.78rem}.compass-meta{letter-spacing:.08em;text-transform:uppercase;color:#73d8ffe6;margin-top:10px;font-size:.74rem;font-weight:700}.compass{background:radial-gradient(circle,#50b4ff33,#001224db 64%),conic-gradient(#ffffff38 0deg,#ffffff0a 2deg,#0000 3deg 42deg,#ffffff24 45deg,#0000 48deg 87deg,#ffffff38 90deg,#0000 93deg 132deg,#ffffff24 135deg,#0000 138deg 177deg,#ffffff38 180deg,#0000 183deg 222deg,#ffffff24 225deg,#0000 228deg 267deg,#ffffff38 270deg,#0000 273deg 312deg,#ffffff24 315deg,#0000 318deg 360deg);border:1px solid #78dcff73;border-radius:50%;width:132px;height:132px;position:relative;box-shadow:inset 0 0 28px #28c8ff29,0 0 26px #38c8f038}.compass-ring{border:1px solid #ffffff29;border-radius:50%;position:absolute;inset:10px}.compass:before{content:"";border:1px dashed #ffffff21;border-radius:50%;position:absolute;inset:22px}.compass-label{color:#ffffffdb;pointer-events:none;font-size:.72rem;font-weight:800;line-height:1;position:absolute;transform:translate(-50%,-50%)}.compass-n{color:#ff5c5c;font-size:.9rem;top:9%;left:50%}.compass-s{top:91%;left:50%}.compass-e{top:50%;left:91%}.compass-w{top:50%;left:9%}.compass-ne{opacity:.7;top:21%;left:79%}.compass-se{opacity:.7;top:79%;left:79%}.compass-sw{opacity:.7;top:79%;left:21%}.compass-nw{opacity:.7;top:21%;left:21%}.compass-needle{transform-origin:50%;z-index:4;width:8px;height:112px;transition:none;position:absolute;top:50%;left:50%}.needle-head{filter:drop-shadow(0 0 8px #ff3c3c99);border:8px solid #0000;border-bottom:54px solid #ff4d4d;width:0;height:0;position:absolute;top:0;left:50%;transform:translate(-50%)}.needle-tail{border:6px solid #0000;border-top:50px solid #78d2ffd1;width:0;height:0;position:absolute;bottom:0;left:50%;transform:translate(-50%)}.compass-center{z-index:5;background:#fff;border:3px solid #12364d;border-radius:50%;width:15px;height:15px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 12px #ffffffb3}@media (width<=640px){.weather-box{border-radius:var(--radius-md);width:auto;max-height:calc(100vh - 28px);padding:16px;top:14px;left:14px;right:14px}.weather-box.is-collapsed{max-height:64px}.weather-panel-header{margin-bottom:12px;padding-bottom:10px;font-size:16px}.compact-weather-card{padding:12px}.compact-location h2{font-size:18px}.compact-temperature{font-size:30px}.compact-grid{gap:7px}.compact-stat{padding:10px}.compact-stat strong,.weather-row{font-size:12px}.sea-state{padding:12px}.wave-icon{font-size:32px}.floating-compass-hud{border-radius:22px;padding:12px;bottom:14px;right:14px}.floating-compass-hud .compass{width:98px;height:98px}.floating-compass-hud .compass-needle{height:82px}.floating-compass-hud .compass-meta{font-size:.65rem}.needle-head{border-bottom-width:40px}.needle-tail{border-top-width:36px}}
