*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol,"Noto Color Emoji";font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}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;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}:root{--ink: #111111;--slate: #2B4A6B;--paper: #FFFFFF;--cream: #FAFAF7;--mist: #B8C7D6;--hairline: #E8E4DC;--body-bg: #FAFAF7;--frame: #111111;--frame-soft: #E8E4DC;--text-heading: #111111;--text-body: #1F1F1F;--text-muted: #555555;--text-soft: #888888;--font-heading: "IBM Plex Sans", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "IBM Plex Mono", monospace;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.375rem;--text-2xl: 1.875rem;--space-xs: .5rem;--space-sm: .75rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--transition-fast: .15s ease;--transition-base: .2s ease;color-scheme:light}.dark{--ink: #E8E4DC;--slate: #9AB5D1;--paper: #1A1815;--cream: #221F1B;--mist: #4A5862;--hairline: #3A3530;--body-bg: #14110E;--frame: #E8E4DC;--frame-soft: #3A3530;--text-heading: #E8E4DC;--text-body: #D4CFC4;--text-muted: #A8A39A;--text-soft: #807A6E;color-scheme:dark}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{min-height:100%;width:100%}body{background:var(--body-bg);color:var(--text-body);font-family:var(--font-body);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;transition:background var(--transition-fast),color var(--transition-fast)}h1,h2,h3,h4,h5,h6{color:var(--text-heading);font-family:var(--font-heading);font-weight:500;letter-spacing:-.02em;line-height:1.2}button,input,textarea,select{font:inherit}button{color:inherit}::-moz-selection{background:var(--mist);color:var(--ink)}::selection{background:var(--mist);color:var(--ink)}*:focus-visible{outline:2px solid var(--slate);outline-offset:2px}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }.app-shell{margin:0 auto;max-width:920px;min-height:100vh;padding:32px 16px}.framed-page{background:var(--paper);border:1px solid var(--frame)}.wordmark{color:var(--slate);font-family:var(--font-heading);font-size:1.5rem;font-weight:500;letter-spacing:-.02em}.meta,.text-mono{color:var(--text-soft);font-family:var(--font-mono);font-size:.75rem;font-weight:400}.section-label{color:var(--text-soft);font-family:var(--font-mono);font-size:.6875rem;letter-spacing:.06em}.btn{align-items:center;background:var(--paper);border:1px solid var(--frame);border-radius:var(--radius-md);color:var(--text-body);cursor:pointer;display:inline-flex;font-family:var(--font-heading);font-size:var(--text-sm);font-weight:500;gap:.5rem;justify-content:center;min-height:2.5rem;padding:.55rem .875rem;text-decoration:none;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast)}.btn:hover{background:var(--cream)}.btn-primary,.btn-success{background:var(--slate);border-color:var(--slate);color:var(--paper)}.btn-primary:hover,.btn-success:hover{background:var(--paper);color:var(--slate)}.btn-secondary{background:transparent}.icon-button{align-items:center;background:transparent;border:1px solid var(--frame);border-radius:var(--radius-md);color:var(--text-body);cursor:pointer;display:inline-flex;height:2.25rem;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast);width:2.25rem}.icon-button:hover{background:var(--cream);color:var(--slate)}.card{background:var(--paper);border:1px solid var(--frame);border-radius:0}.input{background:var(--paper);border:1px solid var(--frame);border-radius:var(--radius-md);color:var(--text-body);font-family:var(--font-body);font-size:var(--text-base);padding:.7rem .8rem;transition:border-color var(--transition-fast),background var(--transition-fast);width:100%}.input:focus{border-color:var(--slate);outline:none}.input::-moz-placeholder{color:var(--text-soft)}.input::placeholder{color:var(--text-soft)}.badge{align-items:center;border:1px solid var(--hairline);border-radius:var(--radius-md);color:var(--text-soft);display:inline-flex;font-family:var(--font-mono);font-size:.6875rem;gap:.35rem;padding:.25rem .5rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.resize{resize:both}.flex-wrap{flex-wrap:wrap}.border{border-width:1px}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke,opacity,box-shadow,transform,filter,backdrop-filter;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ease-in-out{transition-timing-function:cubic-bezier(.4,0,.2,1)}.sr-only{clip:rect(0,0,0,0);border:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.heatmap-container[data-v-2289f469]{width:100%}.month-navigation[data-v-2289f469]{align-items:center;border-bottom:1px solid var(--hairline);display:flex;justify-content:space-between;margin-bottom:16px;padding-bottom:12px}.nav-button[data-v-2289f469]{align-items:center;background:transparent;border:1px solid var(--frame);border-radius:var(--radius-md);color:var(--text-body);cursor:pointer;display:flex;height:34px;justify-content:center;transition:background var(--transition-fast),color var(--transition-fast),opacity var(--transition-fast);width:34px}.nav-button[data-v-2289f469]:hover:not(:disabled){background:var(--cream);color:var(--slate)}.nav-button[data-v-2289f469]:disabled{cursor:not-allowed;opacity:.35}.nav-button svg[data-v-2289f469]{height:18px;width:18px}.month-title[data-v-2289f469]{font-size:var(--text-lg)}.weekday-labels[data-v-2289f469],.calendar-grid[data-v-2289f469]{display:grid;gap:6px;grid-template-columns:repeat(7,minmax(0,1fr))}.weekday-labels[data-v-2289f469]{margin-bottom:8px}.weekday-label[data-v-2289f469]{color:var(--text-soft);font-family:var(--font-mono);font-size:.6875rem;text-align:center}.day-cell[data-v-2289f469]{align-items:flex-start;aspect-ratio:1;background:var(--paper);border:1px solid var(--hairline);border-radius:var(--radius-sm);color:var(--text-body);cursor:pointer;display:flex;justify-content:flex-start;min-width:0;padding:5px;transition:border-color var(--transition-fast),background var(--transition-fast),color var(--transition-fast)}.day-cell.current-month[data-v-2289f469]:hover{border-color:var(--slate)}.day-cell.other-month[data-v-2289f469]{cursor:default;opacity:.28}.day-cell.today[data-v-2289f469]{border-color:var(--frame)}.day-number[data-v-2289f469]{font-family:var(--font-mono);font-size:.6875rem;line-height:1}.level-0[data-v-2289f469]{background:var(--paper)}.level-1[data-v-2289f469]{background:color-mix(in srgb,var(--mist) 24%,var(--paper))}.level-2[data-v-2289f469]{background:color-mix(in srgb,var(--mist) 45%,var(--paper))}.level-3[data-v-2289f469]{background:color-mix(in srgb,var(--slate) 55%,var(--paper));color:var(--paper)}.level-4[data-v-2289f469]{background:var(--slate);border-color:var(--slate);color:var(--paper)}.heatmap-legend[data-v-2289f469]{align-items:center;border-top:1px solid var(--hairline);display:flex;gap:6px;justify-content:flex-end;margin-top:16px;padding-top:12px}.legend-text[data-v-2289f469]{color:var(--text-soft);font-family:var(--font-mono);font-size:.6875rem}.legend-item[data-v-2289f469]{border:1px solid var(--hairline);border-radius:var(--radius-sm);display:inline-block;height:16px;width:16px}@media(max-width:640px){.weekday-labels[data-v-2289f469],.calendar-grid[data-v-2289f469]{gap:4px}.day-cell[data-v-2289f469]{padding:3px}.month-title[data-v-2289f469]{font-size:var(--text-base)}}.habit-list[data-v-9580ea6c]{width:100%}.empty-state[data-v-9580ea6c]{background:var(--cream);border:1px solid var(--hairline);border-radius:var(--radius-md);padding:28px}.empty-state h3[data-v-9580ea6c]{font-size:var(--text-xl);margin-top:4px}.empty-state p[data-v-9580ea6c]{color:var(--text-muted);margin:6px 0 18px}.habit-table[data-v-9580ea6c]{border:1px solid var(--frame);background:var(--paper)}.habit-row[data-v-9580ea6c]{align-items:center;background:transparent;border:0;border-bottom:1px solid var(--hairline);color:var(--text-body);cursor:pointer;display:grid;gap:14px;grid-template-columns:28px minmax(0,1fr) auto;padding:14px 16px;text-align:left;transition:background var(--transition-fast);width:100%}.habit-row[data-v-9580ea6c]:last-child{border-bottom:0}.habit-row[data-v-9580ea6c]:hover{background:var(--cream)}.habit-row.completed[data-v-9580ea6c]{background:color-mix(in srgb,var(--slate) 7%,var(--paper))}.habit-check[data-v-9580ea6c]{align-items:center;border:1px solid var(--frame);border-radius:var(--radius-sm);color:var(--slate);display:inline-flex;height:22px;justify-content:center;width:22px}.habit-check svg[data-v-9580ea6c]{height:16px;width:16px}.completed .habit-check[data-v-9580ea6c]{border-color:var(--slate)}.habit-main[data-v-9580ea6c]{display:flex;flex-direction:column;min-width:0}.habit-name[data-v-9580ea6c]{color:var(--text-heading);font-family:var(--font-heading);font-size:var(--text-base);font-weight:500;overflow-wrap:anywhere}.habit-description[data-v-9580ea6c]{color:var(--text-muted);font-size:var(--text-sm);margin-top:2px;overflow-wrap:anywhere}.habit-meta[data-v-9580ea6c]{align-items:flex-end;color:var(--text-soft);display:flex;flex-direction:column;font-size:var(--text-xs);white-space:nowrap}.habit-meta .text-mono[data-v-9580ea6c]{color:var(--slate);font-size:var(--text-sm)}@media(max-width:640px){.habit-row[data-v-9580ea6c]{grid-template-columns:26px minmax(0,1fr)}.habit-meta[data-v-9580ea6c]{grid-column:2;align-items:flex-start;flex-direction:row;gap:5px}}.modal-overlay[data-v-6e8f3fb8]{align-items:center;background:#1111116b;display:flex;inset:0;justify-content:center;padding:16px;position:fixed;z-index:9999}.dark .modal-overlay[data-v-6e8f3fb8]{background:#0000009e}.modal-card[data-v-6e8f3fb8]{background:var(--paper);border:1px solid var(--frame);max-width:420px;padding:24px;width:100%}.modal-header[data-v-6e8f3fb8]{border-bottom:1px solid var(--hairline);margin-bottom:16px;padding-bottom:12px}.modal-header h2[data-v-6e8f3fb8]{font-size:var(--text-xl);margin-top:4px}.modal-message[data-v-6e8f3fb8]{color:var(--text-muted);margin-bottom:22px}.modal-footer[data-v-6e8f3fb8]{display:flex;gap:10px;justify-content:flex-end}.modal-enter-active[data-v-6e8f3fb8],.modal-leave-active[data-v-6e8f3fb8]{transition:opacity .16s ease}.modal-enter-from[data-v-6e8f3fb8],.modal-leave-to[data-v-6e8f3fb8]{opacity:0}@media(max-width:480px){.modal-footer[data-v-6e8f3fb8]{flex-direction:column-reverse}}.home-page[data-v-58dc98ee]{overflow:hidden}.home-header[data-v-58dc98ee]{align-items:flex-start;border-bottom:1px solid var(--frame);display:flex;gap:var(--space-md);justify-content:space-between;padding:24px 28px 20px}.header-row[data-v-58dc98ee]{align-items:baseline;display:flex;flex-wrap:wrap;gap:12px}.user-line[data-v-58dc98ee]{color:var(--text-muted);font-size:var(--text-sm);margin-top:4px}.header-actions[data-v-58dc98ee]{display:flex;gap:8px}.action-icon[data-v-58dc98ee]{height:20px;width:20px}.summary-band[data-v-58dc98ee]{align-items:center;background:var(--cream);border-bottom:1px solid var(--hairline);display:flex;gap:var(--space-md);justify-content:space-between;padding:18px 28px}.current-date[data-v-58dc98ee]{color:var(--text-heading);font-family:var(--font-heading);font-size:var(--text-lg);font-weight:500}.completion-block[data-v-58dc98ee]{align-items:flex-end;display:flex;flex-direction:column}.completion-count[data-v-58dc98ee]{color:var(--slate);font-size:1rem}.completion-label[data-v-58dc98ee]{color:var(--text-soft);font-size:var(--text-xs)}.selected-date-row[data-v-58dc98ee]{align-items:center;border-bottom:1px solid var(--hairline);display:flex;gap:10px;padding:12px 28px}.clear-filter-button[data-v-58dc98ee]{background:transparent;border:0;color:var(--slate);cursor:pointer;font-family:var(--font-heading);font-size:var(--text-sm)}.content-section[data-v-58dc98ee]{padding:28px}.content-section+.content-section[data-v-58dc98ee]{border-top:1px solid var(--hairline)}.section-heading[data-v-58dc98ee]{align-items:baseline;display:flex;gap:var(--space-md);justify-content:space-between;margin-bottom:14px}.section-heading h2[data-v-58dc98ee]{font-size:1.375rem}.heatmap-card[data-v-58dc98ee]{padding:18px}@media(max-width:640px){.app-shell[data-v-58dc98ee]{padding:16px 10px}.home-header[data-v-58dc98ee],.summary-band[data-v-58dc98ee],.content-section[data-v-58dc98ee],.selected-date-row[data-v-58dc98ee]{padding-left:16px;padding-right:16px}.home-header[data-v-58dc98ee],.summary-band[data-v-58dc98ee]{align-items:flex-start;flex-direction:column}.header-actions[data-v-58dc98ee]{align-self:flex-end}.completion-block[data-v-58dc98ee]{align-items:flex-start}}.theme-toggle[data-v-ecc3e87b]{border:1px solid var(--frame);border-radius:var(--radius-md);display:inline-flex;overflow:hidden}.theme-option[data-v-ecc3e87b]{align-items:center;background:transparent;border:0;border-right:1px solid var(--hairline);color:var(--text-muted);cursor:pointer;display:flex;font-family:var(--font-heading);font-size:var(--text-sm);gap:6px;padding:.55rem .7rem;transition:background var(--transition-fast),color var(--transition-fast)}.theme-option[data-v-ecc3e87b]:last-child{border-right:0}.theme-option[data-v-ecc3e87b]:hover{background:var(--cream);color:var(--text-heading)}.theme-option.active[data-v-ecc3e87b]{background:var(--cream);color:var(--slate)}.option-icon[data-v-ecc3e87b]{height:17px;width:17px}.option-label[data-v-ecc3e87b]{white-space:nowrap}@media(max-width:640px){.option-label[data-v-ecc3e87b]{display:none}.theme-option[data-v-ecc3e87b]{padding:.55rem}}.settings-page[data-v-b05cb4f2]{overflow:hidden}.settings-header[data-v-b05cb4f2]{align-items:flex-start;border-bottom:1px solid var(--frame);display:flex;justify-content:space-between;padding:24px 28px 20px}.back-link[data-v-b05cb4f2]{align-items:center;background:transparent;border:0;color:var(--slate);cursor:pointer;display:inline-flex;font-family:var(--font-heading);font-size:var(--text-sm);gap:4px;margin-bottom:8px;padding:0}.back-icon[data-v-b05cb4f2]{height:16px;width:16px}.settings-subtitle[data-v-b05cb4f2]{color:var(--text-muted);font-size:var(--text-sm);margin-top:4px}.settings-section[data-v-b05cb4f2]{padding:28px}.settings-section+.settings-section[data-v-b05cb4f2]{border-top:1px solid var(--hairline)}.section-heading[data-v-b05cb4f2]{align-items:baseline;display:flex;justify-content:space-between;margin-bottom:16px}.section-heading h2[data-v-b05cb4f2]{font-size:var(--text-xl)}.setting-row[data-v-b05cb4f2]{align-items:center;background:var(--cream);border:1px solid var(--hairline);border-radius:var(--radius-md);display:flex;gap:18px;justify-content:space-between;padding:16px}.setting-row h3[data-v-b05cb4f2]{font-size:var(--text-base)}.setting-row p[data-v-b05cb4f2],.empty-state p[data-v-b05cb4f2],.habit-details p[data-v-b05cb4f2]{color:var(--text-muted);font-size:var(--text-sm)}.habit-form[data-v-b05cb4f2]{display:grid;gap:16px}.form-group[data-v-b05cb4f2]{display:grid;gap:7px}.form-group.compact[data-v-b05cb4f2]{gap:5px}.form-label[data-v-b05cb4f2]{align-items:baseline;color:var(--text-heading);display:flex;font-family:var(--font-heading);font-size:var(--text-sm);font-weight:500;gap:8px}.form-textarea[data-v-b05cb4f2]{min-height:88px;resize:vertical}.input.small[data-v-b05cb4f2]{font-size:var(--text-sm);padding:.55rem .65rem}.color-picker[data-v-b05cb4f2]{display:flex;flex-wrap:wrap;gap:8px}.color-option[data-v-b05cb4f2]{background:var(--color-bg);border:1px solid var(--frame);border-radius:var(--radius-md);cursor:pointer;height:34px;position:relative;width:34px}.color-option.selected[data-v-b05cb4f2]:after{border:1px solid var(--paper);border-radius:var(--radius-sm);content:"";inset:5px;position:absolute}.small-swatch[data-v-b05cb4f2]{height:28px;width:28px}.submit-button[data-v-b05cb4f2]{justify-self:start}.empty-state[data-v-b05cb4f2]{background:var(--cream);border:1px solid var(--hairline);border-radius:var(--radius-md);padding:18px}.empty-state h3[data-v-b05cb4f2]{font-size:var(--text-base)}.habits-list[data-v-b05cb4f2]{border:1px solid var(--frame)}.habit-item[data-v-b05cb4f2]{border-bottom:1px solid var(--hairline);padding:14px 16px}.habit-item[data-v-b05cb4f2]:last-child{border-bottom:0}.view-mode[data-v-b05cb4f2]{align-items:center;display:flex;gap:16px;justify-content:space-between}.habit-info[data-v-b05cb4f2]{align-items:center;display:flex;gap:12px;min-width:0}.habit-color-indicator[data-v-b05cb4f2]{border:1px solid var(--frame);border-radius:var(--radius-sm);flex:0 0 auto;height:20px;width:20px}.habit-details[data-v-b05cb4f2]{min-width:0}.habit-details h3[data-v-b05cb4f2]{font-size:var(--text-base);overflow-wrap:anywhere}.habit-actions[data-v-b05cb4f2]{display:flex;flex:0 0 auto;gap:8px}.habit-actions svg[data-v-b05cb4f2]{height:17px;width:17px}.edit-mode[data-v-b05cb4f2]{display:grid;gap:12px}.edit-actions[data-v-b05cb4f2]{display:flex;gap:8px}@media(max-width:640px){.settings-header[data-v-b05cb4f2],.settings-section[data-v-b05cb4f2]{padding-left:16px;padding-right:16px}.settings-header[data-v-b05cb4f2],.setting-row[data-v-b05cb4f2],.view-mode[data-v-b05cb4f2]{align-items:flex-start;flex-direction:column}.habit-actions[data-v-b05cb4f2]{align-self:flex-end}}.login-page[data-v-f44ba71c]{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:24px}.login-panel[data-v-f44ba71c]{background:var(--paper);border:1px solid var(--frame);max-width:440px;width:100%}.login-header[data-v-f44ba71c]{border-bottom:1px solid var(--frame);padding:24px 28px 20px}.login-content[data-v-f44ba71c]{padding:28px}.login-content h2[data-v-f44ba71c]{font-size:var(--text-xl);margin-bottom:8px}.login-content p[data-v-f44ba71c]{color:var(--text-muted);margin-bottom:22px}.login-button[data-v-f44ba71c]{width:100%}.button-arrow[data-v-f44ba71c]{height:18px;width:18px}.login-footer[data-v-f44ba71c]{background:var(--cream);border-top:1px solid var(--hairline);padding:14px 28px}.callback-page[data-v-cd1c7009]{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:24px}.callback-panel[data-v-cd1c7009]{background:var(--paper);border:1px solid var(--frame);max-width:440px;width:100%}.callback-header[data-v-cd1c7009]{border-bottom:1px solid var(--frame);padding:24px 28px 20px}.callback-content[data-v-cd1c7009]{padding:28px}.callback-content h2[data-v-cd1c7009]{font-size:var(--text-xl);margin:4px 0 8px}.message[data-v-cd1c7009]{color:var(--text-muted);margin-bottom:22px}.loading-row[data-v-cd1c7009]{display:flex;gap:8px}.loading-row span[data-v-cd1c7009]{animation:loading-fade-cd1c7009 .9s ease-in-out infinite;background:var(--slate);border-radius:999px;display:block;height:7px;width:7px}.loading-row span[data-v-cd1c7009]:nth-child(2){animation-delay:.15s}.loading-row span[data-v-cd1c7009]:nth-child(3){animation-delay:.3s}@keyframes loading-fade-cd1c7009{0%,to{opacity:.3}50%{opacity:1}}
