*{box-sizing:border-box;margin:0;padding:0}:root{--bg:#0f0f0f;--surface:#1a1a1a;--surface2:#242424;--border:#2e2e2e;--text:#f0e8d8;--text-muted:#8a7a6a;--accent:#f5a623;--accent2:#e8855a;--green:#4caf7d;--red:#e05c5c;--blue:#5c9ee0;--radius:16px}body{background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;min-height:100dvh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}#root{flex-direction:column;width:100%;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}button{cursor:pointer;border:none;outline:none;font-family:inherit}input,select{border:none;outline:none;font-family:inherit}.onboarding{flex-direction:column;gap:32px;min-height:100dvh;padding:40px 20px;display:flex}.ob-header{text-align:center}.ob-icon{background:#f5a6231f;border-radius:20px;justify-content:center;align-items:center;width:64px;height:64px;margin:0 auto 16px;display:flex}.ob-header h1{color:var(--text);letter-spacing:-.5px;margin-bottom:6px;font-size:28px;font-weight:700}.ob-header p{color:var(--text-muted);font-size:15px}.ob-step{flex-direction:column;gap:16px;display:flex}.ob-step-title{color:var(--text);align-items:center;gap:8px;font-size:17px;font-weight:600;display:flex}.ob-hint{color:var(--text-muted);font-size:14px;line-height:1.5}.ob-input{background:var(--surface);border:1.5px solid var(--border);color:var(--text);border-radius:12px;width:100%;padding:14px 16px;font-size:15px;transition:border-color .15s}.ob-input:focus{border-color:var(--accent)}.ob-error{color:var(--red);font-size:13px}.ob-btn-primary{background:var(--accent);color:#000;border-radius:14px;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:15px 24px;font-size:16px;font-weight:600;transition:opacity .15s;display:flex}.ob-btn-primary:disabled{opacity:.4}.ob-btn-primary:active:not(:disabled){opacity:.85}.skin-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.skin-card{background:var(--surface);border:2px solid var(--border);text-align:left;border-radius:14px;flex-direction:column;gap:8px;padding:14px 12px;transition:border-color .15s;display:flex}.skin-card.selected{border-color:var(--accent);background:#f5a62314}.skin-swatch{background:var(--skin-color);border-radius:50%;width:32px;height:32px}.skin-label{color:var(--text);font-size:14px;font-weight:600}.skin-desc{color:var(--text-muted);font-size:12px;line-height:1.4}.water-card{background:var(--surface);border:1.5px solid #5c9ee059;border-radius:18px;flex-direction:column;gap:12px;padding:18px 16px 14px;display:flex}.water-header{justify-content:space-between;align-items:center;display:flex}.water-title{color:var(--text);font-size:14px;font-weight:700}.water-goal-label{color:var(--blue);letter-spacing:-.5px;font-size:22px;font-weight:800}.water-progress-row{align-items:center;gap:10px;display:flex}.water-bar-bg{background:var(--border);border-radius:8px;flex:1;height:8px;overflow:hidden}.water-bar-fill{background:linear-gradient(90deg,#5c9ee0,#7dd4fc);border-radius:8px;height:100%;transition:width .5s}.water-pct{color:var(--blue);text-align:right;min-width:36px;font-size:13px;font-weight:700}.water-drops{flex-wrap:wrap;gap:2px;display:flex}.water-drop{opacity:.2;font-size:18px;line-height:1;transition:opacity .3s}.water-drop.filled{opacity:1}.water-amount{text-align:center;font-size:13px}.water-drunk{color:var(--blue);letter-spacing:-1px;font-size:26px;font-weight:800}.water-sep{color:var(--text-muted);margin:0 2px;font-size:16px}.water-total{color:var(--text-muted);font-size:18px;font-weight:600}.water-motivation{background:#5c9ee014;border-radius:10px;padding:10px 12px}.water-mot-text{color:var(--text);font-size:13px;font-weight:600}.water-mot-sub{color:var(--text-muted);margin-top:3px;font-size:12px}.water-btns{gap:8px;display:flex}.water-btn{color:var(--text);background:#5c9ee01f;border:1.5px solid #5c9ee040;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:10px 6px;font-size:14px;transition:background .15s,transform .1s;display:flex}.water-btn:active:not(:disabled){background:#5c9ee038;transform:scale(.96)}.water-btn:disabled{opacity:.35}.water-btn-ml{color:var(--blue);font-size:10px;font-weight:600}.water-reason{color:var(--text-muted);text-align:center;font-size:11px}.sc-card{background:var(--surface);border:1.5px solid color-mix(in srgb, var(--sc-color) 40%, transparent);border-radius:16px;overflow:hidden}.sc-header{text-align:left;background:0 0;justify-content:space-between;align-items:flex-start;gap:12px;width:100%;padding:15px 16px;display:flex}.sc-header-left{flex:1;align-items:flex-start;gap:12px;min-width:0;display:flex}.sc-shield{background:color-mix(in srgb, var(--sc-color) 12%, transparent);border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;display:flex}.sc-title{color:var(--text);margin-bottom:4px;font-size:14px;font-weight:700}.sc-subtitle{font-size:13px;font-weight:500;line-height:1.4}.sc-chevron{color:var(--text-muted);flex-shrink:0;padding-top:2px}.sc-details{border-top:1px solid var(--border);flex-direction:column;gap:10px;margin-top:0;padding:14px 16px 16px;display:flex}.sc-phase{background:var(--surface2);opacity:.6;border-radius:10px;padding:10px 12px}.sc-phase.active{opacity:1;border:1px solid color-mix(in srgb, var(--sc-color) 30%, transparent);background:color-mix(in srgb, var(--sc-color) 6%, var(--surface2))}.sc-phase-label{color:var(--sc-color);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:10px;font-weight:700}.sc-phase-text{color:var(--text);font-size:13px;line-height:1.5}.sc-extra-warn{color:var(--text-muted);background:#f5a62314;border-radius:8px;padding:10px 12px;font-size:12px;line-height:1.5}.dashboard{flex-direction:column;gap:14px;padding:20px 16px;display:flex}.dash-header{margin-bottom:4px}.dash-greeting{color:var(--text-muted);letter-spacing:.3px;margin-bottom:4px;font-size:13px}.dash-title{color:var(--text);letter-spacing:-.5px;font-size:26px;font-weight:700}.location-bar{position:relative}.location-search{background:var(--surface);border:1.5px solid var(--border);border-radius:12px;align-items:center;gap:8px;padding:0 12px;display:flex}.location-search input{color:var(--text);background:0 0;flex:1;padding:12px 0;font-size:14px}.location-search input::placeholder{color:var(--text-muted)}.loc-icon{color:var(--text-muted);flex-shrink:0}.loc-gps{color:var(--text-muted);background:0 0;border-radius:6px;padding:4px;transition:color .15s}.loc-gps:hover{color:var(--accent)}.suggestions{background:var(--surface2);border:1.5px solid var(--border);z-index:50;border-radius:12px;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow:hidden}.suggestion-item{width:100%;color:var(--text);text-align:left;border-bottom:1px solid var(--border);background:0 0;align-items:center;gap:8px;padding:12px 14px;font-size:14px;transition:background .1s;display:flex}.suggestion-item:last-child{border-bottom:none}.suggestion-item:active{background:var(--border)}.dash-error{color:var(--red);background:#e05c5c1a;border:1px solid #e05c5c4d;border-radius:12px;align-items:center;gap:8px;padding:12px 14px;font-size:13px;display:flex}.uv-card{background:var(--surface);border:1.5px solid var(--border);border-radius:18px;flex-direction:column;gap:12px;padding:20px;display:flex}.uv-card.optimal{border-color:var(--accent);background:#f5a6230f}.uv-main{align-items:center;gap:20px;display:flex}.uv-number{color:var(--text);letter-spacing:-2px;font-size:64px;font-weight:700;line-height:1}.uv-label{font-size:20px;font-weight:600}.uv-desc{color:var(--text-muted);margin-top:2px;font-size:12px}.uv-weather{color:var(--text-muted);align-items:center;gap:4px;margin-top:6px;font-size:13px;display:flex}.dash-empty,.dash-loading{background:var(--surface);border:1.5px solid var(--border);color:var(--text-muted);text-align:center;border-radius:18px;flex-direction:column;align-items:center;gap:12px;padding:32px;font-size:14px;display:flex}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:28px;height:28px;animation:.8s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.status-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;align-items:center;gap:14px;padding:16px;display:flex}.status-card.ready{border-color:#4caf7d66}.status-card.waiting{border-color:#f5a62366}.status-title{color:var(--text);font-size:15px;font-weight:600}.status-sub{color:var(--text-muted);margin-top:2px;font-size:12px}.rec-card{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:16px}.rec-title{color:var(--text-muted);letter-spacing:.3px;text-transform:uppercase;margin-bottom:14px;font-size:13px;font-weight:500}.rec-times{align-items:center;gap:0;display:flex}.rec-side{flex-direction:column;flex:1;align-items:center;gap:4px;display:flex}.rec-emoji{font-size:24px}.rec-label{color:var(--text-muted);font-size:12px}.rec-min{color:var(--accent);font-size:24px;font-weight:700}.rec-divider{background:var(--border);width:1px;height:48px}.rec-warning{color:var(--red);align-items:center;gap:6px;margin-top:12px;font-size:12px;display:flex}.rec-info{color:var(--text-muted);text-align:center;margin-top:12px;font-size:12px}.rec-total{color:var(--text-muted);text-align:center;border-top:1px solid var(--border);margin-top:12px;padding-top:10px;font-size:12px}.uv-optimal-badge{color:var(--accent);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.uv-warn-badge{color:var(--red);align-items:center;gap:6px;font-size:13px;font-weight:500;display:flex}.uv-low-badge{color:var(--text-muted);font-size:13px}.windows-card{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:16px}.windows-title{color:var(--text);margin-bottom:12px;font-size:14px;font-weight:600}.windows-list{flex-direction:column;gap:8px;display:flex}.window-item{background:var(--surface2);border:1.5px solid var(--border);border-radius:12px;align-items:center;gap:12px;padding:12px 14px;display:flex}.window-item.best{background:#f5a6230f;border-color:#f5a62366}.window-item.now{background:#4caf7d0f;border-color:#4caf7d80}.window-rank{color:var(--accent);text-align:center;flex-shrink:0;width:20px;font-size:16px;font-weight:700}.window-body{flex:1}.window-time-range{color:var(--text);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.window-now-badge{background:var(--green);color:#000;letter-spacing:.3px;border-radius:20px;padding:2px 7px;font-size:10px;font-weight:700}.window-meta{color:var(--text-muted);margin-top:3px;font-size:12px}.window-uv-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.windows-none{color:var(--text-muted);text-align:center;padding:8px 0;font-size:13px}.afterwork-card{background:var(--surface);border:1.5px solid #5c9ee04d;border-radius:16px;flex-direction:column;gap:10px;padding:16px;display:flex}.afterwork-card-title{color:var(--text);font-size:14px;font-weight:600}.afterwork-forecast-hint{color:var(--text-muted);background:#f5a62312;border:1px solid #f5a62333;border-radius:10px;padding:10px 12px;font-size:13px;line-height:1.55}.afterwork-card-none{color:var(--text-muted);font-size:13px;line-height:1.5}.afterwork-block{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:10px;padding-top:10px;display:flex}.afterwork-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.4px;font-size:12px;font-weight:600}.afterwork-none{color:var(--text-muted);padding:8px 0 2px;font-size:13px;line-height:1.5}.window-item.afterwork{background:#5c9ee00d;border-color:#5c9ee04d}.window-item.afterwork.weak{border-color:var(--border);background:var(--surface2);opacity:.8}.afterwork-tip{color:var(--text-muted)}.hourly-item.now .hourly-time{color:var(--accent);font-weight:600}.tips-card{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;padding:16px}.tips-header{color:var(--accent);text-transform:uppercase;letter-spacing:.4px;align-items:center;gap:6px;margin-bottom:12px;font-size:12px;font-weight:600;display:flex}.tips-nav{color:var(--text-muted);text-transform:none;letter-spacing:0;align-items:center;gap:4px;margin-left:auto;font-size:12px;font-weight:400;display:flex}.tips-nav button{background:var(--surface2);border:1px solid var(--border);color:var(--text-muted);border-radius:6px;justify-content:center;align-items:center;width:26px;height:26px;transition:color .15s;display:flex}.tips-nav button:active{color:var(--accent)}.tips-body{align-items:flex-start;gap:12px;display:flex}.tip-emoji{flex-shrink:0;margin-top:2px;font-size:28px;line-height:1}.tip-title{color:var(--text);margin-bottom:6px;font-size:14px;font-weight:700}.tip-text{color:var(--text-muted);font-size:13px;line-height:1.55}.tip-source{color:var(--text-muted);opacity:.6;margin-top:8px;font-size:11px;font-style:italic}.window-card{background:#f5a62314;border:1.5px solid #f5a62340;border-radius:14px;padding:14px 16px}.window-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:4px;font-size:12px}.window-time{color:var(--accent);font-size:18px;font-weight:600}.hourly{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;padding:16px}.hourly-title{color:var(--text-muted);text-transform:uppercase;letter-spacing:.3px;margin-bottom:12px;font-size:13px}.hourly-scroll{scrollbar-width:none;gap:8px;padding-bottom:4px;display:flex;overflow-x:auto}.hourly-scroll::-webkit-scrollbar{display:none}.hourly-item{flex-direction:column;align-items:center;gap:6px;min-width:44px;display:flex}.hourly-time{color:var(--text-muted);font-size:10px}.hourly-bar-wrap{align-items:flex-end;height:64px;display:flex}.hourly-bar{border-radius:4px;width:8px;min-height:4px;transition:height .3s}.hourly-uv{font-size:10px;font-weight:600}.start-btn{background:var(--accent);color:#000;border-radius:16px;justify-content:center;align-items:center;gap:10px;margin-top:4px;padding:16px;font-size:16px;font-weight:700;transition:opacity .15s,transform .1s;display:flex}.start-btn:active:not(.disabled){transform:scale(.98)}.start-btn.disabled{opacity:.35;cursor:not-allowed}.timer-page{flex-direction:column;align-items:center;gap:32px;min-height:100dvh;padding:60px 24px 40px;display:flex;position:relative}.timer-cancel{background:var(--surface);border:1.5px solid var(--border);width:40px;height:40px;color:var(--text-muted);border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;top:20px;right:20px}.timer-side{color:var(--text);align-items:center;gap:10px;font-size:18px;font-weight:600;display:flex}.timer-side-emoji{font-size:24px}.timer-side-count{color:var(--text-muted);font-size:13px;font-weight:400}.timer-ring-wrap{width:260px;height:260px;position:relative}.timer-svg{position:absolute;top:0;left:0}.timer-display{flex-direction:column;justify-content:center;align-items:center;gap:6px;display:flex;position:absolute;inset:0}.timer-time{color:var(--text);letter-spacing:-2px;font-variant-numeric:tabular-nums;font-size:52px;font-weight:700}.timer-label{color:var(--text-muted);font-size:14px}.timer-actions{gap:12px;width:100%;display:flex}.timer-btn-secondary{background:var(--surface);border:1.5px solid var(--border);color:var(--text);border-radius:14px;flex:1;padding:14px;font-size:15px;font-weight:600;transition:opacity .15s}.timer-btn-secondary:active{opacity:.7}.timer-btn-skip{background:var(--accent);color:#000;border-radius:14px;flex:1;justify-content:center;align-items:center;gap:8px;padding:14px;font-size:15px;font-weight:600;transition:opacity .15s;display:flex}.timer-btn-skip:active{opacity:.85}.timer-flip-hint{color:var(--accent);text-align:center;background:#f5a6231f;border:1.5px solid #f5a6234d;border-radius:12px;padding:12px 20px;font-size:15px;font-weight:600;animation:2s ease-in-out infinite pulse}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.timer-done{text-align:center;flex-direction:column;align-items:center;gap:16px;padding-top:40px;display:flex}.timer-done-icon{background:#4caf7d1f;border-radius:50%;justify-content:center;align-items:center;width:80px;height:80px;display:flex}.timer-done h2{color:var(--text);font-size:24px;font-weight:700}.timer-done p{color:var(--text-muted);font-size:15px}.timer-done-stats{background:var(--surface);border:1.5px solid var(--border);width:100%;color:var(--text-muted);text-align:left;border-radius:14px;flex-direction:column;gap:10px;padding:18px 20px;font-size:14px;display:flex}.timer-done-stats strong{color:var(--text)}.timer-done-btn{background:var(--green);color:#000;border-radius:16px;width:100%;margin-top:8px;padding:16px 32px;font-size:16px;font-weight:700}.history{flex-direction:column;gap:16px;padding:20px 16px;display:flex}.history-header h2{color:var(--text);font-size:22px;font-weight:700}.history-stats{background:var(--surface);border:1.5px solid var(--border);border-radius:16px;display:flex;overflow:hidden}.h-stat{text-align:center;border-right:1px solid var(--border);flex:1;padding:16px}.h-stat:last-child{border-right:none}.h-stat-val{color:var(--accent);font-size:24px;font-weight:700}.h-stat-label{color:var(--text-muted);margin-top:2px;font-size:11px}.history-list{flex-direction:column;gap:10px;display:flex}.h-item{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;justify-content:space-between;align-items:center;padding:14px 16px;display:flex}.h-item-left{align-items:center;gap:12px;display:flex}.h-uv-dot{border-radius:50%;flex-shrink:0;width:10px;height:10px}.h-date{color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.h-time{color:var(--text-muted);font-size:12px;font-weight:400}.h-meta{color:var(--text-muted);margin-top:3px;font-size:12px}.h-duration{color:var(--text);text-align:right;font-size:20px;font-weight:700}.h-duration small{color:var(--text-muted);margin-left:2px;font-size:11px;font-weight:400}.history-empty{min-height:60vh;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;font-size:15px;display:flex}.history-empty span{font-size:13px}.settings{flex-direction:column;gap:24px;padding:20px 16px;display:flex}.settings h2{color:var(--text);font-size:22px;font-weight:700}.settings-section{flex-direction:column;gap:8px;display:flex}.settings-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:0 4px;font-size:12px;font-weight:600}.skin-list{background:var(--surface);border:1.5px solid var(--border);border-radius:14px;overflow:hidden}.skin-row{width:100%;color:var(--text);border-bottom:1px solid var(--border);background:0 0;align-items:center;gap:12px;padding:13px 16px;font-size:14px;transition:background .1s;display:flex}.skin-row:last-child{border-bottom:none}.skin-row:active{background:var(--surface2)}.skin-row span{text-align:left;flex:1}.skin-row.active{background:#f5a6230f}.skin-row-swatch{border-radius:50%;width:22px;height:22px}.weight-row{align-items:center;gap:10px;display:flex}.weight-unit{color:var(--text-muted);font-size:15px;font-weight:600}.api-key-row{gap:8px;display:flex}.settings-input{background:var(--surface);border:1.5px solid var(--border);color:var(--text);border-radius:10px;flex:1;padding:12px 14px;font-size:14px}.settings-input:focus{border-color:var(--accent)}.save-btn{background:var(--accent);color:#000;white-space:nowrap;border-radius:10px;padding:12px 16px;font-size:14px;font-weight:600}.settings-hint{color:var(--text-muted);padding:0 4px;font-size:12px;line-height:1.5}.danger-row{background:var(--surface);border:1.5px solid var(--border);color:var(--red);border-radius:12px;align-items:center;gap:10px;width:100%;padding:13px 16px;font-size:14px;font-weight:500;transition:opacity .15s;display:flex}.danger-row:active{opacity:.7}.confirm-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.confirm-card{background:var(--surface2);border:1.5px solid var(--border);border-radius:20px;flex-direction:column;gap:12px;width:100%;max-width:320px;padding:24px;display:flex}.confirm-card h3{color:var(--text);font-size:18px;font-weight:700}.confirm-card p{color:var(--text-muted);font-size:14px}.confirm-btns{gap:10px;margin-top:4px;display:flex}.confirm-cancel{background:var(--border);color:var(--text);border-radius:10px;flex:1;padding:12px;font-size:14px;font-weight:600}.confirm-ok{background:var(--red);color:#fff;border-radius:10px;flex:1;padding:12px;font-size:14px;font-weight:600}.settings-info{background:var(--surface);border:1.5px solid var(--border);color:var(--text-muted);border-radius:14px;flex-direction:column;gap:8px;padding:16px;font-size:12px;line-height:1.6;display:flex}.nav{-webkit-backdrop-filter:blur(20px);border-top:1px solid var(--border);width:100%;max-width:480px;padding:8px 0 env(safe-area-inset-bottom,8px);z-index:100;background:#121212eb;display:flex;position:fixed;bottom:0;left:50%;transform:translate(-50%)}.nav-btn{color:var(--text-muted);letter-spacing:.3px;background:0 0;flex-direction:column;flex:1;align-items:center;gap:4px;padding:6px 0;font-size:11px;transition:color .15s;display:flex}.nav-btn.active{color:var(--accent)}.nav-btn:active{opacity:.7}.app{flex-direction:column;min-height:100dvh;display:flex}.app-content{flex:1;padding-bottom:80px;overflow-y:auto}
