:root{--surface:oklch(.978 .004 85);--surface-2:oklch(.962 .006 88);--surface-3:oklch(.94 .008 90);--surface-paper:oklch(.995 .003 85);--surface-ink:oklch(.18 .018 150);--surface-ink-2:oklch(.235 .02 150);--ink:oklch(.22 .015 150);--ink-2:oklch(.42 .015 150);--ink-3:oklch(.58 .012 150);--ink-4:oklch(.72 .01 150);--ink-on-dark:oklch(.96 .006 90);--brand:oklch(.42 .08 148);--brand-strong:oklch(.32 .075 150);--brand-soft:oklch(.92 .025 145);--brand-haze:oklch(.96 .012 145);--brand-ink:oklch(.25 .06 150);--safe:oklch(.62 .16 145);--safe-soft:oklch(.93 .05 145);--safe-ink:oklch(.34 .12 145);--avoid:oklch(.58 .18 28);--avoid-soft:oklch(.94 .045 30);--avoid-ink:oklch(.38 .14 28);--warn:oklch(.74 .14 75);--warn-soft:oklch(.95 .05 80);--warn-ink:oklch(.44 .12 70);--line:oklch(.92 .006 90);--line-soft:oklch(.95 .005 90);--line-strong:oklch(.84 .008 90);--line-brand:color-mix(in oklch,var(--brand) 28%,transparent);--ease-out:cubic-bezier(.23,1,.32,1);--ease-out-quart:cubic-bezier(.165,.84,.44,1);--ease-in-out:cubic-bezier(.77,0,.175,1);--ease-drawer:cubic-bezier(.32,.72,0,1);--ease-snap:cubic-bezier(.34,1.2,.64,1);--dur-press:.14s;--dur-fast:.18s;--dur-base:.22s;--dur-slow:.32s;--font-display:"Outfit",system-ui,sans-serif;--font-body:"DM Sans",system-ui,sans-serif;--font-mono:ui-monospace,"JetBrains Mono","SFMono-Regular",Menlo,monospace;--fs-2xs:.6875rem;--fs-xs:.78rem;--fs-sm:.9rem;--fs-base:1.02rem;--fs-md:1.15rem;--fs-lg:1.32rem;--fs-xl:1.6rem;--fs-2xl:2rem;--fs-3xl:2.6rem;--fs-4xl:3.4rem;--fs-display:clamp(2.4rem,4.6vw + .6rem,4.4rem);--lh-tight:1.05;--lh-snug:1.18;--lh-normal:1.5;--lh-relaxed:1.7;--tracking-tight:-.025em;--tracking-snug:-.012em;--tracking-normal:0;--tracking-wide:.06em;--fw-regular:400;--fw-medium:500;--fw-semibold:600;--fw-bold:700;--fw-extra:800;--space-1:.25rem;--space-2:.5rem;--space-3:.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-7:1.75rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--space-20:5rem;--space-24:6rem;--space-32:8rem;--radius-xs:4px;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:22px;--radius-2xl:28px;--radius-pill:999px;--radius-full:9999px;--shadow-xs:0 1px 2px oklch(.22 .015 150/.05);--shadow-sm:0 1px 3px oklch(.22 .015 150/.06),0 1px 2px oklch(.22 .015 150/.04);--shadow-md:0 6px 14px -6px oklch(.22 .015 150/.1),0 2px 5px -1px oklch(.22 .015 150/.05);--shadow-lg:0 18px 30px -10px oklch(.22 .015 150/.12),0 6px 12px -3px oklch(.22 .015 150/.06);--shadow-xl:0 28px 60px -14px oklch(.22 .015 150/.16),0 10px 20px -6px oklch(.22 .015 150/.08);--shadow-soft:0 8px 24px -8px oklch(.22 .015 150/.08);--shadow-rim:inset 0 1px 0 oklch(1 0 0/.6);--z-dropdown:100;--z-sticky:200;--z-modal:300;--z-toast:400;--color-bg-primary:var(--surface);--color-bg-secondary:var(--surface-paper);--color-bg-tertiary:var(--surface-2);--color-bg-card:var(--surface-paper);--color-bg-hover:var(--brand-haze);--color-bg-section-alt:var(--surface-2);--color-bg-dark:var(--surface-ink);--color-bg-dark-card:var(--surface-ink-2);--color-text-primary:var(--ink);--color-text-secondary:var(--ink-2);--color-text-muted:var(--ink-3);--color-text-on-dark:var(--ink-on-dark);--color-accent:var(--brand);--color-accent-hover:var(--brand-strong);--color-accent-light:var(--brand-soft);--color-accent-surface:var(--brand-haze);--color-accent-deep:var(--brand-ink);--color-accent-text:var(--brand-ink);--color-secondary-accent:var(--avoid);--color-secondary-bg:var(--avoid-soft);--color-success:var(--safe);--color-success-bg:var(--safe-soft);--color-warning:var(--warn);--color-warning-bg:var(--warn-soft);--color-danger:var(--avoid);--color-danger-bg:var(--avoid-soft);--color-border:var(--line);--color-border-light:var(--line-soft);--color-border-accent:var(--line-brand);--font-size-xs:var(--fs-xs);--font-size-sm:var(--fs-sm);--font-size-base:var(--fs-base);--font-size-lg:var(--fs-md);--font-size-xl:var(--fs-lg);--font-size-2xl:var(--fs-xl);--font-size-3xl:var(--fs-2xl);--font-size-4xl:var(--fs-3xl);--font-weight-normal:var(--fw-regular);--font-weight-medium:var(--fw-medium);--font-weight-semibold:var(--fw-semibold);--font-weight-bold:var(--fw-bold);--line-height-tight:var(--lh-snug);--line-height-normal:var(--lh-normal);--line-height-relaxed:var(--lh-relaxed);--transition-fast:var(--dur-fast) var(--ease-out);--transition-base:var(--dur-base) var(--ease-out);--transition-slow:var(--dur-slow) var(--ease-out)}@media(prefers-reduced-motion:reduce){:root{--dur-press:0ms;--dur-fast:0ms;--dur-base:0ms;--dur-slow:0ms}}.fade-in{animation:fadeIn .6s ease-out forwards}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in-up{animation:fadeInUp .6s ease-out forwards}@keyframes fadeInUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.scale-in{animation:scaleIn .5s cubic-bezier(.34,1.56,.64,1) forwards}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.slide-up{animation:slideUp .8s ease-out forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.shimmer{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#f1f5f9 25%,#e2e8f0,#f1f5f9 75%);background-size:200% 100%}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(1turn)}}.stagger-1{animation-delay:.05s}.stagger-2{animation-delay:.1s}.stagger-3{animation-delay:.15s}.stagger-4{animation-delay:.2s}.stagger-5{animation-delay:.25s}.stagger-6{animation-delay:.3s}[class*=stagger-]{animation-fill-mode:forwards;opacity:0}@media(prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}.shimmer,.spin{animation:none!important}}.card-elevated{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);transition:box-shadow var(--transition-base),transform var(--transition-base),border-color var(--transition-base)}.card-elevated:hover{border-color:var(--color-border-accent);box-shadow:var(--shadow-lg);transform:scale(1.015)}.badge{align-items:center;border-radius:var(--radius-sm);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);gap:4px;letter-spacing:.05em;padding:4px 10px;text-transform:uppercase}.badge-safe{background:var(--color-success-bg);color:var(--color-accent-deep)}.badge-warning{background:var(--color-warning-bg);color:#92400e}.badge-danger{background:var(--color-danger-bg);color:#991b1b}.badge-neutral{background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.badge-pill{border-radius:var(--radius-full)}.icon-container{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:44px;justify-content:center;transition:transform var(--transition-fast);width:44px}.icon-container:hover{transform:scale(1.05)}.icon-container.green{background:var(--color-accent-light);color:var(--color-accent-deep)}.icon-container.blue{background:#dbeafe;color:#1d4ed8}.icon-container.rose{background:#ffe4e6;color:#be123c}.icon-container.amber{background:#fef3c7;color:#92400e}.icon-container.violet{background:#ede9fe;color:#6d28d9}.icon-container.sky{background:#e0f2fe;color:#0369a1}.icon-container.orange{background:#ffedd5;color:#ea580c}.icon-container.pink{background:#fce7f3;color:#db2777}*,:after,:before{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:var(--color-bg-primary);font-family:var(--font-body);font-size:var(--font-size-base);line-height:var(--line-height-normal);min-height:100vh;min-height:100dvh}body,h1,h2,h3,h4,h5,h6{color:var(--color-text-primary)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:var(--font-weight-bold);letter-spacing:-.02em;line-height:var(--line-height-tight)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}a{color:var(--color-accent);font-weight:var(--font-weight-medium);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-accent-hover)}.btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-family:var(--font-display);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);gap:var(--space-2);justify-content:center;line-height:1;overflow:hidden;padding:var(--space-3) var(--space-6);position:relative;text-decoration:none;transition:all var(--transition-base)}.btn:disabled{cursor:not-allowed;filter:grayscale(.3);opacity:.5}.btn-primary{background:var(--color-text-primary);box-shadow:var(--shadow-sm);color:#fff}.btn-primary:hover:not(:disabled){background:#0f172a;box-shadow:var(--shadow-lg);transform:scale(1.015)}.btn-accent{background:var(--color-accent);box-shadow:var(--shadow-sm);color:#fff}.btn-accent:hover:not(:disabled){background:var(--color-accent-hover);box-shadow:var(--shadow-lg);transform:scale(1.015)}.btn-secondary{background:var(--color-bg-secondary);border:1px solid var(--color-border);color:var(--color-text-primary)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:var(--color-text-muted)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text-primary)}.btn-outline{background:transparent;border:1.5px solid var(--color-accent);color:var(--color-accent)}.btn-outline:hover:not(:disabled){background:var(--color-accent-surface);box-shadow:var(--shadow-lg);transform:scale(1.015)}.btn-white{background:#fff;box-shadow:var(--shadow-md);color:var(--color-text-primary)}.btn-white:hover:not(:disabled){background:#f8fafc;box-shadow:var(--shadow-lg);transform:scale(1.015)}.btn-lg{font-size:var(--font-size-lg);padding:var(--space-4) var(--space-8)}.btn-sm{font-size:var(--font-size-sm);padding:var(--space-2) var(--space-4)}.btn-icon{border-radius:var(--radius-md);height:40px;padding:0;width:40px}a.btn.btn-accent,a.btn.btn-primary{color:#fff}a.btn.btn-white{color:var(--color-text-primary)}a.btn.btn-outline{color:var(--color-accent)}a.btn.btn-secondary{color:var(--color-text-primary)}a.btn.btn-ghost{color:var(--color-text-secondary)}.card{background:var(--color-bg-card);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-xs);padding:var(--space-6)}.card-hover{transition:transform var(--transition-base),box-shadow var(--transition-base),border-color var(--transition-base)}.card-hover:hover{border-color:var(--color-border-accent);box-shadow:var(--shadow-lg);transform:scale(1.015)}.input{background:var(--color-bg-tertiary);border:1.5px solid transparent;border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-body);font-size:var(--font-size-base);outline:none;padding:var(--space-3) var(--space-4);transition:all var(--transition-fast);width:100%}.input:focus{background:var(--color-bg-secondary);border-color:var(--color-accent);outline:3px solid var(--color-accent-light);outline-offset:0}.input::-moz-placeholder{color:var(--color-text-muted)}.input::placeholder{color:var(--color-text-muted)}.result-safe{background:linear-gradient(135deg,#f0fdf4,#fff);border-color:var(--color-success)}.result-warning{background:linear-gradient(135deg,#fef9c3,#fff);border-color:var(--color-warning)}.result-danger{background:linear-gradient(135deg,#fee2e2,#fff);border-color:var(--color-danger)}.fade-enter-active,.fade-leave-active{transition:opacity var(--transition-base)}.fade-enter-from,.fade-leave-to{opacity:0}.slide-up-enter-active,.slide-up-leave-active{transition:all var(--transition-base)}.slide-up-enter-from,.slide-up-leave-to{opacity:0;transform:translateY(16px)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-muted{color:var(--color-text-muted)}.text-accent{color:var(--color-accent)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.font-display{font-family:var(--font-display)}.font-medium{font-weight:var(--font-weight-medium)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-bold{font-weight:var(--font-weight-bold)}.sr-only{height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;width:1px;clip:rect(0,0,0,0);border:0;white-space:nowrap}img{height:auto;max-width:100%}.container{margin:0 auto;max-width:1200px;padding:0 var(--space-4);width:100%}.container--narrow{max-width:800px}.container--wide{max-width:1100px}.page-shell{min-height:80vh;padding-bottom:var(--space-16)}.page-header--public{padding:var(--space-12) 0 var(--space-8);text-align:center}.page-header--public h1{color:var(--color-text-primary);font-size:var(--font-size-4xl);font-weight:800;letter-spacing:-.03em;line-height:1.15;margin-bottom:var(--space-3)}.page-header--public .subtitle{color:var(--color-text-secondary);font-size:var(--font-size-lg);line-height:1.7;margin:0 auto;max-width:600px}@media(max-width:640px){.container{overflow-x:hidden}.page-header--public h1{font-size:var(--font-size-3xl)}.page-header--public .subtitle{font-size:var(--font-size-base)}}.page-header--app{margin-bottom:var(--space-6)}.page-header--app h1{color:var(--color-text-primary);font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-1)}.page-header--app p{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.page-enter-active,.page-leave-active{transition:all .25s ease}.page-enter-from,.page-leave-to{opacity:0;transform:translateY(8px)}.p-0{padding:0}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.mt-4{margin-top:var(--space-4)}.mb-4{margin-bottom:var(--space-4)}.mr-2{margin-right:var(--space-2)}.mx-auto{margin-left:auto;margin-right:auto}.w-full{width:100%}.btn-icon-sm{align-items:center;background:var(--color-accent);border:none;border-radius:var(--radius-lg);color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;height:32px;justify-content:center;line-height:1;transition:transform var(--transition-fast),background var(--transition-fast),box-shadow var(--transition-fast);width:32px}.btn-icon-sm:hover:not(:disabled){transform:scale(1.05)}.btn-icon-sm:disabled{cursor:not-allowed;opacity:.5}.btn-icon-sm.cancel{background:var(--color-text-muted)}.btn-icon-sm.cancel:hover:not(:disabled){background:var(--color-danger)}.btn-icon-sm--compact{border-radius:var(--radius-md);font-size:.8rem;height:24px;width:24px}.spinner{animation:spin .8s cubic-bezier(.4,0,.2,1) infinite;border:3px solid var(--color-bg-tertiary);border-radius:50%;border-top-color:var(--color-accent);flex-shrink:0;height:24px;width:24px}.spinner--sm{border-width:2px;height:20px;width:20px}.spinner--muted{border-color:currentColor hsla(0,0%,100%,.3) hsla(0,0%,100%,.3)}.spinner--lg{border-width:4px;height:40px;width:40px}.spinner-inline{animation:spin .7s linear infinite;border:2px solid hsla(0,0%,100%,.4);border-radius:50%;border-top-color:#fff;display:inline-block;height:18px;margin-right:var(--space-2);vertical-align:middle;width:18px}.banner{align-items:flex-start;border-radius:var(--radius-lg);display:flex;font-size:var(--font-size-sm);gap:var(--space-3);line-height:1.5;padding:var(--space-3) var(--space-4)}.banner--between{align-items:center;justify-content:space-between}.banner__icon{flex-shrink:0;font-size:1.25rem;line-height:1}.banner__body{display:flex;flex:1;flex-direction:column;gap:2px;min-width:0}.banner__title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold)}.banner__hint{font-size:var(--font-size-sm);opacity:.9}.banner p{flex:1;margin:0;min-width:0}.banner__cta{color:var(--color-accent);flex-shrink:0;font-weight:var(--font-weight-semibold)}.banner__dismiss{background:none;border:none;color:inherit;cursor:pointer;flex-shrink:0;font-size:1.1rem;line-height:1;opacity:.85;padding:var(--space-1) var(--space-2)}.banner__dismiss:hover{opacity:1}.banner--error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.banner--error.banner--simple{border:none;color:#b91c1c;padding:var(--space-3)}.banner--info{background:#f0fdf4;color:#166534}.banner--warning{background:#fffbeb;color:#92400e}.banner--notice{align-items:center;background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:var(--radius-xl);cursor:pointer;display:flex;gap:var(--space-3);padding:var(--space-4)}.banner--notice .banner__icon{font-size:1.5rem}.banner--notice .banner__title{color:#92400e}.banner--notice .banner__hint{color:#b45309}.banner--promo{align-items:center;background:linear-gradient(135deg,#f0fdf4,#ecfeff);border:1px solid var(--color-accent);color:inherit;gap:var(--space-4);margin-bottom:var(--space-6);padding:var(--space-4);text-decoration:none;transition:transform .15s ease,box-shadow .15s ease}.banner--promo:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.banner--promo .banner__body{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.banner--promo .banner__body strong{color:var(--color-text-primary);font-size:var(--font-size-base)}.banner--promo .banner__body>span{display:block}.banner--promo .banner__icon{font-size:1.75rem}.nav-icon-tone--home{color:#f97316}.nav-icon-tone--scan{color:#22c55e}.nav-icon-tone--tracker{color:#8b5cf6}.nav-icon-tone--calendar{color:#ec4899}.nav-icon-tone--history{color:#0ea5e9}.nav-icon-tone--profile{color:#f59e0b}.nav-icon-tone--tools{color:#14b8a6}.auth-global-overlay{align-items:center;background:var(--color-bg-primary,#fff);display:flex;inset:0;justify-content:center;position:fixed;z-index:99999}.auth-global-spinner{animation:auth-spin .8s linear infinite;border:3px solid #e2e8f0;border-radius:50%;border-top:3px solid var(--color-accent,#4ade80);height:36px;width:36px}@keyframes auth-spin{to{transform:rotate(1turn)}}.auth-overlay-fade-enter-active,.auth-overlay-fade-leave-active{transition:opacity .25s ease}.auth-overlay-fade-enter-from,.auth-overlay-fade-leave-to{opacity:0}
