:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.toast-container{position:fixed;bottom:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px;background:var(--color-surface, #fff);box-shadow:0 4px 12px #00000026;border-left:4px solid var(--toast-color, #3b82f6);pointer-events:auto;animation:toast-enter .3s ease-out}.toast-exit{animation:toast-exit .3s ease-in forwards}@keyframes toast-enter{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}@keyframes toast-exit{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}.toast-info{--toast-color: #3b82f6}.toast-success{--toast-color: #22c55e}.toast-warning{--toast-color: #eab308}.toast-error{--toast-color: #ef4444}.toast-milestone{--toast-color: #f59e0b;border-left-width:5px;padding:14px 18px;font-size:15px;animation:toast-milestone-enter .4s cubic-bezier(.34,1.56,.64,1)}@keyframes toast-milestone-enter{0%{opacity:0;transform:translate(100%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}.toast-message{flex:1;font-size:14px;color:#111827;line-height:1.4}.toast-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.toast-btn-undo{padding:6px 12px;border:none;border-radius:4px;background:var(--color-primary, #3b82f6);color:#fff;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s}.toast-btn-undo:hover{background:var(--color-primary-dark, #2563eb)}.toast-btn-close{width:24px;height:24px;border:none;border-radius:4px;background:transparent;color:var(--color-text-muted, #6b7280);font-size:18px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s}.toast-btn-close:hover{background:var(--color-border, #e5e7eb)}[data-theme=dark] .toast{background:var(--color-surface, #1f2937);box-shadow:0 4px 12px #0000004d}[data-theme=dark] .toast-message{color:var(--color-text, #f3f4f6)}[data-theme=dark] .toast-btn-close:hover{background:var(--color-border, #374151)}@media(max-width:480px){.toast-container{left:10px;right:10px;max-width:none}}@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-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--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-leading:initial;--tw-font-weight:initial;--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-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-ease:initial;--tw-animation-delay:0s;--tw-animation-direction:normal;--tw-animation-duration:initial;--tw-animation-fill-mode:none;--tw-animation-iteration-count:1;--tw-enter-blur:0;--tw-enter-opacity:1;--tw-enter-rotate:0;--tw-enter-scale:1;--tw-enter-translate-x:0;--tw-enter-translate-y:0;--tw-exit-blur:0;--tw-exit-opacity:1;--tw-exit-rotate:0;--tw-exit-scale:1;--tw-exit-translate-x:0;--tw-exit-translate-y:0}}}@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;--color-black:#000;--color-white:#fff;--spacing:.25rem;--container-xs:20rem;--container-sm:24rem;--container-lg:32rem;--text-xs:.75rem;--text-xs--line-height:calc(1 / .75);--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-base:1rem;--text-base--line-height: 1.5 ;--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-medium:500;--font-weight-semibold:600;--radius-sm:calc(var(--radius) - 4px);--radius-md:calc(var(--radius) - 2px);--radius-lg:var(--radius);--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--ease-out:cubic-bezier(0, 0, .2, 1);--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);--color-card:var(--card);--color-primary:var(--primary);--color-secondary:var(--secondary);--color-muted:var(--muted);--color-muted-foreground:var(--muted-foreground);--color-accent:var(--accent);--color-border:var(--border)}}@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;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}*{border-color:var(--border);outline-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){*{outline-color:color-mix(in oklab,var(--ring) 50%,transparent)}}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--background);color:var(--foreground)}}@layer components;@layer utilities{.\@container\/card-header{container:card-header/inline-size}.invisible{visibility:hidden}.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.right-4{right:calc(var(--spacing) * 4)}.left-\[50\%\]{left:50%}.isolate{isolation:isolate}.z-\[1500\]{z-index:1500}.col-start-2{grid-column-start:2}.row-span-2{grid-row:span 2/span 2}.row-start-1{grid-row-start:1}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.contents{display:contents}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-flex{display:inline-flex}.table{display:table}.size-4{width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.size-6{width:calc(var(--spacing) * 6);height:calc(var(--spacing) * 6)}.size-8{width:calc(var(--spacing) * 8);height:calc(var(--spacing) * 8)}.size-9{width:calc(var(--spacing) * 9);height:calc(var(--spacing) * 9)}.size-10{width:calc(var(--spacing) * 10);height:calc(var(--spacing) * 10)}.h-6{height:calc(var(--spacing) * 6)}.h-8{height:calc(var(--spacing) * 8)}.h-9{height:calc(var(--spacing) * 9)}.h-10{height:calc(var(--spacing) * 10)}.max-h-\[90vh\]{max-height:90vh}.w-6{width:calc(var(--spacing) * 6)}.w-fit{width:fit-content}.w-full{width:100%}.max-w-\[calc\(100\%-2rem\)\]{max-width:calc(100% - 2rem)}.max-w-lg{max-width:var(--container-lg)}.max-w-sm{max-width:var(--container-sm)}.max-w-xs{max-width:var(--container-xs)}.min-w-0{min-width:calc(var(--spacing) * 0)}.shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.grow{flex-grow:1}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.cursor-pointer{cursor:pointer}.resize{resize:both}.auto-rows-min{grid-auto-rows:min-content}.grid-rows-\[auto_auto\]{grid-template-rows:auto auto}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-center{justify-content:center}.gap-1{gap:calc(var(--spacing) * 1)}.gap-1\.5{gap:calc(var(--spacing) * 1.5)}.gap-2{gap:calc(var(--spacing) * 2)}.gap-4{gap:calc(var(--spacing) * 4)}.gap-6{gap:calc(var(--spacing) * 6)}.self-start{align-self:flex-start}.justify-self-end{justify-self:flex-end}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:calc(var(--radius) + 4px)}.border{border-style:var(--tw-border-style);border-width:1px}.border-border{border-color:var(--border)}.border-input{border-color:var(--input)}.border-transparent{border-color:#0000}.bg-background{background-color:var(--background)}.bg-black\/50{background-color:#00000080}@supports (color:color-mix(in lab,red,red)){.bg-black\/50{background-color:color-mix(in oklab,var(--color-black) 50%,transparent)}}.bg-card{background-color:var(--card)}.bg-destructive{background-color:var(--destructive)}.bg-primary{background-color:var(--primary)}.bg-secondary{background-color:var(--secondary)}.bg-transparent{background-color:#0000}.p-6{padding:calc(var(--spacing) * 6)}.px-2{padding-inline:calc(var(--spacing) * 2)}.px-3{padding-inline:calc(var(--spacing) * 3)}.px-4{padding-inline:calc(var(--spacing) * 4)}.px-6{padding-inline:calc(var(--spacing) * 6)}.py-0\.5{padding-block:calc(var(--spacing) * .5)}.py-1{padding-block:calc(var(--spacing) * 1)}.py-2{padding-block:calc(var(--spacing) * 2)}.py-6{padding-block:calc(var(--spacing) * 6)}.pr-10{padding-right:calc(var(--spacing) * 10)}.text-center{text-align:center}.text-left{text-align:left}.text-base{font-size:var(--text-base);line-height:var(--tw-leading,var(--text-base--line-height))}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.text-xs{font-size:var(--text-xs);line-height:var(--tw-leading,var(--text-xs--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-medium{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.text-wrap{text-wrap:wrap}.whitespace-nowrap{white-space:nowrap}.text-card-foreground{color:var(--card-foreground)}.text-foreground{color:var(--foreground)}.text-muted{color:var(--muted)}.text-muted-foreground{color:var(--muted-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-secondary{color:var(--secondary)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-white{color:var(--color-white)}.underline-offset-4{text-underline-offset:4px}.opacity-60{opacity:.6}.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)}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px 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)}.shadow-sm{--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)}.shadow-xs{--tw-shadow:0 1px 2px 0 var(--tw-shadow-color,#0000000d);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}.blur{--tw-blur:blur(8px);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,)}.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,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))}.transition-\[color\,box-shadow\]{transition-property:color,box-shadow;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-all{transition-property:all;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}.ease-out{--tw-ease:var(--ease-out);transition-timing-function:var(--ease-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.paused{animation-play-state:paused}.peer-disabled\:cursor-not-allowed:is(:where(.peer):disabled~*){cursor:not-allowed}.peer-disabled\:opacity-50:is(:where(.peer):disabled~*){opacity:.5}.selection\:bg-primary ::selection{background-color:var(--primary)}.selection\:bg-primary::selection{background-color:var(--primary)}.selection\:text-primary-foreground ::selection{color:var(--primary-foreground)}.selection\:text-primary-foreground::selection{color:var(--primary-foreground)}.file\:inline-flex::file-selector-button{display:inline-flex}.file\:h-7::file-selector-button{height:calc(var(--spacing) * 7)}.file\:border-0::file-selector-button{border-style:var(--tw-border-style);border-width:0}.file\:bg-transparent::file-selector-button{background-color:#0000}.file\:text-sm::file-selector-button{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.file\:font-medium::file-selector-button{--tw-font-weight:var(--font-weight-medium);font-weight:var(--font-weight-medium)}.file\:text-foreground::file-selector-button{color:var(--foreground)}.placeholder\:text-muted-foreground::placeholder{color:var(--muted-foreground)}@media(hover:hover){.hover\:bg-accent:hover{background-color:var(--accent)}.hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive) 90%,transparent)}}.hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--primary) 90%,transparent)}}.hover\:bg-secondary\/80:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){.hover\:bg-secondary\/80:hover{background-color:color-mix(in oklab,var(--secondary) 80%,transparent)}}.hover\:text-accent-foreground:hover{color:var(--accent-foreground)}.hover\:underline:hover{text-decoration-line:underline}.hover\:opacity-100:hover{opacity:1}}.focus-visible\:border-ring:focus-visible{border-color:var(--ring)}.focus-visible\:ring-\[3px\]:focus-visible{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(3px + 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)}.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-destructive\/20:focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:var(--ring)}@supports (color:color-mix(in lab,red,red)){.focus-visible\:ring-ring\/50:focus-visible{--tw-ring-color:color-mix(in oklab, var(--ring) 50%, transparent)}}.disabled\:pointer-events-none:disabled{pointer-events:none}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.has-data-\[slot\=card-action\]\:grid-cols-\[1fr_auto\]:has([data-slot=card-action]){grid-template-columns:1fr auto}.has-\[\>svg\]\:px-1\.5:has(>svg){padding-inline:calc(var(--spacing) * 1.5)}.has-\[\>svg\]\:px-2\.5:has(>svg){padding-inline:calc(var(--spacing) * 2.5)}.has-\[\>svg\]\:px-3:has(>svg){padding-inline:calc(var(--spacing) * 3)}.has-\[\>svg\]\:px-4:has(>svg){padding-inline:calc(var(--spacing) * 4)}.aria-invalid\:border-destructive[aria-invalid=true]{border-color:var(--destructive)}.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.aria-invalid\:ring-destructive\/20[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 20%, transparent)}}.data-\[state\=closed\]\:animate-out[data-state=closed]{animation:exit var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=closed\]\:fade-out-0[data-state=closed]{--tw-exit-opacity:0}.data-\[state\=closed\]\:zoom-out-95[data-state=closed]{--tw-exit-scale:.95}.data-\[state\=open\]\:animate-in[data-state=open]{animation:enter var(--tw-animation-duration,var(--tw-duration,.15s))var(--tw-ease,ease)var(--tw-animation-delay,0s)var(--tw-animation-iteration-count,1)var(--tw-animation-direction,normal)var(--tw-animation-fill-mode,none)}.data-\[state\=open\]\:fade-in-0[data-state=open]{--tw-enter-opacity:0}.data-\[state\=open\]\:zoom-in-95[data-state=open]{--tw-enter-scale:.95}@media(min-width:40rem){.sm\:max-w-lg{max-width:var(--container-lg)}.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}}@media(min-width:48rem){.md\:text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}}.dark\:border-input:is(.dark *){border-color:var(--input)}.dark\:bg-destructive\/60:is(.dark *){background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-destructive\/60:is(.dark *){background-color:color-mix(in oklab,var(--destructive) 60%,transparent)}}.dark\:bg-input\/30:is(.dark *){background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:bg-input\/30:is(.dark *){background-color:color-mix(in oklab,var(--input) 30%,transparent)}}@media(hover:hover){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:var(--accent)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-accent\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--accent) 50%,transparent)}}.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:var(--input)}@supports (color:color-mix(in lab,red,red)){.dark\:hover\:bg-input\/50:is(.dark *):hover{background-color:color-mix(in oklab,var(--input) 50%,transparent)}}}.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:focus-visible\:ring-destructive\/40:is(.dark *):focus-visible{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){.dark\:aria-invalid\:ring-destructive\/40:is(.dark *)[aria-invalid=true]{--tw-ring-color:color-mix(in oklab, var(--destructive) 40%, transparent)}}.\[\&_svg\]\:pointer-events-none svg{pointer-events:none}.\[\&_svg\]\:shrink-0 svg{flex-shrink:0}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-3 svg:not([class*=size-]){width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}.\[\&_svg\:not\(\[class\*\=\'size-\'\]\)\]\:size-4 svg:not([class*=size-]){width:calc(var(--spacing) * 4);height:calc(var(--spacing) * 4)}.\[\.border-b\]\:pb-6.border-b{padding-bottom:calc(var(--spacing) * 6)}.\[\.border-t\]\:pt-6.border-t{padding-top:calc(var(--spacing) * 6)}.\[\&\>svg\]\:pointer-events-none>svg{pointer-events:none}.\[\&\>svg\]\:size-3>svg{width:calc(var(--spacing) * 3);height:calc(var(--spacing) * 3)}@media(hover:hover){a.\[a\&\]\:hover\:bg-accent:hover{background-color:var(--accent)}a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:var(--destructive)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-destructive\/90:hover{background-color:color-mix(in oklab,var(--destructive) 90%,transparent)}}a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:var(--primary)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-primary\/90:hover{background-color:color-mix(in oklab,var(--primary) 90%,transparent)}}a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:var(--secondary)}@supports (color:color-mix(in lab,red,red)){a.\[a\&\]\:hover\:bg-secondary\/90:hover{background-color:color-mix(in oklab,var(--secondary) 90%,transparent)}}a.\[a\&\]\:hover\:text-accent-foreground:hover{color:var(--accent-foreground)}a.\[a\&\]\:hover\:underline:hover{text-decoration-line:underline}}}@property --tw-animation-delay{syntax:"*";inherits:false;initial-value:0s}@property --tw-animation-direction{syntax:"*";inherits:false;initial-value:normal}@property --tw-animation-duration{syntax:"*";inherits:false}@property --tw-animation-fill-mode{syntax:"*";inherits:false;initial-value:none}@property --tw-animation-iteration-count{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-enter-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-enter-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-blur{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-opacity{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-rotate{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-scale{syntax:"*";inherits:false;initial-value:1}@property --tw-exit-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-exit-translate-y{syntax:"*";inherits:false;initial-value:0}:root{color-scheme:light;--color-primary:#3b5bdb;--color-primary-dark:#3730a3;--color-secondary:#2196f3;--color-accent:#f59e0b;--color-danger:#ef4444;--color-success:#10b981;--color-warning:#d97706;--color-bg:#fafaf8;--color-card:#fff;--color-text:#1c1c1a;--color-text-secondary:#6b6b65;--color-border:#e8e6e0;--radius-sm:6px;--radius-md:14px;--radius-lg:18px;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 2px 8px #00000014;--font-sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--radius:.625rem;--background:oklch(100% 0 0);--foreground:oklch(14.5% 0 0);--card:oklch(100% 0 0);--card-foreground:oklch(14.5% 0 0);--popover:oklch(100% 0 0);--popover-foreground:oklch(14.5% 0 0);--primary:#3b5bdb;--primary-foreground:#fff;--secondary:oklch(97% 0 0);--secondary-foreground:oklch(20.5% 0 0);--muted:oklch(97% 0 0);--muted-foreground:oklch(55.6% 0 0);--accent:oklch(97% 0 0);--accent-foreground:oklch(20.5% 0 0);--destructive:oklch(57.7% .245 27.325);--border:oklch(92.2% 0 0);--input:oklch(92.2% 0 0);--ring:oklch(70.8% 0 0);--chart-1:oklch(64.6% .222 41.116);--chart-2:oklch(60% .118 184.704);--chart-3:oklch(39.8% .07 227.392);--chart-4:oklch(82.8% .189 84.429);--chart-5:oklch(76.9% .188 70.08);--sidebar:oklch(98.5% 0 0);--sidebar-foreground:oklch(14.5% 0 0);--sidebar-primary:oklch(20.5% 0 0);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(97% 0 0);--sidebar-accent-foreground:oklch(20.5% 0 0);--sidebar-border:oklch(92.2% 0 0);--sidebar-ring:oklch(70.8% 0 0)}.dark{color-scheme:dark;--color-bg:#0d0d14;--color-card:#16161f;--color-text:#e2e8f0;--color-text-secondary:#94a3b8;--color-border:#334155;--shadow-sm:0 1px 3px #00000059;--shadow-md:0 2px 8px #00000073;--background:oklch(14.5% 0 0);--foreground:oklch(98.5% 0 0);--card:oklch(20.5% 0 0);--card-foreground:oklch(98.5% 0 0);--popover:oklch(20.5% 0 0);--popover-foreground:oklch(98.5% 0 0);--primary:#3b5bdb;--primary-foreground:#fff;--secondary:oklch(26.9% 0 0);--secondary-foreground:oklch(98.5% 0 0);--muted:oklch(26.9% 0 0);--muted-foreground:oklch(70.8% 0 0);--accent:oklch(26.9% 0 0);--accent-foreground:oklch(98.5% 0 0);--destructive:oklch(70.4% .191 22.216);--border:oklch(100% 0 0/.1);--input:oklch(100% 0 0/.15);--ring:oklch(55.6% 0 0);--chart-1:oklch(48.8% .243 264.376);--chart-2:oklch(69.6% .17 162.48);--chart-3:oklch(76.9% .188 70.08);--chart-4:oklch(62.7% .265 303.9);--chart-5:oklch(64.5% .246 16.439);--sidebar:oklch(20.5% 0 0);--sidebar-foreground:oklch(98.5% 0 0);--sidebar-primary:oklch(48.8% .243 264.376);--sidebar-primary-foreground:oklch(98.5% 0 0);--sidebar-accent:oklch(26.9% 0 0);--sidebar-accent-foreground:oklch(98.5% 0 0);--sidebar-border:oklch(100% 0 0/.1);--sidebar-ring:oklch(55.6% 0 0)}body{font-family:var(--font-sans);background-color:var(--color-bg);color:var(--color-text);line-height:1.5;overflow-x:clip}.app{max-width:600px;min-height:100vh;margin:0 auto;padding:16px;overflow-x:clip}.app-header{text-align:center;margin-bottom:24px}.app-header h1{color:var(--color-primary);margin-bottom:4px;font-size:24px;font-weight:700}.today-date{color:var(--color-text-secondary);font-size:14px}.theme-toggle{background:var(--color-card);border-radius:var(--radius-md);cursor:pointer;border:none;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;transition:all .2s;display:flex}.theme-toggle:hover{background:var(--color-border)}.app-header-row{align-items:center;margin-bottom:8px;display:flex}.app-header-left,.app-header-right{flex:1}.app-header-right{justify-content:flex-end;display:flex}.app-header-center{flex:none;justify-content:center;display:flex}.header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.header-btn{min-width:44px;flex-direction:column!important;align-items:center!important;gap:2px!important;height:auto!important;padding:4px 8px!important;display:flex!important}.header-btn-label{opacity:.7;font-size:10px;font-weight:500;line-height:1}@media(max-width:520px){.header-btn-label{display:none}.header-btn{min-width:32px;padding:6px!important}.header-actions{gap:4px}}.login-standalone-hint{color:var(--color-text-secondary,#888);text-align:right;flex-direction:column;gap:4px;max-width:200px;font-size:12px;display:flex}.login-standalone-hint p{margin:0;line-height:1.4}.login-standalone-hint-sub{opacity:.8;font-size:11px}.login-standalone-link{color:var(--color-primary,#4caf50);margin-top:2px;font-size:12px;font-weight:600;text-decoration:none}.header-actions .login-button{padding:8px 12px;font-size:13px}.header-actions .login-button svg{width:16px;height:16px}.error-banner{color:var(--color-danger);border-radius:var(--radius-md);background-color:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:12px 16px;font-size:14px}.progress-dashboard{margin-bottom:24px}.progress-card{background:var(--color-card);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-md);padding:24px}.progress-percent{margin-bottom:8px;font-size:48px;font-weight:700;line-height:1}.progress-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-size:14px;font-weight:600}.progress-detail{color:var(--color-text-secondary);font-size:14px}.habits-section{margin-bottom:24px}.section-header{justify-content:space-between;align-items:center;margin-bottom:16px;display:flex}.section-header--centered{justify-content:center}.section-header-actions{gap:8px;display:flex}.section-header h2{font-size:18px;font-weight:600}.btn-add{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;padding:8px 16px;font-size:14px;font-weight:500;transition:background .2s}.btn-add:hover{background:var(--color-primary-dark)}.filters-bar{flex-direction:column;gap:12px;margin-bottom:12px;display:flex}.search-bar{margin-bottom:8px;position:relative}.search-icon{color:var(--color-muted-foreground);pointer-events:none;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-input{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);width:100%;color:var(--color-text);padding:12px 40px 12px 36px;font-size:14px;transition:border-color .2s,box-shadow .2s}.search-input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 3px #4caf501a}.search-input::placeholder{color:var(--color-text-secondary)}.search-clear{background:var(--color-bg);width:28px;height:28px;color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:18px;transition:all .2s;display:flex;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.search-clear:hover{background:var(--color-border);color:var(--color-text)}.search-results-count{color:var(--color-text-secondary);align-items:center;gap:6px;margin-bottom:12px;padding-left:4px;font-size:13px;display:flex}.btn-clear-filter{background:var(--color-bg);width:20px;height:20px;color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;font-size:14px;line-height:1;transition:all .2s;display:inline-flex}.sort-controls{-ms-overflow-style:none;scrollbar-width:none;flex-wrap:nowrap;align-items:center;gap:4px;display:flex;overflow-x:auto}.sort-controls::-webkit-scrollbar{display:none}.sort-label{color:var(--color-text-secondary);white-space:nowrap;margin-right:4px;font-size:12px}.sort-btn{border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:4px 10px;font-size:12px;transition:all .15s}.sort-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.sort-btn.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.habit-list li[draggable=true],.habit-list li[draggable=true] .habit-card{cursor:grab}.habit-list li[draggable=true]:active,.habit-list li[draggable=true]:active .habit-card{cursor:grabbing}.habit-list li.drag-over>.habit-card{outline:2px dashed var(--color-primary);outline-offset:2px;opacity:.75}.habit-list li.drag-ready>*{box-shadow:var(--shadow-lg);opacity:.9;cursor:grabbing;transform:scale(1.02)}.reorder-modal-list{flex-direction:column;gap:4px;max-height:60vh;margin:0;padding:2px;list-style:none;display:flex;overflow-y:auto}.reorder-item{border:1px solid var(--color-border);background:var(--color-card);cursor:grab;-webkit-user-select:none;user-select:none;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;transition:background .15s,outline .1s;display:flex}.reorder-item:active{cursor:grabbing}.reorder-item.drag-over{outline:2px dashed var(--color-primary);outline-offset:2px;opacity:.75}.reorder-item-handle{color:var(--color-text-secondary);flex-shrink:0;font-size:16px;line-height:1}.reorder-item-color{border-radius:50%;flex-shrink:0;width:10px;height:10px}.reorder-item-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;flex:1;min-width:0;font-size:14px;font-weight:500;overflow:hidden}.reorder-item-stars{color:var(--color-accent);flex-shrink:0;font-size:11px}.btn-clear-filter:hover{background:var(--color-border);color:var(--color-text)}.btn-clear-search{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);cursor:pointer;margin-top:12px;padding:8px 16px;font-size:14px;transition:all .2s}.btn-clear-search:hover{background:var(--color-bg);border-color:var(--color-primary)}.empty-state{background:var(--color-card);border-radius:var(--radius-lg);text-align:center;color:var(--color-text-secondary);padding:48px 24px}.empty-state p{margin-bottom:8px}.empty-state-icon{margin-bottom:12px;font-size:48px}.empty-state-title{color:var(--color-text);margin-bottom:8px;font-size:17px;font-weight:600}.empty-state-cta{margin-top:16px}.habit-list{flex-direction:column;gap:12px;list-style:none;display:flex}.habit-card{cursor:pointer;touch-action:pan-y;border-left:3px solid #0000;transition:box-shadow .2s,transform .15s;position:relative;overflow:hidden}.habit-fill-bg{opacity:.13;pointer-events:none;z-index:0;border-radius:inherit;transition:width .12s;position:absolute;top:0;bottom:0;left:0}.habit-card.swiping .habit-fill-bg{transition:none}.habit-card-content,.habit-paused-badge{z-index:1;position:relative}.swipe-hint{text-align:center;color:var(--color-text-secondary);pointer-events:none;padding:5px 12px 8px;font-size:12px;animation:4s forwards swipe-hint-fade}@keyframes swipe-hint-fade{0%{opacity:0}15%{opacity:1}75%{opacity:1}to{opacity:0}}.habit-value-text{color:var(--color-text-secondary);white-space:nowrap;font-size:11px;transition:color .1s,font-weight .1s}.habit-value-text--live{color:var(--color-text);font-weight:700}.habit-card.completed{border-left-color:var(--color-success)}.habit-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.habit-card-content{flex-wrap:wrap;align-items:flex-start;gap:10px;display:flex;padding:12px 14px!important}.habit-left-accent{flex-direction:column;flex-shrink:0;align-items:center;gap:4px;display:flex}.emoji-box-container{position:relative}.habit-emoji-box{background:var(--color-bg-secondary);border:1.5px solid var(--color-border);width:42px;height:42px;color:var(--color-text);cursor:default;pointer-events:none;-webkit-user-select:none;user-select:none;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:22px;font-weight:700;line-height:1;display:flex;overflow:hidden}.habit-info{flex:1;min-width:80px;overflow:hidden}.habit-right-col{flex-shrink:0;justify-content:flex-end;align-items:center;display:flex}.habit-name{-webkit-line-clamp:2;overflow-wrap:normal;-webkit-box-orient:vertical;flex:1;min-width:0;font-weight:500;display:-webkit-box;overflow:hidden}.habit-weight{color:var(--color-accent);font-size:12px}.habit-name-row{align-items:center;gap:8px;margin-bottom:2px;display:flex}.habit-streak{white-space:nowrap;border-radius:6px;flex-shrink:0;align-items:center;gap:4px;font-weight:600;line-height:1;display:inline-flex}.habit-streak--footer{border-radius:8px;flex:0 0 100%;margin-top:2px;padding:5px 10px;font-size:12px;font-weight:600}.habit-streak--base{color:#f97316;background:#f9731621}.habit-streak--warm{color:#ea580c;background:#ea580c29;font-weight:700}.habit-streak--hot{color:#b45309;background:#d977062e;font-weight:700;box-shadow:0 0 8px #d977064d}.habit-streak--legendary{color:#92400e;background:#b453092e;font-weight:700;animation:2.5s ease-in-out infinite streak-pulse;box-shadow:0 0 10px #b4530959}@keyframes streak-pulse{0%,to{box-shadow:0 0 6px #b4530940}50%{box-shadow:0 0 14px #b453098c}}.habit-meta{flex-wrap:wrap;align-items:center;gap:8px;display:flex;overflow:hidden}.habit-category-badge{white-space:nowrap;text-overflow:ellipsis;border-radius:12px;max-width:100%;padding:2px 8px;font-size:11px;font-weight:500;display:inline-block;overflow:hidden}.habit-category-badge--footer{flex:0 0 100%;margin-top:2px;display:inline-block}.habit-meta .habit-category-badge{display:none}.habit-timeframe-badge{background-color:var(--color-primary);color:#fff;opacity:.85;text-transform:uppercase;letter-spacing:.03em;border-radius:6px;flex-shrink:0;align-items:center;padding:1px 5px;font-size:9px;font-weight:700;display:inline-flex}.habit-progress-container{flex-direction:column;flex:1;gap:4px;min-width:100px;display:flex}.habit-progress{background:var(--color-border);border-radius:var(--radius-sm);width:100%;height:20px;position:relative;overflow:hidden}.habit-progress .progress-bar{background:var(--color-primary);border-radius:var(--radius-sm);height:100%;transition:width .3s}.progress-text{color:var(--color-text-secondary);pointer-events:none;text-align:right;font-size:11px;font-weight:500;line-height:1}.habit-progress-slider{overflow:visible}.progress-slider{cursor:pointer;appearance:none;z-index:0;background:0 0;width:100%;height:100%;margin:0;padding:0;position:absolute;top:0;left:0}.progress-slider::-webkit-slider-runnable-track{border-radius:var(--radius-sm);background:0 0;width:100%;height:20px}.progress-slider::-moz-range-track{border-radius:var(--radius-sm);background:0 0;width:100%;height:20px}.progress-slider::-webkit-slider-thumb{appearance:none;border:2px solid var(--progress-color,var(--color-primary));cursor:grab;background:#fff;border-radius:50%;width:20px;height:20px;transition:transform .1s;box-shadow:0 2px 4px #0003}.progress-slider::-moz-range-thumb{border:2px solid var(--progress-color,var(--color-primary));cursor:grab;background:#fff;border-radius:50%;width:20px;height:20px;box-shadow:0 2px 4px #0003}.progress-slider::-webkit-slider-thumb:hover{transform:scale(1.1)}.progress-slider::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15)}.progress-slider:focus{outline:none}.progress-slider:focus::-webkit-slider-thumb{box-shadow:0 0 0 3px #3b82f64d}.habit-stepper{border:1.5px solid var(--color-border);background:var(--color-bg);border-radius:20px;flex-shrink:0;align-items:stretch;height:32px;display:flex;overflow:hidden}.habit-stepper-btn{cursor:pointer;width:28px;color:var(--color-text-secondary);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:16px;font-weight:500;transition:background .12s,color .12s;display:flex}.habit-stepper-btn:hover:not(:disabled){background:var(--color-surface)}.habit-stepper-btn--plus:hover:not(:disabled){color:var(--color-primary)}.habit-stepper-btn--minus:hover:not(:disabled){color:var(--color-danger)}.habit-stepper-btn:disabled{opacity:.3;cursor:not-allowed}.habit-stepper-val{text-align:center;min-width:36px;color:var(--color-text);border-left:1px solid var(--color-border);border-right:1px solid var(--color-border);white-space:nowrap;-webkit-user-select:none;user-select:none;justify-content:center;align-items:center;padding:0 4px;font-size:12px;font-weight:600;display:flex}.habit-stepper-val--live{color:var(--color-primary)}.habit-stepper--boolean .habit-stepper-btn{flex:1}.habit-actions{flex-wrap:nowrap;align-items:center;gap:8px;display:flex}.btn-increment,.btn-decrement,.btn-check,.btn-pause,.btn-resume,.btn-complete-max{cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:20px;font-weight:600;transition:all .15s;display:flex}.btn-complete-max{background:var(--color-primary);color:#fff}.btn-complete-max:hover:not(:disabled){background:var(--color-primary-dark)}.btn-complete-max:disabled{opacity:.4;cursor:not-allowed}.btn-increment{background:var(--color-primary);color:#fff}.btn-increment:hover:not(:disabled){background:var(--color-primary-dark)}.btn-increment:disabled{opacity:.4;cursor:not-allowed}.btn-decrement{background:var(--color-danger);color:#fff;border:none}.btn-decrement:hover:not(:disabled){background:#dc2626}.btn-decrement:disabled{opacity:.4;cursor:not-allowed}.btn-edit{background:var(--color-bg);color:var(--color-text-secondary);margin-left:8px}.btn-edit:hover{color:var(--color-secondary);background:#dbeafe}.btn-delete{background:var(--color-bg);color:var(--color-text-secondary)}.btn-delete:hover{color:var(--color-danger);background:#fee2e2}.btn-pause{background:var(--color-bg);color:var(--color-text-secondary);font-size:14px}.btn-pause:hover{color:#b45309;background:#fef3c7}.btn-resume{background:var(--color-primary);color:#fff;font-size:14px}.btn-resume:hover{background:var(--color-primary-dark)}.habit-card.paused{opacity:.55;cursor:default}.habit-paused-badge{color:#92400e!important;background:#fef3c7!important}[data-theme=dark] .habit-paused-badge{color:#fcd34d!important;background:#451a03!important}.paused-habits-count{color:var(--color-text-secondary);text-align:center;margin:4px 0 0;padding:4px;font-size:12px}@media(max-width:480px){.habit-card-content{flex-wrap:wrap}.btn-increment,.btn-decrement,.btn-check,.btn-edit,.btn-delete,.btn-complete-max{width:30px;height:30px;font-size:14px;line-height:1}.btn-increment,.btn-decrement,.btn-resume{width:38px;height:38px;font-size:18px}.habit-actions{gap:6px}.habit-info{overflow:hidden}.habit-name{font-size:.82rem}}.modal-overlay{z-index:1000;padding:max(env(safe-area-inset-top),16px) 16px 16px;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--color-card);border-radius:var(--radius-lg);width:100%;max-width:400px;box-shadow:var(--shadow-md);padding:24px;animation:.2s ease-out modal-enter}@keyframes modal-enter{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-title{color:var(--color-text);margin-bottom:12px;font-size:18px;font-weight:600}.modal-text{color:var(--color-text-secondary);margin-bottom:24px;font-size:14px;line-height:1.6}.modal-actions{justify-content:flex-end;gap:12px;display:flex}.btn-danger{border-radius:var(--radius-md);background:var(--color-danger);color:#fff;cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.btn-danger:hover{background:#dc2626}.btn-check{background:var(--color-bg);color:var(--color-border);border:1px solid var(--color-border)}.btn-check:hover{border-color:var(--color-primary);color:var(--color-primary)}.btn-check.checked{background:var(--color-success);border-color:var(--color-success);color:#fff}.form-section{margin-bottom:24px}.habit-form{background:var(--color-card);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:24px}.form-title{color:var(--color-text);margin-bottom:20px;font-size:18px;font-weight:600}.form-group{margin-bottom:20px}.name-emoji-row{align-items:center;gap:8px;display:flex}.name-emoji-row>:last-child{flex:1;min-width:0}.emoji-picker-container{flex-shrink:0;position:relative}.emoji-trigger{border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary);width:44px;height:40px;color:var(--color-text-secondary);cursor:pointer;justify-content:center;align-items:center;padding:0;font-size:16px;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.emoji-trigger.has-emoji{color:var(--color-text);border-color:var(--color-primary);background:var(--color-primary);font-size:22px}@supports (color:color-mix(in lab,red,red)){.emoji-trigger.has-emoji{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}}.emoji-trigger:hover{border-color:var(--color-primary);background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.emoji-trigger:hover{background:color-mix(in srgb,var(--color-primary) 6%,var(--color-bg-secondary))}}.emoji-trigger:hover{box-shadow:0 0 0 3px var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.emoji-trigger:hover{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}}.emoji-trigger:active{transform:scale(.94)}.emoji-dropdown{z-index:100;box-shadow:var(--shadow-md);border-radius:var(--radius-md);position:absolute;top:calc(100% + 4px);left:0;overflow:hidden}.emoji-dropdown input[type=text],.emoji-dropdown input[type=search]{border:unset!important;width:auto!important;font-size:unset!important;border-radius:unset!important;padding:8px 8px 8px 36px!important;transition:unset!important}.emoji-dropdown .epr-category-nav{display:none!important}.emoji-clear-btn{border:none;border-top:1px solid var(--color-border);background:var(--color-card);width:100%;color:var(--color-text-secondary);cursor:pointer;text-align:center;padding:8px;font-size:12px;font-weight:500;transition:background .15s,color .15s}.emoji-clear-btn:hover{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.emoji-clear-btn:hover{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-card))}}.emoji-clear-btn:hover{color:var(--color-primary)}.form-group label{color:var(--color-text);margin-bottom:8px;font-size:14px;font-weight:500;display:block}.label-hint{color:var(--color-text-secondary);margin-top:2px;font-size:12px;font-weight:400;display:block}.form-group input[type=text],.form-group input[type=number]{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;padding:12px;font-size:16px;transition:border-color .2s}.form-group input:focus{border-color:var(--habit-color,var(--color-primary));outline:none}.description-textarea{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);width:100%;color:var(--color-text);resize:vertical;min-height:70px;padding:10px 12px;font-family:inherit;font-size:14px;transition:border-color .2s}.description-textarea::placeholder{color:var(--color-text-secondary);opacity:.6}.description-textarea:focus{border-color:var(--habit-color,var(--color-primary));outline:none}.form-error{color:var(--color-danger);margin-top:4px;font-size:12px;display:block}.type-selector{flex-direction:column;gap:8px;display:flex}.type-option{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);cursor:pointer;color:var(--color-text);flex-direction:column;align-items:flex-start;padding:12px;transition:all .2s;display:flex}.type-option:hover{border-color:var(--habit-color,var(--color-primary))}.type-option.active{border-color:var(--habit-color,var(--color-primary));background:var(--habit-color,var(--color-primary))}@supports (color:color-mix(in lab,red,red)){.type-option.active{background:color-mix(in srgb,var(--habit-color,var(--color-primary)) 12%,transparent)}}.type-label{color:var(--color-text);font-size:14px;font-weight:500}.type-desc{color:var(--color-text-secondary);margin-top:2px;font-size:12px}.weight-selector{flex-direction:column;gap:8px;display:flex}.weight-stars{gap:4px;display:flex}.weight-star{width:36px;height:36px;color:var(--color-border);cursor:pointer;background:0 0;border:none;padding:0;font-size:24px;transition:all .2s}.weight-star:hover{transform:scale(1.1)}.weight-star.active{color:var(--color-accent)}.weight-star:disabled{cursor:not-allowed}.weight-label{color:var(--color-text-secondary);font-size:13px}.impact-preview,.target-preview{color:var(--color-text-secondary);background:var(--color-bg);border-radius:var(--radius-sm);margin-top:8px;padding:8px;font-size:12px}.color-picker{flex-wrap:wrap;gap:8px;display:flex}.color-option{aspect-ratio:1;cursor:pointer;border:2px solid #0000;border-radius:50%;flex-shrink:0;width:32px;min-width:32px;height:32px;min-height:32px;padding:0;transition:all .2s}.color-option:hover{transform:scale(1.1)}.color-option.active{border-color:var(--color-text);box-shadow:0 0 0 2px var(--color-card)}.target-with-unit{align-items:center;gap:8px;display:flex}.target-input{border:1px solid var(--color-border);border-radius:var(--radius-md);text-align:center;width:80px;padding:12px;font-size:16px}.target-input:focus{border-color:var(--habit-color,var(--color-primary));outline:none}.unit-select{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);cursor:pointer;flex:1;padding:12px;font-size:14px}.unit-select:focus{border-color:var(--habit-color,var(--color-primary));outline:none}.category-select{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);width:100%;color:var(--color-text);cursor:pointer;padding:12px;font-size:14px}.category-select:focus{border-color:var(--habit-color,var(--color-primary));outline:none}.unit-select optgroup{color:var(--color-text);font-weight:600}.unit-select option{padding:4px;font-weight:400}.form-actions{border-top:1px solid var(--color-border);justify-content:flex-end;gap:12px;margin-top:24px;padding-top:16px;display:flex}.btn-cancel{border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);cursor:pointer;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.btn-cancel:hover{background:var(--color-bg)}.btn-submit{border-radius:var(--radius-md);background:var(--color-primary);color:#fff;cursor:pointer;border:none;padding:10px 20px;font-size:14px;font-weight:500;transition:all .2s}.btn-submit:hover{background:var(--color-primary-dark)}.debug-footer{border-top:1px solid var(--color-border);margin-top:32px;padding-top:16px}.debug-footer summary{color:var(--color-text-secondary);cursor:pointer;font-size:12px}.debug-footer pre{color:#22c55e;border-radius:var(--radius-md);background:#1a1a1a;margin-top:8px;padding:12px;font-size:11px;overflow-x:auto}.debug-controls{border-radius:var(--radius-md);background:#2a2a2a;margin-top:12px;padding:12px}.debug-controls p{color:#ccc;margin-bottom:8px;font-size:12px}.debug-buttons{flex-direction:column;gap:8px;display:flex}.debug-habit-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.debug-habit-row span{color:#eee;flex:1;min-width:100px;font-size:12px}.debug-habit-row button{cursor:pointer;background:var(--color-primary);color:#fff;border:none;border-radius:4px;padding:4px 8px;font-size:11px}.debug-habit-row button:last-child{background:#ef4444}.app-loading{width:100%;min-height:100vh;font-size:16px;font-family:var(--font-sans,system-ui, -apple-system, sans-serif);color:var(--color-text-secondary);letter-spacing:.01em;justify-content:center;align-items:center;display:flex}.app-loading-bg{background:var(--color-bg);width:100%;min-height:100vh}@keyframes app-appear{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.app{animation:.35s ease-out app-appear}@media(min-width:480px){.app{padding:24px}.progress-percent{font-size:64px}}.habit-detail-overlay{z-index:1000;padding:max(env(safe-area-inset-top),16px) 16px 16px;background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.habit-detail-modal{background:var(--color-card);border-radius:var(--radius-lg);width:100%;max-width:450px;max-height:90vh;box-shadow:var(--shadow-md);padding:24px;animation:.2s ease-out modal-enter;overflow-y:auto}.habit-detail-header{align-items:center;gap:12px;margin-bottom:20px;display:flex}.habit-detail-color{border-radius:50%;flex-shrink:0;width:16px;height:16px}.habit-detail-header h2{flex:1;margin:0;font-size:20px;font-weight:600}.habit-detail-header .btn-close{background:var(--color-bg);border-radius:var(--radius-md);cursor:pointer;width:32px;height:32px;color:var(--color-text-secondary);border:none;font-size:20px;transition:all .2s}.habit-detail-header .btn-close:hover{background:var(--color-border);color:var(--color-text)}.habit-detail-description{color:var(--color-text-secondary);text-align:center;white-space:pre-wrap;margin:0;padding:0 16px 12px;font-size:13px;line-height:1.5}.habit-freeze-badge{cursor:default;font-size:12px}.dayview-frozen-badge{color:#0369a1;background:#e0f2fe;border-radius:4px;margin-bottom:4px;margin-left:auto;padding:2px 7px;font-size:11px;font-weight:600;display:inline-block}[data-theme=dark] .dayview-frozen-badge{color:#7dd3fc;background:#0c4a6e40}.btn-freeze{cursor:pointer;background:0 0;border:1px solid #bae6fd;border-radius:6px;flex-shrink:0;padding:4px 8px;font-size:14px;transition:background .15s}.btn-freeze:hover{background:#e0f2fe}[data-theme=dark] .btn-freeze{color:#7dd3fc;border-color:#0369a140}[data-theme=dark] .btn-freeze:hover{background:#0c4a6e40}.day-edit-freeze{border-top:1px solid var(--border);flex-direction:column;gap:6px;margin-top:12px;padding-top:12px;display:flex}.btn-freeze-detail{cursor:pointer;color:#0369a1;background:#e0f2fe;border:1px solid #bae6fd;border-radius:6px;align-self:flex-start;padding:6px 12px;font-size:13px;font-weight:600;transition:background .15s}.btn-freeze-detail:hover{background:#bae6fd}.btn-freeze-confirm{cursor:pointer;color:#fff;background:#0369a1;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:600;transition:background .15s}.btn-freeze-confirm:hover{background:#0284c7}.day-edit-freeze-hint{color:var(--text-secondary);margin:0;font-size:12px}.day-edit-frozen-note{color:#0369a1;margin:12px 0 0;font-size:12px;font-weight:600}.calendar-day.frozen{color:#0369a1;background:#e0f2fe;font-weight:600}[data-theme=dark] .calendar-day.frozen{color:#7dd3fc;background:#0c4a6e40}[data-theme=dark] .btn-freeze-detail{color:#7dd3fc;background:#0c4a6e40;border-color:#0369a140}[data-theme=dark] .btn-freeze-detail:hover{background:#0c4a6e70}.legend-dot.frozen{background:#7dd3fc}.habit-atrisk-chip{color:#b45309;background:#fef3c7;border-radius:4px;margin-top:2px;margin-bottom:4px;padding:2px 6px;font-size:11px;font-weight:600;line-height:1.4;display:block}[data-theme=dark] .habit-atrisk-chip{color:#fcd34d;background:#78350f40}.habit-atrisk-chip--footer{border-radius:8px;flex:0 0 100%;margin-top:4px;margin-bottom:0;padding:4px 10px;font-size:12px;display:block}.habit-detail-atrisk-note{color:#f59e0b;border-radius:var(--radius-sm);text-align:center;background:#f59e0b14;margin:0 0 12px;padding:8px 12px;font-size:13px}.habit-stats-grid{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.stat-card{background:var(--color-bg);border-radius:var(--radius-md);text-align:center;flex-direction:column;align-items:center;gap:4px;padding:16px 12px;display:flex}.stat-icon{font-size:20px}.stat-value{color:var(--color-text);font-size:24px;font-weight:700}.stat-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px;font-size:11px}.habit-calendar-section{margin-bottom:24px}.habit-calendar-section h3{color:var(--color-text);margin-bottom:12px;font-size:14px;font-weight:600}.habit-calendar-nav{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.habit-cal-nav-btn{cursor:pointer;color:var(--color-text);border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;font-size:16px;transition:background .15s}.habit-cal-nav-btn:hover:not(:disabled){background:var(--color-border)}.habit-cal-nav-btn:disabled{opacity:.3;cursor:default}.habit-cal-month-title{color:var(--color-text);font-size:13px;font-weight:600}.habit-calendar-weekdays{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px;display:grid}.habit-cal-weekday{color:var(--color-text-secondary);text-align:center;padding:2px 0;font-size:10px;font-weight:600}.calendar-day.other-month{opacity:.3}.habit-calendar-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.calendar-day{aspect-ratio:1;border-radius:var(--radius-sm);cursor:default;color:var(--color-text-secondary);justify-content:center;align-items:center;font-size:10px;font-weight:500;transition:all .2s;display:flex}.calendar-day.missed{background:var(--color-border)}.calendar-day.partial{background:var(--color-warning);color:#000000b3}.calendar-day.completed{background:var(--color-success);color:#ffffffe6}.calendar-day.future{border:1px dashed var(--color-border);background:0 0}.calendar-legend{color:var(--color-text-secondary);gap:16px;margin-top:12px;font-size:12px;display:flex}.legend-dot{border-radius:var(--radius-sm);vertical-align:middle;width:12px;height:12px;margin-right:4px;display:inline-block}.legend-dot.missed{background:var(--color-border)}.legend-dot.partial{background:var(--color-warning)}.legend-dot.completed{background:var(--color-success)}.habit-info-section{border-top:1px solid var(--color-border);padding-top:16px}.habit-info-section p{color:var(--color-text-secondary);margin-bottom:8px;font-size:14px}.habit-info-section strong{color:var(--color-text)}.habit-reminder-section{border-top:1px solid var(--color-border);margin-top:20px;padding-top:16px}.habit-reminder-disabled{color:var(--color-text-muted);margin:0;font-size:13px}.habit-reminder-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.habit-reminder-label{color:var(--color-text);cursor:pointer;font-size:14px;font-weight:500}.habit-reminder-toggle{cursor:pointer;width:18px;height:18px;accent-color:var(--color-primary);flex-shrink:0}.habit-reminder-time-row{align-items:center;gap:12px;margin-top:10px;display:flex}.habit-reminder-time-label{color:var(--color-text-muted);font-size:13px}.habit-reminder-time-input{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-input-bg);color:var(--color-text);cursor:pointer;padding:6px 10px;font-size:14px}.habit-edit-zone{border-top:1px solid var(--color-border);text-align:center;margin-top:20px;padding-top:16px}.btn-edit-outline{border-radius:var(--radius-md);cursor:pointer;border:1px solid var(--color-primary);color:var(--color-primary);background:0 0;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.btn-edit-outline:hover{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.btn-edit-outline:hover{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}}.dark .btn-edit-outline:hover{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.dark .btn-edit-outline:hover{background:color-mix(in srgb,var(--color-primary) 12%,transparent)}}.habit-danger-zone{border-top:1px solid var(--color-border);text-align:center;margin-top:12px;padding-top:16px}.btn-danger-outline{border-radius:var(--radius-md);cursor:pointer;color:#ef4444;background:0 0;border:1px solid #ef4444;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.btn-danger-outline:hover{background:#fef2f2}.dark .btn-danger-outline:hover{background:#ef44441a}.clear-history-confirm{text-align:left}.clear-history-warning{color:#ef4444;margin-bottom:8px;font-size:13px}.btn-delete-small{border-radius:var(--radius-md);cursor:pointer;color:#fff;background:#ef4444;border:none;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.btn-delete-small:hover{background:#dc2626}.calendar-hint{color:var(--color-text-secondary);margin-bottom:8px;font-size:12px}.calendar-day.clickable{cursor:pointer;transition:transform .15s,box-shadow .15s}.calendar-day.clickable:hover{transform:scale(1.15);box-shadow:0 2px 8px #0003}.calendar-day.editing{outline:2px solid var(--color-primary);outline-offset:2px}.day-edit-form{background:var(--color-bg);border-radius:var(--radius-md);margin-bottom:16px;padding:16px;animation:.2s ease-out slide-down}@keyframes slide-down{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.day-edit-title{color:var(--color-text);margin-bottom:12px;font-size:14px;font-weight:600}.day-edit-boolean{justify-content:center;display:flex}.btn-boolean{border:2px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-card);color:var(--color-text);cursor:pointer;padding:12px 24px;font-size:16px;font-weight:500;transition:all .2s}.btn-boolean:hover{border-color:var(--color-primary)}.btn-boolean.active{background:var(--color-success);border-color:var(--color-success);color:#fff}.day-edit-numeric{justify-content:center;align-items:center;gap:8px;display:flex}.day-edit-numeric .btn-increment,.day-edit-numeric .btn-decrement{width:40px;height:40px}.edit-value-input{text-align:center;border:1px solid var(--color-border);border-radius:var(--radius-md);width:90px;height:40px;font-size:18px;font-weight:600}.edit-value-input:focus{border-color:var(--color-primary);outline:none}.edit-target{color:var(--color-text-secondary);margin-left:4px;font-size:14px}.day-edit-actions{justify-content:center;gap:12px;margin-top:12px;display:flex}.btn-cancel-small,.btn-save-small{border-radius:var(--radius-md);cursor:pointer;padding:8px 16px;font-size:13px;font-weight:500;transition:all .2s}.btn-cancel-small{background:var(--color-card);border:1px solid var(--color-border);color:var(--color-text)}.btn-cancel-small:hover{background:var(--color-bg)}.btn-save-small{background:var(--color-primary);color:#fff;border:none}.btn-save-small:hover{background:var(--color-primary-dark)}.today-date-btn{border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);border-radius:var(--radius-md);cursor:pointer;align-items:center;gap:8px;padding:8px 16px;font-size:.95rem;font-weight:500;transition:all .2s;display:flex}.today-date-btn:hover{background:var(--color-bg);border-color:var(--color-primary)}.today-date-btn .calendar-icon{font-size:1.1rem}.dayview-overlay{touch-action:none;z-index:1000;padding:max(env(safe-area-inset-top),16px) 16px 16px;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.dayview-modal{background:var(--color-card);border-radius:var(--radius-lg);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-md);overflow-y:auto}.dayview-header{border-bottom:1px solid var(--color-border);background:var(--color-card);z-index:10;justify-content:space-between;align-items:center;padding:16px;display:flex;position:sticky;top:0}.dayview-date{text-align:center;flex:1}.dayview-date h2{margin:0;font-size:1.1rem}.dayview-today-badge{background:var(--color-primary);color:#fff;border-radius:10px;margin-left:8px;padding:2px 8px;font-size:.7rem;display:inline-block}.dayview-nav-btn{border:1px solid var(--color-border);background:var(--color-card);border-radius:var(--radius-md);cursor:pointer;width:36px;height:36px;color:var(--color-text);justify-content:center;align-items:center;font-size:1.2rem;display:flex}.dayview-nav-btn:hover:not(:disabled){background:var(--color-bg)}.dayview-nav-btn:disabled{opacity:.3;cursor:not-allowed}.dayview-close{margin-left:8px}.dayview-calendar-picker{border-bottom:1px solid var(--color-border);background:var(--color-bg);padding:12px 16px}.dayview-calendar-grid{grid-template-columns:repeat(10,1fr);gap:4px;display:grid}.dayview-calendar-day{aspect-ratio:1;background:var(--color-card);border-radius:var(--radius-sm);cursor:pointer;width:100%;color:var(--color-text);border:none;font-size:.75rem;transition:all .15s}.dayview-calendar-day:hover{background:var(--color-primary);color:#fff}.dayview-calendar-day.selected{background:var(--color-primary);color:#fff;font-weight:700}.dayview-calendar-day.today{border:2px solid var(--color-primary)}.dayview-calendar-day.today.selected{border-color:#fff}.dayview-future-warning{background:var(--color-warning);color:#000;text-align:center;padding:8px;font-size:.85rem}.dayview-progress{border-bottom:1px solid var(--color-border);align-items:center;gap:16px;padding:20px;display:flex}.dayview-progress-circle{text-align:center;min-width:80px;font-size:2rem;font-weight:700}.dayview-progress-info{flex-direction:column;display:flex}.dayview-progress-label{color:var(--color-text-secondary);font-size:.9rem}.dayview-progress-detail{font-size:1rem;font-weight:500}.dayview-habits{padding:16px}.dayview-empty{text-align:center;color:var(--color-text-secondary);padding:32px}.dayview-habit-list{flex-direction:column;gap:12px;list-style:none;display:flex}.dayview-habit-card{background:var(--color-bg);border-radius:var(--radius-md);touch-action:pan-y;border-left:4px solid #0000;flex-direction:column;gap:8px;padding:16px;transition:background-color .2s;display:flex;position:relative;overflow:hidden}.dayview-habit-card .dayview-habit-info,.dayview-habit-card .dayview-habit-row{z-index:1;position:relative}.dayview-habit-row,.dayview-habit-info{align-items:center;gap:8px;display:flex}.dayview-habit-color{border-radius:50%;flex-shrink:0;width:12px;height:12px}.dayview-habit-name{font-size:.9rem;font-weight:500}.dayview-habit-progress{background:var(--color-card);border-radius:var(--radius-sm);flex:1;height:24px;position:relative;overflow:hidden}.dayview-progress-bar{border-radius:var(--radius-sm);height:100%;transition:width .3s}.dayview-progress-text{color:var(--color-text-secondary);font-size:.75rem;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.dayview-habit-actions{gap:4px;margin-left:auto;display:flex}.dayview-modal-calendar{box-sizing:border-box;width:100%;max-width:480px;max-height:90vh;overflow:hidden auto}.dayview-month-title{text-align:center;flex:1}.dayview-month-title h2{margin:0;font-size:1.1rem}.dayview-report-cards{border-bottom:1px solid var(--color-border);background:var(--color-bg);grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 16px;display:grid}.dayview-mini-card{background:var(--color-card);border-radius:var(--radius-md);flex-direction:column;align-items:center;gap:2px;min-width:0;padding:8px 4px;display:flex;overflow:hidden}.dayview-mini-icon{font-size:14px}.dayview-mini-title{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px;text-align:center;white-space:nowrap;text-overflow:ellipsis;max-width:100%;font-size:.65rem;overflow:hidden}.dayview-mini-percent{font-size:1.25rem;font-weight:700;line-height:1}.dayview-calendar{border-bottom:1px solid var(--color-border);padding:12px 16px}.dayview-calendar-unified-grid{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.dayview-weekday{text-align:center;color:var(--color-text-secondary);text-transform:uppercase;padding:4px 0 6px;font-size:.7rem;font-weight:600}.dayview-calendar-day-monthly{box-sizing:border-box;aspect-ratio:1;background:var(--color-card);border-radius:var(--radius-sm);cursor:pointer;width:100%;color:var(--color-text);border:none;justify-content:center;align-items:center;font-size:.8rem;transition:all .15s;display:flex}.dayview-calendar-day-monthly:hover:not(.future):not(.other-month){background:var(--color-primary);color:#fff}.dayview-calendar-day-monthly.selected{background:var(--color-primary);color:#fff;font-weight:700}.dayview-calendar-day-monthly.today{border:2px solid var(--color-primary)}.dayview-calendar-day-monthly.today.selected{border-color:#fff}.dayview-calendar-day-monthly.other-month{color:var(--color-text-secondary);opacity:.4}.dayview-calendar-day-monthly.other-month.selected{opacity:1;color:#fff}.dayview-calendar-day-monthly.future{opacity:.3;cursor:not-allowed}.dayview-selected-info{background:var(--color-bg);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.dayview-selected-info h3{align-items:center;gap:8px;margin:0;font-size:.95rem;display:flex}.dayview-selected-stats{color:var(--color-text-secondary);font-size:.85rem}@media(max-width:600px){.dayview-overlay{padding-top:max(env(safe-area-inset-top),16px);padding-bottom:max(env(safe-area-inset-bottom),16px);align-items:flex-start}}@media(max-width:400px){.dayview-overlay{padding-left:0;padding-right:0}.dayview-modal-calendar{border-radius:0;width:100%;max-width:100%;max-height:100dvh}.dayview-report-cards{gap:6px;padding:10px 12px}.dayview-mini-card{padding:6px 2px}.dayview-mini-percent{font-size:1.1rem}.dayview-calendar-day-monthly{font-size:.75rem}}.report-cards-container{grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;display:grid}.report-card{background:var(--color-card);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);padding:16px;transition:box-shadow .2s,transform .2s;position:relative}.report-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.report-card-header{justify-content:center;align-items:center;gap:6px;margin-bottom:8px;display:flex}.report-card-icon{align-items:center;font-size:16px;line-height:1;display:inline-flex}.report-card-title{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px;font-size:13px;font-weight:600}.scoring-note{text-align:center;color:var(--color-text-secondary);margin:-4px 0 8px;font-size:12px}.monthly-insight-modal{max-width:480px;max-height:90vh;overflow-y:auto}.monthly-insight-title{color:var(--color-text);font-size:20px;font-weight:700}.monthly-insight-body{flex-direction:column;gap:12px;padding-top:8px;display:flex}.monthly-insight-card--score{background:var(--color-primary-10,#64b46414);border-radius:var(--radius-md);text-align:center;flex-direction:column;align-items:center;padding:20px;display:flex}.monthly-insight-stat{color:var(--color-primary);font-size:48px;font-weight:800;line-height:1}.monthly-insight-label{color:var(--color-text-secondary);margin-top:4px;font-size:13px}.monthly-insight-delta{border-radius:99px;margin-top:6px;padding:2px 8px;font-size:12px;font-weight:600}.monthly-insight-delta.positive{color:#22c55e;background:#22c55e1f}.monthly-insight-delta.negative{color:#ef4444;background:#ef44441f}.monthly-insight-grid{grid-template-columns:1fr 1fr;gap:10px;display:grid}.monthly-insight-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:2px;padding:14px 12px;display:flex}.monthly-insight-card-icon{margin-bottom:4px;font-size:18px;line-height:1}.monthly-insight-card-label{color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em;font-size:11px;font-weight:500}.monthly-insight-card-value{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:15px;font-weight:700;overflow:hidden}.monthly-insight-card-sub{color:var(--color-text-secondary);margin-top:1px;font-size:11px}.monthly-insight-footer{flex-direction:column;gap:8px;margin-top:4px;display:flex}.monthly-insight-btn-report{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;width:100%;padding:12px;font-size:14px;font-weight:600;transition:opacity .15s}.monthly-insight-btn-report:hover{opacity:.88}.monthly-insight-btn-close{width:100%;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:0 0;padding:10px;font-size:14px;transition:background .15s}.monthly-insight-btn-close:hover{background:var(--color-border)}.comeback-modal{text-align:center;max-width:420px;padding:32px 28px 28px}.comeback-hero{flex-direction:column;align-items:center;gap:4px;display:flex}.comeback-hero-emoji{margin-bottom:12px;font-size:48px;line-height:1}.comeback-headline{color:var(--color-text);margin:0;font-size:22px;font-weight:700}.comeback-subtitle{color:var(--color-text-secondary);margin:8px 0 28px;font-size:15px;line-height:1.5}.comeback-btn{background:var(--color-primary);color:#fff;cursor:pointer;border:none;border-radius:12px;width:100%;padding:14px;font-size:16px;font-weight:600;transition:opacity .15s}.comeback-btn:hover{opacity:.88}@media(max-width:480px){.comeback-modal{padding:24px 20px 20px}.comeback-hero-emoji{font-size:40px}.comeback-headline{font-size:20px}}.reportview-header-actions{flex-shrink:0;align-items:center;gap:8px;display:flex}.btn-share{border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:0 0;padding:6px 10px;font-size:16px;line-height:1;transition:background .15s}.btn-share:hover{background:var(--color-surface-hover)}.share-card-modal{flex-direction:column;gap:16px;max-width:420px;display:flex}.share-card-title{color:var(--color-text);margin:0;font-size:18px;font-weight:700}.share-card-preview{aspect-ratio:1;background:var(--color-surface);border:1px solid var(--color-border);border-radius:12px;justify-content:center;align-items:center;width:100%;display:flex;overflow:hidden}.share-card-generating{color:var(--color-text-secondary);font-size:14px}.share-card-empty{text-align:center;color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;font-size:14px;line-height:1.5;display:flex}.share-card-img{object-fit:cover;border-radius:12px;width:100%;height:100%}.share-card-error{color:var(--color-danger);text-align:center;padding:0 8px;font-size:13px}.share-card-actions{gap:10px;display:flex}.share-card-btn{cursor:pointer;border:none;border-radius:10px;flex:1;padding:12px;font-size:14px;font-weight:600;transition:opacity .15s}.share-card-btn:disabled{opacity:.4;cursor:not-allowed}.share-card-btn--primary{background:var(--color-primary);color:#fff}.share-card-btn--secondary{color:var(--color-text);border:1px solid var(--color-border);background:0 0}.share-card-btn:hover:not(:disabled){opacity:.85}.scoring-info-modal{max-width:560px;max-height:80vh;overflow-y:auto}.scoring-info-body{flex-direction:column;gap:20px;padding-top:4px;display:flex}.scoring-info-section h3{color:var(--color-text);margin-bottom:8px;font-size:14px;font-weight:600}.scoring-info-section p{color:var(--color-text-secondary,#888);margin-bottom:6px;font-size:13px;line-height:1.5}.scoring-formula-box{background:var(--color-surface,#1a1a1a);border:1px solid var(--color-border);color:var(--color-primary);border-radius:8px;margin:8px 0;padding:10px 14px;font-family:monospace;font-size:13px}.scoring-weight-grid{flex-direction:column;gap:6px;margin:8px 0;display:flex}.scoring-weight-row{align-items:center;gap:10px;font-size:13px;display:flex}.scoring-weight-stars{min-width:60px;font-size:12px}.scoring-timeframe-table{border-collapse:collapse;width:100%;margin:8px 0;font-size:13px}.scoring-timeframe-table th{text-align:left;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary,#888);padding:6px 8px;font-size:12px}.scoring-timeframe-table td{border-bottom:1px solid var(--color-border);color:var(--color-text);padding:6px 8px}.scoring-info-note{opacity:.8;font-style:italic;font-size:12px!important}.scoring-info-list{flex-direction:column;gap:8px;margin:8px 0;padding:0;list-style:none;display:flex}.scoring-info-list li{color:var(--color-text-secondary,#888);border-left:2px solid var(--color-border);padding-left:12px;font-size:13px;line-height:1.5}.scoring-examples-grid{border:1px solid var(--color-border);border-radius:8px;flex-direction:column;gap:6px;margin-top:10px;display:flex;overflow:hidden}.scoring-example-row{border-bottom:1px solid var(--color-border);align-items:center;gap:10px;padding:7px 12px;font-size:13px;display:flex}.scoring-example-row:last-child{border-bottom:none}.scoring-example-row span:first-child{color:var(--color-text-secondary,#888);flex:1}.scoring-example-row strong{text-align:right;min-width:44px;color:var(--color-primary)}.scoring-example-calc{color:var(--color-text-secondary,#888);opacity:.7;min-width:60px;font-size:11px}.report-card-info{border:1px solid var(--color-text-secondary);width:13px;height:13px;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;opacity:.55;z-index:1;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:9px;font-style:italic;font-weight:700;transition:opacity .15s;display:flex;position:absolute;bottom:6px;right:6px}.report-card-info:hover{opacity:1}.report-card-tooltip{background:var(--color-text);color:var(--color-bg);text-transform:none;letter-spacing:0;z-index:100;pointer-events:none;border-radius:6px;padding:8px 10px;font-size:11px;font-style:normal;font-weight:400;line-height:1.5;position:absolute;bottom:28px;left:4px;right:4px;box-shadow:0 4px 12px #0003}.tf-card-info{border:1px solid var(--color-text-secondary);width:11px;height:11px;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;opacity:.5;z-index:1;background:0 0;border-radius:50%;justify-content:center;align-items:center;font-size:8px;font-style:italic;font-weight:700;transition:opacity .15s;display:flex;position:absolute;bottom:5px;right:5px}.tf-card-info:hover{opacity:1}.tf-card-tooltip{background:var(--color-text);color:var(--color-bg);text-transform:none;letter-spacing:0;z-index:100;pointer-events:none;border-radius:5px;padding:6px 8px;font-size:10px;font-style:normal;font-weight:400;line-height:1.4;position:absolute;bottom:22px;left:2px;right:2px;box-shadow:0 4px 12px #0003}.view-title-group{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.view-title-group h2{margin:0}.view-subtitle{color:var(--color-text-secondary);margin:0;font-size:12px;line-height:1.4}.report-card-percent{margin-bottom:10px;font-size:32px;font-weight:700;line-height:1}.report-card-bar{background:var(--color-bg);border-radius:3px;height:6px;margin-bottom:8px;overflow:hidden}.report-card-bar-fill{border-radius:3px;height:100%;transition:width .5s}.report-card-subtitle{color:var(--color-text-secondary);font-size:11px}@media(max-width:480px){.report-cards-container{grid-template-columns:1fr;gap:8px}.report-card{text-align:left;align-items:center;gap:16px;padding:12px 16px;display:flex}.report-card-header{flex-direction:column;min-width:70px;margin-bottom:0}.report-card-percent{min-width:70px;margin-bottom:0;font-size:28px}.report-card-bar{flex:1;margin-bottom:0}.report-card-subtitle{text-align:right;min-width:80px}}.report-cards-wrapper{flex-direction:column;gap:10px;margin-bottom:20px;display:flex}.report-cards-wrapper .report-cards-container{margin-bottom:0}.tf-card{border-radius:var(--radius-sm);background:var(--color-bg);flex-direction:column;flex:1;align-items:center;gap:3px;padding:8px 4px;display:flex;position:relative}.tf-card-icon{align-items:center;font-size:14px;line-height:1;display:inline-flex}.tf-card-label{color:var(--color-text-secondary);font-size:11px;font-weight:500}.tf-card-percent{margin-top:2px;font-size:20px;font-weight:700;line-height:1.1}.tf-card-bar{background:var(--color-border);border-radius:2px;width:100%;height:4px;overflow:hidden}.tf-card-bar-fill{border-radius:2px;height:100%}.tf-card-count{color:var(--color-text-secondary);font-size:10px}.reportview-overlay{touch-action:none;z-index:1000;padding:max(env(safe-area-inset-top),16px) 16px 16px;background:#0009;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}@media(max-width:600px){.reportview-overlay{padding-bottom:max(env(safe-area-inset-bottom),16px);align-items:flex-start}}.reportview-modal{background:var(--color-card);border-radius:var(--radius-lg);overscroll-behavior:contain;-webkit-overflow-scrolling:touch;width:100%;max-width:500px;max-height:90vh;box-shadow:var(--shadow-md);overflow-y:auto}.reportview-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:flex-start;gap:8px;padding:16px 56px 16px 16px;display:flex;position:relative}.reportview-header h2{margin:0;font-size:18px;font-weight:700}.reportview-header-actions{align-items:center;gap:6px;display:flex;position:absolute;top:12px;right:12px}.reportview-header .btn-close{background:var(--color-border);border-radius:var(--radius-md);cursor:pointer;width:32px;height:32px;color:var(--color-text);border:none;flex-shrink:0;font-size:20px}.reportview-header .btn-close:hover{background:var(--color-text-secondary);color:var(--color-card)}.reportview-tabs{border-bottom:1px solid var(--color-border);gap:8px;padding:12px 16px;display:flex}.reportview-tab{background:var(--color-border);border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);border:none;flex:1;padding:6px 0;font-size:13px;font-weight:500;transition:background .15s,color .15s}.reportview-tab:hover{color:var(--color-text)}.reportview-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.reportview-selectors{border-bottom:1px solid var(--color-border);gap:8px;padding:12px 16px;display:flex}.reportview-select{border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-card);color:var(--color-text);cursor:pointer;flex:1;padding:6px 12px;font-size:13px}.reportview-select:focus{border-color:var(--color-primary);outline:none}.reportview-progress{border-bottom:1px solid var(--color-border);align-items:center;gap:16px;padding:20px 16px;display:flex}.reportview-progress-circle{text-align:center;min-width:100px;font-size:2.5rem;font-weight:700}.reportview-progress-info{flex:1}.reportview-progress-title{color:var(--color-text);font-size:1.1rem;font-weight:600}.reportview-progress-subtitle{color:var(--color-text-secondary);margin-top:4px;font-size:.85rem}.reportview-breakdown{padding:16px}.reportview-breakdown h3{color:var(--color-text);margin-bottom:12px;font-size:.9rem;font-weight:600}.reportview-weekday-headers{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:8px;display:grid}.reportview-weekday{text-align:center;color:var(--color-text-secondary);text-transform:uppercase;font-size:.7rem;font-weight:600}.reportview-days{flex-direction:column;gap:6px;display:flex}.reportview-days.week-view{grid-template-columns:repeat(7,1fr);gap:4px;display:grid}.reportview-day{background:var(--color-bg);border-radius:var(--radius-sm);padding:8px;position:relative;overflow:hidden}.reportview-days.month-view .reportview-day{align-items:center;gap:8px;display:flex}.reportview-days.week-view .reportview-day{flex-direction:column;align-items:center;min-height:60px;padding:6px 4px;display:flex}.reportview-day.future{opacity:.4}.reportview-day.clickable{cursor:pointer;transition:background .15s}.reportview-day.clickable:hover{background:var(--color-border)}.reportview-day-num{color:var(--color-text);text-align:center;min-width:24px;font-size:.8rem;font-weight:600}.reportview-days.week-view .reportview-day-num{font-size:.9rem}.reportview-day-bar{border-radius:3px;height:6px;transition:width .3s}.reportview-days.month-view .reportview-day-bar{flex:1}.reportview-days.week-view .reportview-day-bar{height:4px;margin-top:4px;width:100%!important}.reportview-day-percent{color:var(--color-text-secondary);text-align:center;min-width:35px;font-size:.75rem}.reportview-days.week-view .reportview-day-percent{margin-top:2px;font-size:.7rem}@media(max-width:400px){.reportview-modal{border-radius:0;max-width:100%;max-height:100vh}.reportview-progress-circle{min-width:80px;font-size:2rem}}.login-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.login-card{background:var(--color-card);border-radius:var(--radius-lg);text-align:center;width:100%;max-width:400px;box-shadow:var(--shadow-md);padding:48px 32px}.login-header{justify-content:center;margin-bottom:24px;display:flex}.login-logo{object-fit:contain;width:auto;height:128px}.login-title{color:var(--color-primary);margin:0 0 8px;font-size:2.5rem;font-weight:700}.login-tagline{color:var(--color-text-secondary);margin:0;font-size:1rem}.login-description{margin-bottom:32px}.login-description p{color:var(--color-text);text-wrap:balance;margin:0 0 8px;font-size:1.1rem;line-height:1.6}.login-actions{justify-content:center;margin-bottom:32px;display:flex}.login-button{color:var(--color-text);background:var(--color-card);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;white-space:nowrap;justify-content:center;align-items:center;gap:10px;min-width:220px;padding:12px 28px;font-size:15px;font-weight:500;transition:box-shadow .2s,border-color .2s,transform .15s;display:flex;box-shadow:0 1px 4px #00000014}.login-button:hover{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary),0 2px 8px #0000001a}@supports (color:color-mix(in lab,red,red)){.login-button:hover{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent),0 2px 8px #0000001a}}.login-button:active{transform:scale(.97)}.login-button--loading{opacity:.65;cursor:wait}.login-button-icon{flex-shrink:0}.login-footer{border-top:1px solid var(--color-border);padding-top:24px}.login-footer p{color:var(--color-text-secondary);margin:0;font-size:.85rem}.login-alpha-note{opacity:.6;margin-top:8px!important;font-size:.75rem!important}.login-loading{font-size:1rem;font-family:var(--font-sans,system-ui, -apple-system, sans-serif);color:var(--color-text-secondary);text-align:center;width:100%;padding:48px 0}@media(max-width:480px){.login-card{padding:32px 24px}.login-title{font-size:2rem}.login-description p{font-size:1rem}}button[data-slot=button][data-variant=default]{background-color:var(--color-primary);color:#fff}button[data-slot=button][data-variant=default]:hover:not(:disabled){background-color:var(--color-primary-dark)}button[data-slot=button][data-variant=outline]{background-color:var(--color-card);color:var(--color-text);border:1px solid var(--color-border)}button[data-slot=button][data-variant=outline]:hover:not(:disabled){background-color:var(--color-bg)}button[data-slot=button][data-variant=ghost]{color:var(--color-text);background-color:#0000}button[data-slot=button][data-variant=ghost]:hover:not(:disabled){background-color:var(--color-bg)}button[data-slot=button][data-variant=destructive]{background-color:var(--color-danger);color:#fff}button[data-slot=button][data-variant=destructive]:hover:not(:disabled){background-color:#dc2626}.pwa-banner{box-sizing:border-box;background:var(--color-primary,#4caf50);align-items:flex-start;gap:12px;width:100%;max-width:100%;padding:12px 40px 12px 16px;display:flex;position:relative}@supports (color:color-mix(in lab,red,red)){.pwa-banner{background:color-mix(in srgb,var(--color-primary,#4caf50) 10%,var(--color-card,#fff))}}.pwa-banner{border:1px solid var(--color-primary,#4caf50)}@supports (color:color-mix(in lab,red,red)){.pwa-banner{border:1px solid color-mix(in srgb,var(--color-primary,#4caf50) 30%,transparent)}}.pwa-banner{border-radius:var(--radius-md,8px);margin-bottom:12px;overflow:hidden}.pwa-banner-content{flex:1;align-items:flex-start;gap:10px;display:flex}.pwa-banner-icon{flex-shrink:0;margin-top:1px;font-size:22px}.pwa-banner-text{color:var(--color-text,#1a1a1a);flex-direction:column;gap:6px;font-size:13px;display:flex}.pwa-banner-text strong{font-size:14px}.pwa-steps{color:var(--color-text,#1a1a1a);flex-direction:column;gap:3px;margin:0;padding-left:16px;display:flex}.pwa-steps li{line-height:1.5}.pwa-step-icon{font-style:normal}.pwa-banner-actions{flex-direction:column;flex-shrink:0;gap:6px;display:flex}.pwa-banner-install{background:var(--color-primary,#4caf50);color:#fff;border-radius:var(--radius-sm,4px);cursor:pointer;white-space:nowrap;border:none;padding:6px 14px;font-size:13px;font-weight:600}.pwa-banner-install:hover{opacity:.9}.pwa-banner-close{width:24px;height:24px;color:var(--color-text-secondary,#888);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;font-size:16px;line-height:1;display:flex;position:absolute;top:8px;right:8px}.pwa-banner-close:hover{background:var(--color-text,#1a1a1a)}@supports (color:color-mix(in lab,red,red)){.pwa-banner-close:hover{background:color-mix(in srgb,var(--color-text,#1a1a1a) 10%,transparent)}}.pwa-banner-dismiss{color:var(--color-text-secondary,#666);cursor:pointer;white-space:nowrap;text-align:right;background:0 0;border:none;padding:4px 8px;font-size:12px}.pwa-banner-dismiss:hover{text-decoration:underline}.pwa-banner--ios-nosafari{background:#fffbeb;border-top:1px solid #fcd34d}[data-theme=dark] .pwa-banner--ios-nosafari{background:#78350f20;border-top:1px solid #92400e}.dark .pwa-banner{background:var(--color-primary,#4caf50)}@supports (color:color-mix(in lab,red,red)){.dark .pwa-banner{background:color-mix(in srgb,var(--color-primary,#4caf50) 15%,var(--color-card))}}.pwa-push-overlay{z-index:9000;padding:0 0 env(safe-area-inset-bottom,0);background:#00000080;justify-content:center;align-items:flex-end;display:flex;position:fixed;inset:0}.pwa-push-sheet{background:var(--color-card,#fff);text-align:center;border-radius:20px 20px 0 0;width:100%;max-width:480px;padding:28px 24px 32px;animation:.3s slideUp}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.pwa-push-icon{margin-bottom:12px;font-size:40px}.pwa-push-title{color:var(--color-text,#1a1a1a);margin:0 0 10px;font-size:18px;font-weight:700}.pwa-push-body{color:var(--color-text-secondary,#666);margin:0 0 24px;font-size:14px;line-height:1.5}.pwa-push-actions{flex-direction:column;gap:10px;display:flex}.pwa-push-btn{cursor:pointer;border:none;border-radius:12px;width:100%;padding:14px;font-size:15px;font-weight:600;transition:opacity .15s}.pwa-push-btn:active{opacity:.8}.pwa-push-btn--primary{background:var(--color-primary,#6366f1);color:#fff}.pwa-push-btn--ghost{color:var(--color-text-secondary,#888);background:0 0;font-weight:400}[data-theme=dark] .pwa-push-sheet{background:var(--color-card)}.template-gallery-dialog{max-width:520px;max-height:85vh;overflow-y:auto}.template-packs-grid{flex-direction:column;gap:8px;margin:4px 0;display:flex}.template-pack-card{background:var(--color-card,#fff);border:1px solid var(--color-border,#e0e0e0);border-radius:var(--radius-md,8px);cursor:pointer;text-align:left;align-items:center;gap:12px;width:100%;padding:12px 14px;transition:border-color .15s,background .15s;display:flex}.template-pack-card:hover{border-color:var(--color-primary,#4caf50);background:var(--color-primary,#4caf50)}@supports (color:color-mix(in lab,red,red)){.template-pack-card:hover{background:color-mix(in srgb,var(--color-primary,#4caf50) 6%,transparent)}}.template-pack-emoji{flex-shrink:0;font-size:28px;line-height:1}.template-pack-info{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.template-pack-name{color:var(--color-text,#1a1a1a);font-size:14px;font-weight:600}.template-pack-desc{color:var(--color-text-secondary,#666);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.template-pack-habits-count{color:var(--color-primary,#4caf50);font-size:11px;font-weight:500}.template-pack-arrow{color:var(--color-text-secondary,#666);flex-shrink:0;font-size:20px}.template-divider{color:var(--color-text-secondary,#666);align-items:center;gap:10px;margin:4px 0;font-size:12px;display:flex}.template-divider:before,.template-divider:after{content:"";background:var(--color-border,#e0e0e0);flex:1;height:1px}.template-blank-btn{width:100%}.template-habits-preview{flex-direction:column;gap:8px;margin:4px 0;display:flex}.template-habits-preview-label{color:var(--color-text-secondary,#666);margin-bottom:4px;font-size:13px}.template-habit-row{background:var(--color-bg,#f5f5f5);border-radius:var(--radius-md,8px);align-items:center;gap:12px;padding:10px 12px;display:flex}.template-habit-emoji{flex-shrink:0;font-size:22px}.template-habit-details{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.template-habit-name{color:var(--color-text,#1a1a1a);font-size:14px;font-weight:500}.template-habit-meta{color:var(--color-text-secondary,#666);font-size:12px}.template-habit-weight{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:3px;display:flex}.template-weight-dots{gap:3px;display:flex}.template-weight-dot{border-radius:50%;width:7px;height:7px;display:inline-block}.template-habit-weight-label{color:var(--color-text-secondary,#666);font-size:10px}.template-habits-note{color:var(--color-text-secondary,#666);margin-top:4px;font-size:12px;font-style:italic}.template-confirm-footer{justify-content:space-between!important}.dark .template-pack-card{background:var(--color-card);border-color:var(--color-border)}.dark .template-habit-row{background:var(--color-bg)}.onboarding-modal{max-width:480px;max-height:90vh;overflow-y:auto;gap:0!important;padding:0!important}.onboarding-header{border-bottom:1px solid var(--color-border);flex-direction:column;align-items:center;gap:4px;padding:20px 24px 12px;display:flex}.onboarding-step-indicator{color:var(--color-text-secondary);letter-spacing:.5px;font-size:12px;font-weight:500}.onboarding-step-title{color:var(--color-text);margin:0;font-size:18px;font-weight:700}.onboarding-step-content{min-height:260px;padding:20px 24px}@keyframes onboarding-slide-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.onboarding-slide-in{animation:.25s ease-out onboarding-slide-in}.onboarding-step-body{flex-direction:column;gap:16px;display:flex}.onboarding-hero-emoji{text-align:center;margin-bottom:4px;font-size:48px}.onboarding-headline{color:var(--color-text);text-align:center;margin:0;font-size:20px;font-weight:700;line-height:1.3}.onboarding-text{color:var(--color-text);margin:0;font-size:14px;line-height:1.6}.onboarding-text strong{color:var(--color-primary)}.onboarding-text--secondary{color:var(--color-text-secondary);font-size:13px;font-style:italic}.onboarding-footer{border-top:1px solid var(--color-border);justify-content:space-between;align-items:center;padding:14px 24px;display:flex}.onboarding-btn-back{color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;background:0 0;padding:8px 16px;font-size:14px;transition:background .15s,opacity .15s}.onboarding-btn-back:hover:not(:disabled){background:var(--color-border)}.onboarding-btn-back:disabled{opacity:.35;cursor:not-allowed}.onboarding-btn-next{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;padding:8px 20px;font-size:14px;font-weight:600;transition:opacity .15s}.onboarding-btn-next:hover:not(:disabled){opacity:.88}.onboarding-btn-next:disabled{opacity:.35;cursor:not-allowed}.onboarding-weight-compare{flex-direction:column;gap:12px;display:flex}.onboarding-weight-item{flex-direction:column;gap:6px;display:flex}.onboarding-weight-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:6px;padding:12px;display:flex}.onboarding-weight-card-header{align-items:center;gap:8px;display:flex}.onboarding-weight-card-emoji{font-size:24px}.onboarding-weight-card-name{color:var(--color-text);font-size:15px;font-weight:600}.onboarding-weight-card-detail{color:var(--color-text-secondary);justify-content:space-between;font-size:12px;display:flex}.onboarding-weight-bar-container{background:var(--color-border);border-radius:4px;height:8px;overflow:hidden}.onboarding-weight-bar{border-radius:4px;height:100%;transition:width .5s ease-out}.onboarding-weight-impact{color:var(--color-text);text-align:right;font-size:13px;font-weight:600}.onboarding-demo-cards{flex-direction:column;gap:10px;display:flex}.onboarding-demo-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);border-left:4px solid;flex-direction:column;gap:8px;padding:12px;display:flex}.onboarding-demo-card-top{align-items:center;gap:10px;display:flex}.onboarding-demo-card-emoji{flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:28px;display:flex}.onboarding-demo-card-info{flex-direction:column;flex:1;min-width:0;display:flex}.onboarding-demo-card-name{color:var(--color-text);font-size:15px;font-weight:600}.onboarding-demo-card-meta{color:var(--color-text-secondary);font-size:12px}.onboarding-demo-card-progress{align-items:center;gap:8px;display:flex}.onboarding-demo-card-bar-container{background:var(--color-border);border-radius:3px;flex:1;height:6px;overflow:hidden}.onboarding-demo-card-bar{border-radius:3px;height:100%;transition:width .4s ease-out}.onboarding-demo-card-pct{color:var(--color-text);text-align:right;min-width:36px;font-size:13px;font-weight:600}.onboarding-demo-card-sub{color:var(--color-text-secondary);font-size:11px}.onboarding-demo-card{position:relative;overflow:hidden}.onboarding-demo-fill{opacity:.12;pointer-events:none;height:100%;transition:width .4s ease-out;position:absolute;top:0;left:0}.onboarding-demo-card-top{z-index:1;position:relative}.onboarding-demo-stepper{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);border-radius:20px;flex-shrink:0;align-items:center;gap:6px;padding:4px 10px;font-size:13px;font-weight:600;display:flex}.onboarding-demo-stepper-val{text-align:center;min-width:40px}.onboarding-demo-stepper--tappable{cursor:pointer;border:none;transition:opacity .15s}.onboarding-demo-stepper--tappable:hover{opacity:.75}.onboarding-demo-check{flex-shrink:0;font-size:18px;font-weight:700}.onboarding-demo-card--swipeable{cursor:grab}.onboarding-demo-card--swipeable:active{cursor:grabbing}.onboarding-swipe-hint{z-index:1;text-align:right;color:var(--color-text-secondary);opacity:.7;padding-top:4px;font-size:12px;position:relative}.onboarding-quick-input{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);flex-direction:column;gap:8px;margin-top:8px;padding:12px;display:flex}.onboarding-quick-input-label{color:var(--color-text);font-size:13px;font-weight:600}.onboarding-quick-input-row{align-items:center;gap:8px;display:flex}.onboarding-quick-input-field{text-align:center;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);width:72px;color:var(--color-text);padding:6px 10px;font-size:16px;font-weight:600}.onboarding-quick-input-unit{color:var(--color-text-secondary);flex:1;font-size:13px}.onboarding-quick-input-confirm{border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;cursor:pointer;border:none;padding:6px 16px;font-size:14px;font-weight:600}.onboarding-demo-check{border:2px solid var(--color-border);cursor:pointer;width:36px;height:36px;color:var(--color-text-secondary);background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:18px;transition:all .2s;display:flex}.onboarding-demo-check:hover{border-color:var(--color-primary);color:var(--color-primary)}.onboarding-demo-check--done{background:var(--color-success,#22c55e);border-color:var(--color-success,#22c55e);color:#fff}.onboarding-demo-check--done:hover{opacity:.85;border-color:var(--color-success,#22c55e);color:#fff}.onboarding-views-list{flex-direction:column;gap:10px;display:flex}.onboarding-view-card{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:flex-start;gap:12px;padding:12px;display:flex}.onboarding-view-icon{flex-shrink:0;margin-top:2px;font-size:24px}.onboarding-view-icon--svg{font-size:inherit;width:28px;height:28px;color:var(--color-text-secondary);justify-content:center;align-items:center;display:flex}.onboarding-view-info{flex-direction:column;gap:2px;display:flex}.onboarding-view-name{color:var(--color-text);font-size:14px;font-weight:600}.onboarding-view-desc{color:var(--color-text-secondary);font-size:13px;line-height:1.4}.onboarding-score-bands{flex-direction:column;gap:10px;display:flex}.onboarding-score-band{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:12px;padding:12px;display:flex}.onboarding-score-band-emoji{flex-shrink:0;font-size:22px}.onboarding-score-band-info{flex-direction:column;min-width:80px;display:flex}.onboarding-score-band-range{color:var(--color-text);font-size:14px;font-weight:700}.onboarding-score-band-label{color:var(--color-text-secondary);font-size:12px;font-weight:600}.onboarding-score-band-desc{color:var(--color-text-secondary);flex:1;font-size:13px}.onboarding-info-box{background:var(--color-primary)18;border:1px solid var(--color-primary)40;border-radius:var(--radius-md);align-items:flex-start;gap:10px;padding:12px;display:flex}.onboarding-info-box-icon{flex-shrink:0;margin-top:1px;font-size:20px}.onboarding-info-box-text{color:var(--color-text);margin:0;font-size:13px;line-height:1.5}.onboarding-info-box-text strong{color:var(--color-primary)}.onboarding-checkin-section{flex-direction:column;gap:8px;display:flex}.onboarding-demo-slider{cursor:pointer;width:100%;height:6px;accent-color:var(--demo-slider-color,var(--color-primary));margin-top:10px}.onboarding-done-label{color:var(--color-success,#22c55e);white-space:nowrap;flex-shrink:0;font-size:13px;font-weight:700}.onboarding-demo-counter{align-items:center;gap:12px;margin-top:10px;display:flex}.onboarding-demo-counter-value{text-align:center;color:var(--color-text);flex:1;font-size:14px;font-weight:600}.onboarding-demo-counter-btn{border-radius:var(--radius-md);cursor:pointer;border:none;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:20px;font-weight:700;transition:opacity .15s;display:flex}.onboarding-demo-counter-btn:disabled{opacity:.35;cursor:not-allowed}.onboarding-demo-counter-btn--plus{background:var(--color-primary);color:#fff}.onboarding-demo-counter-btn--minus{color:#fff;background:#ef4444}.onboarding-demo-counter-btn:not(:disabled):hover{opacity:.85}.onboarding-demo-counter--standalone{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px}.onboarding-form-wrapper{margin-top:4px}.onboarding-skip-overlay{border-radius:inherit;z-index:10;background:#00000080;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.onboarding-skip-dialog{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);text-align:center;max-width:300px;padding:24px}.onboarding-skip-dialog p{color:var(--color-text);margin:0 0 4px;font-size:15px;font-weight:600}.onboarding-skip-sub{color:var(--color-text-secondary)!important;margin-bottom:16px!important;font-size:13px!important;font-weight:400!important}.onboarding-skip-actions{justify-content:center;gap:8px;display:flex}.onboarding-btn-skip{background:var(--color-danger);color:#fff;border-radius:var(--radius-md);cursor:pointer;border:none;padding:8px 16px;font-size:14px;font-weight:600;transition:opacity .15s}.onboarding-btn-skip:hover{opacity:.88}@media(max-width:480px){.onboarding-modal{max-width:calc(100% - 1rem)}.onboarding-step-content{padding:16px}.onboarding-header{padding:16px 16px 10px}.onboarding-footer{padding:12px 16px}}.bottom-nav{background:var(--color-card);border-top:1px solid var(--color-border);z-index:100;padding-bottom:env(safe-area-inset-bottom,0);align-items:flex-start;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -1px 8px #0000000f}.bottom-nav-tab{color:var(--color-text-secondary);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;border:none;outline:none;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:3px;min-height:56px;padding:10px 4px;font-size:10px;font-weight:500;line-height:1;transition:color .15s;display:flex}.bottom-nav-tab.active{color:var(--color-primary)}.bottom-nav-tab:active{opacity:.7}.bottom-nav-icon{justify-content:center;align-items:center;line-height:1;display:flex}.bottom-nav-label{letter-spacing:.01em;font-size:10px;font-weight:500}body{padding-bottom:calc(56px + env(safe-area-inset-bottom,0px))}.fab-add{bottom:calc(80px + env(safe-area-inset-bottom,0px));background:var(--color-primary);color:#fff;cursor:pointer;z-index:99;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;transition:background .2s,transform .15s,box-shadow .2s;display:flex;position:fixed;right:16px;box-shadow:0 4px 12px #3b5bdb66}.fab-add:hover{background:var(--color-primary-dark);transform:scale(1.06);box-shadow:0 6px 16px #3b5bdb80}.fab-add:active{transform:scale(.96)}.fab-add--hidden{display:none}.app-header-brand{align-items:center;gap:10px;display:flex}.app-header-brand h1{margin-bottom:0}.app-logo-extended{object-fit:contain;width:auto;height:68px}.app-logo--dark{display:none}.app-logo--light,.dark .app-logo--dark{display:block}.dark .app-logo--light{display:none}.today-date-btn-inline{height:auto!important;color:var(--color-text-secondary)!important;background:var(--color-bg)!important;border:1px solid var(--color-border)!important;border-radius:var(--radius-md)!important;align-items:center!important;gap:5px!important;padding:4px 10px!important;font-size:13px!important;font-weight:500!important;transition:background .15s,border-color .15s!important;display:inline-flex!important}.today-date-btn-inline:hover{background:var(--color-border)!important;border-color:var(--color-primary)!important;color:var(--color-text)!important}.calendar-icon{font-size:13px;line-height:1}.habit-card-content{gap:8px!important;padding:8px 104px 8px 12px!important}.habit-emoji-box{border-radius:10px!important;width:38px!important;height:38px!important;font-size:20px!important}.habit-card{box-shadow:var(--shadow-sm)!important;border-left-width:4px!important}.habit-card:hover{box-shadow:var(--shadow-md)!important}.btn-complete-max,.btn-increment,.btn-decrement{border-radius:12px!important;width:40px!important;height:40px!important}.habit-list{gap:10px!important}.habit-right-col{min-width:84px;z-index:2!important;flex-direction:column!important;align-items:stretch!important;gap:3px!important;display:flex!important;position:absolute!important;top:50%!important;right:12px!important;transform:translateY(-50%)!important}.habit-streak--chip{white-space:nowrap;border-radius:9px;justify-content:center;align-items:center;height:18px;padding:0 8px;font-size:10px;display:flex;position:static!important}.habit-streak--chip.habit-streak--base{background:linear-gradient(#f9731633,#f9731633),var(--color-card)}.habit-streak--chip.habit-streak--warm{background:linear-gradient(#ea580c38,#ea580c38),var(--color-card)}.habit-streak--chip.habit-streak--hot{background:linear-gradient(#d9770640,#d9770640),var(--color-card)}.habit-streak--chip.habit-streak--legendary{background:linear-gradient(#b4530940,#b4530940),var(--color-card)}.habit-stepper{height:28px!important}.habit-stepper-btn{width:24px!important;font-size:14px!important}.habit-right-col .habit-stepper-val{flex:1}.habit-category-badge--footer{align-items:center;max-width:calc(100% - 80px);height:22px;margin-top:0;border-radius:11px!important;padding:0 10px!important;display:inline-flex!important}.habit-atrisk-chip--inline{color:#b45309;white-space:nowrap;background:#fef3c7;border-radius:4px;align-items:center;padding:1px 5px;font-size:10px;font-weight:600;margin:0!important;display:inline-flex!important}[data-theme=dark] .habit-atrisk-chip--inline{color:#fcd34d;background:#78350f40}.habit-atrisk-chip--bottom{color:#b45309;white-space:nowrap;background:#fef3c7;border-radius:9px;justify-content:center;align-items:center;height:18px;padding:0 8px;font-size:10px;font-weight:600;display:flex;margin:0!important;position:static!important}[data-theme=dark] .habit-atrisk-chip--bottom{color:#fcd34d;background:#78350f40}@media(max-width:480px){.btn-increment,.btn-decrement,.btn-check,.btn-edit,.btn-delete,.btn-complete-max{border-radius:8px!important;width:28px!important;height:28px!important;font-size:14px!important}}.report-ring-wrapper{justify-content:center;align-items:center;width:88px;height:88px;margin:8px auto;display:flex;position:relative}.report-ring-percent{letter-spacing:-.5px;font-size:17px;font-weight:700;line-height:1;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}.three-rings-card{justify-content:space-evenly;align-items:flex-start;margin-bottom:12px;padding:16px 0 8px;display:flex}.three-rings-item{flex-direction:column;flex:1;align-items:center;gap:6px;display:flex;position:relative}.three-rings-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted-foreground);font-size:12px;font-weight:600}.three-rings-sub{color:var(--color-muted-foreground);text-align:center;font-size:11px}.three-rings-ring-row{justify-content:center;align-items:center;display:flex;position:relative}.three-rings-info{background:var(--color-border);width:16px;height:16px;color:var(--color-text-secondary);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-size:10px;font-style:italic;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.three-rings-tooltip{z-index:200;background:var(--color-card);border:1px solid var(--color-border);color:var(--color-text);border-radius:8px;min-width:280px;max-width:300px;padding:8px 10px;font-size:12px;line-height:1.5;position:absolute;top:90px;box-shadow:0 4px 12px #00000026}.three-rings-tooltip--left{left:0}.three-rings-tooltip--center{left:50%;transform:translate(-50%)}.three-rings-tooltip--right{right:0}.report-analytics-nav{flex-direction:column;gap:10px;padding:0 16px;display:flex}.report-analytics-btn{border:1px solid var(--color-border);border-radius:var(--radius-lg,14px);background:var(--color-card);cursor:pointer;text-align:left;align-items:center;gap:14px;padding:16px;transition:background .15s,box-shadow .15s;display:flex}.report-analytics-btn:hover{background:var(--color-hover);box-shadow:var(--shadow-sm,0 1px 3px #0000000f)}.report-analytics-btn:active{transform:scale(.98)}.report-analytics-btn-icon{background:var(--color-bg);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;font-size:28px;display:flex}.report-analytics-btn-text{flex-direction:column;gap:2px;display:flex}.report-analytics-btn-text strong{color:var(--color-text);font-size:15px;font-weight:600}.report-analytics-btn-text small{color:var(--color-muted);font-size:13px}.report-subtab-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;margin-top:8px;margin-bottom:0;padding:8px 16px;display:flex}.report-subtabs{background:var(--color-bg);border-radius:9px;gap:2px;padding:2px;display:flex}.report-subtab{color:var(--color-muted-foreground);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:6px 14px;font-size:13px;font-weight:500;line-height:1.4;transition:color .2s,background .2s,box-shadow .2s}.report-subtab.active{color:var(--color-text);background:var(--color-card);font-weight:600;box-shadow:0 1px 3px #0000001f,0 1px 2px #00000014}.report-subtab:hover:not(.active){color:var(--color-text);background:#80808014}.report-subtab-actions{align-items:center;gap:6px;display:flex}.report-subtab-action-btn{cursor:pointer;width:30px;height:30px;color:var(--color-text-secondary);background:0 0;border:none;border-radius:6px;flex-shrink:0;justify-content:center;align-items:center;font-size:16px;transition:background .15s;display:flex}.report-subtab-action-btn:hover{background:var(--color-hover);color:var(--color-text)}.report-subtab-action-btn:active{transform:scale(.93)}.dayview-modal.dayview-embedded{width:100%;max-width:100%;height:auto;max-height:none;box-shadow:none;background:0 0;border-radius:0;padding-bottom:80px;position:relative;overflow:clip visible}.dayview-modal.dayview-embedded .dayview-header{position:relative}.dayview-tab-intro{padding:16px 16px 8px}.settings-embedded{width:100%;max-width:100%;height:auto;max-height:none;box-shadow:none;border-radius:0;position:relative}.reportview-modal.reportview-embedded{width:100%;max-width:100%;height:auto;max-height:none;box-shadow:none;background:0 0;border-radius:0;padding-bottom:100px;position:relative;overflow-y:visible}.corr-teaser{background:var(--color-primary);grid-template-rows:auto auto;grid-template-columns:1fr auto;align-items:center;gap:4px 8px;width:calc(100% - 32px);margin:0 16px 4px;padding:12px 16px;display:grid}@supports (color:color-mix(in lab,red,red)){.corr-teaser{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-card))}}.corr-teaser{border:1px solid var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.corr-teaser{border:1px solid color-mix(in srgb,var(--color-primary) 25%,transparent)}}.corr-teaser{border-radius:var(--radius-lg);cursor:pointer;text-align:left;transition:box-shadow .2s,border-color .2s}.corr-teaser:hover{border-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.corr-teaser:hover{border-color:color-mix(in srgb,var(--color-primary) 50%,transparent)}}.corr-teaser:hover{box-shadow:0 2px 8px var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.corr-teaser:hover{box-shadow:0 2px 8px color-mix(in srgb,var(--color-primary) 15%,transparent)}}.corr-teaser-label{color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:6px;font-size:12px;font-weight:600;display:flex}.corr-teaser-icon{line-height:1}.corr-teaser-pro{color:var(--color-accent);background:var(--color-accent);font-size:11px;font-weight:600}@supports (color:color-mix(in lab,red,red)){.corr-teaser-pro{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}}.corr-teaser-pro{border:1px solid var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.corr-teaser-pro{border:1px solid color-mix(in srgb,var(--color-accent) 30%,transparent)}}.corr-teaser-pro{white-space:nowrap;border-radius:20px;align-self:center;padding:1px 8px}.corr-teaser-text{color:var(--color-text);grid-column:1;font-size:13px;line-height:1.4}.corr-teaser-cta{color:var(--color-primary);white-space:nowrap;grid-area:2/2;align-self:end;font-size:12px;font-weight:500}.corr-section{background:var(--color-primary);margin:16px 0;padding:16px}@supports (color:color-mix(in lab,red,red)){.corr-section{background:color-mix(in srgb,var(--color-primary) 5%,var(--color-card))}}.corr-section{border:1px solid var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.corr-section{border:1px solid color-mix(in srgb,var(--color-primary) 20%,transparent)}}.corr-section{border-radius:var(--radius-lg)}.corr-header{align-items:center;gap:6px;margin-bottom:12px;display:flex}.corr-title-icon{align-items:center;font-size:16px;line-height:1;display:inline-flex}.corr-title{color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;flex:1;margin:0;font-size:14px;font-weight:700}.corr-pro-badge{color:var(--color-accent);background:var(--color-accent);font-size:11px;font-weight:600}@supports (color:color-mix(in lab,red,red)){.corr-pro-badge{background:color-mix(in srgb,var(--color-accent) 12%,transparent)}}.corr-pro-badge{border:1px solid var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.corr-pro-badge{border:1px solid color-mix(in srgb,var(--color-accent) 30%,transparent)}}.corr-pro-badge{border-radius:20px;padding:2px 8px}.corr-empty{color:var(--color-text-secondary);text-align:center;padding:12px 0;font-size:13px;font-style:italic}.corr-list{flex-direction:column;gap:10px;display:flex}.corr-card{background:var(--color-card);border:1px solid var(--color-border);border-left-width:3px;border-radius:10px;padding:12px 14px}.corr-card--positive{border-left-color:var(--color-success)}.corr-card--negative{border-left-color:#f59e0b}.corr-text{color:var(--color-text);margin:0;font-size:13px;line-height:1.5}.corr-text strong{color:var(--color-text);font-weight:600}.corr-highlight{font-size:14px;font-weight:700}.corr-highlight--positive{color:var(--color-success)}.corr-highlight--negative{color:#f59e0b}.corr-avg{color:var(--color-text-secondary);font-size:12px}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@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-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@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-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-ease{syntax:"*";inherits:false}@keyframes enter{0%{opacity:var(--tw-enter-opacity,1);transform:translate3d(var(--tw-enter-translate-x,0),var(--tw-enter-translate-y,0),0)scale3d(var(--tw-enter-scale,1),var(--tw-enter-scale,1),var(--tw-enter-scale,1))rotate(var(--tw-enter-rotate,0));filter:blur(var(--tw-enter-blur,0))}}@keyframes exit{to{opacity:var(--tw-exit-opacity,1);transform:translate3d(var(--tw-exit-translate-x,0),var(--tw-exit-translate-y,0),0)scale3d(var(--tw-exit-scale,1),var(--tw-exit-scale,1),var(--tw-exit-scale,1))rotate(var(--tw-exit-rotate,0));filter:blur(var(--tw-exit-blur,0))}}
