:root{--bg:#0a0e1a;--bg-elev:#111726;--bg-elev-2:#161d30;--border:#1f2740;--border-strong:#2a335a;--text:#e6e8f0;--text-muted:#8b93b0;--text-dim:#5b6486;--brand:#635bff;--brand-hover:#7a73ff;--brand-soft:rgba(99,91,255,.12);--danger:#dc2626;--danger-strong:#b91c1c;--danger-soft:rgba(220,38,38,.18);--success:#00d924;--tile-empty:#cbd5e1;--tile-no:rgba(220,38,38,.6);--tile-future-border:hsla(0,0%,100%,.5);--year-tile-size:13px;--card-min-width:280px;--year-row-h:18px;--radius:12px;--radius-sm:8px;--shadow-card:0 1px 0 hsla(0,0%,100%,.03) inset,0 8px 24px rgba(0,0,0,.35)}*,:after,:before{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{color:var(--brand);text-decoration:none}a:hover{color:var(--brand-hover)}button{cursor:pointer}button,input,select,textarea{font-family:inherit;font-size:inherit}::placeholder{color:var(--text-dim)}.page{min-height:100dvh;display:flex;flex-direction:column}.container{width:100%;max-width:1100px;margin:0 auto;padding:0 20px}.topbar{border-bottom:1px solid var(--border);background:rgba(10,14,26,.85);-webkit-backdrop-filter:saturate(180%) blur(8px);backdrop-filter:saturate(180%) blur(8px);position:-webkit-sticky;position:sticky;top:0;z-index:10}.topbar-inner{justify-content:space-between;padding:14px 0;gap:8px}.topbar-actions,.topbar-inner{display:flex;align-items:center}.topbar-actions{gap:12px;flex-wrap:nowrap}.topbar-email{color:var(--text-muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:220px}.brand{font-weight:700;letter-spacing:-.01em;color:var(--text);display:inline-flex;align-items:center;gap:10px;flex-shrink:0}.brand-mark{width:22px;height:22px;border-radius:6px}.brand-mark,.brand-suffix{background:linear-gradient(135deg,#635bff,#00d4ff)}.brand-suffix{-webkit-background-clip:text;background-clip:text;color:transparent;font-weight:700}.month-name{color:var(--text-muted);font-weight:500}.card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-card)}.card h2{margin:0 0 12px;font-size:16px;font-weight:600;letter-spacing:-.01em}.card-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.auth-wrap{padding:48px 20px}.auth-card{width:100%;max-width:380px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow-card)}.auth-card h1{font-size:22px;margin:0 0 6px;letter-spacing:-.02em}.auth-card p.subtle{color:var(--text-muted);margin:0 0 22px;font-size:14px}.field{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}.field label{font-size:13px;color:var(--text-muted)}.input,.select{background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius-sm);color:var(--text);padding:10px 12px;outline:none;transition:border-color .12s ease,box-shadow .12s ease}.input:focus,.select:focus{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid transparent;background:var(--bg-elev-2);color:var(--text);font-weight:500;transition:background .12s ease,border-color .12s ease,transform 60ms ease}.btn:hover{background:#1c2440}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-hover)}.btn-ghost{background:transparent;border-color:var(--border-strong);color:var(--text-muted)}.btn-ghost:hover{color:var(--text)}.btn-sm{padding:6px 10px;font-size:13px;border-radius:6px}.btn-block{width:100%}.btn[disabled]{opacity:.6;cursor:not-allowed}.error{background:var(--danger-soft);color:#fecaca;border:1px solid rgba(220,38,38,.35);border-radius:var(--radius-sm)}.error,.notice{padding:10px 12px;font-size:13px;margin-bottom:12px}.notice{background:var(--brand-soft);color:#cfcdff;border:1px solid rgba(99,91,255,.35);border-radius:var(--radius-sm)}.dash-main{flex:1 1;padding:28px 0 64px}.size-toolbar{display:flex;align-items:center;gap:10px;padding:8px 12px;margin-bottom:18px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--text-muted)}.size-toolbar label{letter-spacing:.02em;text-transform:uppercase;font-weight:600;color:var(--text-dim)}.size-toolbar .size-icon{font-size:11px;color:var(--text-dim);-webkit-user-select:none;-moz-user-select:none;user-select:none}.size-toolbar .size-icon.lg{font-size:15px}.size-toolbar input[type=range]{flex:1 1;max-width:280px;accent-color:var(--brand);cursor:-webkit-grab;cursor:grab;background:transparent}.size-toolbar input[type=range]:active{cursor:-webkit-grabbing;cursor:grabbing}.size-toolbar .size-reset{margin-left:auto;background:transparent;border:1px solid var(--border-strong);color:var(--text-muted);border-radius:6px;padding:4px 10px;font-size:12px;cursor:pointer;transition:color .12s ease,border-color .12s ease}.size-toolbar .size-reset:hover{color:var(--text);border-color:var(--brand)}.section{margin-bottom:32px}.section-head{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px;gap:12px}.section-head h2{font-size:18px;margin:0;letter-spacing:-.01em}.section-head .muted{color:var(--text-muted);font-size:13px}.checkin-list{display:grid;grid-template-columns:1fr;grid-gap:10px;gap:10px}.checkin-row{display:flex;align-items:center;gap:12px;padding:12px 14px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius-sm)}.checkin-row .name{flex:1 1;font-weight:500}.dot{width:12px;height:12px;border-radius:999px;flex-shrink:0}.yn{display:inline-flex;gap:6px}.yn .btn{padding:6px 12px;font-size:13px}.yn .btn.active-yes{background:var(--success);color:#06210b;border-color:transparent}.yn .btn.active-no{border-color:transparent}.checkin-row.negative .yn .btn.active-yes,.yn .btn.active-no{background:var(--danger);color:#fff}.checkin-row.negative .yn .btn.active-no{background:var(--success);color:#06210b}.goal-tag{display:inline-block;margin-left:6px;font-size:11px;color:var(--text-dim);font-weight:500;vertical-align:middle}.goal-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:8px;gap:8px;margin-top:6px}.goal-card{display:flex;flex-direction:column;gap:2px;text-align:left;background:var(--bg);border:1px solid var(--border-strong);border-radius:var(--radius-sm);padding:10px 12px;color:var(--text);transition:border-color .12s ease,background .12s ease}.goal-card.selected,.goal-card:hover{border-color:var(--brand)}.goal-card.selected{background:var(--brand-soft)}.goal-card-title{display:inline-flex;align-items:center;gap:6px;font-weight:600;font-size:13px}.goal-card-desc{font-size:12px;color:var(--text-muted)}.goal-arrow{display:inline-flex;align-items:center;justify-content:center;width:18px;height:18px;border-radius:999px;font-size:11px;font-weight:700}.goal-arrow.up{background:rgba(0,217,36,.18);color:var(--success)}.goal-arrow.down{background:var(--danger-soft);color:var(--danger)}@media (max-width:460px){.goal-grid{grid-template-columns:1fr}}.cat-pill{display:inline-flex;align-items:center;gap:6px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:3px 10px;font-size:12px;color:var(--text-muted);white-space:nowrap}.category-grid{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}.cat-chip{display:inline-flex;align-items:center;gap:6px;background:var(--bg);border:1px solid var(--border-strong);border-radius:999px;padding:5px 12px;font-size:13px;color:var(--text);transition:border-color .12s ease,background .12s ease}.cat-chip.selected,.cat-chip:hover{border-color:var(--brand)}.cat-chip.selected{background:var(--brand-soft)}.manage-tabs{display:flex;gap:4px;margin:4px 0 18px;border-bottom:1px solid var(--border)}.manage-tab{padding:8px 14px;font-size:14px;color:var(--text-muted);border-bottom:2px solid transparent;margin-bottom:-1px;transition:color .12s ease,border-color .12s ease}.manage-tab:hover{color:var(--text)}.manage-tab.active{color:var(--text);border-bottom-color:var(--brand)}.cat-form{display:grid;grid-template-columns:80px 1fr 1fr auto;grid-gap:10px;gap:10px;align-items:end}.cat-form .field{margin-bottom:0}.cat-form-submit{display:flex;align-items:end}.cat-row-icon{font-size:22px;line-height:1;width:30px;flex-shrink:0;text-align:center}.cat-key{font-family:ui-monospace,SFMono-Regular,SF Mono,Consolas,monospace;font-size:11px;background:var(--bg);border:1px solid var(--border);border-radius:4px;padding:1px 6px;color:var(--text-muted)}@media (max-width:600px){.cat-form{grid-template-columns:80px 1fr}.cat-form-key,.cat-form-submit{grid-column:1/-1}}.manage-list{display:grid;grid-template-columns:1fr;grid-gap:10px;gap:10px}.manage-row{display:flex;flex-direction:column;gap:10px;padding:14px 16px}.manage-row-main{display:flex;align-items:center;gap:12px}.manage-row-text{flex:1 1;min-width:0}.manage-row-name{font-weight:600;display:inline-flex;align-items:center;gap:6px}.manage-row-meta{display:flex;align-items:center;gap:10px;font-size:12px;margin-top:4px;flex-wrap:wrap}.manage-row-actions{display:flex;gap:6px;flex-wrap:wrap;justify-content:flex-end}.manage-row.editing{align-items:stretch}.danger-btn{color:var(--danger)}.danger-btn:hover{color:#fecaca;background:var(--danger-soft);border-color:rgba(220,38,38,.4)}@media (max-width:600px){.manage-row-actions{justify-content:flex-start}}.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--card-min-width,280px),1fr));grid-gap:16px;gap:16px}.habit-card .meta{display:flex;align-items:center;gap:8px;color:var(--text-muted);font-size:13px;margin-bottom:12px}.habit-card .name{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px;letter-spacing:-.01em}.habit-card .pct{font-size:22px;font-weight:700;letter-spacing:-.02em}.habit-card .pct-row{display:flex;align-items:baseline;justify-content:space-between;margin-top:4px;margin-bottom:14px}.habit-card .sub{color:var(--text-muted);font-size:12px}.tile-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px}.tile{aspect-ratio:1/1;width:100%;border-radius:4px;background:var(--tile-empty);border:1px solid transparent;position:relative;overflow:hidden}.tile.no{background:var(--tile-no)}.tile.future{background:transparent;border-color:var(--tile-future-border)}.tile-day{position:absolute;top:2px;left:4px;font-size:10px;font-weight:500;line-height:1;color:#fff;mix-blend-mode:difference;opacity:.7;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.create-form{display:grid;grid-template-columns:1fr auto;grid-gap:10px;gap:10px;align-items:end}.color-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:6px}.color-swatch{width:26px;height:26px;border-radius:999px;border:2px solid transparent;cursor:pointer;padding:0;background:transparent}.color-swatch.selected{border-color:var(--text);box-shadow:0 0 0 2px var(--bg)}.archived-list{display:flex;flex-wrap:wrap;gap:8px}.archived-pill{display:inline-flex;align-items:center;gap:8px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:6px 10px;font-size:13px}.archived-pill,.empty{color:var(--text-muted)}.empty{text-align:center;padding:40px 20px;border:1px dashed var(--border-strong);border-radius:var(--radius)}.marketing{position:relative;overflow:hidden}.marketing:before{content:"";position:absolute;top:-240px;left:50%;transform:translateX(-50%);width:1200px;height:600px;background:radial-gradient(closest-side,rgba(99,91,255,.22),transparent 70%),radial-gradient(closest-side at 70% 50%,rgba(0,212,255,.16),transparent 70%);filter:blur(20px);pointer-events:none;z-index:0}.marketing>*{position:relative;z-index:1}.hero{padding:64px 0 56px;display:grid;grid-template-columns:1.05fr 1fr;grid-gap:56px;gap:56px;align-items:center}.hero-copy{display:flex;flex-direction:column;gap:18px}.hero-kicker{display:inline-flex;align-items:center;gap:8px;padding:5px 12px;border-radius:999px;background:var(--brand-soft);border:1px solid rgba(99,91,255,.35);color:#cfcdff;font-size:12px;letter-spacing:.06em;text-transform:uppercase;font-weight:600;width:-moz-fit-content;width:fit-content}.hero-kicker .dot-pulse{width:7px;height:7px;border-radius:999px;background:var(--brand);box-shadow:0 0 0 0 rgba(99,91,255,.6);animation:dot-pulse 2.2s ease-out infinite}@keyframes dot-pulse{0%{box-shadow:0 0 0 0 rgba(99,91,255,.45)}70%{box-shadow:0 0 0 10px rgba(99,91,255,0)}to{box-shadow:0 0 0 0 rgba(99,91,255,0)}}.hero h1{font-size:56px;line-height:1.05;letter-spacing:-.035em;margin:0;background:linear-gradient(135deg,#fff,#a28dff 55%,#00d4ff);-webkit-background-clip:text;background-clip:text;color:transparent}.hero-sub{color:var(--text-muted);margin:0;font-size:17px;line-height:1.55;max-width:520px}.hero-cta{display:flex;gap:10px;margin-top:6px;flex-wrap:wrap}.hero-cta .btn{padding:11px 18px;font-size:14px}.hero-meta{display:flex;gap:16px;font-size:12px;color:var(--text-dim);margin-top:6px;flex-wrap:wrap}.hero-meta span{display:inline-flex;align-items:center;gap:6px}.hero-meta .check{color:var(--success)}.preview-stack{position:relative;display:flex;justify-content:center}.preview-card{position:relative;width:100%;max-width:420px;background:var(--bg-elev);border:1px solid var(--border-strong);border-radius:16px;padding:18px;box-shadow:inset 0 1px 0 hsla(0,0%,100%,.04),0 30px 60px rgba(0,0,0,.45),0 0 0 1px rgba(99,91,255,.18);transform:rotate(-1deg)}.preview-card:after{content:"";position:absolute;inset:-1px;border-radius:16px;background:linear-gradient(135deg,rgba(99,91,255,.5),transparent 40%);pointer-events:none;-webkit-mask:linear-gradient(#000,#000) content-box,linear-gradient(#000,#000);-webkit-mask-composite:xor;mask-composite:exclude;padding:1px}.preview-head{display:flex;align-items:center;gap:10px;margin-bottom:12px}.preview-head .dot{width:12px;height:12px;border-radius:999px;flex-shrink:0}.preview-head .name{font-weight:600;flex:1 1;font-size:14px}.preview-head .pct{font-weight:700;font-size:18px;letter-spacing:-.02em}.preview-pill{display:inline-flex;align-items:center;gap:6px;background:var(--bg-elev-2);border:1px solid var(--border);border-radius:999px;padding:3px 10px;font-size:11px;color:var(--text-muted)}.preview-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:4px;gap:4px;margin-top:10px}.preview-tile{aspect-ratio:1/1;border-radius:4px;background:var(--tile-empty);opacity:.45}.preview-tile.miss{background:var(--tile-no);opacity:1}.preview-tile.fill{background:var(--brand)}.preview-tile.fill.l1{opacity:.4}.preview-tile.fill.l2{opacity:.65}.preview-tile.fill.l3{opacity:.9}.preview-tile.fill.l4{opacity:1}.preview-tile.future{background:transparent;border:1px solid var(--tile-future-border)}.preview-meta{display:flex;justify-content:space-between;margin-top:12px;font-size:11px;color:var(--text-dim)}.preview-card.behind{position:absolute;inset:14px -10px auto auto;width:78%;transform:rotate(3deg);opacity:.7;z-index:-1;filter:blur(.4px)}.section-marketing{padding:56px 0}.section-eyebrow{text-align:center;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-dim);font-weight:600;margin:0 0 8px}.section-title{text-align:center;font-size:32px;letter-spacing:-.025em;margin:0 auto 12px;max-width:720px}.section-lede{text-align:center;color:var(--text-muted);font-size:16px;max-width:620px;margin:0 auto 36px}.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px}.feature-card{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:22px 20px;transition:border-color .16s ease,transform .16s ease}.feature-card:hover{border-color:var(--border-strong);transform:translateY(-2px)}.feature-icon{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--brand-soft),rgba(0,212,255,.1));border:1px solid rgba(99,91,255,.25);font-size:18px;margin-bottom:14px}.feature-card h3{font-size:15px;margin:0 0 6px;letter-spacing:-.01em}.feature-card p{margin:0;color:var(--text-muted);font-size:13.5px;line-height:1.55}.steps{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:16px;gap:16px;counter-reset:step}.step{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:22px 20px;position:relative}.step:before{counter-increment:step;content:counter(step);position:absolute;top:14px;right:16px;font-size:36px;font-weight:800;letter-spacing:-.04em;color:transparent;background:linear-gradient(135deg,var(--brand),#00d4ff);-webkit-background-clip:text;background-clip:text;opacity:.5;line-height:1}.step h3{font-size:15px;margin:0 0 6px}.step p{margin:0;font-size:13.5px;color:var(--text-muted)}.cta-banner{margin:32px 0 56px;padding:36px 28px;background:radial-gradient(circle at 0 0,rgba(99,91,255,.25),transparent 50%),radial-gradient(circle at 100% 100%,rgba(0,212,255,.18),transparent 50%),var(--bg-elev);border:1px solid var(--border-strong);border-radius:18px;text-align:center}.cta-banner h2{font-size:28px;margin:0 0 8px;letter-spacing:-.025em}.cta-banner p{margin:0 auto 20px;color:var(--text-muted);font-size:15px;max-width:540px}.site-footer{border-top:1px solid var(--border);padding:22px 0 32px;color:var(--text-dim);font-size:12px}.site-footer-inner{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}.site-footer a{color:var(--text-muted)}.site-footer a:hover{color:var(--text)}@media (max-width:900px){.hero{grid-template-columns:1fr;gap:36px;padding:40px 0 32px;text-align:left}.hero h1{font-size:42px}.preview-card{transform:none;margin:0 auto}.preview-card.behind{display:none}.feature-grid,.steps{grid-template-columns:repeat(2,1fr)}.section-marketing{padding:40px 0}.section-title{font-size:26px}}@media (max-width:600px){.hero h1{font-size:34px}.hero-sub{font-size:15px}.feature-grid,.steps{grid-template-columns:1fr}.cta-banner{padding:28px 18px;margin:24px 0 40px}.cta-banner h2{font-size:22px}}.auth-wrap{flex:1 1;display:flex;align-items:center;justify-content:center;padding:32px 20px}.auth-grid{display:grid;grid-template-columns:minmax(0,380px) minmax(0,360px);grid-gap:32px;gap:32px;align-items:stretch;width:100%;max-width:820px}.auth-side{background:radial-gradient(circle at 0 0,rgba(99,91,255,.22),transparent 55%),radial-gradient(circle at 100% 100%,rgba(0,212,255,.15),transparent 55%),var(--bg-elev);border:1px solid var(--border-strong);border-radius:var(--radius);padding:28px;display:flex;flex-direction:column;gap:14px}.auth-side h2{font-size:18px;margin:0;letter-spacing:-.01em}.auth-side ul{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-direction:column;gap:12px}.auth-side li{display:grid;grid-template-columns:24px 1fr;grid-gap:10px;gap:10px;align-items:start;font-size:13.5px;color:var(--text-muted);line-height:1.45}.auth-side li strong{color:var(--text);font-weight:600;display:block}.auth-side .auth-side-icon{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:6px;background:var(--brand-soft);color:var(--brand);font-size:13px}.auth-side-foot{margin-top:auto;padding-top:14px;border-top:1px dashed var(--border);color:var(--text-dim);font-size:12px}@media (max-width:760px){.auth-grid{grid-template-columns:1fr;max-width:420px}.auth-side{order:2;padding:22px}}.year-grid-wrap{overflow-x:auto;padding-bottom:6px}.year-month-labels{display:grid;grid-template-columns:repeat(var(--year-cols,53),var(--year-tile-size,13px));grid-gap:3px;gap:3px;font-size:10px;color:var(--text-muted);margin-bottom:4px;padding-left:22px}.year-month-labels span{white-space:nowrap}.year-grid{grid-template-columns:repeat(var(--year-cols,53),var(--year-tile-size,13px));grid-auto-flow:column;padding-left:22px;position:relative}.year-day-labels,.year-grid{display:grid;grid-template-rows:repeat(7,var(--year-tile-size,13px));grid-gap:3px;gap:3px}.year-day-labels{position:absolute;left:0;top:0;font-size:9px;color:var(--text-muted);width:18px}.year-day-labels span{line-height:var(--year-tile-size,13px);text-align:right}.ytile{width:var(--year-tile-size,13px);height:var(--year-tile-size,13px);border-radius:3px;background:var(--tile-empty);border:1px solid transparent;padding:0;cursor:default}.ytile.placeholder{visibility:hidden}.ytile.no{background:var(--tile-no)}.ytile.future{background:transparent;border-color:var(--tile-future-border)}button.ytile{cursor:pointer}button.ytile:focus-visible{outline:2px solid var(--brand);outline-offset:1px}button.ytile.future{cursor:not-allowed}.year-overview{padding:18px 20px 16px}.year-rows{display:flex;flex-direction:column;gap:10px;margin-top:6px}.year-row{display:grid;grid-template-columns:minmax(160px,220px) 1fr 110px;align-items:center;grid-gap:14px;gap:14px;padding:6px 0;border-top:1px solid var(--border)}.year-row:first-child{border-top:0}.year-row-label{display:flex;align-items:center;gap:8px;min-width:0}.year-row-name{font-weight:600;font-size:14px;letter-spacing:-.01em;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1 1}.year-row-name:hover{color:var(--brand)}.year-row-cat{font-size:14px;line-height:1;flex-shrink:0;opacity:.8}.year-strip{display:grid;grid-template-columns:repeat(var(--year-cols,53),1fr);grid-gap:2px;gap:2px;height:var(--year-row-h,18px);min-width:0}.year-tile{width:100%;height:100%;border-radius:2px;background:var(--tile-empty);opacity:.35;border:1px solid transparent;transition:transform 80ms ease}.year-tile.placeholder{visibility:hidden}.year-tile.future{background:transparent;border-color:var(--tile-future-border);opacity:.6}.year-tile.filled{opacity:1}.year-tile.filled.level-1{opacity:.3}.year-tile.filled.level-2{opacity:.55}.year-tile.filled.level-3{opacity:.8}.year-tile.filled.level-4{opacity:1}.year-tile:hover{transform:scaleY(1.15)}.year-row-stats{display:flex;align-items:baseline;justify-content:flex-end;gap:14px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.year-stat{display:flex;flex-direction:column;align-items:flex-end;line-height:1.1}.year-stat-value{font-weight:700;font-size:16px;letter-spacing:-.02em;color:var(--text)}.year-stat-label{font-size:10px;text-transform:uppercase;letter-spacing:.04em;color:var(--text-dim);margin-top:1px}.year-axis{display:grid;grid-template-columns:minmax(160px,220px) 1fr 110px;align-items:center;grid-gap:14px;gap:14px;margin-top:10px}.year-axis-strip{display:grid;grid-template-columns:repeat(var(--year-cols,53),1fr);font-size:10px;color:var(--text-dim);letter-spacing:.02em}.year-axis-strip span{white-space:nowrap}.year-axis-spacer{display:block}@media (max-width:720px){.year-row{grid-template-columns:1fr;gap:6px;padding:10px 0}.year-row-stats{justify-content:flex-start;gap:18px}.year-axis{grid-template-columns:1fr}.year-axis-spacer{display:none}}.back-link{display:inline-flex;align-items:center;gap:6px;color:var(--text-muted);font-size:13px;margin-bottom:14px}.back-link:hover{color:var(--text)}.edit-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:4px}.edit-header h1{font-size:22px;margin:0;letter-spacing:-.02em;display:inline-flex;align-items:center;gap:10px}.edit-help{font-size:13px;margin:0 0 18px}.edit-help,.legend{color:var(--text-muted)}.legend{display:flex;align-items:center;gap:14px;font-size:12px;margin-top:14px;flex-wrap:wrap}.legend-item{display:inline-flex;align-items:center;gap:6px}.legend-swatch{width:12px;height:12px;border-radius:3px;background:var(--tile-empty);border:1px solid transparent;display:inline-block}.legend-swatch.yes{background:var(--brand)}.legend-swatch.no{background:var(--tile-no)}.legend-swatch.future{background:transparent;border-color:var(--tile-future-border)}.habit-card .card-title-row .name a{color:var(--text)}.habit-card .card-title-row .name a:hover{color:var(--brand)}@media (max-width:720px){.container{padding:0 16px}.dash-main{padding:18px 0 56px}.section{margin-bottom:24px}.section-head h2{font-size:16px}.topbar-actions{gap:8px}.topbar-email{max-width:140px;font-size:12px}.card{padding:16px}.size-toolbar{padding:6px 10px;gap:8px;flex-wrap:nowrap}.size-toolbar .size-icon{display:none}}@media (max-width:600px){body{font-size:14px}.topbar-email{display:none}.topbar-inner{padding:12px 0}.brand{font-size:14px}.section-head{gap:6px}.section-head h2{font-size:15px}.checkin-row{padding:10px 12px;gap:10px}.checkin-row .name{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:14px}.yn .btn{padding:7px 12px;min-height:36px;font-size:13px}.grid-cards{gap:12px}.habit-card{padding:14px}.habit-card .pct{font-size:19px}.habit-card .pct-row{margin-bottom:10px}.card h2{font-size:15px}.hero{padding:56px 0 40px}.hero h1{font-size:32px}.hero p{font-size:15px}.create-form{grid-template-columns:1fr}.auth-card{padding:22px}.size-toolbar{margin-bottom:14px}.size-toolbar label{font-size:11px}.size-toolbar .size-reset{display:none}.manage-tabs{margin-bottom:14px}.manage-tab{flex:1 1;text-align:center;padding:10px 8px}.manage-row{padding:12px 14px}.manage-row-actions{width:100%;justify-content:flex-start}.year-overview{padding:14px 14px 12px}.year-rows{gap:6px}.year-row-name{font-size:13px}.year-stat-value{font-size:14px}.edit-header h1{font-size:19px}.edit-help{font-size:12px;margin-bottom:14px}.year-grid-wrap{margin:0 -14px;padding:0 14px 8px;-webkit-overflow-scrolling:touch}}@media (max-width:380px){.container{padding:0 12px}.topbar-actions .btn-sm{padding:5px 8px;font-size:12px}.yn .btn{padding:6px 10px;font-size:12px}.checkin-row .name{font-size:13px}.habit-card{padding:12px}}.ov{--ov-day-w:30px;--ov-day-h:30px;--ov-name-w:220px;--ov-row-gap:4px;--ov-col-gap:3px;--ov-radius:6px}.ov-head{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:14px;background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:14px 18px;margin-bottom:14px}.ov-month{font-size:22px;font-weight:600;letter-spacing:-.02em}.ov-stats{display:flex;gap:22px}.ov-stat{text-align:right}.ov-stat-value{font-size:22px;font-weight:600;letter-spacing:-.02em;line-height:1}.ov-stat-label{margin-top:4px;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted)}.ov-scroll{background:var(--bg-elev);border:1px solid var(--border);border-radius:var(--radius);padding:14px;overflow-x:auto;overflow-y:visible;position:relative}.ov-grid{display:grid;grid-template-columns:var(--ov-name-w) repeat(var(--ov-day-cols),var(--ov-day-w));grid-column-gap:var(--ov-col-gap);column-gap:var(--ov-col-gap);grid-row-gap:var(--ov-row-gap);row-gap:var(--ov-row-gap);align-items:stretch;width:max-content;min-width:100%}.ov-cell{display:flex;align-items:center;justify-content:center;height:var(--ov-day-h);font-size:11px;color:var(--text-muted);-webkit-user-select:none;-moz-user-select:none;user-select:none}.ov-analysis-name,.ov-corner,.ov-name,.ov-name-head{position:-webkit-sticky;position:sticky;left:0;z-index:2;background:var(--bg-elev);justify-content:flex-start;padding-left:4px;padding-right:8px;height:var(--ov-day-h);box-shadow:8px 0 12px -8px rgba(0,0,0,.6)}.ov-name-head{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-dim)}.ov-corner{background:var(--bg-elev)}.ov-name{gap:8px;font-size:13px;color:var(--text)}.ov-cat{font-size:14px;width:18px;text-align:center;flex:0 0 auto}.ov-dot{width:8px;height:8px;border-radius:999px;flex:0 0 auto}.ov-habit-link{color:inherit;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:calc(var(--ov-name-w) - 60px)}.ov-habit-link:hover{color:var(--brand)}.ov-goal{margin-left:auto;color:var(--text-dim);font-size:11px;flex:0 0 auto}.ov-week-cell{font-size:10px;color:var(--text-dim);letter-spacing:.05em;height:18px;border-bottom:1px dashed transparent}.ov-week-cell.is-start{color:var(--text-muted);border-left:1px solid var(--border)}.ov-day-head{flex-direction:column;gap:1px;height:32px;border-radius:var(--ov-radius);background:transparent}.ov-day-head .ov-dow{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--text-dim)}.ov-day-head .ov-dom{font-size:12px;color:var(--text-muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.ov-day-head.is-today{background:var(--brand-soft)}.ov-day-head.is-today .ov-dom{color:var(--text);font-weight:600}.ov-day-head.is-week-start{border-left:1px solid var(--border)}.ov-tile{background:var(--bg-elev-2);border:1px solid transparent;border-radius:var(--ov-radius);cursor:pointer;padding:0;position:relative;color:hsla(0,0%,100%,.55);font-size:10px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;transition:transform 80ms ease,background-color .12s ease,border-color .12s ease}.ov-tile:hover:not(:disabled){border-color:var(--border-strong);transform:translateY(-1px)}.ov-tile:focus-visible{outline:2px solid var(--brand);outline-offset:2px}.ov-tile:disabled{cursor:default}.ov-tile.is-today{box-shadow:0 0 0 1.5px var(--brand) inset}.ov-tile.is-week-start{margin-left:2px}.ov-tile.is-future{background:transparent;border:1px dashed var(--border-strong);color:var(--text-dim)}.ov-tile.ov-miss{background:var(--tile-no);color:#fff}.ov-tile.is-pending{opacity:.6}.ov-tile-day{mix-blend-mode:overlay;opacity:.85;pointer-events:none}.ov-section-row{margin-top:6px;padding:6px 4px 4px;border-top:1px solid var(--border);height:auto;justify-content:flex-start;font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-dim)}.ov-analysis-name{font-size:12px;color:var(--text-muted);text-transform:none;letter-spacing:0;font-weight:500}.ov-analysis{background:var(--bg-elev-2);border-radius:var(--ov-radius);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-size:11px;color:var(--text)}.ov-analysis.is-week-start{margin-left:2px}.ov-analysis.is-future{background:transparent;color:transparent}.ov-analysis-pct{color:var(--brand)}.ov-hint{margin:12px 2px 0;font-size:12px;color:var(--text-muted)}.ov-hint strong{color:var(--text);font-weight:500}@media (max-width:900px){.ov{--ov-day-w:26px;--ov-day-h:26px;--ov-name-w:180px}.ov-month,.ov-stat-value{font-size:18px}}@media (max-width:600px){.ov{--ov-day-w:24px;--ov-day-h:24px;--ov-name-w:150px;--ov-col-gap:2px}.ov-head{padding:12px;gap:10px}.ov-stats{gap:14px}.ov-stat-value{font-size:16px}.ov-scroll{padding:10px}.ov-name{font-size:12px}.ov-habit-link{max-width:calc(var(--ov-name-w) - 50px)}.ov-day-head .ov-dom{font-size:11px}}