@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-outline-style:solid;--tw-backdrop-blur:initial;--tw-backdrop-brightness:initial;--tw-backdrop-contrast:initial;--tw-backdrop-grayscale:initial;--tw-backdrop-hue-rotate:initial;--tw-backdrop-invert:initial;--tw-backdrop-opacity:initial;--tw-backdrop-saturate:initial;--tw-backdrop-sepia:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-sm:.25rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.fixed{position:fixed}.sticky{position:sticky}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.table{display:table}.flex-shrink{flex-shrink:1}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.rounded{border-radius:.25rem}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.backdrop-filter{-webkit-backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,);backdrop-filter:var(--tw-backdrop-blur,) var(--tw-backdrop-brightness,) var(--tw-backdrop-contrast,) var(--tw-backdrop-grayscale,) var(--tw-backdrop-hue-rotate,) var(--tw-backdrop-invert,) var(--tw-backdrop-opacity,) var(--tw-backdrop-saturate,) var(--tw-backdrop-sepia,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#f7f8fa;--surface:#fff;--ink:#1a1d21;--ink-soft:#6b7280;--ink-faint:#b6bcc4;--line:#ececf0;--line-strong:#dfe1e6;--accent:#6b7280;--disabled:#f0f1f3;--radius:18px;--radius-sm:12px;--subtle:#f7f8fa;--hover:#eef0f3;--danger:#b04a63;--danger-bg:#fdecef;--flame:#f59e0b;--switch-bg:#ffffffd9;--overlay:#14161a73;--shadow-card-hover:0 2px 12px #14161a12;--shadow-switch:0 8px 30px #14161a24, 0 2px 8px #14161a0f;--shadow-row:0 2px 10px #14161a0f;--border:var(--line-strong);--white:var(--surface);--ink2:var(--ink-soft);--parchment:var(--hover);--gold-mid:var(--ink-soft);--shadow-login:0 2px 8px #14161a0f;--shadow-dropdown:0 4px 16px #14161a1f;--theme-toggle-topbar-stack:56px;--theme-toggle-row-below-topbar:8px;-webkit-tap-highlight-color:transparent}html.dark{--bg:#0f1117;--surface:#1a1d24;--ink:#e4e6ea;--ink-soft:#9ca3af;--ink-faint:#5b616c;--line:#2a2d35;--line-strong:#363940;--accent:#9ca3af;--disabled:#22252c;--subtle:#20232b;--hover:#262a32;--danger:#e5859a;--danger-bg:#3a1a22;--switch-bg:#1a1d24d9;--overlay:#0009;--shadow-card-hover:0 2px 14px #00000080;--shadow-switch:0 8px 30px #0009, 0 2px 8px #0006;--shadow-row:0 2px 12px #00000073;--shadow-login:0 2px 8px #0000004d;--shadow-dropdown:0 4px 16px #0006}html.dark .habit-icon svg{color:#1c1f26}html.dark .cal-day.today,html.dark .grid-day.today{box-shadow:inset 0 0 0 2px #1c1f26}*{box-sizing:border-box}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;font-family:DM Sans,-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif}button{font-family:inherit}.app{background:var(--bg);flex-direction:column;max-width:480px;min-height:100dvh;margin:0 auto;display:flex}.topbar{padding:20px 20px 12px;padding-top:calc(env(safe-area-inset-top,0px) + 20px);justify-content:space-between;align-items:center;display:flex}.brand{letter-spacing:-.02em;font-size:22px;font-weight:800}.brand span{color:var(--ink-faint);font-weight:700}.topbar-actions{align-items:center;gap:14px;display:flex}.icon-btn{width:40px;height:40px;color:var(--ink);cursor:pointer;background:0 0;border:none;border-radius:10px;place-items:center;transition:background .15s;display:grid}.icon-btn:hover{background:var(--hover)}.icon-btn svg{width:22px;height:22px}.habits{flex-direction:column;gap:16px;padding:8px 16px 110px;display:flex}.habits.view-compact{flex-flow:wrap;gap:14px}.habits.view-compact .card{width:calc(50% - 7px);padding:14px}.habits.view-compact .card-head{align-items:center;gap:10px}.habits.view-compact .habit-icon{border-radius:11px;width:38px;height:38px}.habits.view-compact .habit-icon svg{width:20px;height:20px}.habits.view-compact .habit-title{font-size:14px}.habits.view-compact .habit-title .type-tag,.habits.view-compact .habit-sub,.habits.view-compact .habit-action,.habits.view-compact .grid-nav,.habits.view-compact .weekday-row{display:none}.habits.view-compact .mini-month{color:var(--ink-soft);margin-top:2px;font-size:11px;font-weight:700}.habits.view-compact .grid-day{border-radius:4px;font-size:0}.habits.view-compact .grid-days{gap:3px}.habits.view-compact .progress-row{margin-top:10px}.habits.view-compact .progress-label{font-size:11px}.habits.view-compact .done-banner{margin-top:10px;padding:8px;font-size:11.5px}.binary-pct{text-align:center;background:var(--tint);border-radius:12px;margin-top:12px;padding:10px 4px}.binary-pct-num{color:var(--tint-ink);letter-spacing:-.02em;font-size:28px;font-weight:800;line-height:1}.binary-pct-label{color:var(--tint-ink);opacity:.75;margin-top:4px;font-size:11px;font-weight:600}.binary-pct.done{background:var(--tint-strong)}.binary-pct.done .binary-pct-num,.binary-pct.done .binary-pct-label{color:#fff;opacity:1}.binary-pct.done .binary-pct-label{opacity:.9}.habits.view-list{gap:10px}.list-head{grid-template-columns:88px repeat(7,1fr);align-items:end;gap:4px;margin-top:4px;padding:0 4px 4px;display:grid}.list-head .spacer{text-align:left;grid-column:1/2}.list-head .range-pill{color:var(--ink-soft);border:1px solid var(--line-strong);background:var(--surface);white-space:nowrap;border-radius:999px;padding:5px 9px;font-size:11px;font-weight:600;display:inline-block}.list-head .dcol{text-align:center;line-height:1.2}.list-head .dcol .dow{color:var(--ink-soft);font-size:10px}.list-head .dcol .dnum{font-size:12px;font-weight:600}.list-head .dcol.today .dow,.list-head .dcol.today .dnum{color:var(--ink);font-weight:800}.habits.view-list .card{padding:8px}.list-row{grid-template-columns:88px repeat(7,1fr);align-items:center;gap:4px;display:grid}.list-row .row-label{grid-column:1/2;align-items:center;gap:6px;min-width:0;display:flex}.list-row .habit-icon{border-radius:9px;flex-shrink:0;width:30px;height:30px}.list-row .habit-icon svg{width:17px;height:17px}.list-row .row-name{background:var(--tint);color:var(--tint-ink);white-space:nowrap;text-overflow:ellipsis;border-radius:8px;flex:1;min-width:0;padding:6px 8px;font-size:12px;font-weight:600;overflow:hidden}.list-cell{aspect-ratio:1;background:var(--tint);cursor:pointer;border:none;border-radius:9px;place-items:center;width:100%;transition:transform .1s,background .15s;display:grid}.list-cell:hover:not([disabled]){transform:scale(1.06)}.list-cell.filled{background:var(--tint-strong)}.list-cell.filled svg{color:#fff;width:16px;height:16px}.list-cell[disabled]{opacity:.4;cursor:not-allowed}.list-cell.binary-cell.filled svg{color:#fff}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;transition:box-shadow .2s,opacity .2s;position:relative}.card.completed{box-shadow:0 0 0 2px var(--tint-strong) inset}.card.disabled{opacity:.55}.card[data-open]{cursor:pointer}.card[data-open]:hover{box-shadow:var(--shadow-card-hover)}.card.completed[data-open]:hover{box-shadow:0 0 0 2px var(--tint-strong) inset, var(--shadow-card-hover)}.row-card{padding:14px}.collapsed-row{align-items:center;gap:14px;display:flex}.collapsed-row .habit-icon{width:48px;height:48px}.collapsed-row .habit-icon svg{width:24px;height:24px}.collapsed-row .habit-meta{flex:1;min-width:0}.row-check{background:var(--tint);border-radius:14px;flex-shrink:0;place-items:center;width:48px;height:48px;transition:background .15s;display:grid}.row-check svg{width:26px;height:26px;color:var(--tint-ink)}.row-check.on{background:var(--tint-strong)}.row-check.on svg{color:#fff}.row-check.complete{background:var(--tint-strong)}.row-check.complete svg{color:#fff}.card-head{align-items:flex-start;gap:14px;display:flex}.habit-icon{background:var(--tint);border-radius:14px;flex-shrink:0;place-items:center;width:54px;height:54px;display:grid}.habit-icon svg{width:26px;height:26px;color:var(--ink)}.habit-meta{flex:1;min-width:0}.habit-title{letter-spacing:-.01em;flex-wrap:wrap;align-items:center;gap:8px;font-size:18px;font-weight:700;display:flex}.habit-sub{color:var(--ink-soft);margin-top:2px;font-size:14px}.type-tag{text-transform:uppercase;letter-spacing:.06em;background:var(--tint);color:var(--tint-ink);border-radius:999px;padding:3px 8px;font-size:10.5px;font-weight:700}.progress-row{align-items:center;gap:12px;margin-top:14px;display:flex}.progress-track{background:var(--tint);border-radius:999px;flex:1;height:8px;overflow:hidden}.progress-fill{background:var(--tint-strong);border-radius:999px;height:100%;transition:width .35s cubic-bezier(.2,.8,.2,1)}.progress-label{color:var(--ink-soft);white-space:nowrap;font-variant-numeric:tabular-nums;font-size:13px;font-weight:600}.done-banner{background:var(--tint);color:var(--tint-ink);border-radius:12px;align-items:center;gap:8px;margin-top:14px;padding:10px 12px;font-size:13.5px;font-weight:600;display:flex}.done-banner svg{flex-shrink:0;width:18px;height:18px}.grid-wrap{margin-top:16px}.grid-days{grid-template-columns:repeat(7,1fr);gap:5px;display:grid}.grid-day{aspect-ratio:1;background:var(--tint);color:var(--ink-faint);border:none;border-radius:7px;place-items:center;font-size:11px;font-weight:600;display:grid;position:relative}.grid-day.empty{background:0 0}.grid-day.filled{background:var(--tint-strong);color:#fff}.grid-day.today{box-shadow:0 0 0 2px var(--ink) inset}.grid-day.future{opacity:.5}.view-switch{bottom:20px;bottom:calc(env(safe-area-inset-bottom,0px) + 20px);z-index:50;background:var(--switch-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--line-strong);box-shadow:var(--shadow-switch);border-radius:999px;gap:4px;padding:6px;display:flex;position:fixed;left:50%;transform:translate(-50%)}.view-switch button{cursor:pointer;width:62px;height:42px;color:var(--ink-soft);background:0 0;border:none;border-radius:999px;place-items:center;transition:background .15s,color .15s;display:grid}.view-switch button:hover{color:var(--ink)}.view-switch button.active{background:var(--hover);color:var(--ink)}.view-switch svg{width:20px;height:20px}.sheet-overlay{background:var(--overlay);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:90;opacity:0;visibility:hidden;pointer-events:none;justify-content:center;align-items:flex-end;transition:opacity .28s,visibility 0s linear .28s;display:flex;position:fixed;inset:0}.sheet-overlay.show{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .28s,visibility}.sheet{background:var(--surface);border-radius:24px 24px 0 0;width:100%;max-width:480px;max-height:88vh;padding:0;transition:transform .32s cubic-bezier(.32,.72,0,1);overflow-y:auto;transform:translateY(100%)}.sheet-overlay.show .sheet{transform:translateY(0)}.sheet-sticky{z-index:2;background:var(--surface);border-radius:24px 24px 0 0;padding:10px 20px 12px;position:sticky;top:0}.sheet-sticky:after{content:"";background:var(--line);opacity:0;height:1px;transition:opacity .2s;position:absolute;bottom:-1px;left:0;right:0}.sheet.scrolled .sheet-sticky:after{opacity:1}.sheet-body{padding:4px 20px 28px}.sheet-grip{background:var(--line-strong);border-radius:999px;width:40px;height:4px;margin:4px auto 14px}.sheet-head{align-items:flex-start;gap:14px;display:flex}.sheet-head .habit-icon{background:var(--tint)}.sheet-title{letter-spacing:-.01em;font-size:20px;font-weight:800}.sheet-sub{color:var(--ink-soft);margin-top:2px;font-size:14px}.sheet-close{border:1px solid var(--line-strong);background:var(--surface);cursor:pointer;width:36px;height:36px;color:var(--ink-soft);border-radius:999px;flex-shrink:0;place-items:center;margin-left:auto;display:grid}.sheet-close svg{width:18px;height:18px}.sheet-edit{border:1px solid var(--line-strong);background:var(--surface);cursor:pointer;width:36px;height:36px;color:var(--ink-soft);border-radius:999px;flex-shrink:0;place-items:center;margin-left:auto;display:grid}.sheet-edit svg{width:17px;height:17px}.sheet-edit+.sheet-close{margin-left:8px}.sheet-status{margin:4px 0 8px}.sheet-status .done-banner{margin-top:0}.contrib-wrap{gap:6px;margin:18px 0 4px;display:flex}.contrib-rows-label{color:var(--ink-faint);flex-shrink:0;grid-template-rows:repeat(7,1fr);align-items:center;gap:3px;width:22px;font-size:8px;display:grid}.contrib-grid{flex:1;justify-content:flex-end;gap:3px;display:flex;overflow:hidden}.contrib-col{flex:1;grid-template-rows:repeat(7,1fr);gap:3px;min-width:0;display:grid}.contrib-cell{aspect-ratio:1;background:var(--tint);border-radius:3px}.contrib-cell.filled{background:var(--tint-strong)}.contrib-cell.future{opacity:.35}.sheet-chips{gap:8px;margin:14px 0 4px;display:flex}.chip{color:var(--ink);background:var(--surface);border:1px solid var(--line-strong);font-variant-numeric:tabular-nums;border-radius:10px;align-items:center;gap:5px;padding:8px 12px;font-size:13px;font-weight:600;display:inline-flex}.chip-flame{display:inline-flex}.chip-flame svg{width:15px;height:15px;color:var(--flame)}.sheet-cal-wrap{margin-top:10px}.cal-nav{justify-content:space-between;align-items:center;margin:8px 0 12px;display:flex}.cal-month{font-size:15px;font-weight:700}.cal-nav-btns{gap:6px;display:flex}.nav-btn{border:1px solid var(--line-strong);background:var(--surface);cursor:pointer;width:30px;height:30px;color:var(--ink-soft);border-radius:9px;place-items:center;display:grid}.nav-btn:hover{background:var(--hover)}.nav-btn svg{width:16px;height:16px}.cal-weekdays{grid-template-columns:repeat(7,1fr);gap:6px;margin-bottom:8px;display:grid}.cal-weekdays span{text-align:center;color:var(--ink-soft);font-size:11px;font-weight:600}.cal-days{grid-template-columns:repeat(7,1fr);gap:6px;display:grid}.cal-day{aspect-ratio:1;background:var(--tint);cursor:pointer;color:var(--tint-ink);border:none;border-radius:12px;place-items:center;min-height:40px;font-size:15px;font-weight:600;transition:transform .1s,background .15s;display:grid}.cal-day:active:not([disabled]){transform:scale(.9)}.cal-day.empty{cursor:default;pointer-events:none;background:0 0}.cal-day.filled{background:var(--tint-strong);color:#fff}.cal-day.today{box-shadow:0 0 0 2px var(--ink) inset}.cal-day.future{color:var(--ink-faint)}.cal-day[disabled]{opacity:.4;cursor:not-allowed}.sheet-hint{color:var(--ink-faint);text-align:center;margin-top:14px;font-size:12.5px}.sheet-binary-btn{background:var(--tint);width:100%;color:var(--tint-ink);cursor:pointer;border:none;border-radius:16px;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:18px;font-size:16px;font-weight:700;display:flex}.sheet-binary-btn.on{background:var(--tint-strong);color:#fff}.sheet-binary-btn svg{width:20px;height:20px}.form-overlay{z-index:95}.form-sheet{padding-bottom:20px}.form-header{justify-content:space-between;align-items:center;display:flex}.form-header .form-title{letter-spacing:-.01em;font-size:20px;font-weight:800}.sheet-body>.form-preview{margin-top:16px}.form-field{margin-bottom:20px}.form-label{color:var(--ink);margin-bottom:8px;font-size:13px;font-weight:700;display:block}.form-label .opt{color:var(--ink-faint);font-weight:500}.form-input,.form-textarea{border:1px solid var(--line-strong);width:100%;color:var(--ink);background:var(--surface);-webkit-appearance:none;border-radius:12px;padding:13px 14px;font-family:inherit;font-size:15px}.form-input:focus,.form-textarea:focus{border-color:var(--ink-soft);outline:none}.form-textarea{resize:none;min-height:46px}.type-seg{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.type-opt{border:1px solid var(--line-strong);background:var(--surface);cursor:pointer;text-align:center;border-radius:12px;flex-direction:column;align-items:center;gap:6px;padding:12px 4px;transition:border-color .15s,background .15s;display:flex}.type-opt svg{width:22px;height:22px;color:var(--ink-soft)}.type-opt .type-name{color:var(--ink-soft);font-size:12px;font-weight:600}.type-opt.sel{border-color:var(--ink);background:var(--hover)}.type-opt.sel svg,.type-opt.sel .type-name{color:var(--ink)}.type-locked{border:1px solid var(--line-strong);color:var(--ink);background:var(--subtle);border-radius:12px;align-items:center;gap:8px;padding:12px 16px;font-size:14px;font-weight:600;display:inline-flex}.type-locked svg{width:18px;height:18px;color:var(--ink-soft)}.type-locked .lock-note{color:var(--ink-faint);margin-left:auto;font-size:12px;font-weight:500}.goal-fields{gap:14px;display:grid}.goal-row{align-items:center;gap:12px;display:flex}.goal-row .form-input{text-align:center;max-width:96px;font-size:17px;font-weight:700}.goal-row .goal-desc{color:var(--ink-soft);font-size:14px}.goal-hint{color:var(--ink-faint);background:var(--subtle);border-radius:10px;margin-top:2px;padding:10px 12px;font-size:12.5px;line-height:1.5}.icon-grid{grid-template-columns:repeat(6,1fr);gap:8px;display:grid}.icon-opt{aspect-ratio:1;border:1px solid var(--line-strong);background:var(--surface);cursor:pointer;border-radius:12px;place-items:center;transition:border-color .15s,background .15s;display:grid}.icon-opt svg{width:22px;height:22px;color:var(--ink-soft)}.icon-opt.sel{background:var(--tint);border-color:#0000}.icon-opt.sel svg{color:var(--tint-ink)}.color-grid{flex-wrap:wrap;gap:10px;display:flex}.color-opt{cursor:pointer;border:3px solid #0000;border-radius:999px;place-items:center;width:40px;height:40px;transition:transform .1s;display:grid}.color-opt:active{transform:scale(.92)}.color-opt.sel{border-color:var(--ink)}.color-opt .dot{border-radius:999px;width:22px;height:22px}.form-preview{background:var(--pv-tint);border-radius:14px;align-items:center;gap:12px;margin-bottom:20px;padding:12px 14px;display:flex}.form-preview .pv-icon{background:var(--pv-strong);border-radius:12px;flex-shrink:0;place-items:center;width:44px;height:44px;display:grid}.form-preview .pv-icon svg{color:#fff;width:22px;height:22px}.form-preview .pv-title{color:var(--pv-ink);font-size:15px;font-weight:700}.form-preview .pv-sub{color:var(--pv-ink);opacity:.8;font-size:12.5px}.form-actions{gap:10px;margin-top:8px;display:flex}.btn-primary{background:var(--ink);color:var(--surface);cursor:pointer;border:none;border-radius:14px;flex:1;padding:15px;font-size:15px;font-weight:700}.btn-primary:disabled{opacity:.4;cursor:not-allowed}.btn-ghost{border:1px solid var(--line-strong);background:var(--surface);color:var(--ink-soft);cursor:pointer;border-radius:14px;padding:15px 18px;font-size:15px;font-weight:600}.btn-danger{background:var(--danger-bg);width:100%;color:var(--danger);cursor:pointer;border:none;border-radius:14px;margin-top:12px;padding:14px;font-size:14px;font-weight:700}.analytics-overlay{z-index:96}.an-back{cursor:pointer;color:var(--ink);letter-spacing:-.01em;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-size:16px;font-weight:700;display:inline-flex}.an-back svg{width:20px;height:20px}.stat-cards{grid-template-columns:repeat(3,1fr);gap:10px;margin:16px 0 4px;display:grid}.stat-card{background:var(--subtle);text-align:center;border-radius:14px;padding:14px 10px}.stat-num{letter-spacing:-.02em;color:var(--ink);font-size:22px;font-weight:800}.stat-lbl{color:var(--ink-soft);margin-top:3px;font-size:11px;font-weight:600;line-height:1.2}.chart-block{background:var(--surface);border:1px solid var(--line);border-radius:16px;margin-top:16px;padding:16px}.chart-title{color:var(--ink);font-size:14px;font-weight:700}.chart-sub{color:var(--ink-soft);margin-top:2px;margin-bottom:12px;font-size:12px}.chart-svg{width:100%;height:auto;display:block;overflow:visible}.heatmap{overflow:hidden}.hm-grid{gap:3px;display:flex}.hm-col{flex:1;grid-template-rows:repeat(7,1fr);gap:3px;display:grid}.hm-cell{aspect-ratio:1;background:var(--tint);border-radius:2.5px}.hm-cell.filled{background:var(--tint-strong)}.hm-cell.future{opacity:.3}.timeline{justify-content:space-between;gap:6px;display:flex}.tl-item{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex}.tl-dot{aspect-ratio:1;background:var(--tint);border-radius:12px;place-items:center;width:100%;max-width:40px;display:grid}.tl-dot svg{color:#fff;width:18px;height:18px}.tl-dot.done{background:var(--tint-strong)}.tl-label{color:var(--ink-faint);font-size:10px;font-weight:600}.an-section-label{color:var(--ink);margin:22px 0 10px;font-size:13px;font-weight:700}.an-rows{flex-direction:column;gap:8px;display:flex}.an-row{background:var(--surface);border:1px solid var(--line);cursor:pointer;text-align:left;border-radius:14px;align-items:center;gap:12px;width:100%;padding:12px;transition:box-shadow .15s;display:flex}.an-row:hover{box-shadow:var(--shadow-row)}.an-row .habit-icon{background:var(--tint);border-radius:11px;flex-shrink:0;width:40px;height:40px}.an-row .habit-icon svg{width:21px;height:21px;color:var(--tint-ink)}.an-row-meta{flex-shrink:0;width:40%;min-width:0}.an-row-title{color:var(--ink);white-space:nowrap;text-overflow:ellipsis;font-size:14px;font-weight:700;overflow:hidden}.an-row-sub{color:var(--ink-soft);margin-top:1px;font-size:12px}.an-row-bar{background:var(--tint);border-radius:999px;flex:1;height:8px;overflow:hidden}.an-row-fill{background:var(--tint-strong);border-radius:999px;height:100%}.an-row-chev{width:18px;height:18px;color:var(--ink-faint);flex-shrink:0}.an-habit-head{align-items:center;gap:14px;margin-top:16px;display:flex}.an-habit-head .habit-icon{background:var(--tint);border-radius:14px;width:52px;height:52px}.an-habit-head .habit-icon svg{width:26px;height:26px;color:var(--tint-ink)}.an-habit-title{letter-spacing:-.01em;font-size:19px;font-weight:800}.an-habit-sub{color:var(--ink-soft);margin-top:2px;font-size:13px}.modal-overlay{background:var(--overlay);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:100;opacity:0;visibility:hidden;pointer-events:none;justify-content:center;align-items:center;padding:24px;transition:opacity .25s,visibility 0s linear .25s;display:flex;position:fixed;inset:0}.modal-overlay.show{opacity:1;visibility:visible;pointer-events:auto;transition:opacity .25s,visibility}.modal{background:var(--surface);text-align:center;border-radius:24px;width:100%;max-width:340px;padding:36px 28px 28px;transition:transform .3s cubic-bezier(.2,1.2,.3,1);position:relative;overflow:hidden;transform:scale(.9)}.modal-overlay.show .modal{transform:scale(1)}.modal-emoji{margin-bottom:12px;font-size:52px;line-height:1}.modal-title{letter-spacing:-.02em;font-size:22px;font-weight:800}.modal-habit{margin-top:6px;font-size:15px;font-weight:600}.modal-msg{color:var(--ink-soft);margin-top:12px;font-size:14.5px;line-height:1.5}.modal-btn{background:var(--ink);width:100%;color:var(--surface);cursor:pointer;border:none;border-radius:13px;margin-top:22px;padding:13px;font-size:15px;font-weight:600;transition:opacity .15s}.modal-btn:hover{opacity:.9}.confetti{opacity:0;width:9px;height:9px;position:absolute;top:-10px}@keyframes confetti-fall{0%{opacity:1;transform:translateY(0)rotate(0)}to{opacity:0;transform:translateY(360px)rotate(560deg)}}.login-page{background:var(--bg);justify-content:center;align-items:center;min-height:100dvh;padding:20px;display:flex}.login-card{background:var(--surface);border:1px solid var(--line);text-align:center;border-radius:20px;width:100%;max-width:360px;padding:40px 32px}.login-title{letter-spacing:-.02em;margin:0 0 4px;font-size:28px;font-weight:800}.login-title-accent{color:var(--ink-faint);font-weight:700}.login-subtitle{color:var(--ink-soft);margin:0 0 24px;font-size:14px}.login-input{border:1px solid var(--line-strong);width:100%;color:var(--ink);background:var(--surface);text-align:center;letter-spacing:.3em;-webkit-appearance:none;border-radius:12px;margin-bottom:16px;padding:14px;font-family:inherit;font-size:18px}.login-input:focus{border-color:var(--ink-soft);outline:none}.login-error{color:var(--danger);margin:0 0 12px;font-size:13px}.login-btn{background:var(--ink);width:100%;color:var(--surface);cursor:pointer;border:none;border-radius:12px;padding:14px;font-size:16px;font-weight:700}.login-btn:disabled{opacity:.4;cursor:not-allowed}.login-btn:hover:not(:disabled){opacity:.9}.loading-center{min-height:100dvh;color:var(--ink-soft);place-items:center;font-weight:600;display:grid}.theme-toggle-backdrop{z-index:155;cursor:default;background:0 0;position:fixed;inset:0}.theme-toggle{top:calc(env(safe-area-inset-top,0px) + var(--theme-toggle-topbar-stack) + var(--theme-toggle-row-below-topbar));z-index:160;pointer-events:none;position:fixed;right:0}.theme-toggle__rail{pointer-events:auto;flex-direction:row;justify-content:flex-end;align-items:stretch;transition:transform .25s cubic-bezier(.32,.72,0,1);display:flex;transform:translate(calc(100% - 12px))}.theme-toggle:hover .theme-toggle__rail,.theme-toggle:focus-within .theme-toggle__rail,.theme-toggle.theme-toggle--open .theme-toggle__rail{transform:translate(0)}.theme-toggle__btn{border:1px solid var(--border);background:var(--white);width:40px;height:40px;color:var(--ink2);cursor:pointer;box-shadow:var(--shadow-login);border-right:none;border-radius:10px 0 0 10px;flex-shrink:0;justify-content:center;align-items:center;transition:background .12s,color .12s,box-shadow .2s;display:flex}.theme-toggle:hover .theme-toggle__btn,.theme-toggle:focus-within .theme-toggle__btn,.theme-toggle.theme-toggle--open .theme-toggle__btn{box-shadow:var(--shadow-dropdown)}.theme-toggle__btn:hover{background:var(--parchment);color:var(--ink)}.theme-toggle__btn:focus-visible{outline:2px solid var(--ink-soft);outline-offset:2px;z-index:1}.theme-toggle__icon{width:18px;height:18px}.toast{bottom:calc(env(safe-area-inset-bottom,0px) + 90px);background:var(--ink);color:var(--surface);z-index:200;box-shadow:var(--shadow-switch);border-radius:12px;max-width:calc(100% - 40px);padding:12px 20px;font-size:14px;font-weight:600;animation:.2s fadeIn;position:fixed;left:50%;transform:translate(-50%)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-backdrop-blur{syntax:"*";inherits:false}@property --tw-backdrop-brightness{syntax:"*";inherits:false}@property --tw-backdrop-contrast{syntax:"*";inherits:false}@property --tw-backdrop-grayscale{syntax:"*";inherits:false}@property --tw-backdrop-hue-rotate{syntax:"*";inherits:false}@property --tw-backdrop-invert{syntax:"*";inherits:false}@property --tw-backdrop-opacity{syntax:"*";inherits:false}@property --tw-backdrop-saturate{syntax:"*";inherits:false}@property --tw-backdrop-sepia{syntax:"*";inherits:false}
