:root{--ink:#2a2620;--ink-soft:#5a5247;--ink-mute:#8a8175;--paper:#f6f1e7;--paper-2:#efe7d6;--line:rgba(42,38,32,.12);--line-strong:rgba(42,38,32,.24);--accent:#b56a3c;--accent-soft:#e8c8a8;font-family:Helvetica,Arial,sans-serif}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html,body,#root{height:100%;margin:0;padding:0;overflow:hidden}body{background:var(--paper);color:var(--ink);font-family:Helvetica,Arial,sans-serif;font-size:14px;letter-spacing:.01em;-webkit-font-smoothing:antialiased}button{font:inherit;color:inherit;cursor:pointer;background:none;border:0;padding:0}.app{position:relative;width:100%;height:100%;overflow:hidden}.topbar{position:absolute;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:22px 28px;z-index:30;pointer-events:none}.topbar>*{pointer-events:auto}.brand{font-family:Cormorant Garamond,Georgia,serif;font-size:26px;font-weight:500;letter-spacing:.04em;color:var(--ink);display:flex;align-items:baseline;gap:10px}.brand .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;transform:translateY(-2px)}.brand small{font-family:Helvetica,Arial,sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute);font-weight:400}.brand .brand-short{display:none}.weather-pills{display:flex;gap:6px;background:#f6f1e7b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--line);border-radius:999px;padding:5px}.weather-pills button{padding:7px 14px;border-radius:999px;font-size:12px;letter-spacing:.04em;color:var(--ink-soft);display:inline-flex;align-items:center;gap:7px;transition:background .2s,color .2s}.weather-pills button .glyph{font-size:13px;line-height:1}.weather-pills button.active{background:var(--ink);color:var(--paper)}.weather-pills .time-chip{display:inline-flex;align-items:center;gap:7px;padding:7px 12px 7px 10px;font-size:12px;letter-spacing:.04em;color:var(--ink-soft);border-left:1px solid var(--line);margin-left:4px}.weather-pills .time-chip .glyph{font-size:13px;line-height:1}.app.night .topbar .brand,.app.night .topbar .brand small{color:#f5efe1}.app.night .topbar .brand .dot{background:#f3c87a}.app.night .weather-pills{background:#14161c8c;border-color:#ffffff1a}.app.night .weather-pills button{color:#cfc8b8}.app.night .weather-pills button.active{background:#f5efe1;color:#1a1c22}.app.night .weather-pills .time-chip{color:#cfc8b8;border-left-color:#ffffff29}.app.night .stats,.app.night .stats .num{color:#f5efe1}.app.night .stats{color:#a8a294}.app.night .dock .panel{background:#120f0aeb;border-color:#ffffff21;box-shadow:0 18px 40px -22px #000000b3}.app.night .dock .digits{color:#f0ebe0}.app.night .dock .timer-head .label{color:#f0ebe080}.app.night .dock .timer-head .target{color:#f0ebe0a6}.app.night .dock .timer-head .target b{color:#f0ebe0}.app.night .dock .ph{color:#f0ebe080}.app.night .dock .preset{color:#f0ebe0b3;border-color:#ffffff26}.app.night .dock .preset.active{background:#f0ebe0eb;color:#18150f;border-color:transparent}.app.night .dock .preset.custom{background:#b56a3c26;border-color:#b56a3c66;color:#e8c8a8}.app.night .dock .preset.custom input{background:#ffffff14;border-color:#b56a3c66;color:#f0ebe0}.app.night .dock .preset.custom.active input{background:#ffffff24;border-color:#ffffff59;color:#fff}.app.night .dock .btn{color:#f0ebe0cc;border-color:#ffffff2e}.app.night .dock .btn.primary{background:#f0ebe0e6;color:#18150f;border-color:transparent}.app.night .dock .btn.primary:hover{background:#fff}.app.night .dock .btn.ghost{color:#f0ebe080}.app.night .dock .species{background:linear-gradient(180deg,#282218d9,#1a160ef2);border-color:#ffffff24}.app.night .dock .species.active{border-color:#f0ebe0bf;box-shadow:0 0 0 2px #f0ebe0bf inset,0 0 0 4px #120f0aeb inset}.app.night .dock .timer-bar{background:#ffffff1a}.app.night .dock .water-toggle{color:#f0ebe0a6;border-color:#ffffff26}.app.night .dock .water-toggle b{color:#e8c8a8}.stage{position:absolute;top:0;right:0;bottom:0;left:0;overflow:hidden}.sky{position:absolute;top:0;right:0;bottom:0;left:0;transition:background 1.2s ease}.ground{position:absolute;left:0;right:0;bottom:0;height:42%;pointer-events:none;transition:filter 1.2s ease}.trees-layer{position:absolute;left:0;right:0;bottom:0;height:100%;pointer-events:none}.tree-slot{position:absolute;bottom:0;transform-origin:50% 100%;cursor:pointer;pointer-events:auto}.tree-slot .label{position:absolute;top:-26px;left:50%;transform:translate(-50%);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);background:#f6f1e7d9;padding:3px 8px;border-radius:999px;white-space:nowrap;opacity:0;transition:opacity .2s;border:1px solid var(--line)}.tree-slot:hover .label{opacity:1}.tree-slot.selected .label{opacity:1;color:var(--accent);border-color:var(--accent-soft)}.sway{transform-origin:50% 100%;animation:sway 6s ease-in-out infinite}@keyframes sway{0%,to{transform:rotate(-1.2deg)}50%{transform:rotate(1.2deg)}}.sway-sm{transform-origin:50% 100%;animation:swaySm 4.2s ease-in-out infinite}@keyframes swaySm{0%{transform:rotate(-1.6deg)}30%{transform:rotate(2deg)}60%{transform:rotate(-1.2deg)}to{transform:rotate(-1.6deg)}}.windy .sway{animation:swayHard 1.8s ease-in-out infinite}@keyframes swayHard{0%,to{transform:rotate(-3.5deg)}50%{transform:rotate(3.5deg)}}.bamboo-grove{display:inline-block}.bs{transform-box:fill-box;transform-origin:bottom center;animation:bambooBend 2.6s ease-in-out infinite}.pf{transform-box:fill-box;transform-origin:center 85%;animation:palmFrond 3s ease-in-out infinite}@keyframes palmFrond{0%,to{transform:rotate(-3.5deg)}40%{transform:rotate(4deg)}70%{transform:rotate(-2deg)}}.windy .pf{animation-name:palmFrondHard;animation-duration:1.1s}@keyframes palmFrondHard{0%,to{transform:rotate(-7deg)}40%{transform:rotate(9deg)}70%{transform:rotate(-4deg)}}@keyframes bambooBend{0%,to{transform:rotate(-2.8deg)}35%{transform:rotate(3.6deg)}65%{transform:rotate(-1.6deg)}}.windy .bs{animation-name:bambooBendHard;animation-duration:1.1s}@keyframes bambooBendHard{0%,to{transform:rotate(-6deg)}35%{transform:rotate(8deg)}65%{transform:rotate(-4deg)}}.dock{position:absolute;left:50%;bottom:32px;transform:translate(-50%);z-index:25;display:flex;flex-direction:column;align-items:stretch;gap:10px;width:520px}.dock-collapse{align-self:center;display:inline-flex;align-items:center;gap:10px;background:#f6f1e7eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-size:12px;letter-spacing:.06em;color:var(--ink-soft);box-shadow:0 10px 24px -16px #0000004d;cursor:pointer;transition:background .15s,border-color .15s}.dock-collapse:hover{background:var(--paper);border-color:var(--line-strong)}.dock-collapse .swatch{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.dock-collapse .mini-digits{font-family:JetBrains Mono,ui-monospace,monospace;color:var(--ink);font-variant-numeric:tabular-nums}.dock-collapse .chev{font-size:10px;color:var(--ink-mute)}.dock.collapsed{gap:0}.app.night .dock-collapse{background:#16120cd1;border-color:#ffffff24;color:#f0ebe0b3}.app.night .dock-collapse .mini-digits{color:#f0ebe0}.dock-collapse{cursor:grab}.dock-collapse:active{cursor:grabbing}.panel{background:#f6f1e7eb;-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);border:1px solid var(--line);border-radius:18px;box-shadow:0 18px 40px -22px #00000059}.timer-card{padding:22px 26px 18px;width:100%}.timer-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.timer-head .label{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute)}.timer-head .target{font-size:12px;letter-spacing:.04em;color:var(--ink-soft);display:flex;align-items:center;gap:8px}.timer-head .target b{font-weight:500;color:var(--ink)}.timer-head .target .swatch{width:10px;height:10px;border-radius:50%;background:var(--accent)}.digits{font-family:JetBrains Mono,ui-monospace,Menlo,monospace;font-weight:300;font-size:84px;letter-spacing:-.02em;line-height:1;color:var(--ink);display:flex;align-items:baseline;justify-content:center;gap:2px;font-variant-numeric:tabular-nums}.digits .sep{opacity:.35;animation:blink 1.2s steps(2) infinite}.timer-card.idle .digits .sep{animation:none;opacity:.35}@keyframes blink{50%{opacity:.05}}.presets{display:flex;gap:6px;justify-content:center;margin-top:14px;flex-wrap:wrap}.preset{padding:7px 12px;border:1px solid var(--line);border-radius:999px;font-size:12px;color:var(--ink-soft);letter-spacing:.04em;background:transparent;transition:all .15s}.preset:hover{border-color:var(--line-strong);color:var(--ink)}.preset.active{background:var(--ink);color:var(--paper);border-color:var(--ink)}.preset.custom{display:inline-flex;align-items:center;gap:6px;border-style:dashed;padding:7px 12px 7px 10px;background:#b56a3c0f;border-color:var(--accent-soft);color:var(--accent)}.preset.custom .custom-label{font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-right:2px}.preset.custom input{width:38px;background:#fff;border:1px solid var(--accent-soft);border-radius:6px;padding:2px 4px;outline:0;font:inherit;color:var(--ink);text-align:center;font-variant-numeric:tabular-nums;font-weight:500}.preset.custom input:focus{border-color:var(--accent)}.preset.custom.active{background:var(--accent);border-color:var(--accent);color:#fff}.preset.custom.active .custom-label{color:#ffffffd9}.preset.custom.active input{background:#ffffff1f;border-color:#ffffff59;color:#fff}.preset.custom input::-webkit-outer-spin-button,.preset.custom input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.controls{display:flex;gap:8px;justify-content:center;margin-top:14px}.btn{height:40px;padding:0 22px;border-radius:999px;display:inline-flex;align-items:center;gap:8px;font-size:13px;letter-spacing:.06em;border:1px solid var(--line);background:transparent;color:var(--ink);transition:all .15s}.btn:hover{border-color:var(--line-strong)}.btn.primary{background:var(--ink);color:var(--paper);border-color:var(--ink)}.btn.primary:hover{background:#000}.btn.ghost{color:var(--ink-soft)}.btn.danger{color:#b03a2e;border-color:#e8a89e}.btn.danger:hover{background:#fdf0ee}.btn:disabled{opacity:.4;cursor:not-allowed}.timer-bar{margin:14px 0 0;height:3px;width:100%;background:#2a26201a;border-radius:999px;overflow:hidden}.timer-bar-fill{height:100%;border-radius:999px;transition:width 1s linear,background .3s}.picker{padding:14px 18px;display:flex;flex-direction:row;align-items:center;gap:12px;flex-wrap:wrap}.picker .ph{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);flex:0 0 auto}.species-row{display:flex;gap:6px;flex-wrap:nowrap;flex:1 1 auto;justify-content:flex-end;overflow-x:auto;scrollbar-width:none;-webkit-overflow-scrolling:touch}.species-row::-webkit-scrollbar{display:none}.species{width:42px;height:50px;border:1px solid var(--line);border-radius:10px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:2px;background:linear-gradient(180deg,#f9f3e6,#efe6d2);transition:all .15s}.species:hover{border-color:var(--line-strong)}.species.active{border-color:var(--ink);box-shadow:0 0 0 2px var(--ink) inset,0 0 0 4px var(--paper) inset}.water-toggle{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--ink-soft);padding:8px 10px;border:1px dashed var(--line-strong);border-radius:10px;width:100%}.water-toggle b{color:var(--accent);font-weight:500}.toast{position:absolute;top:80px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--paper);padding:10px 18px;border-radius:999px;font-size:12px;letter-spacing:.06em;z-index:50;animation:toastIn .4s ease;white-space:nowrap}@keyframes toastIn{0%{opacity:0;transform:translate(-50%,-8px)}to{opacity:1;transform:translate(-50%)}}.stats{position:absolute;left:28px;top:78px;display:flex;flex-direction:column;gap:6px;z-index:10;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-mute)}.stats .num{font-family:Cormorant Garamond,Georgia,serif;font-size:32px;letter-spacing:0;text-transform:none;color:var(--ink);font-weight:500;line-height:1}.sun{position:absolute;width:120px;height:120px;border-radius:50%;background:radial-gradient(circle at 50% 50%,#ffe9b0,#ffd06a 60%,#ffd06a00 72%);filter:blur(.5px);transform:translate(-50%,-50%);transition:left 60s linear,top 60s linear}.cloud{position:absolute;background:#ffffffd9;border-radius:999px;filter:blur(2px);animation:drift 60s linear infinite}@keyframes drift{0%{transform:translate(-10vw)}to{transform:translate(110vw)}}.flake,.petal{position:absolute;top:-20px;pointer-events:none;will-change:transform}.flake{width:6px;height:6px;border-radius:50%;background:#fffffff2;box-shadow:0 0 6px #ffffffb3}.petal{width:10px;height:6px;background:#f3b6c4;border-radius:60%/80% 80% 60% 60%;transform:rotate(20deg);opacity:.85}.moon{position:absolute;width:90px;height:90px;border-radius:50%;background:radial-gradient(circle at 35% 35%,#f4eedb,#d8c79a 70%,#d8c79a00);opacity:.75;transform:translate(-50%,-50%);transition:left 60s linear,top 60s linear}.scrim{position:absolute;top:0;right:0;bottom:0;left:0;background:#14120f73;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:60;display:flex;align-items:center;justify-content:center;animation:fade .3s ease}@keyframes fade{0%{opacity:0}to{opacity:1}}.dialog{background:var(--paper);border:1px solid var(--line);border-radius:24px;padding:34px 36px 28px;width:440px;text-align:center;box-shadow:0 30px 80px -20px #0006;position:relative}.dialog h2{font-family:Cormorant Garamond,Georgia,serif;font-weight:500;font-size:34px;margin:18px 0 6px;letter-spacing:.01em}.dialog p{color:var(--ink-soft);font-size:13px;line-height:1.55;margin:0 0 18px}.dialog .preview{height:160px;display:flex;align-items:flex-end;justify-content:center;margin:0 -8px 8px}.dialog input[type=text]{width:100%;font:inherit;font-size:15px;padding:12px 14px;border:1px solid var(--line-strong);background:#fff;border-radius:12px;outline:none;text-align:center;letter-spacing:.04em;color:var(--ink)}.dialog input[type=text]:focus{border-color:var(--ink)}.dialog .row{display:flex;gap:10px;margin-top:14px}.dialog .row .btn{flex:1;justify-content:center}.dialog .close{position:absolute;top:12px;right:14px;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;color:var(--ink-mute);border:1px solid var(--line);background:transparent;cursor:pointer}.dialog .close:hover{color:var(--ink);border-color:var(--line-strong)}.info-dialog{width:520px;text-align:left;padding:30px 32px 26px}.info-head{display:flex;align-items:flex-end;gap:18px;padding-bottom:18px;border-bottom:1px solid var(--line);margin-bottom:18px}.info-preview{width:130px;height:140px;display:flex;align-items:flex-end;justify-content:center;flex:0 0 auto}.info-title{flex:1 1 auto;text-align:left}.info-eyebrow{font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-mute);margin-bottom:6px}.info-title h2{margin:0 0 4px;font-family:Cormorant Garamond,Georgia,serif;font-weight:500;font-size:36px;line-height:1.05;letter-spacing:.01em;color:var(--ink)}.info-latin{font-size:13px;color:var(--ink-soft)}.info-latin i{font-style:italic}.info-list{margin:0 0 20px;display:flex;flex-direction:column;gap:14px}.info-list>div{display:grid;grid-template-columns:140px 1fr;gap:14px;align-items:baseline}.info-list dt{font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-mute);font-weight:400;margin:0}.info-list dd{margin:0;font-size:14px;line-height:1.55;color:var(--ink)}.info-list dd .muted{color:var(--ink-mute);font-size:12px}.tree-tip{position:absolute;top:-44px;left:50%;transform:translate(-50%);background:var(--ink);color:var(--paper);font-size:10px;letter-spacing:.18em;text-transform:uppercase;padding:5px 10px;border-radius:999px;white-space:nowrap;opacity:0;transition:opacity .2s}.tree-slot:hover .tree-tip{opacity:1}@media (max-width:900px){.dock{width:min(560px,calc(100vw - 24px))}.timer-card{padding:18px 20px 16px}.digits{font-size:72px}.stats{left:18px;top:72px}.topbar{padding:16px 18px}.brand{font-size:22px}.brand small{display:none}}@media (max-width:640px){:root{--sat: env(safe-area-inset-top, 0px);--sab: env(safe-area-inset-bottom, 0px)}.topbar{display:grid;grid-template-columns:1fr auto;grid-template-rows:auto auto;align-items:center;gap:6px 6px;padding:calc(10px + var(--sat)) 12px 8px;pointer-events:none}.topbar>*{pointer-events:auto}.topbar>.brand{grid-column:1;grid-row:1;font-size:18px;gap:6px;align-self:center}.topbar>.topbar-user{grid-column:2;grid-row:1;align-self:center}.topbar>.weather-pills{grid-column:1 / -1;grid-row:2;align-self:start;justify-self:start}.brand .dot{width:6px;height:6px}.brand .brand-full{display:none}.brand .brand-short{display:inline}.weather-pills{padding:3px;gap:3px;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none}.weather-pills::-webkit-scrollbar{display:none}.weather-pills button{width:36px;height:36px;padding:0;flex:0 0 36px;font-size:0;display:inline-flex;align-items:center;justify-content:center}.weather-pills button .glyph{font-size:16px;line-height:16px;width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center}.weather-pills .time-chip{display:none}.topbar-user{gap:6px;flex-wrap:nowrap}.topbar-btn{width:34px;height:34px;padding:0;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.topbar-btn .btn-label{display:none}.topbar-btn .btn-icon{font-size:14px;line-height:1}.stats{display:none}.dock{position:fixed!important;left:8px!important;right:8px!important;bottom:8px!important;transform:none!important;width:auto!important;gap:6px;padding-bottom:calc(var(--sab))}.panel{border-radius:14px}.timer-card{padding:10px 12px}.timer-head{margin-bottom:4px}.timer-head .label{font-size:9px;letter-spacing:.16em}.timer-head .target{font-size:10px}.timer-head .target .swatch{width:7px;height:7px}.digits{font-size:44px;letter-spacing:-.01em}.timer-bar{margin-top:6px;height:2px}.presets{margin-top:8px;gap:5px;flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:2px}.presets::-webkit-scrollbar{display:none}.preset{padding:5px 9px;font-size:11px;flex:0 0 auto;white-space:nowrap}.preset.custom{padding:5px 9px 5px 7px;gap:4px}.preset.custom .custom-label{font-size:9px;letter-spacing:.12em}.preset.custom input{width:30px;font-size:11px;padding:1px 2px}.controls{margin-top:8px;gap:6px}.btn{height:34px;padding:0 14px;font-size:11px;letter-spacing:.04em}.picker{padding:8px 10px;gap:8px;flex-wrap:nowrap}.picker .ph{font-size:9px;letter-spacing:.16em;flex:0 0 auto}.species-row{flex:1 1 auto;overflow-x:auto;overflow-y:hidden;gap:5px;justify-content:flex-start;-webkit-overflow-scrolling:touch;scrollbar-width:none}.species-row::-webkit-scrollbar{display:none}.species{width:36px;height:42px;border-radius:8px;flex:0 0 auto;padding-bottom:1px;overflow:hidden}.species>div{transform:scale(.78);transform-origin:50% 100%}.trees-layer .tree-slot{bottom:38%!important}.tree-tip{display:none}.dialog{width:calc(100vw - 16px);max-height:calc(100vh - 32px);overflow:auto;border-radius:18px}.info-dialog{padding:20px 18px 16px}.info-head{flex-direction:column;align-items:flex-start;gap:10px}.info-preview{width:100px;height:110px}.info-title h2{font-size:26px}.info-list>div{grid-template-columns:1fr;gap:2px}.toast{top:auto;bottom:calc(var(--sab) + 200px)}.login-card{margin:16px;padding:28px 24px;max-width:100%}}@media (max-width:380px){.digits{font-size:38px}.btn-label-long{display:none}.btn-label-short{display:inline}.timer-card{padding:8px 10px}.topbar-btn{width:30px;height:30px}.topbar-btn .btn-icon{font-size:12px}}@media (min-width:381px){.btn-label-long{display:inline}.btn-label-short{display:none}}.topbar-user{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.topbar-btn{font-size:13px;letter-spacing:.04em;padding:9px 20px;border-radius:999px;background:#f6f1e7d1;border:1px solid var(--line-strong);color:var(--ink-soft);transition:background .18s,color .18s,box-shadow .18s;white-space:nowrap;box-shadow:0 1px 4px #2a262014;display:inline-flex;align-items:center;gap:6px}.topbar-btn:hover{background:var(--paper);color:var(--ink);box-shadow:0 2px 8px #2a262024}.topbar-logout{color:var(--ink-mute)}.app.night .topbar-btn{background:#1e1c18b8;border-color:#ffffff29;color:#ffffffb3}.app.night .topbar-btn:hover{background:#322e28e0;color:#fff}.login-page{display:flex;align-items:center;justify-content:center;height:100%;background:linear-gradient(160deg,#f6f1e7,#efe7d6)}.login-card{background:var(--paper);border:1px solid var(--line-strong);border-radius:18px;padding:40px 44px;width:100%;max-width:380px;box-shadow:0 8px 40px #2a26201a;display:flex;flex-direction:column;gap:24px}.login-brand{font-family:Cormorant Garamond,Georgia,serif;font-size:28px;font-weight:500;letter-spacing:.04em;color:var(--ink);display:flex;align-items:baseline;gap:10px;justify-content:center}.login-brand .dot{width:8px;height:8px;border-radius:50%;background:var(--accent);display:inline-block;margin-bottom:2px;flex-shrink:0}.login-brand small{font-size:11px;letter-spacing:.14em;color:var(--ink-mute);font-family:inherit}.login-tabs{display:flex;border-radius:10px;background:var(--paper-2);padding:3px;gap:3px}.login-tabs button{flex:1;padding:7px;border-radius:8px;font-size:13px;color:var(--ink-mute);transition:background .18s,color .18s}.login-tabs button.active{background:var(--paper);color:var(--ink);box-shadow:0 1px 4px #2a26201f}.login-form{display:flex;flex-direction:column;gap:14px}.login-form label{display:flex;flex-direction:column;gap:6px;font-size:12px;letter-spacing:.08em;color:var(--ink-soft)}.login-form input{height:40px;border-radius:8px;border:1px solid var(--line-strong);background:var(--paper);padding:0 12px;font-size:14px;color:var(--ink);outline:none;transition:border-color .18s}.login-form input:focus{border-color:var(--accent)}.login-error{color:#c0392b;font-size:12px;text-align:center}.login-submit{width:100%;height:42px;border-radius:10px;font-size:14px;letter-spacing:.05em}.login-hint{font-size:11px;color:var(--ink-mute);text-align:center;margin:0}.stats-dialog{min-width:340px;max-width:480px}.stats-summary{display:flex;gap:24px;margin-bottom:20px}.stats-summary .num{font-size:28px}.stats-loading{color:var(--ink-mute);font-size:13px;padding:16px 0}.stats-chart{display:flex;align-items:flex-end;gap:6px;height:140px;margin-bottom:16px}.stats-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;height:100%}.stats-bar-wrap{flex:1;width:100%;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;position:relative}.stats-count{font-size:10px;color:var(--ink-soft);margin-bottom:3px}.stats-bar{width:100%;border-radius:5px 5px 3px 3px;background:var(--accent);opacity:.8;min-height:2px;transition:height .3s}.stats-day{font-size:11px;color:var(--ink-mute);letter-spacing:.05em}.celebrate-dialog{overflow:hidden;animation:celebrateIn .5s cubic-bezier(.34,1.56,.64,1) both}@keyframes celebrateIn{0%{opacity:0;transform:scale(.82) translateY(16px)}to{opacity:1;transform:scale(1) translateY(0)}}.celebrate-tree{height:180px;display:flex;align-items:flex-end;justify-content:center;margin:0 -8px 12px;animation:treeBounce .6s cubic-bezier(.34,1.56,.64,1) .15s both}@keyframes treeBounce{0%{transform:scale(.7) translateY(20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.celebrate-badge{display:inline-block;font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--paper);background:var(--accent);padding:4px 12px;border-radius:999px;margin-bottom:10px}.celebrate-sub{color:var(--ink-soft);font-size:13px;margin:0 0 4px}.celebrate-ok{width:100%;justify-content:center;height:44px;font-size:14px}.celebrate-sparks{position:absolute;top:0;left:50%;pointer-events:none}.spark{position:absolute;width:6px;height:6px;border-radius:50%;background:var(--accent);animation:sparkFly .7s cubic-bezier(.2,.8,.4,1) calc(var(--i) * .06s) both}.spark:nth-child(odd){background:#f5c97a}.spark:nth-child(3n){background:#86c26b;width:5px;height:5px}@keyframes sparkFly{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(calc((var(--i) - 3.5) * 28px),calc(-40px - var(--i) * 8px)) scale(.3)}}.admin-dialog{min-width:420px;max-width:600px}.admin-table-wrap{overflow-x:auto;max-height:340px;overflow-y:auto}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table th{text-align:left;padding:8px 12px;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-mute);border-bottom:1px solid var(--line)}.admin-table td{padding:9px 12px;border-bottom:1px solid var(--line)}.admin-table tr:last-child td{border-bottom:none}.admin-badge{font-size:9px;letter-spacing:.1em;text-transform:uppercase;background:var(--accent);color:#fff;border-radius:999px;padding:2px 7px;margin-left:6px}
