@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-ext-wght-normal-BOeWTOD4.woff2)format("woff2-variations");unicode-range:U+460-52F,U+1C80-1C8A,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-cyrillic-wght-normal-DqGufNeO.woff2)format("woff2-variations");unicode-range:U+301,U+400-45F,U+490-491,U+4B0-4B1,U+2116}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-ext-wght-normal-DlzME5K_.woff2)format("woff2-variations");unicode-range:U+1F??}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-greek-wght-normal-CkhJZR-_.woff2)format("woff2-variations");unicode-range:U+370-377,U+37A-37F,U+384-38A,U+38C,U+38E-3A1,U+3A3-3FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-vietnamese-wght-normal-CBcvBZtf.woff2)format("woff2-variations");unicode-range:U+102-103,U+110-111,U+128-129,U+168-169,U+1A0-1A1,U+1AF-1B0,U+300-301,U+303-304,U+308-309,U+323,U+329,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-ext-wght-normal-DO1Apj_S.woff2)format("woff2-variations");unicode-range:U+100-2BA,U+2BD-2C5,U+2C7-2CC,U+2CE-2D7,U+2DD-2FF,U+304,U+308,U+329,U+1D00-1DBF,U+1E00-1E9F,U+1EF2-1EFF,U+2020,U+20A0-20AB,U+20AD-20C0,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter Variable;font-style:normal;font-display:swap;font-weight:100 900;src:url(/assets/inter-latin-wght-normal-Dx4kXJAl.woff2)format("woff2-variations");unicode-range:U+??,U+131,U+152-153,U+2BB-2BC,U+2C6,U+2DA,U+2DC,U+304,U+308,U+329,U+2000-206F,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}:root{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--canvas:#090909;--surface-1:#141414;--surface-2:#1c1c1c;--hairline:#262626;--hairline-soft:#1a1a1a;--ink:#fff;--ink-muted:#999;--accent-blue:#09f;--grad-magenta:#d44df0;--grad-violet:#6a4cf5;--grad-orange:#ff7a3d;--grad-coral:#f57;--success:#22c55e;--bg:var(--canvas);--surface:color-mix(in srgb, var(--surface-1) 80%, transparent);--surface-solid:var(--surface-1);--control:color-mix(in srgb, var(--surface-2) 85%, transparent);--glass-blur:blur(18px) saturate(1.5);--text:var(--ink);--muted:var(--ink-muted);--border:var(--hairline);--coral:var(--grad-coral);--gold:var(--grad-orange);--navy:var(--grad-violet);--ok:var(--success);--danger:#ef5350;--radius:20px;--radius-pill:100px;--tabbar-height:2.85rem;--shadow:0 10px 30px #00000040;--motion-fast:.12s;--motion-base:.18s;--motion-slow:.24s;--motion-flip:.42s;--ease-out:cubic-bezier(.22, 1, .36, 1);--ease-in-out:cubic-bezier(.4, 0, .2, 1);--ease-in:cubic-bezier(.4, 0, 1, 1);--sans:"Inter Variable", "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;--text-scale:1;font-size:calc(100% * var(--text-scale));font-family:var(--sans);font-feature-settings:"cv01", "cv05", "cv09", "cv11", "ss03", "ss07";color:var(--text);background:var(--canvas);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}:root[data-theme=light]{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--canvas:#fff;--surface-1:#f6f6f7;--surface-2:#ececee;--hairline:#e2e2e5;--hairline-soft:#eeeeef;--ink:#0a0a0a;--ink-muted:#5f5f66;--accent-blue:#07d;--success:#16a34a;--danger:#d32f2f;--shadow:0 10px 30px #0000001f}*{box-sizing:border-box}body:before{content:"";z-index:-1;pointer-events:none;background:radial-gradient(34rem 24rem at 12% -4%, color-mix(in srgb, var(--grad-violet) 13%, transparent), transparent 70%), radial-gradient(30rem 22rem at 105% 16%, color-mix(in srgb, var(--grad-coral) 10%, transparent), transparent 70%), radial-gradient(36rem 26rem at 50% 112%, color-mix(in srgb, var(--accent-blue) 10%, transparent), transparent 72%);position:fixed;inset:0}html{min-height:calc(100% + env(safe-area-inset-top))}html,body{height:100%;margin:0;overflow:hidden}#app{height:100dvh;padding-top:env(safe-area-inset-top);flex-direction:column;margin:0;display:flex;overflow:hidden}body{touch-action:manipulation;line-height:1.5}h1{letter-spacing:-.02em;margin:0 0 .25rem;font-size:1.7rem}h1.brand{color:var(--ink);letter-spacing:-.045em;font-weight:700}p{margin:0 0 .75rem}button{font:inherit;cursor:pointer}input{font:inherit}.top-progress{top:env(safe-area-inset-top);background:var(--accent-blue);height:2px;box-shadow:0 0 8px color-mix(in srgb, var(--accent-blue) 60%, transparent);z-index:1100;pointer-events:none;transition:width .2s,opacity .3s;position:fixed;left:0}.top-progress--instant{transition:none}.offline-banner{z-index:900;margin-top:calc(-1 * env(safe-area-inset-top));padding:.4rem calc(.75rem + env(safe-area-inset-right)) .4rem calc(.75rem + env(safe-area-inset-left));padding-top:calc(.4rem + env(safe-area-inset-top));text-align:center;color:var(--muted);background:var(--surface);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border-bottom:1px solid var(--border);font-size:.8rem;position:sticky;top:0}@keyframes rise-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.001ms!important;animation-duration:.001ms!important;animation-iteration-count:1!important}}.screen{max-width:32rem;padding:1.25rem 1.25rem calc(2rem + env(safe-area-inset-bottom));flex:auto;width:100%;min-height:0;margin:0 auto;overflow-y:auto}.screen--centered{min-height:calc(100svh - env(safe-area-inset-top));justify-content:center;align-items:center;display:flex}.screen{animation:rise-in var(--motion-base) var(--ease-out)}.screen--centered{animation:none}.screen__head{margin-bottom:1rem}.screen__head--row{justify-content:space-between;align-items:flex-start;display:flex}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:1.25rem}.auth-card,.first-run{text-align:center;width:100%;max-width:24rem}.stack{flex-direction:column;gap:1rem;display:flex}.field{text-align:left;border:0;flex-direction:column;gap:.35rem;margin:0;padding:0;display:flex}.field>span,.field>legend{font-size:.95rem;font-weight:600}.field input{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:12px;min-height:48px;padding:.85rem .9rem}.field input:focus-visible{outline:3px solid var(--accent-blue);outline-offset:1px}.field-with-action{display:flex;position:relative}.field-with-action input{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text);border-radius:12px;flex:1;min-height:48px;padding:.85rem 3rem .85rem .9rem}.field-with-action input:focus-visible{outline:3px solid var(--accent-blue);outline-offset:1px}.field-action{width:40px;height:40px;color:var(--muted);transition:color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out);background:0 0;border:0;border-radius:9px;justify-content:center;align-items:center;display:inline-flex;position:absolute;top:50%;right:.4rem;transform:translateY(-50%)}.field-action:hover{color:var(--text);background:color-mix(in srgb, var(--text) 8%, transparent)}.field-action:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px}input[type=date],input[type=time]{appearance:none;width:100%;max-width:100%;min-height:48px;font-size:1rem}input[type=date]::-webkit-date-and-time-value{text-align:left}input[type=time]::-webkit-date-and-time-value{text-align:left}input[type=date]::-webkit-calendar-picker-indicator{opacity:.65;cursor:pointer;filter:invert(.9);width:1.4rem;height:1.4rem;margin-left:.25rem;padding:.2rem}input[type=time]::-webkit-calendar-picker-indicator{opacity:.65;cursor:pointer;filter:invert(.9);width:1.4rem;height:1.4rem;margin-left:.25rem;padding:.2rem}svg.lucide{vertical-align:-.15em;flex:none}.btn{border-radius:var(--radius-pill);letter-spacing:-.14px;min-height:48px;transition:transform var(--motion-fast) var(--ease-out), box-shadow var(--motion-base) var(--ease-in-out), background var(--motion-base) var(--ease-in-out), border-color var(--motion-base) var(--ease-in-out), opacity var(--motion-base) var(--ease-in-out);border:0;justify-content:center;align-items:center;gap:.5rem;padding:.85rem 1.25rem;font-weight:600;display:inline-flex}.btn:active:not(:disabled){transform:translateY(1px)scale(.99)}.btn:focus-visible{outline:3px solid var(--accent-blue);outline-offset:2px}.btn--block{width:100%}.btn--primary{background:var(--ink);color:var(--canvas)}.btn--primary:hover:not(:disabled){background:color-mix(in srgb, var(--ink) 88%, var(--canvas))}.btn--primary:active:not(:disabled){background:var(--ink)}.btn--primary:disabled{opacity:.5}.btn--accent{background:var(--accent,var(--coral));color:var(--on-accent,#fff)}.btn--accent:hover:not(:disabled){background:color-mix(in srgb, var(--accent,var(--coral)) 88%, #000)}.btn--accent:disabled{opacity:.6}.btn--ghost{background:var(--control);color:var(--ink);border:1px solid var(--hairline);margin-top:1rem}.btn--ghost:hover:not(:disabled){background:color-mix(in srgb, var(--ink) 8%, var(--surface-2));border-color:color-mix(in srgb, var(--ink) 18%, var(--hairline))}.link{color:var(--muted);transition:color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out);background:0 0;border:0;border-radius:8px;padding:.4rem;text-decoration:underline}.link:hover{color:var(--text)}.link:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px}.link--icon{align-items:center;gap:.3rem;text-decoration:none;display:inline-flex}.link--icon:hover{text-decoration:underline}.icon-btn{width:32px;height:32px;color:var(--muted);transition:color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out);background:0 0;border:0;border-radius:9px;justify-content:center;align-items:center;display:inline-flex}.icon-btn:hover{color:var(--text);background:color-mix(in srgb, var(--text) 8%, transparent)}.icon-btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px}.muted{color:var(--muted)}.form-hint{text-align:center;margin:-.25rem 0 0;font-size:.85rem}.tiny{font-size:.85rem}.error{color:var(--danger);font-weight:600}.hint{background:color-mix(in srgb, var(--gold) 14%, var(--surface));border-left:3px solid var(--gold);border-radius:8px;padding:.6rem .75rem;font-size:.9rem}.preview{color:var(--muted);border-left:3px solid var(--accent,var(--border));padding-left:.7rem;font-style:italic}.preview em{color:var(--accent,var(--text));font-style:normal;font-weight:600}.domain-grid{grid-template-columns:1fr 1fr;gap:.6rem;display:grid}.domain-chip{text-align:left;background:var(--bg);border:1.5px solid var(--border);min-height:60px;color:var(--text);transition:border-color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out);border-radius:12px;flex-direction:column;align-items:flex-start;gap:.15rem;padding:.75rem;display:flex}.domain-chip__icon{color:var(--accent,var(--coral));line-height:1}.domain-chip:hover:not(.is-selected){border-color:color-mix(in srgb, var(--accent,var(--coral)) 45%, var(--border))}.domain-chip small{color:var(--muted)}.domain-chip.is-selected{border-color:var(--accent,var(--coral));background:color-mix(in srgb, var(--accent,var(--coral)) 12%, transparent)}.suggestions{flex-wrap:wrap;gap:.4rem;margin-top:.15rem;display:flex}.suggestion{background:color-mix(in srgb, var(--accent,var(--coral)) 8%, transparent);border:1px solid color-mix(in srgb, var(--accent,var(--coral)) 35%, var(--border));color:var(--text);border-radius:999px;min-height:36px;padding:.3rem .7rem;font-size:.85rem}.suggestion:hover{border-color:var(--accent,var(--coral))}.suggestion:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px}.suggestion.is-selected{background:color-mix(in srgb, var(--accent,var(--coral)) 18%, transparent);border-color:var(--accent,var(--coral));color:var(--accent,var(--coral));font-weight:600}.habit-list{flex-direction:column;gap:.6rem;margin:0;padding:0;list-style:none;display:flex}.habit-row{background:var(--surface);border:1px solid var(--border);border-left:2px solid color-mix(in srgb, var(--accent,var(--coral)) 55%, var(--border));border-radius:var(--radius);transition:border-color var(--motion-base) var(--ease-in-out);flex-direction:column;gap:.55rem;padding:.9rem 1rem;display:flex}.habit-row:hover{border-color:color-mix(in srgb, var(--accent,var(--coral)) 30%, var(--border));border-left-color:var(--accent,var(--coral))}.habit-row__top{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.habit-row__main{align-items:flex-start;gap:.8rem;display:flex}.habit-row__body{flex-direction:column;flex:1;align-items:flex-start;gap:.35rem;min-width:0;display:flex}.habit-reveal{width:100%;color:inherit;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:8px;align-items:flex-start;gap:.45rem;padding:0;display:flex}.habit-reveal:focus-visible{outline:2px solid var(--accent-blue);outline-offset:3px}.habit-reveal__chev{color:var(--muted);opacity:.6;flex:none;margin-top:.2rem}.habit-domain-icon{color:color-mix(in srgb, var(--accent,var(--coral)) 70%, var(--text));flex:none;margin-top:.15rem}.habit-row__meta{flex-wrap:wrap;align-items:center;gap:.55rem;display:flex}.habit-undo{color:var(--muted)}.habit-row__aside{flex-direction:column;flex:none;align-items:center;gap:.4rem;min-width:2.75rem;display:flex}.habit-frac{font-variant-numeric:tabular-nums;color:var(--text);font-size:1.05rem;font-weight:700;line-height:1}.habit-frac small{color:var(--muted);font-size:.7em;font-weight:600}.habit-frac.is-done{color:var(--ok)}.habit-frac__n{animation:count-tick var(--motion-base) var(--ease-out);display:inline-block}@keyframes count-tick{0%{opacity:.3;transform:translateY(.18em)}to{opacity:1;transform:none}}.week-dots{gap:3px;display:inline-flex}.week-dot{background:var(--border);width:6px;height:6px;transition:background var(--motion-base) var(--ease-out), box-shadow var(--motion-base) var(--ease-out);border-radius:50%}.week-dot--done{background:var(--ok)}.week-dot--grace{background:var(--gold)}.week-dot--missed{box-shadow:inset 0 0 0 1px color-mix(in srgb, var(--danger) 45%, var(--border));background:0 0}.week-dot--empty{box-shadow:inset 0 0 0 1px var(--border);background:0 0}.week-dot--rest{background:color-mix(in srgb, var(--ok) 30%, var(--border))}.habit-row-wrap[data-domain=training]{--accent:var(--coral)}.habit-row-wrap[data-domain=eating]{--accent:var(--ok)}.habit-row-wrap[data-domain=habits]{--accent:var(--gold);--on-accent:#1a2238}.habit-row-wrap[data-domain=work]{--accent:var(--navy)}.habit-domain{text-transform:uppercase;letter-spacing:.09em;color:color-mix(in srgb, var(--accent,var(--coral)) 70%, var(--text));align-items:center;gap:.35rem;font-size:.7rem;font-weight:700;display:inline-flex}.habit-flip{perspective:1400px}.habit-flip__inner{transform-style:preserve-3d;transition:transform var(--motion-flip) var(--ease-out), height var(--motion-flip) var(--ease-out);position:relative}.habit-flip.is-flipped .habit-flip__inner{transform:rotateY(180deg)}.habit-face{backface-visibility:hidden;width:100%;position:absolute;top:0;left:0}.habit-face--back{transform:rotateY(180deg)}.habit-flip:not(.is-flipped) .habit-face--back,.habit-flip.is-flipped .habit-face--front{pointer-events:none}.flip-btn{width:28px;height:28px;color:var(--muted);transition:color var(--motion-fast) var(--ease-out), background var(--motion-fast) var(--ease-out), transform var(--motion-base) var(--ease-out);background:0 0;border:0;border-radius:8px;justify-content:center;align-items:center;display:inline-flex;position:relative}.flip-btn:before{content:"";border-radius:12px;position:absolute;inset:-8px}.flip-btn:hover{color:var(--accent,var(--coral));background:color-mix(in srgb, var(--accent,var(--coral)) 12%, transparent);transform:rotate(15deg)}.flip-btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px}.habit-row--back{flex-direction:column;align-items:stretch;gap:.6rem}.habit-stats{grid-template-columns:repeat(auto-fit,minmax(4.25rem,1fr));gap:.5rem;display:grid}.stat-tile{border:1px solid color-mix(in srgb, var(--accent,var(--coral)) 22%, var(--border));background:color-mix(in srgb, var(--accent,var(--coral)) 7%, var(--surface));border-radius:12px;flex-direction:column;gap:.15rem;padding:.5rem .6rem;display:flex}.stat-tile__value{color:var(--text);font-size:1.3rem;font-weight:700;line-height:1.1}.stat-tile__value small{color:var(--muted);margin-left:1px;font-size:.7rem;font-weight:600}.stat-tile__label{letter-spacing:.02em;text-transform:uppercase;color:var(--muted);font-size:.7rem;font-weight:600}.habit-plan{flex-direction:column;gap:.35rem;display:flex}.back-label{letter-spacing:.04em;text-transform:uppercase;margin:0;font-weight:700}.habit-row__behavior{margin:0;font-size:1.02rem;font-weight:600;line-height:1.35}.habit-row__anchor{color:var(--muted);font-weight:400}.check{border:2px solid color-mix(in srgb, var(--accent,var(--coral)) 55%, var(--border));background:var(--surface);width:36px;height:36px;color:var(--accent,var(--coral));transition:transform var(--motion-fast) var(--ease-out), background var(--motion-base) var(--ease-in-out), border-color var(--motion-base) var(--ease-in-out), color var(--motion-base) var(--ease-in-out), box-shadow var(--motion-base) var(--ease-in-out);border-radius:10px;flex:none;justify-content:center;align-items:center;margin-top:.12rem;font-weight:700;display:inline-flex}.check:hover:not(:disabled):not(.is-done){border-color:var(--accent,var(--coral));box-shadow:0 0 0 4px color-mix(in srgb, var(--accent,var(--coral)) 12%, transparent)}.check:active:not(:disabled){transform:scale(.9)}.check:focus-visible{outline:3px solid var(--accent-blue);outline-offset:2px}.check:disabled{cursor:default}.check.is-done{background:var(--accent,var(--coral));border-color:var(--accent,var(--coral));color:var(--on-accent,#fff);box-shadow:0 4px 12px color-mix(in srgb, var(--accent,var(--coral)) 30%, transparent);animation:done-pop var(--motion-flip) var(--ease-out)}.check.is-done svg.lucide path{stroke-dasharray:30;animation:.5s cubic-bezier(.65,0,.35,1) 50ms both check-draw}.check--add{background:color-mix(in srgb, var(--accent,var(--coral)) 9%, var(--surface))}@keyframes done-pop{0%{transform:scale(.82)}55%{transform:scale(1.12)}to{transform:scale(1)}}@keyframes check-draw{0%{stroke-dashoffset:30px}to{stroke-dashoffset:0}}.streak{align-items:center;gap:.3rem;font-weight:700;display:inline-flex}.streak__flame{vertical-align:0}.streak--unbroken .streak__flame{color:var(--coral)}.streak--grace .streak__flame{color:var(--gold)}.streak__unit{color:var(--muted);font-size:.85rem;font-weight:500}.streak--unbroken{color:var(--coral)}.streak--grace{color:var(--gold)}.streak--zero{color:var(--muted);font-weight:600}.streak--compact{gap:.2rem;font-size:.95rem}.prompt-card{margin-bottom:1rem}.prompt-card__actions{align-items:center;gap:.75rem;display:flex}.first-run .btn--primary{margin:1rem 0 .5rem}.insight-card{margin-bottom:1rem}.insight-card__label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);align-items:center;gap:.3rem;font-size:.7rem;font-weight:700;display:inline-flex}.insight-card__label .lucide{color:var(--gold)}.insight-card__actions{align-items:center;gap:.5rem;margin-top:.5rem;display:flex}.thumb{background:var(--bg);border:1px solid var(--border);min-width:44px;min-height:40px;color:var(--muted);transition:border-color var(--motion-fast) var(--ease-in-out), color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out);border-radius:10px;justify-content:center;align-items:center;padding:.35rem .6rem;display:inline-flex}.thumb:hover{border-color:color-mix(in srgb, var(--coral) 50%, var(--border));color:var(--text)}.thumb.is-active{border-color:var(--coral);color:var(--coral);background:color-mix(in srgb, var(--coral) 10%, transparent)}.insight-card__head{justify-content:space-between;align-items:center;display:flex}.fresh-card{justify-content:space-between;align-items:flex-start;gap:.75rem;margin-bottom:1rem;display:flex}.fresh-card.is-exiting,.insight-peek.is-exiting{animation:collapse-out var(--motion-slow) var(--ease-in) forwards;pointer-events:none;overflow:hidden}@keyframes collapse-out{0%{opacity:1;transform:none}to{opacity:0;transform:translateY(-4px)scale(.98)}}.fresh-card__body p{margin:.25rem 0 0}.today-summary{color:var(--text);margin:.15rem 0 .1rem;font-size:1.02rem;font-weight:600}.habits-section{margin:0 0 1rem}.habit-strip{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;text-align:left;width:100%;color:inherit;align-items:center;gap:.75rem;padding:.7rem .85rem;display:flex}.habit-strip__text{flex-direction:column;flex:auto;gap:.1rem;min-width:0;display:flex}.habit-strip__title{font-weight:600}.habit-strip__count{color:var(--muted);font-variant-numeric:tabular-nums;font-size:.82rem}.habit-strip__chev{color:var(--muted);transition:transform var(--motion-base) var(--ease-in-out);flex:none}.habit-strip__chev.is-open{transform:rotate(180deg)}.ring{flex:none;place-items:center;width:34px;height:34px;display:inline-grid;position:relative}.ring svg{transform:rotate(-90deg)}.ring__track{stroke:var(--border);stroke-width:3px}.ring__fill{stroke:var(--accent-blue);stroke-width:3px;stroke-linecap:round;transition:stroke-dashoffset .6s var(--ease-out)}.ring.is-done .ring__fill{stroke:var(--ok)}.ring__label{font-variant-numeric:tabular-nums;color:var(--muted);place-items:center;font-size:.62rem;font-weight:700;display:grid;position:absolute;inset:0}.ring.is-done .ring__label{color:var(--ok)}.habit-list>.habit-row-wrap,.todo-list>.todo-row{animation:rise-in var(--motion-base) var(--ease-out) both}.habit-list>.habit-row-wrap:first-child,.todo-list>.todo-row:first-child{animation-delay:0s}.habit-list>.habit-row-wrap:nth-child(2),.todo-list>.todo-row:nth-child(2){animation-delay:30ms}.habit-list>.habit-row-wrap:nth-child(3),.todo-list>.todo-row:nth-child(3){animation-delay:60ms}.habit-list>.habit-row-wrap:nth-child(4),.todo-list>.todo-row:nth-child(4){animation-delay:90ms}.habit-list>.habit-row-wrap:nth-child(5),.todo-list>.todo-row:nth-child(5){animation-delay:.12s}.habit-list>.habit-row-wrap:nth-child(n+6),.todo-list>.todo-row:nth-child(n+6){animation-delay:.15s}.habits-collapsible{margin-top:.85rem}.habits-empty{margin:.25rem 0 .85rem}.show-completed{cursor:pointer;color:var(--muted);background:0 0;border:0;margin:.75rem 0;padding:0;font-size:.82rem;font-weight:600;display:block}.show-completed:hover{color:var(--text)}.habit-divider{border:0;border-top:1px solid var(--border);margin:.5rem 0 .1rem}.habit-manage{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.5rem;display:flex}.btn-soft{border:1px solid var(--border);min-height:38px;color:var(--text);transition:background var(--motion-fast) var(--ease-in-out), color var(--motion-fast) var(--ease-in-out), border-color var(--motion-fast) var(--ease-in-out), transform var(--motion-fast) var(--ease-out);background:0 0;border-radius:10px;align-items:center;gap:.35rem;padding:.45rem .8rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn-soft:hover{border-color:var(--accent,var(--coral));color:var(--accent,var(--coral))}.btn-soft:active{transform:translateY(1px)}.btn-soft:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px}.btn-soft--danger{color:var(--danger)}.btn-soft--danger:hover{border-color:var(--danger);color:var(--danger);background:color-mix(in srgb, var(--danger) 8%, transparent)}.confirm-remove{color:var(--muted);align-items:center;gap:.25rem;display:inline-flex}.link--danger{color:var(--danger)}.habit-row-wrap{list-style:none}.habit-details,.optional-fields{margin-top:.5rem}.habit-details>summary,.optional-fields>summary{cursor:pointer;color:var(--muted);padding:.4rem 0;font-size:.9rem}.optional-fields[open]{flex-direction:column;gap:.75rem;display:flex}.detail-line .lucide{vertical-align:-.2em;margin-right:.15rem}.heatmap{margin:.5rem 0}.heatmap__grid{grid-template-columns:repeat(11,1fr);gap:3px;max-width:18rem;display:grid}.cell{aspect-ratio:1;background:var(--border);border-radius:3px}.cell--done{background:var(--ok)}.cell--grace{background:var(--gold)}.cell--missed{background:#c0392b40}.cell--empty{border:1px dashed var(--border);background:0 0}.cell--rest{background:color-mix(in srgb, var(--ok) 18%, var(--border))}.heatmap__caption{margin-top:.4rem}.heatmap__legend{color:var(--muted);flex-wrap:wrap;gap:.4rem .85rem;margin:.5rem 0 0;padding:0;font-size:.75rem;list-style:none;display:flex}.heatmap__legend li{align-items:center;gap:.3rem;display:inline-flex}.heatmap__legend .cell{aspect-ratio:auto;width:11px;height:11px}.habit-stats-group{flex-direction:column;gap:.5rem;display:flex}.auto-progress{flex-direction:column;gap:.3rem;display:flex}.auto-progress__label{letter-spacing:.02em;text-transform:uppercase;font-weight:600}.auto-progress__bar{background:linear-gradient(to right, var(--accent,var(--coral)) var(--pct,0%), color-mix(in srgb, var(--accent,var(--coral)) 14%, var(--border)) var(--pct,0%));border-radius:3px;height:6px;display:block}.stat-tile--hero{grid-column:1/-1;align-items:flex-start}.stat-tile--hero .stat-tile__value{font-size:1.15rem}.legend-info{align-items:center;display:inline-flex;position:relative}.legend-info__btn{color:var(--muted);cursor:pointer;background:0 0;border:0;justify-content:center;align-items:center;padding:0;line-height:0;display:inline-flex}.legend-info__btn:hover{color:var(--accent,var(--coral))}.legend-info__btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px;border-radius:4px}.legend-info__tip{background:var(--text);width:max-content;max-width:14rem;color:var(--bg);text-transform:none;letter-spacing:0;opacity:0;pointer-events:none;transition:opacity var(--motion-fast) var(--ease-in-out);z-index:5;border-radius:8px;padding:.4rem .55rem;font-size:.72rem;line-height:1.3;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);box-shadow:0 6px 18px #0000002e}.legend-info:hover .legend-info__tip,.legend-info__tip.is-open{opacity:1}.view-details{color:var(--accent,var(--coral));cursor:pointer;background:0 0;border:0;align-self:flex-start;align-items:center;gap:.25rem;padding:.3rem 0;font-size:.9rem;font-weight:600;display:inline-flex}.view-details:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px;border-radius:6px}.view-details .lucide{transition:transform var(--motion-base) var(--ease-out)}.view-details:hover .lucide{transform:translate(2px)}.habit-detail[data-domain=training]{--accent:var(--coral)}.habit-detail[data-domain=eating]{--accent:var(--ok)}.habit-detail[data-domain=habits]{--accent:var(--gold);--on-accent:#1a2238}.habit-detail[data-domain=work]{--accent:var(--navy)}.habit-detail{flex-direction:column;gap:.9rem;display:flex}.habit-detail .screen__head{justify-content:space-between;align-items:center;gap:.75rem;margin-bottom:0;display:flex}.habit-detail__title{margin:0;font-size:1.3rem;line-height:1.3}.habit-detail__title .habit-row__anchor{margin-bottom:.1rem;font-size:.95rem;display:block}.field select{border:1px solid var(--border);background:var(--bg);color:var(--text);border-radius:12px;min-height:48px;padding:.85rem .9rem}.field select:focus-visible{outline:3px solid var(--accent-blue);outline-offset:1px}.target-grid{grid-template-columns:1fr 1fr 1fr;gap:.6rem;display:grid}@property --pct{syntax:"<percentage>";inherits:false;initial-value:0%}.logger{flex-wrap:wrap;align-items:center;gap:.5rem;display:flex}.logger__input{border:1px solid var(--border);background:var(--surface);width:5rem;color:var(--text);text-align:center;min-height:40px;transition:border-color var(--motion-fast) var(--ease-in-out), box-shadow var(--motion-fast) var(--ease-in-out);border-radius:10px;padding:.55rem .6rem;font-weight:600}.logger__input:focus-visible{border-color:var(--accent,var(--gold));box-shadow:0 0 0 3px color-mix(in srgb, var(--accent,var(--gold)) 25%, transparent);outline:none}.btn--sm{min-height:40px;padding:.5rem .75rem}.app-version{text-align:center;color:var(--muted);padding:1rem 0 1.5rem;font-size:.75rem}.head-actions{flex-shrink:0;align-items:center;gap:.4rem;display:flex}.tab-bar{isolation:isolate;left:calc(.9rem + env(safe-area-inset-left));right:calc(.9rem + env(safe-area-inset-right));bottom:calc(.55rem + env(safe-area-inset-bottom,0px));z-index:50;max-width:26rem;height:var(--tabbar-height);background:color-mix(in srgb, var(--surface-1) 72%, transparent);-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);border:1px solid color-mix(in srgb, var(--border) 65%, transparent);border-radius:999px;align-items:stretch;margin:0 auto;padding:0 .35rem;display:flex;position:fixed;box-shadow:0 10px 28px #00000024,inset 0 1px #ffffff14}.tab-bar__pill{width:calc((100% - .7rem) / var(--tab-count,5));background:var(--control);transition:transform var(--motion-slow) var(--ease-out);pointer-events:none;background-clip:padding-box;border-left:.2rem solid #0000;border-right:.2rem solid #0000;border-radius:999px;position:absolute;top:.3rem;bottom:.3rem;left:.35rem}.tab{color:var(--muted);transition:color var(--motion-fast) var(--ease-in-out), transform var(--motion-fast) var(--ease-in-out);background:0 0;border:0;border-radius:999px;flex:1;justify-content:center;align-items:center;padding:.2rem .25rem;display:flex;position:relative}.tab:active{transform:scale(.88)}.tab:hover{color:var(--text)}.tab:focus-visible{outline:2px solid var(--accent-blue);outline-offset:-2px}.tab.is-active{color:var(--text)}.tab.is-active svg{color:var(--accent-blue)}.tabbar-open .screen{padding-bottom:calc(var(--tabbar-height) + env(safe-area-inset-bottom,0px) + 1.3rem)}.settings-card{margin-bottom:1rem}.settings-card__title{text-transform:uppercase;letter-spacing:.04em;color:var(--muted);margin:0 0 .75rem;font-size:.8rem;font-weight:600}.seg{gap:.35rem;display:flex}.seg__btn{border:1px solid var(--border);background:var(--bg);min-height:42px;color:var(--muted);font:inherit;transition:color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out), border-color var(--motion-fast) var(--ease-in-out);border-radius:12px;flex:1;justify-content:center;align-items:center;gap:.35rem;padding:.5rem;font-size:.9rem;font-weight:600;display:inline-flex}.seg__btn:hover{color:var(--text)}.seg__btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px}.seg__btn.is-active{color:var(--text);border-color:color-mix(in srgb, var(--ink) 22%, var(--hairline));background:var(--control)}.text-size{margin-top:.85rem}.text-size__head{justify-content:space-between;align-items:baseline;margin-bottom:.5rem;display:flex}.text-size__value{font-variant-numeric:tabular-nums}.text-size__slider{align-items:center;gap:.6rem;display:flex}.text-size__a{color:var(--muted);flex:none;font-weight:600;line-height:1}.text-size__a--sm{font-size:13px}.text-size__a--lg{font-size:22px}.text-size__range{appearance:none;cursor:pointer;background:0 0;flex:1;min-width:0;height:28px;margin:0}.text-size__range::-webkit-slider-runnable-track{background:var(--border);border-radius:100px;height:4px}.text-size__range::-moz-range-track{background:var(--border);border-radius:100px;height:4px}.text-size__range::-webkit-slider-thumb{appearance:none;border:2px solid var(--canvas);background:var(--accent-blue);border-radius:50%;width:20px;height:20px;margin-top:-8px;box-shadow:0 1px 3px #0000004d}.text-size__range::-moz-range-thumb{border:2px solid var(--canvas);background:var(--accent-blue);border-radius:50%;width:20px;height:20px;box-shadow:0 1px 3px #0000004d}.text-size__range:focus-visible{outline:2px solid var(--accent-blue);outline-offset:4px;border-radius:100px}.text-size__preview{overflow-wrap:anywhere;margin:.6rem 0 0;line-height:1.35}.setting-switch{cursor:pointer;justify-content:space-between;align-items:flex-start;gap:1rem;display:flex}.setting-switch__text{flex-direction:column;gap:.2rem;display:flex}.setting-switch__label{font-weight:600}.setting-switch__sub{margin:0;line-height:1.35}.switch{border:1px solid var(--border);background:var(--control);cursor:pointer;width:46px;height:28px;transition:background var(--motion-base) var(--ease-in-out), border-color var(--motion-base) var(--ease-in-out);border-radius:999px;flex:none;margin-top:.15rem;padding:0;position:relative}.switch:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.switch.is-on{background:var(--ok);border-color:var(--ok)}.switch__knob{width:22px;height:22px;transition:transform var(--motion-base) var(--ease-out);background:#fff;border-radius:50%;position:absolute;top:50%;left:3px;transform:translateY(-50%);box-shadow:0 1px 2px #00000040}.switch.is-on .switch__knob{transform:translate(18px,-50%)}.btn--danger{background:var(--danger);color:#fff}.btn--danger:hover:not(:disabled){background:color-mix(in srgb, var(--danger) 88%, #000)}.signout-confirm{flex-direction:column;gap:.5rem;display:flex}.signout-confirm p{margin:0}.signout-confirm__actions{gap:.5rem;display:flex}.signout-confirm__actions .btn{flex:1;margin-top:0}.field textarea{border:1px solid var(--border);background:var(--bg);color:var(--text);font:inherit;resize:vertical;border-radius:12px;min-height:3.5rem;padding:.85rem .9rem}.field textarea:focus-visible{outline:3px solid var(--accent-blue);outline-offset:1px}.quick-add{flex-direction:column;gap:.5rem;margin-bottom:1rem;display:flex}.quick-add__row{align-items:center;gap:.5rem;display:flex}.quick-add__input{border:1px solid var(--border);background:var(--bg);min-width:0;color:var(--text);border-radius:12px;flex:1;min-height:44px;padding:.7rem .85rem}.quick-add__input:focus-visible{outline:3px solid var(--accent-blue);outline-offset:1px}.quick-add__more{flex:none;margin-top:0}.quick-add__added{color:var(--ok);align-items:center;gap:.3rem;margin:0;animation:1.6s forwards added-fade;display:inline-flex}.quick-add__added svg{flex:none}@keyframes added-fade{0%{opacity:0;transform:translateY(-2px)}12%,70%{opacity:1;transform:none}to{opacity:0}}.todo-add-home{margin:.25rem 0 1rem}.todos-empty{text-align:center;margin:1.5rem 0}.todo-section{margin:0 0 1rem}.todo-section__title{text-transform:uppercase;letter-spacing:.06em;color:color-mix(in srgb, var(--navy) 60%, transparent);align-items:center;gap:.4rem;margin:0 0 .5rem;font-size:.78rem;font-weight:600;display:flex}.todo-section__count{background:color-mix(in srgb, var(--navy) 10%, transparent);letter-spacing:0;border-radius:999px;justify-content:center;align-items:center;min-width:1.25rem;height:1.25rem;padding:0 .35rem;font-size:.7rem;font-weight:600;display:inline-flex}.section-all{text-transform:none;letter-spacing:0;margin-left:auto;font-size:.8rem}.needs-attention .todo-section__title>svg{color:var(--danger)}.todo-list{flex-direction:column;gap:.6rem;margin:0;padding:0;list-style:none;display:flex}.todo-row[data-kind=deadline]{--on-accent:#1a2238}.todo-row{background:var(--surface);border:1px solid var(--border);border-left:2px solid color-mix(in srgb, var(--accent,var(--navy)) 55%, var(--border));border-radius:var(--radius);transition:border-color var(--motion-base) var(--ease-in-out), opacity var(--motion-slow) var(--ease-in-out);align-items:flex-start;gap:.75rem;padding:.85rem .9rem;display:flex}.todo-row:hover{border-left-color:var(--accent,var(--navy))}.todo-row.is-done{opacity:.62}.todo-row.is-done .todo-title{text-decoration:line-through}.todo-row__body{flex:auto;min-width:0}.todo-due{color:var(--muted);background:color-mix(in srgb, var(--accent,var(--navy)) 10%, transparent);border-radius:999px;margin-top:.2rem;padding:.1rem .5rem;font-size:.72rem;font-weight:600;display:inline-block}.todo-due.is-overdue{color:var(--danger);background:color-mix(in srgb, var(--danger) 12%, transparent)}.todo-title{overflow-wrap:anywhere;margin:0;font-weight:600}.todo-kind-icon{vertical-align:-.18em;color:var(--accent,var(--navy));margin-right:.35rem}.todo-notes{overflow-wrap:anywhere;margin:.2rem 0 0}.todo-row__actions{opacity:0;max-width:0;transition:max-width var(--motion-base) var(--ease-in-out), opacity var(--motion-base) var(--ease-in-out);flex-shrink:0;align-items:center;gap:.25rem;display:flex;overflow:hidden}.todo-row:focus-within .todo-row__actions,.todo-row.is-revealed .todo-row__actions{opacity:1;max-width:13rem}@media (hover:hover){.todo-row:hover .todo-row__actions{opacity:1;max-width:13rem}}.todo-confirm{align-items:center;gap:.25rem;display:inline-flex}.flatpickr-calendar{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow);color:var(--text);border-radius:12px}.flatpickr-calendar.arrowTop:before,.flatpickr-calendar.arrowBottom:before{border-bottom-color:var(--border);border-top-color:var(--border)}.flatpickr-calendar.arrowTop:after{border-bottom-color:var(--surface)}.flatpickr-calendar.arrowBottom:after{border-top-color:var(--surface)}.flatpickr-months .flatpickr-month,.flatpickr-current-month,.flatpickr-current-month input.cur-year,.flatpickr-monthDropdown-months{color:var(--text);fill:var(--text)}.flatpickr-monthDropdown-months .flatpickr-monthDropdown-month{background:var(--surface);color:var(--text)}.flatpickr-months .flatpickr-prev-month svg,.flatpickr-months .flatpickr-next-month svg{fill:var(--text)}.flatpickr-months .flatpickr-prev-month:hover svg,.flatpickr-months .flatpickr-next-month:hover svg{fill:var(--accent,var(--coral))}span.flatpickr-weekday{color:var(--muted)}.flatpickr-day{color:var(--text);border-radius:8px}.flatpickr-day:hover,.flatpickr-day:focus{background:color-mix(in srgb, var(--accent,var(--coral)) 14%, var(--surface));border-color:#0000}.flatpickr-day.today{border-color:color-mix(in srgb, var(--accent,var(--coral)) 55%, var(--border))}.flatpickr-day.today:hover,.flatpickr-day.today:focus{background:color-mix(in srgb, var(--accent,var(--coral)) 14%, var(--surface));color:var(--text)}.flatpickr-day.selected,.flatpickr-day.selected:hover,.flatpickr-day.selected:focus{background:var(--accent,var(--coral));border-color:var(--accent,var(--coral));color:#fff}.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay,.flatpickr-day.flatpickr-disabled{color:var(--muted);opacity:.5}.flatpickr-time input,.flatpickr-time .flatpickr-time-separator,.flatpickr-time .flatpickr-am-pm{color:var(--text)}.flatpickr-time input:hover,.flatpickr-time input:focus,.flatpickr-time .flatpickr-am-pm:hover,.flatpickr-time .flatpickr-am-pm:focus{background:color-mix(in srgb, var(--accent,var(--coral)) 10%, var(--surface))}.numInputWrapper span{border-color:var(--border)}.numInputWrapper span:hover{background:color-mix(in srgb, var(--accent,var(--coral)) 12%, transparent)}.numInputWrapper span.arrowUp:after{border-bottom-color:var(--muted)}.numInputWrapper span.arrowDown:after{border-top-color:var(--muted)}.flatpickr-input[readonly],.flatpickr-input[readonly]+.flatpickr-mobile{cursor:pointer}.date-shortcuts{flex-wrap:wrap;justify-content:center;gap:.4rem;margin-top:.5rem;display:flex}.date-shortcut{border:1px solid var(--border);background:var(--surface);color:var(--text);min-height:36px;transition:border-color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out), color var(--motion-fast) var(--ease-in-out);border-radius:999px;padding:.4rem .75rem;font-size:.85rem;font-weight:600}.date-shortcut:hover:not(:disabled){border-color:color-mix(in srgb, var(--accent,var(--coral)) 45%, var(--border));background:color-mix(in srgb, var(--accent,var(--coral)) 10%, var(--surface));color:var(--accent,var(--coral))}.date-shortcut:disabled{opacity:.5;cursor:default}.date-shortcut.is-selected{border-color:var(--accent,var(--coral));background:color-mix(in srgb, var(--accent,var(--coral)) 16%, var(--surface));color:var(--accent,var(--coral))}.date-shortcut--clear{color:var(--muted)}.date-shortcut--clear:hover:not(:disabled){border-color:color-mix(in srgb, var(--danger) 45%, var(--border));background:color-mix(in srgb, var(--danger) 10%, var(--surface));color:var(--danger)}.numfield{border:1px solid var(--border);background:var(--bg);width:100%;min-height:48px;color:var(--text);text-align:left;white-space:nowrap;border-radius:12px;align-items:center;padding:.85rem .9rem;display:inline-flex;overflow:hidden}.numfield:focus-visible{outline:3px solid var(--accent-blue);outline-offset:1px}.numfield:disabled{opacity:.6;cursor:default}.numfield__value{font-weight:600}.numfield__unit{color:var(--muted);font-weight:500}.numfield__placeholder{color:var(--muted)}.logger .numfield{background:var(--surface);text-align:center;justify-content:center;width:5rem;min-height:40px;padding:.55rem .6rem;font-weight:600}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:modal-fade var(--motion-base) var(--ease-in-out);background:#000000a8;display:flex;position:fixed;inset:0}.modal{background:var(--surface);width:100%;height:100dvh;-webkit-backdrop-filter:var(--glass-blur);backdrop-filter:var(--glass-blur);padding:calc(.75rem + env(safe-area-inset-top)) 1.25rem calc(1rem + env(safe-area-inset-bottom));animation:modal-rise var(--motion-base) var(--ease-out);flex-direction:column;display:flex}.modal:focus{outline:none}.modal__inner{flex-direction:column;width:100%;max-width:26rem;height:100%;margin:0 auto;display:flex}@keyframes modal-fade{0%{opacity:0}}@keyframes modal-rise{0%{transform:translateY(10%)}}@media (prefers-reduced-motion:reduce){.modal-overlay,.modal{animation:none}}.modal__head{justify-content:space-between;align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.modal__title{text-overflow:ellipsis;white-space:nowrap;font-weight:700;overflow:hidden}.numpad__display{border-bottom:1px solid var(--border);flex:1;justify-content:center;align-items:center;gap:.4rem;min-height:4rem;margin-bottom:.85rem;padding:1rem .3rem;display:flex}.numpad__num{font-variant-numeric:tabular-nums;font-size:clamp(2.4rem,14vw,3.5rem);font-weight:700;line-height:1}.numpad__unit{color:var(--muted);font-weight:600}.numpad__grid{grid-template-columns:repeat(3,1fr);gap:.55rem;display:grid}.numpad__key{border:1px solid var(--border);background:var(--bg);min-height:64px;color:var(--text);transition:background var(--motion-fast) var(--ease-in-out), transform var(--motion-fast) var(--ease-out);border-radius:12px;justify-content:center;align-items:center;font-size:1.5rem;font-weight:600;display:inline-flex}@media (hover:hover){.numpad__key:hover{background:color-mix(in srgb, var(--accent,var(--coral)) 10%, var(--bg))}}.numpad__key:active{background:color-mix(in srgb, var(--accent,var(--coral)) 16%, var(--bg));transform:scale(.97)}.numpad__key--muted{color:var(--muted);font-size:1.15rem}.numpad__done{margin-top:.85rem}.datefield{border:1px solid var(--border);background:var(--bg);width:100%;min-height:48px;color:var(--text);text-align:left;border-radius:12px;align-items:center;gap:.55rem;padding:.85rem .9rem;display:inline-flex}.datefield:focus-visible{outline:3px solid var(--accent-blue);outline-offset:1px}.datefield:disabled{opacity:.6;cursor:default}.datefield__icon{color:var(--muted);flex:none}.datefield__value{font-weight:600}.datefield__placeholder{color:var(--muted)}.datefield-icon{min-height:44px;color:var(--muted);transition:color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out);background:0 0;border:0;border-radius:10px;align-items:center;gap:.35rem;padding:0 .6rem;display:inline-flex}.datefield-icon:hover:not(:disabled){color:var(--text);background:color-mix(in srgb, var(--text) 8%, transparent)}.datefield-icon:focus-visible{outline:2px solid var(--accent-blue);outline-offset:1px}.datefield-icon.is-active{color:var(--accent,var(--coral));background:color-mix(in srgb, var(--accent,var(--coral)) 12%, transparent)}.datefield-icon:disabled{opacity:.6;cursor:default}.datefield-icon__chip{white-space:nowrap;font-size:.8rem;font-weight:600}.datepad__display{text-align:center;min-height:1.7rem;margin-top:auto;padding:.25rem 0 .6rem;font-size:1.15rem;font-weight:700}.datepad__display--empty{color:var(--muted);font-weight:500}.datepad__cal{flex-direction:column;flex:0 auto;align-items:center;min-height:0;padding:.75rem 0;display:flex;overflow:auto}.datepad__cal~.numpad__done{margin-bottom:auto}.datepad__input{display:none}.datepad__cal .flatpickr-calendar.inline{width:100%;max-width:22rem;box-shadow:none;background:0 0;border:0;margin:0 auto}.datepad__cal .flatpickr-calendar.inline .flatpickr-rContainer,.datepad__cal .flatpickr-calendar.inline .flatpickr-days,.datepad__cal .flatpickr-calendar.inline .dayContainer{width:100%;min-width:0;max-width:none}.datepad__cal .flatpickr-current-month{font-size:1.1rem}.datepad__cal .flatpickr-current-month .flatpickr-monthDropdown-months{margin-right:.4rem}.datepad__cal .flatpickr-day{max-width:none;height:42px;line-height:42px}.datepad__cal .flatpickr-time{width:100%}.datepad__cal .flatpickr-time input,.datepad__cal .flatpickr-time .flatpickr-am-pm{height:3rem;font-size:1.35rem;line-height:3rem}.insight-peek{border:1px solid color-mix(in srgb, var(--gold) 35%, var(--border));background:color-mix(in srgb, var(--gold) 7%, var(--surface));border-radius:12px;align-items:stretch;gap:.25rem;margin-bottom:1rem;display:flex}.insight-peek__main{text-align:left;min-width:0;color:var(--text);cursor:pointer;background:0 0;border:0;flex:auto;align-items:center;gap:.5rem;padding:.65rem .5rem .65rem .75rem;display:flex}.insight-peek__icon{color:var(--gold);flex:none}.insight-peek__text{text-overflow:ellipsis;white-space:nowrap;flex:auto;min-width:0;font-size:.9rem;line-height:1.3;overflow:hidden}.insight-peek__chev{color:var(--muted);flex:none}.insight-peek__close{align-self:center;margin-right:.25rem}.insights-empty{text-align:center;flex-direction:column;align-items:center;gap:.4rem;padding:2.5rem 1rem;display:flex}.insights-empty__icon{color:var(--gold);margin-bottom:.3rem}.insights-empty p{max-width:22rem;margin:0}.insights-section{margin:0 0 1.5rem}.insights-section__title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0 0 .65rem;font-size:.78rem;font-weight:600}.insights-note{margin:.65rem 0 0}.insight-habits{flex-direction:column;gap:.85rem;margin:0;padding:0;list-style:none;display:flex}.insight-habit{border:1px solid color-mix(in srgb, var(--accent,var(--coral)) 18%, var(--border));background:color-mix(in srgb, var(--accent,var(--coral)) 5%, var(--surface));border-radius:12px;flex-direction:column;gap:.5rem;padding:.75rem .85rem;display:flex}.insight-habit[data-domain=training]{--accent:var(--coral)}.insight-habit[data-domain=eating]{--accent:var(--ok)}.insight-habit[data-domain=habits]{--accent:var(--gold)}.insight-habit[data-domain=work]{--accent:var(--navy)}.insight-habit__head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.insight-habit__behavior{text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:.4rem;min-width:0;font-size:.95rem;font-weight:600;display:inline-flex;overflow:hidden}.insight-habit__behavior .habit-domain-icon{flex:none}.insight-habit__meta{align-items:center;gap:.75rem;display:flex}.insight-habit__bar,.insight-habit__new{flex:auto}.daymap-projection{border:1px solid color-mix(in srgb, var(--coral) 30%, var(--border));background:color-mix(in srgb, var(--coral) 8%, var(--surface));flex-direction:row;justify-content:space-between;align-items:center;gap:.6rem;padding:.7rem .9rem;display:flex}.daymap-projection [role=status]{flex:1;min-width:0}.daymap-projection p{margin:0}.daymap-projection__headline{color:var(--text);font-size:1.15rem;font-weight:800;line-height:1.15}.daymap-projection__caption{font-size:.8rem}.daymap-window{border:1px solid var(--border);border-radius:var(--radius-pill);flex:none;align-self:center;gap:2px;padding:2px;display:inline-flex}.daymap-window__btn{border-radius:var(--radius-pill);min-height:1.6rem;color:var(--muted);font-variant-numeric:tabular-nums;cursor:pointer;transition:background var(--motion-fast) var(--ease-in-out), color var(--motion-fast) var(--ease-in-out);background:0 0;border:0;padding:.15rem .55rem;font-size:.7rem;font-weight:600}.daymap-window__btn.is-active{background:var(--accent-blue);color:#fff}.daymap-window__btn:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.daymap-tabs{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-pill);gap:.25rem;margin:.75rem 0 .5rem;padding:.2rem;display:flex}.daymap-tab{border-radius:var(--radius-pill);min-height:2.1rem;color:var(--muted);text-transform:capitalize;cursor:pointer;transition:background var(--motion-base) var(--ease-in-out), color var(--motion-base) var(--ease-in-out);background:0 0;border:none;flex:1 1 0;padding:.4rem .6rem;font-size:.85rem;font-weight:600}.daymap-tab.is-active{background:var(--accent-blue);color:#fff}.daymap-tab:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.daymap-today{flex-direction:column;gap:.75rem;display:flex}.daymap-paintbar{flex-direction:column;gap:.6rem;display:flex}.daymap-head{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.daymap-head h1{margin:0}.daymap-head .daymap-datenav{flex:none}.daymap-review{flex-direction:column;gap:1rem;display:flex}.daymap-datenav{justify-content:space-between;align-items:center;gap:.5rem;display:flex}.daymap-datenav__label{color:var(--text);cursor:pointer;background:0 0;border:none;flex:auto;padding:.35rem;font-weight:700}.daymap-palette{-webkit-overflow-scrolling:touch;scrollbar-width:none;flex-wrap:nowrap;gap:.4rem;display:flex;overflow-x:auto}.daymap-palette::-webkit-scrollbar{display:none}.daymap-chip{border:1px solid var(--border);border-radius:var(--radius-pill);background:var(--surface);min-height:2.4rem;color:var(--text);cursor:pointer;transition:border-color var(--motion-fast) var(--ease-in-out), background var(--motion-fast) var(--ease-in-out);flex:none;align-items:center;gap:.35rem;padding:.35rem .7rem;font-size:.8rem;font-weight:600;display:inline-flex}.daymap-chip__dot{background:var(--chip,var(--muted));border-radius:50%;width:.7rem;height:.7rem}.daymap-chip.is-active{border-color:var(--chip,var(--accent-blue));background:color-mix(in srgb, var(--chip,var(--accent-blue)) 18%, var(--surface));box-shadow:0 0 0 1px var(--chip,var(--accent-blue)) inset}.daymap-chip:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px}.daymap-chip--erase.is-active,.daymap-chip--manage{color:var(--muted)}.day-canvas{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);touch-action:none;-webkit-user-select:none;user-select:none;grid-template-columns:auto repeat(6,1fr);grid-auto-rows:1fr;gap:3px;height:clamp(17rem,46vh,25rem);padding:.5rem;display:grid}.day-canvas.is-painting{outline:2px solid var(--accent-blue);outline-offset:2px}.day-canvas__hour{color:var(--muted);font-variant-numeric:tabular-nums;align-items:center;padding:0 .45rem 0 .15rem;font-size:.7rem;font-weight:600;display:flex}.day-canvas__cell{background:var(--hairline-soft);cursor:pointer;border:none;border-radius:6px;min-width:0;padding:0}.day-canvas__cell.is-filled{background:var(--cell)}.day-canvas__cell:nth-of-type(odd){border-top-right-radius:2px;border-bottom-right-radius:2px}.day-canvas__cell:nth-of-type(2n){border-top-left-radius:2px;border-bottom-left-radius:2px;margin-left:-2px}.day-canvas__cell:focus-visible{outline:2px solid var(--accent-blue);outline-offset:-2px}.day-canvas__cell.is-now{box-shadow:inset 0 0 0 2px var(--accent-blue);animation:now-pulse 2s var(--ease-in-out) infinite}@keyframes now-pulse{50%{box-shadow:inset 0 0 0 2px color-mix(in srgb, var(--accent-blue) 45%, transparent)}}.daymap-actions{justify-content:space-between;align-items:center;gap:.75rem;display:flex}.daymap-actions__meta{font-size:.8rem}.daymap-actions__tools{align-items:center;gap:.4rem;display:inline-flex}.daymap-clear:disabled{opacity:.5;cursor:default;text-decoration:none}.daymap-confirm{align-items:center;gap:.25rem;display:inline-flex}.daymap-savestate{color:var(--muted);align-items:center;gap:.4rem;font-size:.8rem;display:inline-flex}.daymap-savestate--error{color:var(--coral)}.daymap-hint{margin:-.25rem 0 0;font-size:.8rem}.daymap-daytotals{flex-wrap:wrap;gap:.4rem .9rem;margin:0;padding:0;list-style:none;display:flex}.daymap-daytotals__item{align-items:center;gap:.35rem;font-size:.85rem;display:inline-flex}.daymap-daytotals__dot{border-radius:50%;width:.65rem;height:.65rem}.daymap-daytotals__h{color:var(--muted);font-weight:600}.daymap-empty{text-align:center;padding:1.5rem .5rem}.daymap-chart{flex-direction:column;gap:.6rem;margin:0;display:flex}.daymap-chart__body{grid-template-columns:auto 1fr;gap:.5rem;display:grid}.daymap-chart__yaxis{text-align:right;height:9rem;color:var(--muted);font-variant-numeric:tabular-nums;flex-direction:column;justify-content:space-between;font-size:.65rem;display:flex}.daymap-chart__scroll{min-width:0;overflow-x:auto}.daymap-chart__plot{border-left:1px solid var(--border);border-bottom:1px solid var(--border);height:9rem;position:relative}.daymap-chart__gridline{border-top:1px dashed var(--hairline-soft);pointer-events:none;height:0;position:absolute;left:0;right:0}.daymap-chart__cols,.daymap-chart__xaxis{box-sizing:border-box;gap:4px;min-width:100%;padding:0 .45rem;display:flex}.daymap-chart__cols{align-items:flex-end;height:100%}.daymap-chart__col{cursor:pointer;background:0 0;border:0;flex:1 1 0;align-items:flex-end;min-width:0;height:100%;margin:0;padding:0;display:flex}.daymap-chart__col:focus-visible{outline:2px solid var(--accent-blue);outline-offset:2px;border-radius:4px}.daymap-chart__bar{align-items:flex-end;width:100%;max-width:1.1rem;height:100%;margin:0 auto;display:flex}.daymap-chart__total{background:color-mix(in srgb, var(--coral) 20%, var(--surface));border-radius:3px 3px 0 0;align-items:flex-end;width:100%;min-height:2px;display:flex}.daymap-chart__draining{background:var(--coral);border-radius:3px 3px 0 0;width:100%}.daymap-chart__xaxis{margin-top:.3rem}.daymap-chart__tick{text-align:center;min-width:0;color:var(--muted);font-variant-numeric:tabular-nums;flex:1 1 0;font-size:.6rem}.daymap-chart__legend{color:var(--muted);flex-wrap:wrap;gap:.5rem 1rem;font-size:.75rem;display:flex}.daymap-chart__key{align-items:center;gap:.35rem;display:inline-flex}.daymap-chart__key:before{content:"";border-radius:3px;width:.7rem;height:.7rem}.daymap-chart__key--total:before{background:color-mix(in srgb, var(--coral) 20%, var(--surface));border:1px solid var(--border)}.daymap-chart__key--draining:before{background:var(--coral)}.daymap-trends{flex-direction:column;gap:1.25rem;padding-bottom:.5rem;display:flex}.stat-row{grid-template-columns:repeat(3,minmax(0,1fr));gap:.5rem;display:grid}.daymap-trends .stat-tile{min-width:0}.daymap-trends .stat-tile__value{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.daymap-trends .stat-tile__label{overflow-wrap:anywhere;letter-spacing:0}.stat-tile--draining{--accent:var(--coral)}.stat-tile--neutral{--accent:var(--muted)}.stat-tile--productive{--accent:var(--ok)}.daymap-breakdown__title{margin:0 0 .5rem;font-size:.95rem}.daymap-breakdown__list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.daymap-breakdown__row{grid-template-columns:minmax(0,6.5rem) 1fr 2.6rem;align-items:center;gap:.5rem;display:grid}.daymap-breakdown__label{text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:.4rem;font-size:.85rem;display:inline-flex;overflow:hidden}.daymap-breakdown__dot{border-radius:50%;flex:none;width:.65rem;height:.65rem}.daymap-breakdown__track{border-radius:var(--radius-pill);background:var(--surface);border:1px solid var(--border);height:.55rem;overflow:hidden}.daymap-breakdown__fill{border-radius:var(--radius-pill);min-width:2px;height:100%;display:block}.daymap-breakdown__value{color:var(--muted);font-variant-numeric:tabular-nums;text-align:right;font-size:.8rem;font-weight:600}.daymap-cats{-webkit-overflow-scrolling:touch;flex-direction:column;flex:1;gap:.75rem;min-height:0;display:flex;overflow-y:auto}.daymap-cats__list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.daymap-cats__row,.daymap-cats__add{flex-direction:column;gap:.5rem;display:flex}.daymap-cats__top{align-items:center;gap:.5rem;display:flex}.daymap-cats__swatch{border:1px solid var(--border);cursor:pointer;background:0 0;border-radius:6px;flex:none;width:2.25rem;height:2.25rem;padding:0}.daymap-cats__name{border:1px solid var(--border);background:var(--surface);min-width:0;color:var(--text);border-radius:8px;flex:auto;padding:.35rem .5rem}.daymap-cats__kinds .seg__btn{padding-inline:.25rem;font-size:.8rem}.daymap-kind--productive.is-active{background:var(--ok);color:#fff;border-color:var(--ok)}.daymap-kind--neutral.is-active{background:var(--muted);color:#fff;border-color:var(--muted)}.daymap-kind--draining.is-active{background:var(--coral);color:#fff;border-color:var(--coral)}
