:root{color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}.toast-container{position:fixed;bottom:max(20px,calc(env(safe-area-inset-bottom) + 10px));right:20px;z-index:var(--z-toast);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: #facc15;border-left-width:5px;padding:14px 18px;font-size:var(--text-body-lg);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-enhanced{--toast-color: #3b5bdb;border-left-width:5px;padding:16px 20px;font-size:var(--text-body-lg);background:linear-gradient(135deg,var(--color-surface, #fff) 0%,#f0f4ff 100%);animation:toast-enhanced-enter .5s cubic-bezier(.34,1.56,.64,1)}@keyframes toast-enhanced-enter{0%{opacity:0;transform:translate(100%) scale(.85)}to{opacity:1;transform:translate(0) scale(1)}}[data-theme=dark] .toast-enhanced{background:linear-gradient(135deg,var(--color-surface, #1f2937) 0%,#1e293b 100%)}.toast-icon{font-size:var(--text-h1);flex-shrink:0;line-height:1}.toast-enhanced .toast-icon{font-size:26px}.toast-message{flex:1;font-size:var(--text-body);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:var(--text-body-sm);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:var(--text-section);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}}.sync-dead-letter-banner{display:flex;flex-direction:column;gap:12px;padding:12px 16px;background:var(--color-warning-bg, #fef3c7);border-bottom:1px solid var(--color-warning-border, #f59e0b);color:var(--color-warning-text, #78350f);font-size:var(--text-body);line-height:1.4}@media(min-width:640px){.sync-dead-letter-banner{flex-direction:row;align-items:center;justify-content:space-between}}.sync-dead-letter-banner__content{flex:1;min-width:0}.sync-dead-letter-banner__title{font-weight:600;margin-bottom:2px}.sync-dead-letter-banner__body{font-size:var(--text-body-sm);opacity:.85}.sync-dead-letter-banner__escalation{font-weight:500}.sync-dead-letter-banner__actions{display:flex;gap:8px;flex-shrink:0}.sync-dead-letter-banner__retry{padding:8px 14px;background:var(--color-primary, #3b5bdb);color:#fff;border:none;border-radius:6px;font-weight:600;font-size:var(--text-body-sm);cursor:pointer;transition:background .15s}.sync-dead-letter-banner__retry:hover:not(:disabled){background:var(--color-primary-dark, #3730a3)}.sync-dead-letter-banner__retry:disabled{opacity:.6;cursor:not-allowed}.sync-dead-letter-banner__dismiss{padding:8px 14px;background:transparent;color:inherit;border:1px solid currentColor;border-radius:6px;font-size:var(--text-body-sm);cursor:pointer;opacity:.75;transition:opacity .15s}.sync-dead-letter-banner__dismiss:hover{opacity:1}.dark .sync-dead-letter-banner{background:#f59e0b26;border-bottom-color:#f59e0b66;color:#fde68a}.landing-page{min-height:100vh;background:var(--color-bg);color:var(--color-text);font-family:var(--font-sans);overflow-x:hidden}.landing-container{max-width:1100px;margin:0 auto;padding:0 24px}.landing-nav{position:sticky;top:0;z-index:var(--z-fab);background:var(--color-bg);border-bottom:1px solid var(--color-border);padding:14px 0;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.landing-nav-inner{display:flex;align-items:center;justify-content:space-between;max-width:1100px;margin:0 auto;padding:0 24px}.landing-nav-sign-in{background:transparent;border:1.5px solid var(--color-border);color:var(--color-text);font-family:var(--font-sans);font-size:var(--text-body);font-weight:500;padding:8px 18px;border-radius:var(--radius-md);cursor:pointer;transition:border-color .15s,box-shadow .15s}.landing-nav-sign-in:hover{border-color:var(--color-primary);color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 12%,transparent)}.landing-nav-sign-in:disabled{opacity:.6;cursor:wait}.landing-hero{text-align:center;padding:80px 24px}.landing-logo-wrap{display:flex;justify-content:center;align-items:center}.landing-logo-wrap img{height:auto;max-width:100%}.landing-logo-nav img{height:54px}.landing-logo-hero{margin-bottom:40px}.landing-logo-hero img{height:180px}.landing-logo-footer img{height:42px;opacity:.7}.landing-hero-wordmark{font-size:.78rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--color-text-secondary);margin-top:-28px;margin-bottom:36px}.landing-hero-headline{font-size:clamp(1.55rem,4.2vw,2.65rem);font-weight:800;line-height:1.1;letter-spacing:-.02em;color:var(--color-text);max-width:800px;margin:0 auto 24px}.landing-hero-sub{font-size:clamp(1rem,2vw,1.2rem);color:var(--color-text-secondary);line-height:1.65;max-width:560px;margin:0 auto 40px}.landing-hero-cta{display:inline-flex;align-items:center;gap:8px;background:var(--color-primary);color:#fff;font-family:var(--font-sans);font-size:var(--text-base);font-weight:600;padding:14px 32px;border-radius:var(--radius-md);border:none;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;box-shadow:0 4px 14px color-mix(in srgb,var(--color-primary) 35%,transparent)}.landing-hero-cta:hover{background:var(--color-primary-dark);transform:translateY(-1px);box-shadow:0 6px 20px color-mix(in srgb,var(--color-primary) 40%,transparent)}.landing-hero-cta:active{transform:translateY(0)}.landing-hero-cta:disabled{opacity:.75;cursor:wait;transform:none}.landing-hero-trust{margin-top:20px;display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;color:var(--color-text-secondary);font-size:var(--text-body-sm)}.landing-hero-trust-dot{color:var(--color-border)}.landing-section{padding:80px 24px}.landing-section-title{font-size:clamp(1.5rem,4vw,2.2rem);font-weight:700;letter-spacing:-.015em;color:var(--color-text);margin:0 0 16px;text-align:center}.landing-section-sub{font-size:var(--text-base);color:var(--color-text-secondary);text-align:center;max-width:500px;margin:0 auto 56px;line-height:1.6}.landing-problem{background:var(--color-card);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.landing-problem-grid{display:grid;grid-template-columns:1fr;gap:16px;max-width:900px;margin:0 auto}.landing-problem-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:28px;display:flex;gap:16px;align-items:flex-start}.landing-problem-icon{font-size:var(--text-h1);flex-shrink:0;margin-top:2px}.landing-problem-title{font-size:var(--text-base);font-weight:700;color:var(--color-text);margin:0 0 6px}.landing-problem-desc{font-size:var(--text-body);color:var(--color-text-secondary);line-height:1.55;margin:0}.landing-how-steps{display:grid;grid-template-columns:1fr;gap:32px;max-width:900px;margin:0 auto}.landing-how-step{display:flex;gap:24px;align-items:flex-start}.landing-how-number{font-size:var(--text-hero-lg);font-weight:800;color:var(--color-primary);line-height:1;flex-shrink:0;width:56px;letter-spacing:-.03em;font-variant-numeric:tabular-nums}.landing-how-content{padding-top:4px}.landing-how-step-title{font-size:var(--text-section);font-weight:700;color:var(--color-text);margin:0 0 8px}.landing-how-step-desc{font-size:var(--text-body);color:var(--color-text-secondary);line-height:1.6;margin:0}.landing-how-step-weight{display:inline-flex;gap:4px;margin-top:10px}.landing-how-dot{width:10px;height:10px;border-radius:50%}.landing-how-dot--filled{background:var(--color-primary)}.landing-how-dot--empty{background:var(--color-border)}.landing-features-bg{background:var(--color-card);border-top:1px solid var(--color-border);border-bottom:1px solid var(--color-border)}.landing-features-grid{display:grid;grid-template-columns:1fr;gap:16px;max-width:900px;margin:0 auto}.landing-feature-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px}.landing-feature-icon{font-size:var(--text-h1-lg);margin-bottom:10px;display:block}.landing-feature-title{font-size:var(--text-body-lg);font-weight:700;color:var(--color-text);margin:0 0 6px;display:flex;align-items:center;gap:8px}.landing-feature-pro{font-size:var(--text-micro);font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--color-accent);background:color-mix(in srgb,var(--color-accent) 12%,transparent);padding:2px 7px;border-radius:999px}.landing-feature-desc{font-size:var(--text-body-sm);color:var(--color-text-secondary);line-height:1.55;margin:0}.landing-pricing-grid{display:grid;grid-template-columns:1fr;gap:20px;max-width:720px;margin:0 auto}.landing-pricing-card{background:var(--color-card);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:36px 32px}.landing-pricing-card--pro{border-color:var(--color-primary);position:relative;box-shadow:0 4px 24px color-mix(in srgb,var(--color-primary) 15%,transparent)}.landing-pricing-card--plus{border-color:var(--color-primary);position:relative;box-shadow:0 6px 32px color-mix(in srgb,var(--color-primary) 22%,transparent);transform:scale(1.02)}.landing-pricing-badge{position:absolute;top:-12px;left:50%;transform:translate(-50%);background:var(--color-primary);color:#fff;font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;padding:4px 14px;border-radius:999px;white-space:nowrap}.landing-pricing-badge--plus{background:var(--color-primary)}.landing-pricing-badge--pro{background:var(--color-accent, #facc15);color:#1c1c1a}.landing-pricing-plan{font-size:var(--text-body);font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary);margin-bottom:8px}.landing-pricing-price{font-size:2.6rem;font-weight:800;color:var(--color-text);letter-spacing:-.02em;line-height:1;margin-bottom:6px}.landing-pricing-price span{font-size:var(--text-base);font-weight:500;color:var(--color-text-secondary)}.landing-pricing-note{font-size:var(--text-body-sm);color:var(--color-text-secondary);margin-bottom:28px}.landing-pricing-list{list-style:none;padding:0;margin:0 0 28px;display:flex;flex-direction:column;gap:10px}.landing-pricing-list li{display:flex;align-items:center;gap:10px;font-size:var(--text-body);color:var(--color-text)}.landing-pricing-check{color:var(--color-success);font-size:var(--text-base);flex-shrink:0}.landing-pricing-cta{width:100%;padding:13px;border-radius:var(--radius-md);font-family:var(--font-sans);font-size:var(--text-body-lg);font-weight:600;cursor:pointer;transition:background .15s,transform .1s,box-shadow .15s;border:none}.landing-pricing-cta--free{background:transparent;border:1.5px solid var(--color-border);color:var(--color-text)}.landing-pricing-cta--free:hover{border-color:var(--color-primary);color:var(--color-primary)}.landing-pricing-cta--pro{background:var(--color-primary);color:#fff;box-shadow:0 4px 14px color-mix(in srgb,var(--color-primary) 30%,transparent)}.landing-pricing-cta--pro:hover{background:var(--color-primary-dark);transform:translateY(-1px)}.landing-pricing-cta:disabled{opacity:.7;cursor:wait;transform:none}.landing-waitlist{padding:64px 24px;text-align:center;background:var(--color-bg)}.landing-waitlist-inner{max-width:520px;margin:0 auto}.landing-waitlist-form{display:flex;gap:8px;margin-top:24px;justify-content:center}.landing-waitlist-input{flex:1;max-width:320px;padding:12px 16px;border:1.5px solid var(--color-border, #d1d5db);border-radius:var(--radius-md);font-size:var(--text-body-lg);font-family:var(--font-sans);background:var(--color-card, #fff);color:var(--color-text)}.landing-waitlist-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #3b5bdb26}.landing-waitlist-btn{padding:12px 24px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-body-lg);font-weight:600;font-family:var(--font-sans);cursor:pointer;white-space:nowrap}.landing-waitlist-btn:hover{background:var(--color-primary-dark)}.landing-waitlist-btn:disabled{opacity:.6;cursor:not-allowed}.landing-waitlist-success{margin-top:20px;color:var(--color-success);font-weight:600;font-size:var(--text-body-lg)}.landing-waitlist-error{margin-top:12px;color:#e53e3e;font-size:var(--text-body)}@media(max-width:480px){.landing-waitlist-form{flex-direction:column;align-items:center}.landing-waitlist-input{max-width:100%;width:100%}.landing-waitlist-btn{width:100%}}.landing-final-cta{background:var(--color-primary);padding:80px 24px;text-align:center}.landing-final-cta .landing-section-title{color:#fff}.landing-final-cta .landing-section-sub{color:#ffffffc7}.landing-final-cta-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;color:var(--color-primary);font-family:var(--font-sans);font-size:var(--text-base);font-weight:700;padding:14px 36px;border-radius:var(--radius-md);border:none;cursor:pointer;transition:transform .1s,box-shadow .15s;box-shadow:0 4px 20px #00000026}.landing-final-cta-btn:hover{transform:translateY(-2px);box-shadow:0 8px 28px #0003}.landing-final-cta-btn:active{transform:translateY(0)}.landing-final-cta-btn:disabled{opacity:.7;cursor:wait;transform:none}.landing-footer{background:var(--color-card);border-top:1px solid var(--color-border);padding:32px 24px;text-align:center}.landing-footer-inner{max-width:1100px;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:16px}.landing-footer-copy{font-size:var(--text-body-sm);color:var(--color-text-secondary)}.landing-footer-links{display:flex;gap:20px}.landing-footer-link{font-size:var(--text-body-sm);color:var(--color-text-secondary);text-decoration:none;cursor:pointer;background:none;border:none;font-family:var(--font-sans);padding:0}.landing-footer-link:hover{color:var(--color-primary);text-decoration:underline}@media(min-width:640px){.landing-problem-grid,.landing-how-steps{grid-template-columns:repeat(3,1fr)}.landing-how-step{flex-direction:column;gap:12px}.landing-how-number{width:auto}.landing-pricing-grid{grid-template-columns:1fr 1fr 1fr;max-width:1080px}.landing-footer-inner{flex-direction:row;justify-content:space-between}}@media(min-width:480px){.landing-features-grid{grid-template-columns:1fr 1fr}}@media(min-width:768px){.landing-features-grid{grid-template-columns:repeat(3,1fr)}}.dark .landing-problem-card,.dark .landing-feature-card{background:color-mix(in srgb,var(--color-card) 60%,var(--color-bg))}.dark .landing-final-cta{background:var(--color-primary-dark)}.landing-golden-section{background:linear-gradient(135deg,#f59e0b0a,#fbbf2414)}.landing-golden-pro-tag{display:inline-block;font-size:var(--text-xs);font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:#7c3a03;background:linear-gradient(135deg,#fef3c7,#fcd34d);border:1px solid #facc15;padding:4px 12px;border-radius:999px;margin-bottom:12px}.landing-golden-container{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:48px;align-items:center}.landing-golden-text{max-width:480px;min-width:0}.landing-golden-visual{display:flex;justify-content:center;align-items:center;min-width:0}@media(max-width:768px){.landing-golden-container{grid-template-columns:1fr;gap:32px}.landing-golden-text{text-align:center;max-width:100%}}.hm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;z-index:var(--z-overlay);padding:16px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:none}.hm-modal{background:var(--color-card);color:var(--color-text);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:680px;padding:20px;margin:auto}.hm-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.hm-header h2{margin:0;font-size:var(--text-section);font-weight:700}.btn-close{background:none;border:none;font-size:var(--text-h1);cursor:pointer;color:var(--color-text-secondary);min-width:44px;min-height:44px;padding:0;display:inline-flex;align-items:center;justify-content:center;line-height:1;border-radius:var(--radius-md);flex-shrink:0}.btn-close:hover{color:var(--color-text);background:var(--color-border)}.hm-tabs{display:flex;gap:4px;margin-bottom:12px}.hm-tab{flex:1;padding:6px 0;font-size:var(--text-body-sm);font-weight:500;background:var(--color-border);border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);transition:background .15s,color .15s}.hm-tab:hover{background:var(--color-border);color:var(--color-text)}.hm-tab.active{background:var(--color-primary);color:#fff}.hm-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.hm-nav button{background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:4px 12px;font-size:var(--text-base);cursor:pointer;color:var(--color-text);line-height:1.5}.hm-nav button:hover:not(:disabled){background:var(--color-border)}.hm-nav button:disabled{opacity:.35;cursor:default}.hm-period-label{font-size:var(--text-body);font-weight:600;color:var(--color-text)}.hm-legend{display:flex;gap:14px;align-items:center;margin-bottom:14px;flex-wrap:wrap}.hm-legend-item{display:flex;align-items:center;gap:5px;font-size:var(--text-caption);color:var(--color-text-secondary)}.hm-legend-dot{width:10px;height:10px;border-radius:2px;flex-shrink:0}.hm-legend-dot--empty{background:var(--color-border);opacity:.6}.hm-habits-list{display:flex;flex-direction:column;gap:20px}.hm-empty{text-align:center;color:var(--color-text-secondary);padding:32px 0}.hm-habit-block{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px}.hm-habit-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.hm-habit-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.hm-habit-name{font-size:var(--text-body);font-weight:600;flex:1}.hm-habit-avg{font-size:var(--text-caption);color:var(--color-text-secondary);white-space:nowrap}.hm-month-grid{display:flex;flex-direction:column;gap:4px}.hm-weekday-row{display:grid;grid-template-columns:repeat(7,1fr);gap:3px;margin-bottom:2px}.hm-weekday-row span{text-align:center;font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:500}.hm-cells{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}.hm-cell{aspect-ratio:1;border-radius:var(--radius-sm);background:var(--color-border);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;min-width:0}.hm-cell:hover:not(.empty):not(.future){opacity:.8}.hm-cell.empty{background:transparent;cursor:default;pointer-events:none}.hm-cell.future{background:transparent;border:1px dashed var(--color-border);cursor:default}.hm-cell.no-data{background:var(--color-border);opacity:.5}.hm-cell-num{font-size:var(--text-xs);font-weight:600;color:#fff;-webkit-user-select:none;user-select:none;text-shadow:0 1px 2px rgba(0,0,0,.4)}.hm-cell.no-data .hm-cell-num{color:var(--color-text-secondary);text-shadow:none}.hm-cells.compact .hm-cell{border-radius:2px}.hm-quarterly-months{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.hm-quarterly-month-name{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);text-align:center;margin-bottom:4px;text-transform:uppercase;letter-spacing:.04em}.hm-yearly-container{overflow-x:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.hm-yearly-container::-webkit-scrollbar{height:4px}.hm-yearly-container::-webkit-scrollbar-track{background:transparent}.hm-yearly-container::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.hm-yearly-scroll{display:inline-flex;flex-direction:column;gap:2px;min-width:max-content}.hm-yearly-months{display:flex;gap:2px;padding-bottom:2px}.hm-yearly-day-spacer{width:22px;flex-shrink:0}.hm-yearly-month-slot{width:13px;font-size:var(--text-micro);color:var(--color-text-secondary);white-space:nowrap;overflow:visible}.hm-yearly-row{display:flex;gap:2px;align-items:center}.hm-yearly-day-label{width:22px;font-size:var(--text-micro);color:var(--color-text-secondary);text-align:right;padding-right:4px;flex-shrink:0}.hm-yearly-cell{width:11px;height:11px;border-radius:2px;background:var(--color-border);cursor:pointer;transition:opacity .15s;flex-shrink:0}.hm-yearly-cell:hover:not(.empty):not(.future){opacity:.75}.hm-yearly-cell.empty{background:transparent;cursor:default;pointer-events:none}.hm-yearly-cell.future{background:transparent;border:1px dashed var(--color-border);cursor:default}.hm-yearly-cell.no-data{background:var(--color-border);opacity:.4}.hm-modal.hm-embedded{position:relative;width:100%;max-width:100%;border-radius:0;box-shadow:none;background:transparent;padding:16px 16px 100px}@media(max-width:480px){.hm-modal{padding:14px}.hm-quarterly-months{gap:8px}}.tv-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;z-index:var(--z-overlay);padding:16px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:none}.tv-modal{background:var(--color-card);color:var(--color-text);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:560px;padding:20px;margin:auto}.tv-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.tv-header h2{margin:0;font-size:var(--text-section);font-weight:700}.tv-tabs{display:flex;gap:4px;margin-bottom:16px}.tv-tab{flex:1;padding:6px 0;font-size:var(--text-body-sm);font-weight:500;background:var(--color-border);border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-secondary);transition:background .15s,color .15s}.tv-tab:hover{color:var(--color-text)}.tv-tab.active{background:var(--color-primary);color:#fff}.tv-range-pills{display:flex;gap:4px;margin-bottom:12px;flex-wrap:wrap}.tv-range-pill{padding:3px 8px;font-size:var(--text-xs);font-weight:500;background:transparent;border:1px solid var(--color-border);border-radius:4px;cursor:pointer;color:var(--color-text-secondary);transition:background .12s,color .12s,border-color .12s;display:flex;align-items:center;gap:3px}.tv-range-pill:hover:not(.pro-locked){color:var(--color-text);border-color:var(--color-text-secondary)}.tv-range-pill.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.tv-range-pill.pro-locked{opacity:.45;cursor:not-allowed}.tv-range-pill-lock{font-size:9px}.tv-chart{margin-bottom:16px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px 8px 0}.tv-list{display:flex;flex-direction:column;gap:6px;max-height:70vh;overflow-y:auto;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.tv-list::-webkit-scrollbar{width:4px}.tv-list::-webkit-scrollbar-track{background:transparent}.tv-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:2px}.tv-row{display:grid;grid-template-columns:148px 1fr 46px;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--color-bg);border:1px solid var(--color-border)}.tv-row.clickable{cursor:pointer;transition:background .15s}.tv-row.clickable:hover{background:var(--color-border)}.tv-row-label{font-size:var(--text-body-sm);color:var(--color-text);white-space:nowrap}.tv-row-bar{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.tv-row-bar-fill{height:100%;border-radius:4px}.tv-row-percent{font-size:var(--text-body-sm);font-weight:700;text-align:right;white-space:nowrap}.tv-row-empty{font-size:var(--text-caption);color:var(--color-text-secondary);font-style:italic;grid-column:2 / 4}.tv-modal.tv-embedded{position:relative;width:100%;max-width:100%;border-radius:0;box-shadow:none;background:transparent;padding:16px 16px 100px}@media(max-width:480px){.tv-modal{padding:14px}.tv-row{grid-template-columns:120px 1fr 42px}}.celebration-overlay{position:fixed;inset:0;z-index:var(--z-toast);display:flex;align-items:center;justify-content:center;pointer-events:auto;background:#00000073;animation:celebration-fade-in .3s ease;transition:opacity .2s ease-out}.celebration-overlay[data-closing=true]{opacity:0;pointer-events:none}@keyframes celebration-fade-in{0%{opacity:0}to{opacity:1}}.celebration-confetti-container{position:fixed;inset:0;overflow:hidden;pointer-events:none}.celebration-confetti{position:absolute;top:-10px;left:var(--x);opacity:.9;animation:confetti-fall var(--duration) var(--delay) ease-in forwards}@keyframes confetti-fall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(var(--rotation));opacity:0}}.celebration-message{text-align:center;z-index:var(--z-stack-1);animation:celebration-pop .4s .2s ease both}@keyframes celebration-pop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.1)}to{transform:scale(1);opacity:1}}.celebration-emoji{font-size:56px;display:block;margin-bottom:8px}.celebration-text{font-size:var(--text-h1);font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5);margin:0;padding:0 24px}.welcome-back-overlay{position:fixed;inset:0;z-index:var(--z-toast);display:flex;align-items:center;justify-content:center;pointer-events:auto;background:#00000059;animation:welcome-back-fade-in .6s ease}@keyframes welcome-back-fade-in{0%{opacity:0}to{opacity:1}}.welcome-back-content{text-align:center;z-index:var(--z-stack-1);animation:welcome-back-rise .7s .2s ease both}@keyframes welcome-back-rise{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.welcome-back-emoji{font-size:52px;display:block;margin-bottom:12px}.welcome-back-text{font-size:var(--text-h1);font-weight:700;color:#fff;text-shadow:0 2px 8px rgba(0,0,0,.5);margin:0;padding:0 24px}.welcome-back-subtext{font-size:var(--text-body-lg);font-weight:400;color:#fffc;text-shadow:0 1px 4px rgba(0,0,0,.4);margin:8px 0 0;padding:0 24px}.comeback-modal{max-width:420px;text-align:center;padding:32px 28px 28px}.comeback-hero{display:flex;flex-direction:column;align-items:center;gap:4px}.comeback-hero-emoji{font-size:var(--text-hero-lg);line-height:1;margin-bottom:12px}.comeback-headline{font-size:var(--text-h1);font-weight:700;color:var(--color-text);margin:0}.comeback-subtitle{font-size:var(--text-body-lg);color:var(--color-text-secondary);line-height:1.5;margin:8px 0 28px}.comeback-btn{width:100%;padding:14px;background:var(--color-primary);color:#fff;border:none;border-radius:12px;font-size:var(--text-base);font-weight:600;cursor:pointer;transition:opacity .15s}.comeback-btn:hover{opacity:.88}@media(max-width:480px){.comeback-modal{padding:24px 20px 20px}.comeback-hero-emoji{font-size:var(--text-hero)}.comeback-headline{font-size:var(--text-h2)}}.onboarding-modal{max-width:480px;max-height:90vh;overflow-y:auto;padding:0!important;gap:0!important}.onboarding-header{display:flex;flex-direction:column;align-items:center;gap:4px;padding:20px 24px 12px;border-bottom:1px solid var(--color-border)}.onboarding-step-indicator{font-size:var(--text-caption);font-weight:500;color:var(--color-text-secondary);letter-spacing:.5px}.onboarding-step-title{font-size:var(--text-section);font-weight:700;color:var(--color-text);margin:0}.onboarding-step-content{padding:20px 24px;min-height:260px}@keyframes onboarding-slide-in{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}.onboarding-slide-in{animation:onboarding-slide-in .25s ease-out}.onboarding-step-body{display:flex;flex-direction:column;gap:16px}.onboarding-track-choice{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.onboarding-track-btn{flex:1 1 calc(50% - 5px);min-width:0;padding:14px 12px;border-radius:var(--radius-md);font-size:var(--text-body);font-weight:600;cursor:pointer;transition:all .2s}.onboarding-track-btn--fast{background:linear-gradient(135deg,#6366f1,#3b5bdb);color:#fff;border:none}.onboarding-track-btn--fast:hover{background:linear-gradient(135deg,#4f46e5,#2f4cc8)}.onboarding-track-btn--full{background:transparent;color:var(--color-text-secondary, #888);border:1px solid var(--color-border)}.onboarding-track-btn--full:hover{border-color:var(--color-primary);color:var(--color-primary)}.onboarding-track-nudge{flex:1 1 100%;font-size:var(--text-caption);color:var(--color-text-secondary, #888);text-align:center;margin:4px 0 0}.onboarding-hero-emoji{font-size:var(--text-hero-lg);text-align:center;margin-bottom:4px}.onboarding-hero-icon{width:48px;height:48px;margin:0 auto 4px;display:block;color:var(--color-primary)}.onboarding-track-icon{width:16px;height:16px;vertical-align:-3px;display:inline}.onboarding-step-title-icon{width:18px;height:18px;vertical-align:-3px;display:inline;margin-left:6px;color:var(--color-primary)}.onboarding-bitai-pencil{width:14px;height:14px;flex-shrink:0;color:var(--color-text-secondary)}.onboarding-headline{font-size:var(--text-h2);font-weight:700;color:var(--color-text);text-align:center;margin:0;line-height:1.3}.onboarding-text{font-size:var(--text-body);line-height:1.6;color:var(--color-text);margin:0}.onboarding-text strong{color:var(--color-primary)}.onboarding-text--secondary{font-size:var(--text-body-sm);color:var(--color-text-secondary);font-style:italic}.onboarding-footer{display:flex;justify-content:space-between;align-items:center;padding:14px 24px;border-top:1px solid var(--color-border)}.onboarding-btn-back{padding:8px 16px;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-body);cursor:pointer;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{padding:8px 20px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-body);font-weight:600;cursor:pointer;transition:opacity .15s}.onboarding-btn-next:hover:not(:disabled){opacity:.88}.onboarding-btn-next:disabled{opacity:.35;cursor:not-allowed}.onboarding-weight-compare{display:flex;flex-direction:column;gap:12px}.onboarding-weight-item{display:flex;flex-direction:column;gap:6px}.onboarding-weight-card{display:flex;flex-direction:column;gap:6px;padding:12px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.onboarding-weight-card-header{display:flex;align-items:center;gap:8px}.onboarding-weight-card-emoji{font-size:var(--text-h1-lg)}.onboarding-weight-card-name{font-size:var(--text-body-lg);font-weight:600;color:var(--color-text)}.onboarding-weight-card-detail{display:flex;justify-content:space-between;font-size:var(--text-caption);color:var(--color-text-secondary)}.onboarding-weight-bar-container{height:8px;background:var(--color-border);border-radius:4px;overflow:hidden}.onboarding-weight-bar{height:100%;border-radius:4px;transition:width .5s ease-out}.onboarding-weight-impact{font-size:var(--text-body-sm);font-weight:600;color:var(--color-text);text-align:right}.onboarding-demo-cards{display:flex;flex-direction:column;gap:10px}.onboarding-demo-card{display:flex;flex-direction:column;gap:8px;padding:12px;background:var(--color-card);border:1px solid var(--color-border);border-left:4px solid;border-radius:var(--radius-md)}.onboarding-demo-card-top{display:flex;align-items:center;gap:10px}.onboarding-demo-card-emoji{font-size:var(--text-display);width:38px;height:38px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.onboarding-demo-card-info{display:flex;flex-direction:column;flex:1;min-width:0}.onboarding-demo-card-name{font-size:var(--text-body-lg);font-weight:600;color:var(--color-text)}.onboarding-demo-card-meta{font-size:var(--text-caption);color:var(--color-text-secondary)}.onboarding-demo-card-progress{display:flex;align-items:center;gap:8px}.onboarding-demo-card-bar-container{flex:1;height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.onboarding-demo-card-bar{height:100%;border-radius:3px;transition:width .4s ease-out}.onboarding-demo-card-pct{font-size:var(--text-body-sm);font-weight:600;color:var(--color-text);min-width:36px;text-align:right}.onboarding-demo-card-sub{font-size:var(--text-xs);color:var(--color-text-secondary)}.onboarding-demo-card{position:relative;overflow:hidden}.onboarding-demo-fill{position:absolute;top:0;left:0;height:100%;opacity:.12;transition:width .4s ease-out;pointer-events:none}.onboarding-demo-card-top{position:relative;z-index:var(--z-stack-1)}.onboarding-demo-stepper{display:flex;align-items:center;gap:6px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;padding:4px 10px;font-size:var(--text-body-sm);font-weight:600;color:var(--color-text);flex-shrink:0}.onboarding-demo-stepper-val{min-width:40px;text-align:center}.onboarding-demo-stepper--tappable{cursor:pointer;border:none;transition:opacity .15s}.onboarding-demo-stepper--tappable:hover{opacity:.75}.onboarding-demo-check{font-size:var(--text-section);flex-shrink:0;font-weight:700}.onboarding-demo-card--swipeable{cursor:grab}.onboarding-demo-card--swipeable:active{cursor:grabbing}.onboarding-swipe-hint{position:relative;z-index:var(--z-stack-1);text-align:right;font-size:var(--text-caption);color:var(--color-text-secondary);padding-top:4px;opacity:.7}.onboarding-quick-input{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:12px;display:flex;flex-direction:column;gap:8px;margin-top:8px}.onboarding-quick-input-label{font-size:var(--text-body-sm);font-weight:600;color:var(--color-text)}.onboarding-quick-input-row{display:flex;align-items:center;gap:8px}.onboarding-quick-input-field{width:72px;padding:6px 10px;font-size:var(--text-base);font-weight:600;text-align:center;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text)}.onboarding-quick-input-unit{font-size:var(--text-body-sm);color:var(--color-text-secondary);flex:1}.onboarding-quick-input-confirm{padding:6px 16px;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:var(--text-body);font-weight:600;border:none;cursor:pointer}.onboarding-demo-check{width:36px;height:36px;border-radius:50%;border:2px solid var(--color-border);background:transparent;font-size:var(--text-section);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s ease;color:var(--color-text-secondary)}.onboarding-demo-check:hover{border-color:var(--color-primary);color:var(--color-primary)}.onboarding-demo-check--done{background:var(--color-success, #10b981);border-color:var(--color-success, #10b981);color:#fff}.onboarding-demo-check--done:hover{opacity:.85;border-color:var(--color-success, #10b981);color:#fff}.onboarding-views-list{display:flex;flex-direction:column;gap:10px}.onboarding-view-card{display:flex;align-items:flex-start;gap:12px;padding:12px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.onboarding-view-icon{font-size:var(--text-h1-lg);flex-shrink:0;margin-top:2px}.onboarding-view-icon--svg{font-size:inherit;width:28px;height:28px;display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary)}.onboarding-view-info{display:flex;flex-direction:column;gap:2px}.onboarding-view-name{font-size:var(--text-body);font-weight:600;color:var(--color-text)}.onboarding-view-desc{font-size:var(--text-body-sm);line-height:1.4;color:var(--color-text-secondary)}.onboarding-score-bands{display:flex;flex-direction:column;gap:10px}.onboarding-score-band{display:flex;align-items:center;gap:12px;padding:12px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.onboarding-score-band-emoji{font-size:var(--text-h1);flex-shrink:0}.onboarding-score-band-info{display:flex;flex-direction:column;min-width:80px}.onboarding-score-band-range{font-size:var(--text-body);font-weight:700;color:var(--color-text)}.onboarding-score-band-label{font-size:var(--text-caption);font-weight:600;color:var(--color-text-secondary)}.onboarding-score-band-desc{font-size:var(--text-body-sm);color:var(--color-text-secondary);flex:1}.onboarding-info-box{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--color-primary)18;border:1px solid var(--color-primary)40;border-radius:var(--radius-md)}.onboarding-info-box-icon{width:20px;height:20px;flex-shrink:0;margin-top:1px;color:var(--color-primary)}.onboarding-info-box-text{font-size:var(--text-body-sm);line-height:1.5;color:var(--color-text);margin:0}.onboarding-info-box-text strong{color:var(--color-primary)}.onboarding-bitai-demo{display:flex;flex-direction:column;gap:10px;margin:14px 0}.onboarding-bitai-input{display:flex;align-items:flex-start;gap:10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:12px 14px}.onboarding-bitai-input-text{font-size:.87rem;color:var(--color-text-secondary);font-style:italic;line-height:1.4}.onboarding-bitai-arrow{text-align:center;font-size:.8rem;font-weight:700;color:var(--color-primary);letter-spacing:.03em}.onboarding-bitai-habits{display:flex;flex-direction:column;gap:8px}.onboarding-bitai-habit{display:flex;align-items:center;gap:12px;background:var(--color-surface);border:1px solid var(--color-border);border-left:3px solid var(--color-primary);border-radius:10px;padding:10px 14px}.onboarding-bitai-habit-emoji{font-size:1.3rem;flex-shrink:0}.onboarding-bitai-habit-name{display:block;font-size:.88rem;font-weight:600;color:var(--color-text)}.onboarding-bitai-habit-meta{display:block;font-size:.78rem;color:var(--color-text-secondary);margin-top:2px}.onboarding-checkin-section{display:flex;flex-direction:column;gap:8px}.onboarding-demo-slider{width:100%;height:6px;margin-top:10px;cursor:pointer;accent-color:var(--demo-slider-color, var(--color-primary))}.onboarding-done-label{font-size:var(--text-body-sm);font-weight:700;color:var(--color-success, #10b981);white-space:nowrap;flex-shrink:0}.onboarding-demo-counter{display:flex;align-items:center;gap:12px;margin-top:10px}.onboarding-demo-counter-value{flex:1;text-align:center;font-size:var(--text-body);font-weight:600;color:var(--color-text)}.onboarding-demo-counter-btn{width:36px;height:36px;border-radius:var(--radius-md);border:none;font-size:var(--text-h2);font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:opacity .15s;flex-shrink:0}.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{background:#ef4444;color:#fff}.onboarding-demo-counter-btn:not(:disabled):hover{opacity:.85}.onboarding-demo-counter--standalone{padding:12px;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md)}.onboarding-form-wrapper{margin-top:4px}.onboarding-skip-overlay{position:absolute;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;border-radius:inherit;z-index:var(--z-stack-10)}.onboarding-skip-dialog{background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:24px;max-width:300px;text-align:center}.onboarding-skip-dialog p{font-size:var(--text-body-lg);font-weight:600;color:var(--color-text);margin:0 0 4px}.onboarding-skip-sub{font-size:var(--text-body-sm)!important;font-weight:400!important;color:var(--color-text-secondary)!important;margin-bottom:16px!important}.onboarding-skip-actions{display:flex;gap:8px;justify-content:center}.onboarding-btn-skip{padding:8px 16px;background:var(--color-danger);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-body);font-weight:600;cursor:pointer;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}}.monthly-insight-modal{max-width:480px;max-height:90vh;overflow-y:auto}.monthly-insight-title{font-size:var(--text-h2);font-weight:700;color:var(--color-text)}.monthly-insight-body{display:flex;flex-direction:column;gap:12px;padding-top:8px}.monthly-insight-card--score{display:flex;flex-direction:column;align-items:center;background:var(--color-primary-10, rgba(100,180,100,.08));border-radius:var(--radius-md);padding:20px;text-align:center}.monthly-insight-stat{font-size:var(--text-hero-lg);font-weight:800;color:var(--color-primary);line-height:1}.monthly-insight-label{font-size:var(--text-body-sm);color:var(--color-text-secondary);margin-top:4px}.monthly-insight-delta{font-size:var(--text-caption);font-weight:600;margin-top:6px;padding:2px 8px;border-radius:99px}.monthly-insight-delta.positive{color:var(--color-success);background:color-mix(in srgb,var(--color-success) 12%,transparent)}.monthly-insight-delta.negative{color:#ef4444;background:#ef44441f}.monthly-insight-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.monthly-insight-card{display:flex;flex-direction:column;background:var(--color-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:14px 12px;gap:2px}.monthly-insight-card-icon{font-size:var(--text-section);line-height:1;margin-bottom:4px}.monthly-insight-card-label{font-size:var(--text-xs);font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.monthly-insight-card-value{font-size:var(--text-body-lg);font-weight:700;color:var(--color-text);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monthly-insight-card-sub{font-size:var(--text-xs);color:var(--color-text-secondary);margin-top:1px}.monthly-insight-footer{display:flex;flex-direction:column;gap:8px;margin-top:4px}.monthly-insight-btn-report{width:100%;padding:12px;background:var(--color-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--text-body);font-weight:600;cursor:pointer;transition:opacity .15s}.monthly-insight-btn-report:hover{opacity:.88}.monthly-insight-btn-close{width:100%;padding:10px;background:transparent;color:var(--color-text-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-body);cursor:pointer;transition:background .15s}.monthly-insight-btn-close:hover{background:var(--color-border)}.settings-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:flex-start;justify-content:center;z-index:var(--z-nav);padding:16px 16px 80px;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch;touch-action:pan-y}.settings-modal{background:var(--color-card);color:var(--color-text);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);width:100%;max-width:520px;padding:20px;margin:auto}.settings-header{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid var(--color-border)}.settings-back-btn{background:none;border:none;color:var(--color-primary);font-size:var(--text-body);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm)}.settings-back-btn:hover{background:var(--color-bg)}.settings-title{font-size:var(--text-section);font-weight:600;margin:0}.settings-section{margin-bottom:24px}.settings-section:last-of-type{margin-bottom:0}.settings-section-title{font-size:var(--text-body);font-weight:600;color:var(--color-text-secondary);margin:0 0 8px;text-transform:uppercase;letter-spacing:.5px;display:flex;align-items:center;gap:6px}.settings-section-icon{width:14px;height:14px;flex-shrink:0}.settings-card{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px}.settings-digest-unsubscribed-banner{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px;padding:10px 12px;background:#fef9c3;border:1px solid #fde047;border-radius:8px;font-size:var(--text-body-sm);color:#713f12}.settings-digest-reactivate-btn{flex-shrink:0;background:#111827;color:#fff;border:none;border-radius:6px;padding:5px 12px;font-size:var(--text-caption);font-weight:600;cursor:pointer}@media(prefers-color-scheme:dark){.settings-digest-unsubscribed-banner{background:#422006;border-color:#78350f;color:#fde68a}}.settings-profile{display:flex;align-items:center;gap:14px;padding-bottom:16px;border-bottom:1px solid var(--color-border);margin-bottom:12px}.settings-avatar{width:48px;height:48px;border-radius:50%;flex-shrink:0}.settings-avatar-placeholder{background-color:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--text-section);font-weight:600}.settings-profile-info{display:flex;flex-direction:column;gap:2px;min-width:0}.settings-profile-name{font-weight:600;font-size:var(--text-body-lg)}.settings-profile-email{font-size:var(--text-body-sm);color:var(--color-text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-profile-since{font-size:var(--text-caption);color:var(--color-text-secondary)}.settings-actions{display:flex;flex-direction:column;gap:4px;padding-top:8px}.settings-action-btn{display:flex;align-items:flex-start;gap:12px;width:100%;padding:12px;background:none;border:none;border-radius:var(--radius-sm);cursor:pointer;text-align:left;color:var(--color-text);transition:background .15s}.settings-action-btn:hover{background:var(--color-card)}.settings-action-btn:disabled{opacity:.6;cursor:wait}.settings-action-btn>span:first-child{font-size:var(--text-section);line-height:1;margin-top:1px}.settings-action-btn>.settings-action-icon{width:18px;height:18px;flex-shrink:0;margin-top:1px;color:var(--color-text-secondary)}.settings-action-btn--danger>.settings-action-icon{color:var(--color-danger)}.settings-inline-icon{width:14px;height:14px;vertical-align:-2px;display:inline}.settings-action-btn>div{display:flex;flex-direction:column;gap:2px}.settings-action-label{font-size:var(--text-body);font-weight:500}.settings-action-desc{font-size:var(--text-caption);color:var(--color-text-secondary)}.settings-action-btn--danger .settings-action-label{color:var(--color-danger)}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;gap:16px}.settings-toggle-row>div{display:flex;flex-direction:column;gap:2px}.settings-toggle-row--sub{margin-top:12px;padding-top:12px;border-top:1px solid var(--color-border)}.settings-language-select{font-size:var(--text-body);padding:6px 10px;border-radius:8px;border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);cursor:pointer;flex-shrink:0;appearance:auto}.settings-theme-toggle{position:relative;width:52px;height:28px;border-radius:14px;border:none;background:var(--color-border);cursor:pointer;padding:0;flex-shrink:0;transition:background .2s}.settings-theme-toggle--dark{background:var(--color-primary)}.settings-theme-toggle-knob{position:absolute;top:2px;left:2px;width:24px;height:24px;border-radius:50%;background:var(--color-card);display:flex;align-items:center;justify-content:center;font-size:var(--text-body);transition:transform .2s;box-shadow:0 1px 3px #0003;color:var(--color-text)}.settings-theme-toggle-knob>svg{width:14px;height:14px}.settings-theme-toggle--dark .settings-theme-toggle-knob{transform:translate(24px)}.settings-info-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0;font-size:var(--text-body)}.settings-info-row+.settings-info-row{border-top:1px solid var(--color-border)}.settings-info-value{color:var(--color-text-secondary);font-size:var(--text-body-sm)}.settings-link-btn{background:none;border:none;color:var(--color-text);cursor:pointer;font-size:var(--text-body);padding:0}.settings-link-btn:hover{color:var(--color-primary)}.settings-delete-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:var(--z-section-overlay);padding:20px}.settings-delete-dialog{background:var(--color-card);color:var(--color-text);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, .25));padding:24px;max-width:420px;width:100%}.settings-delete-dialog h3{margin:0 0 12px;font-size:var(--text-section);color:var(--color-danger)}.settings-delete-dialog p{font-size:var(--text-body);line-height:1.5;margin:0 0 8px}.settings-delete-dialog ul{font-size:var(--text-body);margin:0 0 12px;padding-left:20px}.settings-delete-dialog li{margin-bottom:4px}.settings-delete-warning{color:var(--color-danger);font-size:var(--text-body-sm)}.settings-delete-checkbox{display:flex;align-items:center;gap:8px;font-size:var(--text-body);margin:16px 0;cursor:pointer}.settings-delete-checkbox input{width:16px;height:16px;cursor:pointer}.settings-delete-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.settings-delete-cancel{padding:8px 16px;background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-size:var(--text-body)}.settings-delete-cancel:hover{background:var(--color-bg)}.settings-delete-confirm{padding:8px 16px;background:var(--color-danger);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-size:var(--text-body);font-weight:500}.settings-delete-confirm:disabled{opacity:.5;cursor:not-allowed}.settings-delete-confirm:not(:disabled):hover{filter:brightness(1.1)}.settings-time-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0 4px;margin-top:0}.settings-time-row span{font-size:var(--text-body);color:var(--color-text-secondary)}.settings-time-hint{font-size:var(--text-caption);color:var(--color-text-secondary);line-height:1.4;margin:0 0 8px;padding:0}.settings-time-input{padding:4px 8px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:var(--text-body);cursor:pointer}.settings-timezone-row{display:flex;flex-direction:column;gap:4px;padding:12px 0;border-bottom:1px solid var(--color-border)}.settings-timezone-select{width:100%;margin-top:6px;padding:8px 12px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text);font-size:var(--text-body);cursor:pointer}.settings-test-push-btn{width:100%;margin-top:10px;padding:9px 14px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-surface);color:var(--color-text-secondary);font-size:.82rem;cursor:pointer;text-align:center;transition:background .15s,color .15s}.settings-test-push-btn:hover:not(:disabled){background:var(--color-border);color:var(--color-text)}.settings-test-push-btn:disabled{opacity:.6;cursor:not-allowed}.settings-notifications-info{font-size:var(--text-body-sm);color:var(--color-text-secondary);padding:8px 0 4px;line-height:1.4}.settings-pro-status-row{align-items:center}.settings-pro-badge{display:inline-flex;align-items:center;gap:4px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-dark));color:#fff;font-size:var(--text-caption);font-weight:700;padding:3px 10px;border-radius:20px;letter-spacing:.3px}.settings-pro-expiry{font-weight:400;opacity:.85}.settings-free-badge{font-size:var(--text-caption);font-weight:600;color:var(--color-text-secondary);background:var(--color-bg);border:1px solid var(--color-border);padding:3px 10px;border-radius:20px}.settings-plan-skeleton{display:inline-block;width:56px;height:22px;border-radius:20px;background:var(--color-border);opacity:.5;animation:settings-plan-skeleton-pulse 1.2s ease-in-out infinite}@keyframes settings-plan-skeleton-pulse{0%,to{opacity:.35}50%{opacity:.65}}@media(prefers-reduced-motion:reduce){.settings-plan-skeleton{animation:none}}.settings-divider{height:1px;background:var(--color-border);margin:12px 0}.settings-referral-block{display:flex;flex-direction:column;gap:8px}.settings-referral-title{font-size:.9rem;font-weight:600;color:var(--color-text);margin:0}.settings-referral-desc{font-size:.8rem;color:var(--color-text-secondary);line-height:1.5;margin:0}.settings-referral-actions{display:flex;flex-direction:column;gap:8px;margin-top:4px}.settings-referral-link-box{background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px 12px;overflow:hidden}.settings-referral-link-text{font-size:var(--text-caption);color:var(--color-text-secondary);font-family:monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.settings-referral-btns{display:flex;gap:8px}.settings-referral-btn{flex:1;padding:8px 12px;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-card);color:var(--color-text);font-size:.8rem;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.settings-referral-btn:hover{background:var(--color-bg)}.settings-referral-btn--primary{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.settings-referral-btn--primary:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark)}.settings-mfa-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-mfa-row>div{display:flex;flex-direction:column;gap:2px}.settings-mfa-active-label{color:var(--color-success)!important}.settings-mfa-btn{flex-shrink:0;padding:7px 16px;font-size:var(--text-body-sm);font-weight:500;color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent);border:1.5px solid var(--color-primary);border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;white-space:nowrap}.settings-mfa-btn:hover{background:color-mix(in srgb,var(--color-primary) 18%,transparent)}.settings-mfa-btn:disabled{opacity:.5;cursor:not-allowed}.settings-mfa-btn--danger{color:#dc2626;background:color-mix(in srgb,#ef4444 10%,transparent);border-color:#dc2626}.settings-mfa-btn--danger:hover{background:color-mix(in srgb,#ef4444 18%,transparent)}.settings-mfa-btn--success{color:var(--color-success);background:color-mix(in srgb,var(--color-success) 14%,transparent);border-color:var(--color-success)}.settings-mfa-btn--success:disabled{opacity:1;cursor:default}.settings-mfa-btn--error-state{color:#dc2626;background:color-mix(in srgb,#ef4444 12%,transparent);border-color:#dc2626}.settings-mfa-enroll{display:flex;flex-direction:column;gap:8px}.settings-mfa-enroll-step{font-size:var(--text-body-sm);color:var(--color-text);margin:0;line-height:1.5}.settings-mfa-secret-label{margin-top:12px!important}.settings-mfa-qr-wrapper{display:flex;justify-content:center;padding:12px 0}.settings-mfa-qr{width:160px;height:160px;border-radius:var(--radius-sm);border:1px solid var(--color-border)}.settings-mfa-secret{display:block;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:8px 10px;font-size:var(--text-caption);font-family:monospace;letter-spacing:.05em;word-break:break-all;color:var(--color-text-secondary);text-align:center}.settings-mfa-verify-row{display:flex;gap:8px;align-items:center}.settings-mfa-code-input{flex:1;padding:8px 12px;font-size:1.2rem;font-weight:600;letter-spacing:.2em;text-align:center;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg);color:var(--color-text);outline:none;font-variant-numeric:tabular-nums}.settings-mfa-code-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}.settings-mfa-error{background:color-mix(in srgb,#ef4444 12%,transparent);border:1px solid color-mix(in srgb,#ef4444 30%,transparent);color:#b91c1c;border-radius:var(--radius-sm);padding:8px 10px;font-size:var(--text-caption);margin-top:4px}[data-theme=dark] .settings-mfa-error{color:#fca5a5}.settings-mfa-cancel{background:none;border:none;cursor:pointer;font-size:var(--text-body-sm);color:var(--color-text-secondary);padding:4px 0;text-align:left;margin-top:4px}.settings-mfa-cancel:hover{color:var(--color-text)}.settings-notifications-warning{background:#fef3c7;border:1px solid #fcd34d;border-radius:10px;padding:12px 14px;margin-top:8px;display:flex;flex-direction:column;gap:8px}.settings-notifications-warning p{margin:0;font-size:var(--text-body-sm);color:#78350f;line-height:1.4}.settings-notifications-warning-btn{background:var(--color-primary);color:#fff;border:none;border-radius:8px;padding:8px 12px;font-size:var(--text-body-sm);font-weight:600;cursor:pointer;align-self:flex-start;transition:opacity .15s}.settings-notifications-warning-btn:disabled{opacity:.5;cursor:not-allowed}.settings-notifications-warning-btn:not(:disabled):hover{opacity:.88}[data-theme=dark] .settings-notifications-warning{background:#422006;border-color:#92400e}[data-theme=dark] .settings-notifications-warning p{color:#fcd34d}@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-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-red-500:oklch(63.7% .237 25.331);--color-blue-500:oklch(62.3% .214 259.815);--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;--font-weight-bold:700;--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-in-out:cubic-bezier(.4, 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}.collapse{visibility:collapse}.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}.start{inset-inline-start:var(--spacing)}.end{inset-inline-end:var(--spacing)}.top-0{top:calc(var(--spacing) * 0)}.top-2{top:calc(var(--spacing) * 2)}.right-0{right:calc(var(--spacing) * 0)}.right-2{right:calc(var(--spacing) * 2)}.left-0{left:calc(var(--spacing) * 0)}.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}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.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)}.size-\[18px\]{width:18px;height:18px}.h-1{height:calc(var(--spacing) * 1)}.h-2{height:calc(var(--spacing) * 2)}.h-3{height:calc(var(--spacing) * 3)}.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)}.h-11{height:calc(var(--spacing) * 11)}.h-123{height:calc(var(--spacing) * 123)}.max-h-\[90vh\]{max-height:90vh}.w-11{width:calc(var(--spacing) * 11)}.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-0{flex-shrink:0}.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}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.rounded{border-radius:.25rem}.rounded-full{border-radius:3.40282e38px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.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-blue-500{background-color:var(--color-blue-500)}.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-4{padding:calc(var(--spacing) * 4)}.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-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-bold{--tw-font-weight:var(--font-weight-bold);font-weight:var(--font-weight-bold)}.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)}.whitespace-nowrap{white-space:nowrap}.text-card-foreground{color:var(--card-foreground)}.text-foreground{color:var(--foreground)}.text-muted-foreground{color:var(--muted-foreground)}.text-primary{color:var(--primary)}.text-primary-foreground{color:var(--primary-foreground)}.text-red-500{color:var(--color-red-500)}.text-secondary-foreground{color:var(--secondary-foreground)}.text-white{color:var(--color-white)}.uppercase{text-transform:uppercase}.italic{font-style:italic}.line-through{text-decoration-line:line-through}.underline-offset-4{text-underline-offset:4px}.opacity-60{opacity:.6}.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}.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-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}.outline-none{--tw-outline-style:none;outline-style:none}.select-none{-webkit-user-select:none;user-select:none}.fade-out{--tw-exit-opacity:0}.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}*,:before,:after{box-sizing:border-box}:root{color-scheme:light;--color-primary:#3b5bdb;--color-primary-dark:#3730a3;--color-secondary:#2196f3;--color-accent:#facc15;--color-pro:#facc15;--color-danger:#ef4444;--color-success:#10b981;--color-score-mid:#f59e0b;--color-warning:#f59e0b;--color-bg:#f0eee7;--color-card:#faf8f2;--color-text:#1c1c1a;--color-text-secondary:#6b6b65;--color-border:#e8e6e0;--radius-sm:6px;--radius-md:14px;--radius-lg:18px;--text-micro:10px;--text-xs:11px;--text-caption:12px;--text-body-sm:13px;--text-body:14px;--text-body-lg:15px;--text-base:16px;--text-section:18px;--text-h2:20px;--text-h1:22px;--text-h1-lg:24px;--text-display:28px;--text-hero:40px;--text-hero-lg:48px;--font-weight-regular:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--z-base:0;--z-stack-1:1;--z-stack-2:2;--z-stack-3:3;--z-stack-10:10;--z-overlay:50;--z-section-overlay:60;--z-fab:100;--z-nav:110;--z-panel-bg:200;--z-dialog:1000;--z-pwa:2000;--z-celebration:9000;--z-toast:9999;--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(95.3% .008 85);--foreground:oklch(14.5% 0 0);--card:oklch(97.5% .008 85);--card-foreground:oklch(14.5% 0 0);--popover:oklch(97.5% .008 85);--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{font-size:var(--text-h1-lg);color:var(--color-primary);margin-bottom:4px;font-weight:700}.today-date{font-size:var(--text-body);color:var(--color-text-secondary)}.theme-toggle{background:var(--color-card);border-radius:var(--radius-md);width:40px;height:40px;font-size:var(--text-h2);cursor:pointer;border:none;justify-content:center;align-items:center;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{font-size:var(--text-micro);opacity:.7;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{font-size:var(--text-caption);color:var(--color-text-secondary,#888);text-align:right;flex-direction:column;gap:4px;max-width:200px;display:flex}.login-standalone-hint p{margin:0;line-height:1.4}.login-standalone-hint-sub{font-size:var(--text-xs);opacity:.8}.login-standalone-link{color:var(--color-primary,#4caf50);font-size:var(--text-caption);margin-top:2px;font-weight:600;text-decoration:none}.header-actions .login-button{font-size:var(--text-body-sm);padding:8px 12px}.header-actions .login-button svg{width:16px;height:16px}.error-banner{color:#b91c1c;border-radius:var(--radius-md);font-size:var(--text-body);background-color:#fef2f2;border:1px solid #fecaca;margin-bottom:16px;padding:12px 16px}.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{font-size:var(--text-hero-lg);margin-bottom:8px;font-weight:700;line-height:1}.progress-label{font-size:var(--text-body);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:600}.progress-detail{font-size:var(--text-body);color:var(--color-text-secondary)}.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:var(--text-section);font-weight:600}.btn-add{background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-size:var(--text-body);cursor:pointer;border:none;padding:8px 16px;font-weight:500;transition:background .2s}.btn-add:hover{background:var(--color-primary-dark)}.filters-bar{flex-direction:column;gap:18px;margin-bottom:16px;display:flex}.search-bar{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);width:100%;font-size:var(--text-base);background:var(--color-card);color:var(--color-text);padding:12px 40px 12px 36px;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;font-size:var(--text-section);color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;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{font-size:var(--text-body-sm);color:var(--color-text-secondary);align-items:center;gap:6px;margin-bottom:12px;padding-left:4px;display:flex}.btn-clear-filter{background:var(--color-bg);width:20px;height:20px;font-size:var(--text-body);color:var(--color-text-secondary);cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;line-height:1;transition:all .2s;display:inline-flex}.sort-controls{flex-direction:column;gap:8px;display:flex}.sort-label{font-size:var(--text-caption);color:var(--color-text-secondary);white-space:nowrap}.sort-buttons{grid-template-columns:repeat(6,minmax(0,1fr));gap:6px;display:grid}.sort-buttons .sort-btn:nth-child(-n+3){grid-column:span 2}.sort-buttons .sort-btn:nth-child(n+4){grid-column:span 3}.sort-btn{border:1px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--text-caption);cursor:pointer;white-space:nowrap;background:0 0;border-radius:6px;padding:4px 10px;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)}.sort-btn--pro{opacity:.5;cursor:not-allowed;border-style:dashed}.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)}.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);font-size:var(--text-body);cursor:pointer;margin-top:12px;padding:8px 16px;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{font-size:var(--text-hero-lg);margin-bottom:12px}.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-list>li{touch-action:pan-y;margin-left:-16px;padding-left:16px}.habit-card{cursor:pointer;touch-action:pan-y;-webkit-user-select:none;user-select:none;border-left:3px solid #0000;transition:box-shadow .2s,transform .15s;position:relative;overflow:hidden}.habit-fill-bg{width:100%;transform:scaleX(var(--fill,0));transform-origin:0;opacity:.13;pointer-events:none;z-index:var(--z-base);border-radius:inherit;will-change:transform;transition:transform .12s;position:absolute;top:0;bottom:0;left:0}.habit-card.swiping .habit-fill-bg,.dayview-habit-card.swiping .habit-fill-bg{transition:none}.habit-card.completed:not(.swiping) .habit-fill-bg,.dayview-habit-card.completed:not(.swiping) .habit-fill-bg{opacity:0}.dark .habit-card.completed:not(.swiping) .habit-fill-bg,.dark .dayview-habit-card.completed:not(.swiping) .habit-fill-bg,[data-theme=dark] .habit-card.completed:not(.swiping) .habit-fill-bg,[data-theme=dark] .dayview-habit-card.completed:not(.swiping) .habit-fill-bg{opacity:.13}.habit-card-content,.habit-paused-badge{z-index:var(--z-stack-1);position:relative}.swipe-hint{text-align:center;font-size:var(--text-caption);color:var(--color-text-secondary);pointer-events:none;padding:5px 12px 8px;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{font-size:var(--text-xs);color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;transition:color .1s,font-weight .1s;overflow:hidden}.habit-value-text--live{color:var(--color-text);font-weight:700}.habit-card.completed{border-left-color:var(--color-success)}.habit-card:not(.completed),.dayview-habit-card:not(.completed),.habit-detail-day-card:not(.completed){background-color:#fff}.habit-card.completed,.dayview-habit-card.completed,.habit-detail-day-card.completed{background:var(--habit-tint,var(--color-success))}@supports (color:color-mix(in lab,red,red)){.habit-card.completed,.dayview-habit-card.completed,.habit-detail-day-card.completed{background:color-mix(in srgb,var(--habit-tint,var(--color-success)) 10%,#fff)}}.dark .habit-card:not(.completed),.dark .dayview-habit-card:not(.completed),.dark .habit-detail-day-card:not(.completed),[data-theme=dark] .habit-card:not(.completed),[data-theme=dark] .dayview-habit-card:not(.completed),[data-theme=dark] .habit-detail-day-card:not(.completed){background-color:var(--color-card)}.dark .habit-card.completed,.dark .dayview-habit-card.completed,.dark .habit-detail-day-card.completed,[data-theme=dark] .habit-card.completed,[data-theme=dark] .dayview-habit-card.completed,[data-theme=dark] .habit-detail-day-card.completed{background:var(--habit-tint,var(--color-success))}@supports (color:color-mix(in lab,red,red)){.dark .habit-card.completed,.dark .dayview-habit-card.completed,.dark .habit-detail-day-card.completed,[data-theme=dark] .habit-card.completed,[data-theme=dark] .dayview-habit-card.completed,[data-theme=dark] .habit-detail-day-card.completed{background:color-mix(in srgb,var(--habit-tint,var(--color-success)) 10%,transparent)}}.habit-card.golden{border:2px solid #facc15;border-left-width:4px}.habit-card.golden.completed{border-color:#facc15}.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;font-size:var(--text-h1);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-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{font-size:var(--text-xs);letter-spacing:1.5px;color:var(--color-accent);align-items:center;gap:0;line-height:1;display:inline-flex}.habit-weight__filled{color:inherit}.habit-weight__empty{opacity:.25;margin-left:1.5px}.habit-name-row{align-items:center;gap:8px;margin-bottom:2px;display:flex}.habit-streak{white-space:nowrap;text-overflow:ellipsis;border-radius:6px;flex-shrink:0;align-items:center;gap:4px;font-weight:600;line-height:1;display:inline-flex;overflow:hidden}.habit-streak--footer{font-size:var(--text-caption);border-radius:8px;flex:0 0 100%;margin-top:2px;padding:5px 10px;font-weight:600}.habit-streak--base{color:#c2410c;background:#f9731621}.habit-streak--warm{color:#9a3412;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{font-size:var(--text-xs);white-space:nowrap;text-overflow:ellipsis;border-radius:12px;max-width:100%;padding:2px 8px;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{font-size:var(--text-xs);color:var(--color-text-secondary);pointer-events:none;text-align:right;font-weight:500;line-height:1}.habit-progress-slider{overflow:visible}.progress-slider{cursor:pointer;appearance:none;width:100%;height:100%;z-index:var(--z-base);background:0 0;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:#fff;border-radius:20px;flex-shrink:0;align-items:stretch;height:32px;display:flex;overflow:hidden}.dark .habit-stepper,[data-theme=dark] .habit-stepper{background:var(--color-bg)}.habit-stepper-btn{cursor:pointer;width:28px;font-size:var(--text-base);color:var(--color-text-secondary);background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;padding:0;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;font-size:var(--text-caption);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-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;width:40px;height:40px;font-size:var(--text-h2);border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;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{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.btn-edit:hover{background:color-mix(in srgb,var(--color-primary) 12%,transparent)}}.btn-edit:hover{color:var(--color-secondary)}.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:var(--text-body)}.btn-pause:hover{color:#b45309;background:#fef3c7}.btn-resume{background:var(--color-primary);color:#fff;font-size:var(--text-body)}.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{font-size:var(--text-caption);color:var(--color-text-secondary);text-align:center;margin:4px 0 0;padding:4px}@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:var(--text-body);line-height:1}.btn-increment,.btn-decrement,.btn-resume{width:38px;height:38px;font-size:var(--text-section)}.habit-actions{gap:6px}.habit-info{overflow:hidden}.habit-name{font-size:.82rem}}.modal-overlay{z-index:var(--z-dialog);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{font-size:var(--text-section);color:var(--color-text);margin-bottom:12px;font-weight:600}.modal-text{font-size:var(--text-body);color:var(--color-text-secondary);margin-bottom:24px;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;font-size:var(--text-body);cursor:pointer;border:none;padding:10px 20px;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{font-size:var(--text-section);color:var(--color-text);margin-bottom:20px;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(--habit-color,var(--color-border));border-radius:var(--radius-md);background:var(--color-bg-secondary);width:44px;height:40px;color:var(--color-text-secondary);font-size:var(--text-base);cursor:pointer;justify-content:center;align-items:center;padding:0;transition:border-color .15s,background .15s,box-shadow .15s;display:flex}.emoji-trigger.has-emoji{font-size:var(--text-h1);color:var(--color-text);border-color:var(--habit-color,var(--color-primary));background:var(--habit-color,var(--color-primary))}@supports (color:color-mix(in lab,red,red)){.emoji-trigger.has-emoji{background:color-mix(in srgb,var(--habit-color,var(--color-primary)) 8%,transparent)}}.emoji-trigger:hover{border-color:var(--habit-color,var(--color-primary));background:var(--habit-color,var(--color-primary))}@supports (color:color-mix(in lab,red,red)){.emoji-trigger:hover{background:color-mix(in srgb,var(--habit-color,var(--color-primary)) 6%,var(--color-bg-secondary))}}.emoji-trigger:hover{box-shadow:0 0 0 3px var(--habit-color,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(--habit-color,var(--color-primary)) 15%,transparent)}}.emoji-trigger:active{transform:scale(.94)}.emoji-dropdown{z-index:var(--z-fab);box-shadow:var(--shadow-md);border-radius:var(--radius-md);position:absolute;top:calc(100% + 4px);left:0;overflow:hidden}.emoji-picker-dialog{flex-direction:column;gap:12px;max-width:360px;padding:16px;display:flex}.emoji-picker-dialog-header{justify-content:space-between;align-items:center;display:flex}.emoji-picker-dialog-title{font-size:var(--text-base);color:var(--color-text);margin:0;font-weight:600}.emoji-picker-recent{flex-direction:column;gap:6px;display:flex}.emoji-picker-recent-label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0;font-weight:600}.emoji-picker-recent-grid{grid-template-columns:repeat(8,1fr);gap:4px;display:grid}.emoji-picker-recent-btn{aspect-ratio:1;width:100%;font-size:var(--text-h1);background:var(--color-card);border:1px solid var(--color-border);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;padding:0;transition:background .15s,transform .1s;display:flex}.emoji-picker-recent-btn:hover{background:var(--color-hover)}.emoji-picker-recent-btn:active{transform:scale(.92)}.emoji-picker-clear-btn{border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--text-body-sm);color:var(--color-text-secondary);cursor:pointer;background:0 0;align-self:flex-start;padding:8px 16px;transition:background .15s,color .15s}.emoji-picker-clear-btn:hover{background:var(--color-danger-bg,var(--color-danger))}@supports (color:color-mix(in lab,red,red)){.emoji-picker-clear-btn:hover{background:var(--color-danger-bg,color-mix(in srgb, var(--color-danger) 10%, transparent))}}.emoji-picker-clear-btn:hover{color:var(--color-danger);border-color:var(--color-danger)}.emoji-picker-dialog .EmojiPickerReact{border:1px solid var(--color-border);border-radius:var(--radius-md);max-width:100%;--epr-bg-color:var(--color-card)!important;--epr-category-label-bg-color:var(--color-card)!important;--epr-text-color:var(--color-text)!important;--epr-search-input-bg-color:var(--color-bg)!important;--epr-search-input-text-color:var(--color-text)!important;--epr-search-input-placeholder-color:var(--color-text-secondary)!important;--epr-search-border-color:var(--color-border)!important;--epr-picker-border-color:var(--color-border)!important;--epr-hover-bg-color:var(--color-hover)!important;--epr-focus-bg-color:var(--color-hover)!important;--epr-category-icon-active-color:var(--color-primary)!important;--epr-highlight-color:var(--color-primary)!important;--epr-emoji-padding:4px!important}.emoji-picker-dialog .EmojiPickerReact .epr-cat-btn:focus:before,.emoji-picker-dialog .EmojiPickerReact .epr-cat-btn:focus-visible:before,.emoji-picker-dialog .EmojiPickerReact .epr-cat-btn.epr-active:before,.emoji-picker-dialog .EmojiPickerReact .epr-cat-btn.epr-active:focus:before{content:none!important;border:none!important;display:none!important}.emoji-picker-dialog .EmojiPickerReact .epr-search-container input.epr-search{padding-left:36px!important}.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);font-size:var(--text-caption);cursor:pointer;text-align:center;padding:8px;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{font-size:var(--text-body);color:var(--color-text);margin-bottom:8px;font-weight:500;display:block}.label-hint{font-size:var(--text-caption);color:var(--color-text-secondary);margin-top:2px;font-weight:400;display:block}.weight-info-details{font-size:var(--text-caption);color:var(--color-text-secondary);margin-top:8px}.weight-info-details summary{cursor:pointer;color:var(--color-primary);-webkit-user-select:none;user-select:none;align-items:center;gap:4px;font-weight:500;list-style:none;display:inline-flex}.weight-info-details summary::-webkit-details-marker{display:none}.weight-info-details summary:before{content:"?";border:1px solid var(--color-primary);width:14px;height:14px;font-size:var(--text-micro);border-radius:50%;justify-content:center;align-items:center;font-weight:600;display:inline-flex}.weight-info-details[open] summary:before{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.weight-info-details summary:hover{text-decoration:underline}.weight-info-details p{background:var(--color-primary);margin-top:6px;padding:8px 10px}@supports (color:color-mix(in lab,red,red)){.weight-info-details p{background:color-mix(in srgb,var(--color-primary) 6%,var(--color-card))}}.weight-info-details p{border-radius:var(--radius-sm);border-left:3px solid var(--color-primary);line-height:1.5}.form-group input[type=text],.form-group input[type=number]{border:1px solid var(--color-border);border-radius:var(--radius-md);width:100%;font-size:var(--text-base);padding:12px;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);font-size:var(--text-body);resize:vertical;min-height:70px;padding:10px 12px;font-family:inherit;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);font-size:var(--text-caption);margin-top:4px;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{font-weight:500;font-size:var(--text-body);color:var(--color-text)}.type-desc{font-size:var(--text-caption);color:var(--color-text-secondary);margin-top:2px}.weight-selector{flex-direction:column;gap:8px;display:flex}.weight-stars{gap:4px;display:flex}.weight-star{width:36px;height:36px;font-size:var(--text-h1-lg);color:var(--color-border);cursor:pointer;background:0 0;border:none;padding:0;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{font-size:var(--text-body-sm);color:var(--color-text-secondary)}.impact-preview,.target-preview{font-size:var(--text-caption);color:var(--color-text-secondary);background:var(--color-bg);border-radius:var(--radius-sm);margin-top:8px;padding:8px}.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);width:80px;font-size:var(--text-base);text-align:center;padding:12px}.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);font-size:var(--text-body);background:var(--color-card);cursor:pointer;flex:1;padding:12px}.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);width:100%;font-size:var(--text-body);background:var(--color-card);color:var(--color-text);cursor:pointer;padding:12px}.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-advanced-toggle{border:1px solid var(--habit-color,var(--color-border));width:100%;color:var(--color-text-secondary,#888);cursor:pointer;background:0 0;border-radius:10px;justify-content:space-between;align-items:center;margin:12px 0;padding:10px 14px;font-size:.9rem;transition:color .15s,border-color .15s;display:flex}.form-advanced-toggle:hover{color:var(--habit-color,var(--color-primary));border-color:var(--habit-color,var(--color-primary))}.form-advanced-chevron{transition:transform .2s}.form-advanced-chevron.open{transform:rotate(90deg)}.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);font-size:var(--text-body);cursor:pointer;padding:10px 20px;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;font-size:var(--text-body);cursor:pointer;border:none;padding:10px 20px;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{font-size:var(--text-caption);color:var(--color-text-secondary);cursor:pointer}.debug-footer pre{color:var(--color-success);border-radius:var(--radius-md);font-size:var(--text-xs);background:#1a1a1a;margin-top:8px;padding:12px;overflow-x:auto}.debug-controls{border-radius:var(--radius-md);background:#2a2a2a;margin-top:12px;padding:12px}.debug-controls p{color:#ccc;font-size:var(--text-caption);margin-bottom:8px}.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;min-width:100px;font-size:var(--text-caption);flex:1}.debug-habit-row button{font-size:var(--text-xs);cursor:pointer;background:var(--color-primary);color:#fff;border:none;border-radius:4px;padding:4px 8px}.debug-habit-row button:last-child{background:#ef4444}.app-loading{width:100%;min-height:100vh;font-size:var(--text-base);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:var(--z-dialog);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{font-size:var(--text-h2);flex:1;margin:0;font-weight:600}.habit-detail-header .btn-close{background:var(--color-bg);border-radius:var(--radius-md);width:44px;min-width:44px;height:44px;min-height:44px;font-size:var(--text-h1);cursor:pointer;color:var(--color-text-secondary);border:none;flex-shrink:0;justify-content:center;align-items:center;transition:all .2s;display:inline-flex}.habit-detail-header .btn-close:hover{background:var(--color-border);color:var(--color-text)}.habit-detail-description{font-size:var(--text-body-sm);color:var(--color-text-secondary);text-align:center;white-space:pre-wrap;margin:0;padding:0 16px 12px;line-height:1.5}.habit-freeze-badge{font-size:var(--text-caption);cursor:default;background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:inline-flex}.habit-freeze-icon{color:#0284c7;width:14px;height:14px}[data-theme=dark] .habit-freeze-icon{color:#38bdf8}.habit-note-icon{width:14px;height:14px;color:var(--color-text-secondary)}.habit-note-icon--filled{color:var(--color-primary)}.habit-freeze-badge--btn{cursor:pointer;border-radius:4px;padding:1px 3px;transition:background .15s}.habit-freeze-badge--btn:hover{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.habit-freeze-badge--btn:hover{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-card))}}[data-theme=dark] .habit-freeze-badge--btn:hover{background:#0c4a6e40}.habit-note-btn{font-size:var(--text-caption);cursor:pointer;opacity:.5;background:0 0;border:none;padding:0 2px;line-height:1;transition:opacity .15s}.habit-note-btn:hover{opacity:1}.habit-restore-btn{z-index:var(--z-stack-3);cursor:pointer;color:var(--color-text-secondary);opacity:.75;background:0 0;border:none;justify-content:center;align-items:center;padding:6px;line-height:1;transition:opacity .15s,color .15s,transform .15s;display:inline-flex;position:absolute;top:4px;right:4px}.habit-restore-btn:hover,.habit-restore-btn:active{opacity:1;color:var(--color-primary);transform:scale(1.1)}.note-modal-textarea{border:1px solid var(--color-border,#e2e2e0);width:100%;min-height:120px;font-size:var(--text-base);background:var(--color-bg,#fafaf8);color:var(--color-text,#1c1c1a);resize:vertical;border-radius:8px;outline:none;padding:12px;font-family:inherit}.note-modal-textarea:focus{border-color:var(--color-primary)}.note-modal-footer{justify-content:space-between;align-items:center;margin-top:8px;display:flex}.habit-note-count{font-size:var(--text-caption);color:#999;white-space:nowrap}[data-theme=dark] .note-modal-textarea{background:var(--color-bg-dark,#1a1a2e);border-color:#333}.dayview-frozen-badge{font-size:var(--text-xs);color:var(--color-primary-dark);background:var(--color-primary);margin-left:auto;font-weight:600}@supports (color:color-mix(in lab,red,red)){.dayview-frozen-badge{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-card))}}.dayview-frozen-badge{border-radius:4px;margin-bottom:4px;padding:2px 7px;display:inline-block}[data-theme=dark] .dayview-frozen-badge{color:#7dd3fc;background:#0c4a6e40}.btn-freeze{font-size:var(--text-body);border:1px solid var(--color-primary);background:0 0}@supports (color:color-mix(in lab,red,red)){.btn-freeze{border:1px solid color-mix(in srgb,var(--color-primary) 25%,transparent)}}.btn-freeze{cursor:pointer;border-radius:6px;flex-shrink:0;padding:4px 8px;transition:background .15s}.btn-freeze:hover{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.btn-freeze:hover{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-card))}}[data-theme=dark] .btn-freeze{border-color:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){[data-theme=dark] .btn-freeze{border-color:color-mix(in srgb,var(--color-primary) 25%,transparent)}}[data-theme=dark] .btn-freeze{color:#7dd3fc}[data-theme=dark] .btn-freeze:hover{background:#0c4a6e40}.btn-restore{font-size:var(--text-body);border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-secondary);background:0 0;border-radius:6px;flex-shrink:0;padding:4px 8px;line-height:1;transition:background .15s,color .15s}.btn-restore:hover{background:var(--color-surface);color:var(--color-primary)}[data-theme=dark] .btn-restore{border-color:var(--color-border);color:var(--color-text-secondary)}[data-theme=dark] .btn-restore:hover{background:var(--color-surface);color:var(--color-primary)}.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{font-size:var(--text-body-sm);background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.btn-freeze-detail{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-card))}}.btn-freeze-detail{border:1px solid var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.btn-freeze-detail{border:1px solid color-mix(in srgb,var(--color-primary) 25%,transparent)}}.btn-freeze-detail{cursor:pointer;color:var(--color-primary-dark);border-radius:6px;align-self:flex-start;padding:6px 12px;font-weight:600;transition:background .15s}.btn-freeze-detail:hover{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.btn-freeze-detail:hover{background:color-mix(in srgb,var(--color-primary) 25%,transparent)}}.btn-freeze-confirm{font-size:var(--text-body);background:var(--color-primary-dark);cursor:pointer;color:#fff;border:none;border-radius:6px;padding:8px 16px;font-weight:600;transition:background .15s}.btn-freeze-confirm:hover{background:#0284c7}.day-edit-freeze-hint{font-size:var(--text-caption);color:var(--text-secondary);margin:0}.day-edit-frozen-note{font-size:var(--text-caption);color:var(--color-primary-dark);margin:12px 0 0;font-weight:600}.calendar-day.frozen{background:var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.calendar-day.frozen{background:color-mix(in srgb,var(--color-primary) 8%,var(--color-card))}}.calendar-day.frozen{color:var(--color-primary-dark);font-weight:600}[data-theme=dark] .calendar-day.frozen{color:#7dd3fc;background:#0c4a6e40}[data-theme=dark] .btn-freeze-detail{border-color:var(--color-primary);background:#0c4a6e40}@supports (color:color-mix(in lab,red,red)){[data-theme=dark] .btn-freeze-detail{border-color:color-mix(in srgb,var(--color-primary) 25%,transparent)}}[data-theme=dark] .btn-freeze-detail{color:#7dd3fc}[data-theme=dark] .btn-freeze-detail:hover{background:#0c4a6e70}.legend-dot.frozen{background:#7dd3fc}.habit-atrisk-chip{font-size:var(--text-xs);color:#b45309;background:#fef3c7;border-radius:4px;margin-top:2px;margin-bottom:4px;padding:2px 6px;font-weight:600;line-height:1.4;display:block}[data-theme=dark] .habit-atrisk-chip{color:#fcd34d;background:#78350f40}.at-risk-badge{font-size:var(--text-xs);color:#ea580c;background:0 0;border:none;align-items:center;gap:4px;padding:0;font-weight:600;line-height:1.4;display:inline-flex}.dark .at-risk-badge,[data-theme=dark] .at-risk-badge{color:#f87171}.at-risk-badge-icon{flex-shrink:0;width:12px;height:12px}.at-risk-badge-wrapper{z-index:var(--z-stack-2);pointer-events:none;position:absolute!important;top:6px!important;left:50%!important;right:auto!important;transform:translate(-50%)!important}.at-risk-badge--top,.at-risk-badge--inline{white-space:nowrap;margin:0}.habit-atrisk-chip--footer{font-size:var(--text-caption);border-radius:8px;flex:0 0 100%;margin-top:4px;margin-bottom:0;padding:4px 10px;display:block}.habit-detail-atrisk-note{font-size:var(--text-body-sm);color:#f59e0b;border-radius:var(--radius-sm);text-align:center;background:#f59e0b14;margin:0 0 12px;padding:8px 12px}.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:var(--text-h2)}.stat-value{font-size:var(--text-h1-lg);color:var(--color-text);font-weight:700}.stat-label{font-size:var(--text-xs);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px}.habit-calendar-section{margin-bottom:24px}.habit-calendar-section h3{font-size:var(--text-body);color:var(--color-text);margin-bottom:12px;font-weight:600}.habit-calendar-nav{justify-content:space-between;align-items:center;margin-bottom:8px;display:flex}.habit-cal-nav-btn{cursor:pointer;font-size:var(--text-base);color:var(--color-text);border-radius:var(--radius-sm);background:0 0;border:none;padding:4px 8px;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{font-size:var(--text-body-sm);color:var(--color-text);font-weight:600}.habit-calendar-weekdays{grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px;display:grid}.habit-cal-weekday{font-size:var(--text-micro);color:var(--color-text-secondary);text-align:center;padding:2px 0;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;font-size:var(--text-micro);color:var(--color-text-secondary);justify-content:center;align-items:center;font-weight:500;transition:all .2s;display:flex}.calendar-day.missed{background:var(--color-border)}.calendar-day.partial{background:var(--color-score-mid);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{font-size:var(--text-caption);color:var(--color-text-secondary);gap:16px;margin-top: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-score-mid)}.legend-dot.completed{background:var(--color-success)}.habit-info-section{border-top:1px solid var(--color-border);padding-top:16px}.habit-info-section p{font-size:var(--text-body);color:var(--color-text-secondary);margin-bottom:8px}.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{font-size:var(--text-body-sm);color:var(--color-text-muted);margin:0}.habit-reminder-row{justify-content:space-between;align-items:center;gap:12px;display:flex}.habit-reminder-label{font-size:var(--text-body);color:var(--color-text);cursor:pointer;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{font-size:var(--text-body-sm);color:var(--color-text-muted)}.habit-reminder-time-input{border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-input-bg);color:var(--color-text);font-size:var(--text-body);cursor:pointer;padding:6px 10px}.time-picker-5min{align-items:center;gap:2px;display:inline-flex}.time-picker-5min__sep{color:var(--color-text);-webkit-user-select:none;user-select:none;padding:0 1px;font-weight:600}.habit-edit-zone{border-top:1px solid var(--color-border);flex-wrap:wrap;justify-content:center;gap:8px;margin-top:20px;padding-top:16px;display:flex}.btn-edit-outline{border-radius:var(--radius-md);min-height:42px;font-size:var(--text-body-sm);cursor:pointer;border:1px solid var(--color-primary);color:var(--color-primary);background:0 0;flex:1;padding:10px 16px;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);flex-wrap:wrap;justify-content:center;gap:8px;margin-top:12px;padding-top:16px;display:flex}.btn-golden-outline{border-radius:var(--radius-md);min-height:42px;font-size:var(--text-body-sm);cursor:pointer;color:#b45309;background:0 0;border:1px solid #facc15;flex:1;padding:10px 16px;font-weight:500;transition:all .2s}.btn-golden-outline:hover:not(:disabled){background:#fffbeb}.btn-golden-outline:disabled{opacity:.5;cursor:not-allowed}.btn-golden-outline.btn-golden-locked{color:#4b5563;border-color:#9ca3af}.btn-golden-active{border-radius:var(--radius-md);min-height:42px;font-size:var(--text-body-sm);cursor:pointer;color:#92400e;background:#fef3c7;border:2px solid #facc15;flex:1;padding:10px 16px;font-weight:600;transition:all .2s}.btn-golden-active:hover{background:#fde68a}[data-theme=dark] .btn-golden-outline:hover:not(:disabled){background:#f59e0b1a}[data-theme=dark] .btn-golden-active{color:#fbbf24;background:#f59e0b26}.btn-danger-outline{border-radius:var(--radius-md);min-height:42px;font-size:var(--text-body-sm);cursor:pointer;color:#b91c1c;background:0 0;border:1px solid #ef4444;flex:1;padding:10px 16px;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{font-size:var(--text-body-sm);color:#b91c1c;margin-bottom:8px}.btn-delete-small{border-radius:var(--radius-md);font-size:var(--text-body-sm);cursor:pointer;color:#fff;background:#ef4444;border:none;padding:8px 16px;font-weight:500;transition:all .2s}.btn-delete-small:hover{background:#dc2626}.calendar-hint{font-size:var(--text-caption);color:var(--color-text-secondary);margin-bottom:8px}.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{font-size:var(--text-body);color:var(--color-text);margin-bottom:12px;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);font-size:var(--text-base);cursor:pointer;padding:12px 24px;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;width:90px;height:40px;font-size:var(--text-section);border:1px solid var(--color-border);border-radius:var(--radius-md);font-weight:600}.edit-value-input:focus{border-color:var(--color-primary);outline:none}.edit-target{font-size:var(--text-body);color:var(--color-text-secondary);margin-left:4px}.day-edit-actions{justify-content:center;gap:12px;margin-top:12px;display:flex}.btn-cancel-small,.btn-save-small{border-radius:var(--radius-md);font-size:var(--text-body-sm);cursor:pointer;padding:8px 16px;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:var(--z-dialog);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:var(--z-stack-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);width:100%;font-size:var(--text-caption);cursor:pointer;color:var(--color-text);border:none;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:var(--font-weight-bold)}.dayview-calendar-day.today{border:2px solid var(--color-primary)}.dayview-calendar-day.today.selected{border-color:#fff}.dayview-future-warning{background:var(--color-score-mid);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{font-size:2rem;font-weight:var(--font-weight-bold);text-align:center;min-width:80px}.dayview-progress-info{flex-direction:column;display:flex}.dayview-progress-label{color:var(--color-text-secondary);font-size:.9rem}.dayview-progress-detail{font-size:var(--text-base);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-card);border-radius:var(--radius-md);border-left:4px solid #0000;border-top:1px solid var(--color-border);border-right:1px solid var(--color-border);border-bottom:1px solid var(--color-border);touch-action:pan-y;-webkit-user-select:none;user-select:none;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:var(--z-stack-1);position:relative}.dayview-habit-row{align-items:center;gap:8px;display:flex}.dayview-habit-card.golden{border:2px solid #facc15;border-left-width:4px}.dayview-habit-info{flex-direction:column;gap:4px;display:flex}.dayview-habit-name-row{align-items:center;gap:8px;display:flex}.dayview-habit-meta{flex-wrap:wrap;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{font-size:var(--text-caption);color:var(--color-text-secondary);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{width:16px;height:16px;color:var(--color-text-secondary)}.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:var(--text-h2);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,minmax(0,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:var(--font-weight-bold)}.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:var(--text-caption)}}.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{font-size:var(--text-base);align-items:center;line-height:1;display:inline-flex}.report-card-title{font-size:var(--text-body-sm);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.3px;font-weight:600}.scoring-note{text-align:center;font-size:var(--text-caption);color:var(--color-text-secondary);margin:-4px 0 8px}.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);font-size:var(--text-base);cursor:pointer;color:var(--color-text);background:0 0;justify-content:center;align-items:center;padding:6px 10px;line-height:1;transition:background .15s;display:inline-flex}.btn-share>svg{width:18px;height:18px}.btn-share:hover{background:var(--color-surface-hover)}.share-card-modal{flex-direction:column;gap:16px;max-width:420px;display:flex}.share-card-title{font-size:var(--text-section);color:var(--color-text);margin:0;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{font-size:var(--text-body);color:var(--color-text-secondary)}.share-card-empty{text-align:center;font-size:var(--text-body);color:var(--color-text-secondary);flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:24px;line-height:1.5;display:flex}.share-card-img{object-fit:cover;border-radius:12px;width:100%;height:100%}.share-card-error{font-size:var(--text-body-sm);color:var(--color-danger);text-align:center;padding:0 8px}.share-card-actions{gap:10px;display:flex}.share-card-btn{font-size:var(--text-body);cursor:pointer;border:none;border-radius:10px;flex:1;padding:12px;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}.share-card-period-picker{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;gap:4px;width:100%;padding:4px;display:flex}.share-card-period-btn{min-height:36px;color:var(--color-text-secondary);font-size:var(--text-body);cursor:pointer;background:0 0;border:none;border-radius:7px;flex:1;padding:8px 12px;font-weight:600;transition:background .15s,color .15s}.share-card-period-btn.is-active{background:var(--color-primary);color:#fff}.share-card-period-btn:not(.is-active):hover{color:var(--color-text)}.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{font-size:var(--text-body);color:var(--color-text);margin-bottom:8px;font-weight:600}.scoring-info-section p{font-size:var(--text-body-sm);color:var(--color-text-secondary,#888);margin-bottom:6px;line-height:1.5}.scoring-formula-box{background:var(--color-surface,#1a1a1a);border:1px solid var(--color-border);font-family:monospace;font-size:var(--text-body-sm);color:var(--color-primary);border-radius:8px;margin:8px 0;padding:10px 14px}.scoring-weight-grid{flex-direction:column;gap:6px;margin:8px 0;display:flex}.scoring-weight-row{font-size:var(--text-body-sm);align-items:center;gap:10px;display:flex}.scoring-weight-stars{min-width:60px;font-size:var(--text-caption)}.scoring-timeframe-table{border-collapse:collapse;width:100%;font-size:var(--text-body-sm);margin:8px 0}.scoring-timeframe-table th{text-align:left;border-bottom:1px solid var(--color-border);font-size:var(--text-caption);color:var(--color-text-secondary,#888);padding:6px 8px}.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:var(--text-caption)!important}.scoring-info-list{flex-direction:column;gap:8px;margin:8px 0;padding:0;list-style:none;display:flex}.scoring-info-list li{font-size:var(--text-body-sm);color:var(--color-text-secondary,#888);border-left:2px solid var(--color-border);padding-left:12px;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{font-size:var(--text-body-sm);border-bottom:1px solid var(--color-border);align-items:center;gap:10px;padding:7px 12px;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{font-size:var(--text-xs);color:var(--color-text-secondary,#888);opacity:.7;min-width:60px}.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:var(--z-stack-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);font-size:var(--text-xs);text-transform:none;letter-spacing:0;z-index:var(--z-fab);pointer-events:none;border-radius:6px;padding:8px 10px;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:var(--z-stack-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);font-size:var(--text-micro);text-transform:none;letter-spacing:0;z-index:var(--z-fab);pointer-events:none;border-radius:5px;padding:6px 8px;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{font-size:var(--text-caption);color:var(--color-text-secondary);margin:0;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{font-size:var(--text-xs);color:var(--color-text-secondary)}@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{font-size:var(--text-display);min-width:70px;margin-bottom:0}.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{font-size:var(--text-body);align-items:center;line-height:1;display:inline-flex}.tf-card-label{font-size:var(--text-xs);color:var(--color-text-secondary);font-weight:500}.tf-card-percent{font-size:var(--text-h2);margin-top:2px;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{font-size:var(--text-micro);color:var(--color-text-secondary)}.reportview-overlay{touch-action:none;z-index:var(--z-dialog);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{font-size:var(--text-section);margin:0;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);width:44px;min-width:44px;height:44px;min-height:44px;font-size:var(--text-h1);cursor:pointer;color:var(--color-text);border:none;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.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);font-size:var(--text-body-sm);cursor:pointer;color:var(--color-text-secondary);border:none;flex:1;padding:6px 0;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);font-size:var(--text-body-sm);background:var(--color-card);color:var(--color-text);cursor:pointer;flex:1;padding:6px 12px}.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{font-size:var(--text-hero);text-align:center;min-width:100px;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{font-size:var(--text-caption);color:var(--color-text-secondary);text-align:center;min-width:35px}.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-header--clickable{cursor:pointer;background:0 0;border:none;border-radius:8px;width:100%;padding:0;transition:opacity .15s,transform .15s}.login-header--clickable:hover{opacity:.85}.login-header--clickable:active{transform:scale(.98)}.login-header--clickable:focus-visible{outline:2px solid var(--color-primary);outline-offset:4px}.login-logo{object-fit:contain;width:auto;height:128px}.login-title{font-size:var(--text-hero);color:var(--color-primary);margin:0 0 8px;font-weight:700}.login-tagline{font-size:var(--text-base);color:var(--color-text-secondary);margin:0}.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{font-size:var(--text-body-lg);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-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-terms-label{font-size:var(--text-body-sm);color:var(--color-text-secondary);cursor:pointer;align-items:flex-start;gap:10px;margin-bottom:4px;line-height:1.5;display:flex}.login-terms-label input[type=checkbox]{accent-color:var(--color-primary);cursor:pointer;flex-shrink:0;width:15px;height:15px;margin-top:2px}.login-terms-label a{color:var(--color-primary);text-decoration:none}.login-terms-label a:hover{text-decoration:underline}.login-terms-disclaimer{font-size:var(--text-caption);color:var(--color-text-secondary);text-align:center;margin:12px 4px 0;line-height:1.5}.login-terms-disclaimer a{color:var(--color-primary);text-decoration:none}.login-terms-disclaimer a:hover{text-decoration:underline}.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;font-size:var(--text-caption)!important;margin-top:8px!important}.login-loading{font-size:var(--text-base);font-family:var(--font-sans,system-ui, -apple-system, sans-serif);color:var(--color-text-secondary);text-align:center;width:100%;padding:48px 0}.login-tabs{border:1.5px solid var(--color-border);border-radius:var(--radius-md);margin-bottom:20px;display:flex;overflow:hidden}.login-tab{font-size:var(--text-body);cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;flex:1;padding:9px 0;font-weight:500;transition:background .15s,color .15s}.login-tab--active{background:var(--color-primary);color:#fff}.login-form{text-align:left;flex-direction:column;gap:14px;margin-bottom:16px;display:flex}.login-field{flex-direction:column;gap:5px;display:flex}.login-field label{font-size:var(--text-body-sm);color:var(--color-text);justify-content:space-between;align-items:center;font-weight:500;display:flex}.login-field input{font-size:var(--text-body-lg);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);outline:none;padding:10px 12px;transition:border-color .15s,box-shadow .15s}.login-field input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.login-field input:focus{box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,transparent)}}.login-forgot-link{cursor:pointer;font-size:var(--text-caption);color:var(--color-primary);background:0 0;border:none;padding:0;font-weight:400}.login-forgot-link:hover{text-decoration:underline}.login-submit-btn{width:100%;font-size:var(--text-body-lg);color:#fff;background:var(--color-primary);border-radius:var(--radius-md);cursor:pointer;border:none;margin-top:2px;padding:11px;font-weight:600;transition:background .15s,opacity .15s}.login-submit-btn:hover{background:var(--color-primary-dark)}.login-submit-btn:disabled{opacity:.6;cursor:not-allowed}.login-privacy-badge{background:var(--color-primary);align-items:center;gap:6px;padding:8px 10px;display:flex}@supports (color:color-mix(in lab,red,red)){.login-privacy-badge{background:color-mix(in srgb,var(--color-primary) 6%,transparent)}}.login-privacy-badge{border:1px solid var(--color-primary)}@supports (color:color-mix(in lab,red,red)){.login-privacy-badge{border:1px solid color-mix(in srgb,var(--color-primary) 18%,transparent)}}.login-privacy-badge{border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--text-caption);margin-bottom:4px;line-height:1.4}.login-privacy-badge svg{color:var(--color-primary);flex-shrink:0}[data-theme=dark] .login-privacy-badge{color:var(--color-text)}.login-error{color:#b91c1c;border-radius:var(--radius-sm);font-size:var(--text-body-sm);text-align:left;background:#ef44441f;border:1px solid #ef44444d;margin-bottom:4px;padding:10px 12px}[data-theme=dark] .login-error{color:#fca5a5}.login-error.login-error--success{background:var(--color-success)}@supports (color:color-mix(in lab,red,red)){.login-error.login-error--success{background:color-mix(in srgb,var(--color-success) 12%,transparent)}}.login-error.login-error--success{border-color:var(--color-success)}@supports (color:color-mix(in lab,red,red)){.login-error.login-error--success{border-color:color-mix(in srgb,var(--color-success) 30%,transparent)}}.login-error.login-error--success{color:#047857}[data-theme=dark] .login-error.login-error--success{color:#6ee7b7}.login-recovery-done{background:var(--color-success)}@supports (color:color-mix(in lab,red,red)){.login-recovery-done{background:color-mix(in srgb,var(--color-success) 12%,transparent)}}.login-recovery-done{border:1px solid var(--color-success)}@supports (color:color-mix(in lab,red,red)){.login-recovery-done{border:1px solid color-mix(in srgb,var(--color-success) 30%,transparent)}}.login-recovery-done{border-radius:var(--radius-md);text-align:center;color:#047857;margin-bottom:16px;padding:16px}[data-theme=dark] .login-recovery-done{color:#6ee7b7}.login-recovery-done-title{font-size:var(--text-base);margin:0 0 4px;font-weight:600}.login-recovery-done-desc{font-size:var(--text-body-sm);opacity:.85;margin:0 0 12px}.login-recovery-done-btn{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm);font-size:var(--text-body);cursor:pointer;border:none;padding:8px 20px;font-weight:500;transition:background .15s}.login-recovery-done-btn:hover{background:var(--color-primary-dark)}.login-divider{color:var(--color-text-secondary);font-size:var(--text-body-sm);align-items:center;gap:12px;margin:4px 0 16px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--color-border);flex:1;height:1px}.login-subtitle{font-size:var(--text-base);color:var(--color-text-secondary);text-align:center;margin:0 0 16px}.login-link{cursor:pointer;font-size:var(--text-body);color:var(--color-primary);background:0 0;border:none;margin-top:8px;padding:4px 0;display:block}.login-link--center{text-align:center;width:100%}.login-link:hover{text-decoration:underline}.login-check-email{text-align:center;padding:8px 0 16px}.login-check-email-icon{font-size:var(--text-hero);margin-bottom:12px}.login-check-email-text{color:var(--color-text);margin:0 0 20px;font-size:.95rem;line-height:1.6}.login-mfa-hint{color:var(--color-text-secondary);text-align:center;margin:0 0 20px;font-size:.9rem;line-height:1.5}.login-mfa-input{letter-spacing:.2em;text-align:center;font-variant-numeric:tabular-nums;font-weight:600;font-size:1.4rem!important}@media(max-width:480px){.login-card{padding:32px 24px}.login-title{font-size:2rem}.login-description p{font-size:var(--text-base)}}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{font-size:var(--text-h1);flex-shrink:0;margin-top:1px}.pwa-banner-text{font-size:var(--text-body-sm);color:var(--color-text,#1a1a1a);flex-direction:column;gap:6px;display:flex}.pwa-banner-text strong{font-size:var(--text-body)}.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);font-size:var(--text-body-sm);cursor:pointer;white-space:nowrap;border:none;padding:6px 14px;font-weight:600}.pwa-banner-install:hover{opacity:.9}.pwa-banner-close{width:24px;height:24px;color:var(--color-text-secondary,#888);font-size:var(--text-base);cursor:pointer;background:0 0;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;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);font-size:var(--text-caption);cursor:pointer;white-space:nowrap;text-align:right;background:0 0;border:none;padding:4px 8px}.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:var(--z-celebration);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{font-size:var(--text-hero);margin-bottom:12px}.pwa-push-title{font-size:var(--text-section);color:var(--color-text,#1a1a1a);margin:0 0 10px;font-weight:700}.pwa-push-body{font-size:var(--text-body);color:var(--color-text-secondary,#666);margin:0 0 24px;line-height:1.5}.pwa-push-actions{flex-direction:column;gap:10px;display:flex}.pwa-push-btn{width:100%;font-size:var(--text-body-lg);cursor:pointer;border:none;border-radius:12px;padding:14px;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)}.loading-spinner{border:3px solid var(--bg-tertiary,#0000001a);border-top-color:var(--color-primary,#6366f1);border-radius:50%;width:24px;height:24px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.bottom-nav{background:var(--color-card);border-top:1px solid var(--color-border);z-index:var(--z-pwa);padding-bottom:env(safe-area-inset-bottom,0);touch-action:manipulation;align-items:flex-start;display:flex;position:fixed;bottom:0;left:0;right:0;box-shadow:0 -1px 8px #0000000f}[data-slot=dialog-overlay]{bottom:calc(56px + env(safe-area-inset-bottom,0px))!important}.bottom-nav *{pointer-events:auto!important}.bottom-nav-tab{color:var(--color-text-secondary);cursor:pointer;min-height:56px;font-size:var(--text-micro);-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;padding:10px 4px;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{font-size:var(--text-caption);letter-spacing:.01em;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;width:56px;height:56px;z-index:var(--z-fab);border:none;border-radius:50%;justify-content:center;align-items:center;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;font-size:var(--text-body-sm)!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-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:var(--text-body-sm);line-height:1}.habit-card-content{gap:8px!important;padding:8px 104px 8px 12px!important}.habit-emoji-box{width:38px!important;height:38px!important;font-size:var(--text-h2)!important;border-radius:10px!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:var(--z-stack-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,.habit-streak--chip.habit-streak--base,.habit-streak--chip.habit-streak--warm,.habit-streak--chip.habit-streak--hot,.habit-streak--chip.habit-streak--legendary{height:auto!important;box-shadow:none!important;font-size:var(--text-xs)!important;color:#c2410c!important;white-space:nowrap!important;background:0 0!important;border:none!important;border-radius:0!important;justify-content:center!important;align-self:stretch!important;align-items:center!important;gap:4px!important;padding:0!important;font-weight:600!important;line-height:1.4!important;display:flex!important;position:static!important}.habit-streak-icon{flex-shrink:0;width:12px;height:12px}@keyframes streak-glow-base{0%,88%,to{filter:drop-shadow(0 0 #0000)}91%{filter:drop-shadow(0 0 3px color-mix(in srgb,currentColor 35%,transparent))}94%{filter:drop-shadow(0 0 4px color-mix(in srgb,currentColor 60%,transparent))}97%{filter:drop-shadow(0 0 2px color-mix(in srgb,currentColor 25%,transparent))}}@keyframes streak-glow-warm{0%,80%,to{filter:drop-shadow(0 0 #0000)}83%{filter:drop-shadow(0 0 5px color-mix(in srgb,currentColor 65%,transparent))}87%{filter:drop-shadow(0 0 8px)}91%{filter:drop-shadow(0 0 6px color-mix(in srgb,currentColor 80%,transparent))}95%{filter:drop-shadow(0 0 4px color-mix(in srgb,currentColor 40%,transparent))}}@keyframes streak-glow-hot{0%,60%,to{filter:drop-shadow(0 0 #0000)}68%{filter:drop-shadow(0 0 6px color-mix(in srgb,currentColor 70%,transparent))}74%{filter:drop-shadow(0 0 10px currentColor) drop-shadow(0 0 18px color-mix(in srgb,currentColor 50%,transparent))}80%{filter:drop-shadow(0 0 12px currentColor) drop-shadow(0 0 22px color-mix(in srgb,currentColor 60%,transparent))}86%{filter:drop-shadow(0 0 12px currentColor) drop-shadow(0 0 22px color-mix(in srgb,currentColor 60%,transparent))}91%{filter:drop-shadow(0 0 9px color-mix(in srgb,currentColor 75%,transparent))}96%{filter:drop-shadow(0 0 4px color-mix(in srgb,currentColor 40%,transparent))}}@keyframes streak-glow-legendary{0%,40%,to{filter:drop-shadow(0 0 #0000)}50%{filter:drop-shadow(0 0 8px color-mix(in srgb,currentColor 75%,transparent))}60%{filter:drop-shadow(0 0 14px currentColor) drop-shadow(0 0 24px color-mix(in srgb,currentColor 60%,transparent))}68%{filter:drop-shadow(0 0 16px currentColor) drop-shadow(0 0 30px color-mix(in srgb,currentColor 70%,transparent))}76%{filter:drop-shadow(0 0 16px currentColor) drop-shadow(0 0 30px color-mix(in srgb,currentColor 70%,transparent))}84%{filter:drop-shadow(0 0 16px currentColor) drop-shadow(0 0 30px color-mix(in srgb,currentColor 70%,transparent))}90%{filter:drop-shadow(0 0 12px currentColor) drop-shadow(0 0 22px color-mix(in srgb,currentColor 55%,transparent))}95%{filter:drop-shadow(0 0 7px color-mix(in srgb,currentColor 60%,transparent))}}.habit-streak--chip.habit-streak--warm,.habit-streak--chip.habit-streak--hot,.habit-streak--chip.habit-streak--legendary{will-change:filter}@supports not color-mix(in srgb,red 50%,blue){@keyframes streak-glow-base{0%,88%,to{filter:drop-shadow(0 0 #0000)}93%{filter:drop-shadow(0 0 3px)}}@keyframes streak-glow-warm{0%,80%,to{filter:drop-shadow(0 0 #0000)}87%{filter:drop-shadow(0 0 6px)}}@keyframes streak-glow-hot{0%,60%,to{filter:drop-shadow(0 0 #0000)}78%{filter:drop-shadow(0 0 10px)}}@keyframes streak-glow-legendary{0%,40%,to{filter:drop-shadow(0 0 #0000)}72%{filter:drop-shadow(0 0 14px)}}}.habit-streak--chip.habit-streak--base{animation:7s ease-in-out infinite streak-glow-base}.habit-streak--chip.habit-streak--warm{animation:5s ease-in-out infinite streak-glow-warm}.habit-streak--chip.habit-streak--hot{animation:4s ease-in-out infinite streak-glow-hot}.habit-streak--chip.habit-streak--legendary{animation:3s ease-in-out infinite streak-glow-legendary}@media(prefers-reduced-motion:reduce){.habit-streak--chip{animation:none!important}}.dark .habit-streak--chip,.dark .habit-streak--chip.habit-streak--base,.dark .habit-streak--chip.habit-streak--warm,.dark .habit-streak--chip.habit-streak--hot,.dark .habit-streak--chip.habit-streak--legendary,[data-theme=dark] .habit-streak--chip,[data-theme=dark] .habit-streak--chip.habit-streak--base,[data-theme=dark] .habit-streak--chip.habit-streak--warm,[data-theme=dark] .habit-streak--chip.habit-streak--hot,[data-theme=dark] .habit-streak--chip.habit-streak--legendary{color:#fbbf24!important}.habit-stepper{height:28px!important}.habit-stepper-btn{width:24px!important;font-size:var(--text-body)!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{font-size:var(--text-micro);color:#b45309;white-space:nowrap;background:#fef3c7;border-radius:4px;align-items:center;padding:1px 5px;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{height:18px;font-size:var(--text-micro);color:#b45309;white-space:nowrap;background:#fef3c7;border-radius:9px;justify-content:center;align-items:center;padding:0 8px;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{width:28px!important;height:28px!important;font-size:var(--text-body)!important;border-radius:8px!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-end;gap:8px;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-item--hero{flex:1.3}.three-rings-item--hero .three-rings-label{font-size:var(--text-body);color:var(--color-primary);font-weight:700}.three-rings-label{font-size:var(--text-caption);text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted-foreground);font-weight:600}.three-rings-sub{font-size:var(--text-xs);color:var(--color-muted-foreground);text-align:center}.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);font-size:var(--text-micro);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:50%;justify-content:center;align-items:center;font-style:italic;font-weight:700;line-height:1;display:flex;position:absolute;top:-4px;right:-4px}.three-rings-tooltip{z-index:var(--z-panel-bg);background:var(--color-card);border:1px solid var(--color-border);font-size:var(--text-caption);color:var(--color-text);border-radius:8px;min-width:280px;max-width:300px;padding:8px 10px;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{font-size:var(--text-display);background:var(--color-bg);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.report-analytics-btn-text{flex-direction:column;gap:2px;display:flex}.report-analytics-btn-text strong{font-size:var(--text-body-lg);color:var(--color-text);font-weight:600}.report-analytics-btn-text small{font-size:var(--text-body-sm);color:var(--color-muted)}.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{font-size:var(--text-body-sm);color:var(--color-muted-foreground);cursor:pointer;white-space:nowrap;background:0 0;border:none;border-radius:7px;padding:6px 14px;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{border:1px solid var(--color-border);background:var(--color-card);cursor:pointer;width:36px;height:36px;color:var(--color-text-secondary);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,border-color .15s,transform .1s;display:flex;box-shadow:0 1px 2px #0000000a}.report-subtab-action-btn:hover{background:var(--color-hover);border-color:var(--color-text-secondary);color:var(--color-text)}.report-subtab-action-btn:active{transform:scale(.93)}.report-subtab-action-icon{width:16px;height:16px}.report-subtab-action-btn--ai{border-color:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.report-subtab-action-btn--ai{border-color:color-mix(in srgb,var(--color-accent) 40%,var(--color-border))}}.report-subtab-action-btn--ai{color:var(--color-accent)}.report-subtab-action-btn--ai:hover{background:var(--color-accent)}@supports (color:color-mix(in lab,red,red)){.report-subtab-action-btn--ai:hover{background:color-mix(in srgb,var(--color-accent) 10%,var(--color-card))}}.report-subtab-action-btn--ai:hover{border-color:var(--color-accent);color:var(--color-accent)}.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{font-size:var(--text-caption);color:var(--color-primary);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:6px;font-weight:600;display:flex}.corr-teaser-icon{line-height:1}.corr-teaser-pro{font-size:var(--text-xs);color:var(--color-accent);background:var(--color-accent);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{font-size:var(--text-body-sm);color:var(--color-text);grid-column:1;line-height:1.4}.corr-teaser-cta{font-size:var(--text-caption);color:var(--color-primary);white-space:nowrap;grid-area:2/2;align-self:end;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{width:16px;height:16px;color:var(--color-accent);flex-shrink:0}.corr-upsell-icon{vertical-align:-2px;width:14px;height:14px;color:var(--color-accent);display:inline}.corr-title{font-size:var(--text-body);color:var(--color-accent);text-transform:uppercase;letter-spacing:.04em;flex:1;margin:0;font-weight:700}.corr-pro-badge{font-size:var(--text-xs);color:var(--color-accent);background:var(--color-accent);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{font-size:var(--text-body-sm);color:var(--color-text-secondary);text-align:center;padding:12px 0;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{font-size:var(--text-body-sm);color:var(--color-text);margin:0;line-height:1.5}.corr-text strong{color:var(--color-text);font-weight:600}.corr-highlight{font-weight:700;font-size:var(--text-body)}.corr-highlight--positive{color:var(--color-success)}.corr-highlight--negative{color:#f59e0b}.corr-avg{font-size:var(--text-caption);color:var(--color-text-secondary)}.corr-upsell{border:1px dashed var(--color-border);background:var(--color-primary);border-radius:12px;padding:16px}@supports (color:color-mix(in lab,red,red)){.corr-upsell{background:color-mix(in srgb,var(--color-primary) 5%,transparent)}}.corr-upsell{-webkit-user-select:none;user-select:none}.corr-upsell--clickable{cursor:pointer;transition:transform .15s,background .2s}.corr-upsell--clickable:hover,.corr-upsell--clickable:focus-visible{background:var(--color-primary);transform:translateY(-1px)}@supports (color:color-mix(in lab,red,red)){.corr-upsell--clickable:hover,.corr-upsell--clickable:focus-visible{background:color-mix(in srgb,var(--color-primary) 10%,transparent)}}.corr-upsell--clickable:hover,.corr-upsell--clickable:focus-visible{outline:none}.corr-upsell-title{font-size:var(--text-body);color:var(--color-text);margin:0 0 6px;font-weight:600}.corr-upsell-desc{font-size:var(--text-body-sm);color:var(--color-text-secondary);margin:0 0 10px;line-height:1.5}.corr-upsell-cta{font-size:var(--text-body-sm);color:var(--color-primary);font-weight:600;display:inline-block}.vacation-banner{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:12px;align-items:center;gap:12px;margin:12px 0;padding:12px 16px;display:flex;box-shadow:0 1px 3px #0000000f}[data-theme=dark] .vacation-banner{color:#fef3c7;background:linear-gradient(135deg,#78350f,#92400e);border-color:#f59e0b}.vacation-banner-icon{font-size:var(--text-h1-lg);flex-shrink:0;line-height:1}.vacation-banner-text{flex-direction:column;flex:1;gap:2px;min-width:0;display:flex}.vacation-banner-text strong{font-size:var(--text-body);color:#78350f;font-weight:600}[data-theme=dark] .vacation-banner-text strong{color:#fef3c7}.vacation-banner-text span{font-size:var(--text-caption);color:#92400e;line-height:1.4}[data-theme=dark] .vacation-banner-text span{color:#fde68a}.vacation-banner-btn{font-size:var(--text-caption);color:#78350f;cursor:pointer;background:#fffc;border:1px solid #f59e0b;border-radius:8px;flex-shrink:0;padding:6px 12px;font-weight:600;transition:background .15s}.vacation-banner-btn:hover{background:#fff}[data-theme=dark] .vacation-banner-btn{color:#fef3c7;background:#0000004d;border-color:#f59e0b}[data-theme=dark] .vacation-banner-btn:hover{background:#00000080}.dark .habit-streak--base,[data-theme=dark] .habit-streak--base,.dark .habit-streak--warm,[data-theme=dark] .habit-streak--warm{color:#fb923c}.dark .habit-streak--hot,[data-theme=dark] .habit-streak--hot{color:#facc15}.dark .habit-streak--legendary,[data-theme=dark] .habit-streak--legendary{color:#fbbf24}.dark .habit-weight,[data-theme=dark] .habit-weight{color:var(--color-accent)}.dark .btn-golden-outline,[data-theme=dark] .btn-golden-outline{color:#fbbf24}.dark .btn-golden-outline.btn-golden-locked,[data-theme=dark] .btn-golden-outline.btn-golden-locked{color:#9ca3af}.dark .btn-edit-outline,[data-theme=dark] .btn-edit-outline{color:#7c93f0;border-color:#7c93f0}.dark .btn-danger-outline,[data-theme=dark] .btn-danger-outline{color:#f87171}.test-mode-fab{bottom:calc(160px + env(safe-area-inset-bottom,0px));z-index:9999;border:2px solid var(--color-primary);background:var(--color-card);width:48px;height:48px;color:var(--color-text);font-size:var(--text-display);cursor:pointer;border-radius:50%;justify-content:center;align-items:center;padding:0;transition:transform .15s;display:flex;position:fixed;right:16px;box-shadow:0 4px 12px #0003}.test-mode-fab:hover{transform:scale(1.08)}.test-mode-fab:active{transform:scale(.95)}.test-mode-panel{bottom:calc(220px + env(safe-area-inset-bottom,0px));z-index:9999;background:var(--color-card);border:1px solid var(--color-primary);width:min(360px,100vw - 32px);max-height:70vh;color:var(--color-text);border-radius:12px;padding:16px;position:fixed;right:16px;overflow-y:auto;box-shadow:0 8px 24px #00000040}.test-mode-header{font-weight:700;font-size:var(--text-base);justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.test-mode-close{font-size:var(--text-section);cursor:pointer;color:var(--color-text);background:0 0;border:none;border-radius:4px;padding:4px 8px}.test-mode-close:hover{background:#00000014}.test-mode-scenarios{flex-direction:column;gap:8px;display:flex}.test-mode-label{font-size:var(--text-caption);text-transform:uppercase;opacity:.6;margin:8px 0 4px;font-weight:700}.test-mode-btn{text-align:left;background:var(--color-bg);width:100%;color:var(--color-text);cursor:pointer;font-size:var(--text-body);border:1px solid #0000001f;border-radius:8px;flex-direction:column;gap:2px;padding:10px 12px;font-weight:600;transition:background .15s,border-color .15s;display:flex}.test-mode-btn span{font-size:var(--text-xs);opacity:.7;font-weight:400}.test-mode-btn:hover:not(:disabled){border-color:var(--color-primary);background:#3b5bdb14}.test-mode-btn:disabled{opacity:.5;cursor:not-allowed}.test-mode-btn--danger{color:#ef4444;border-color:#ef444466}.test-mode-divider{border:none;border-top:1px solid #00000014;margin:8px 0}[data-theme=dark] .test-mode-btn{background:#ffffff0d;border-color:#ffffff1f}[data-theme=dark] .test-mode-btn:hover:not(:disabled){background:#7c93f026}[data-theme=dark] .test-mode-divider{border-top-color:#ffffff1a}[data-theme=dark] .test-mode-close:hover{background:#ffffff1a}.dark .clear-history-warning,[data-theme=dark] .clear-history-warning{color:#f87171}@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))}}
