:root{--color-primary: #3d5a47;--color-primary-light: #5a7a63;--color-primary-dark: #2a3f31;--color-primary-bg: #f2f5f3;--color-surface: #ffffff;--color-background: #f8f7f5;--color-text: #1a1a1a;--color-text-muted: #787872;--color-border: #e6e5e1;--color-danger: #b91c1c;--color-warning: #b45309;--color-focus-ring: rgba(61, 90, 71, .25);--color-navbar-bg: rgba(248, 247, 245, .92);--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-display: "Georgia", "Times New Roman", serif;--font-mono: "SF Mono", "Fira Code", monospace;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .03);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .04);--shadow-md: 0 2px 8px rgba(0, 0, 0, .06);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .08);--navbar-height: 56px;--tab-bar-height: 56px;--safe-bottom: env(safe-area-inset-bottom, 0px);--ease-out: cubic-bezier(.22, 1, .36, 1)}[data-theme=dark]{--color-primary: #5a8a64;--color-primary-light: #6ea07a;--color-primary-dark: #3d5a47;--color-primary-bg: #1e2e22;--color-surface: #2a2a2a;--color-background: #1a1a1a;--color-text: #e8e8e8;--color-text-muted: #999999;--color-border: #3a3a3a;--color-danger: #ef4444;--color-warning: #f59e0b;--color-focus-ring: rgba(90, 138, 100, .3);--color-navbar-bg: rgba(26, 26, 26, .92);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .2);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .25);--shadow-md: 0 2px 8px rgba(0, 0, 0, .3);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .4);color-scheme:dark}[data-theme=dark] .badge-meal{background:#1e3025;color:#7cc08a}[data-theme=dark] .badge-meal-breakfast{background:#3a3225;color:#c4a86a}[data-theme=dark] .badge-meal-lunch{background:#1e3025;color:#7cc08a}[data-theme=dark] .badge-meal-dinner{background:#252538;color:#9a9ac8}[data-theme=dark] .badge-meal-snack{background:#35302b;color:#b8a898}[data-theme=dark] .badge-complexity,[data-theme=dark] .badge-admin{background:#3a3225;color:#c4a86a}[data-theme=dark] .badge-tag,[data-theme=dark] .badge-secondary{background:#333;color:#aaa}[data-theme=dark] .error-box,[data-theme=dark] .form-error{background:#3a1c1c;color:#f87171}[data-theme=dark] .item-breakdown-source--off{background:#1e3025;color:#6ea07a}[data-theme=dark] .item-breakdown-source--llm{background:#3a3225;color:#c4a86a}[data-theme=dark] .status-closed{background:#3a1c1c}[data-theme=dark] .admin-off-stat{background:var(--color-surface)}[data-theme=dark] .admin-off-stat-label{color:var(--color-text-muted)}[data-theme=dark] .admin-off-stat-value{color:var(--color-text)}[data-theme=dark] .admin-off-empty{color:var(--color-text-muted)}[data-theme=dark] .admin-off-history-table th,[data-theme=dark] .admin-off-history-table td{border-color:var(--color-border)}[data-theme=dark] .admin-off-progress-bar{background:var(--color-border)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{-webkit-text-size-adjust:100%;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{font-family:var(--font-sans);font-size:15px;line-height:1.6;color:var(--color-text);background:var(--color-background);overflow-x:hidden;min-height:100dvh;padding:env(safe-area-inset-top,0) env(safe-area-inset-right,0) 0 env(safe-area-inset-left,0);letter-spacing:-.01em}a{color:inherit;text-decoration:none}button{font:inherit;cursor:pointer;border:none;background:none}img{display:block;max-width:100%}ul,ol{list-style:none}input,textarea,select{font:inherit;color:inherit}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}:focus:not(:focus-visible){outline:none}.app{display:flex;flex-direction:column;min-height:100dvh}.main-content{flex:1;padding:20px 16px calc(var(--tab-bar-height) + var(--safe-bottom) + 20px);max-width:960px;width:100%;margin:var(--navbar-height) auto 0;animation:fadeIn .25s var(--ease-out)}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.navbar-top{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--navbar-height);display:flex;align-items:center;justify-content:space-between;padding:0 max(16px,env(safe-area-inset-right,16px)) 0 max(16px,env(safe-area-inset-left,16px));background:var(--color-navbar-bg);border-bottom:1px solid var(--color-border);backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2)}.navbar-brand{display:flex;align-items:center;gap:0;font-family:var(--font-display);font-weight:700;font-size:1.1rem;color:var(--color-text);letter-spacing:-.03em}.navbar-user{display:flex;align-items:center;gap:10px;font-size:.82rem;color:var(--color-text-muted)}.navbar-avatar-link{display:flex;align-items:center;gap:8px;text-decoration:none;color:var(--color-text-muted);border-radius:20px;padding:2px 8px 2px 2px;transition:background .15s}.navbar-avatar-link:hover{background:#0000000d;color:var(--color-text)}.navbar-avatar{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:.75rem;font-weight:700;line-height:1;flex-shrink:0}.navbar-logout{display:inline-flex;align-items:center;gap:4px}.navbar-logout svg{width:15px;height:15px}.navbar-logout-label{display:none}@media(min-width:480px){.navbar-logout-label{display:inline}}.navbar-desktop-nav,.navbar-username{display:none}@media(min-width:480px){.navbar-username{display:inline}}.navbar-bottom{position:fixed;bottom:0;left:0;right:0;z-index:100;height:calc(var(--tab-bar-height) + var(--safe-bottom));display:flex;align-items:stretch;justify-content:space-around;background:var(--color-navbar-bg);border-top:1px solid var(--color-border);backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);padding-bottom:var(--safe-bottom)}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;min-height:44px;color:var(--color-text-muted);font-size:.68rem;font-weight:500;transition:color .2s var(--ease-out);-webkit-tap-highlight-color:transparent;letter-spacing:.01em}.tab-item:active{background:#0000000a}.tab-icon{font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center}.tab-icon svg{width:20px;height:20px}.tab-active{color:var(--color-primary)}.tab-active .tab-icon{transition:none}.card{background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-xs);border:1px solid var(--color-border);transition:box-shadow .2s var(--ease-out)}.card:hover{box-shadow:var(--shadow-sm)}.recipe-card{cursor:pointer;padding:0;display:flex;flex-direction:column}.recipe-card:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.recipe-card-placeholder{width:100%;border-radius:var(--radius-md) var(--radius-md) 0 0;overflow:hidden;flex-shrink:0}.recipe-card-placeholder svg{width:100%;height:auto;display:block}.recipe-card--compact .recipe-card-placeholder{display:none}[data-theme=dark] .recipe-card-placeholder{--placeholder-bg: #1a2e1a;--placeholder-fg: #4a7a63}.recipe-card-body{display:flex;flex-direction:column;gap:10px;min-width:0;position:relative;padding:16px}.recipe-card-title{font-size:1rem;font-weight:600;color:var(--color-text);line-height:1.35;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;letter-spacing:-.01em;padding-right:28px}.recipe-card-desc{font-size:.88rem;color:var(--color-text-muted);line-height:1.5}.recipe-card-meta{display:flex;flex-wrap:wrap;gap:6px}.recipe-card-stats{display:flex;flex-wrap:wrap;gap:12px;font-size:.82rem;color:var(--color-text-muted)}.stat{white-space:nowrap;font-size:.8rem}.stat+.stat:before{content:"·";margin-right:12px;color:var(--color-border)}.recipe-card-tags{display:flex;flex-wrap:wrap;gap:6px;margin-top:2px}.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-sm);font-size:.72rem;font-weight:500;line-height:1.6;white-space:nowrap;letter-spacing:.02em;text-transform:uppercase}.badge-meal{background:var(--color-primary-bg);color:var(--color-primary)}.badge-meal-breakfast{background:#faf5ee;color:#8b6e40}.badge-meal-lunch{background:#f2f5f3;color:#3d5a47}.badge-meal-dinner{background:#f0f0f5;color:#4a4a6a}.badge-meal-snack{background:#f5f2f0;color:#6a5a4f}.badge-complexity{background:#f5f0e8;color:#7a6a4f}.badge-tag{background:#f3f3f1;color:#5a5a55;font-weight:500;text-transform:none}.badge-admin{background:#f5f0e8;color:#7a6a4f}.badge-secondary{background:#f3f3f1;color:#5a5a55}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:10px 20px;min-height:44px;font-weight:500;font-size:.88rem;border-radius:var(--radius-sm);transition:background .15s,box-shadow .15s;-webkit-tap-highlight-color:transparent;letter-spacing:-.005em}.btn:active{opacity:.85}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-primary{background:var(--color-primary);color:#fff}.btn-primary:hover,.btn-primary:active{background:var(--color-primary-dark)}.btn-secondary{background:var(--color-border);color:var(--color-text)}.btn-secondary:hover{background:#d1d5db}.btn-secondary:active{background:#c1c5cb}.btn-ghost{color:var(--color-text-muted);padding:6px 10px}.btn-ghost:hover{background:#0000000d;color:var(--color-text)}.btn-ghost:active{background:#00000014}.btn-sm{padding:6px 12px;min-height:36px;font-size:.8rem}.btn-block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.form-group{display:flex;flex-direction:column;gap:6px}.form-label{font-size:.85rem;font-weight:600;color:var(--color-text)}.form-input{padding:10px 14px;min-height:44px;border:1.5px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);font-size:1rem;transition:border-color .2s,box-shadow .2s;outline:none}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-focus-ring)}.form-input::placeholder{color:#aaa}.form-error{font-size:.82rem;color:var(--color-danger);font-weight:500}.spinner-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:14px}.spinner{width:36px;height:36px;border:3.5px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spinner-text{font-size:.88rem;color:var(--color-text-muted)}.text-center{text-align:center}.text-muted{color:var(--color-text-muted)}.mt-1{margin-top:8px}.mt-2{margin-top:16px}.mt-3{margin-top:24px}.mb-1{margin-bottom:8px}.mb-2{margin-bottom:16px}.gap-1{gap:8px}.gap-2{gap:16px}.page-title{font-family:var(--font-display);font-size:1.5rem;font-weight:700;color:var(--color-text);margin-bottom:16px;letter-spacing:-.02em}.recipe-grid{display:grid;grid-template-columns:1fr;gap:14px}.error-box{padding:12px 16px;background:#fef2f2;color:var(--color-danger);border-radius:var(--radius-sm);font-size:.88rem;font-weight:500}.empty-state{text-align:center;padding:40px 16px;color:var(--color-text-muted)}.empty-state-icon{margin-bottom:12px;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.auth-page{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100dvh - var(--navbar-height) - 40px);padding:20px}.auth-card{width:100%;max-width:400px;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border);padding:32px 28px;display:flex;flex-direction:column;gap:20px}.auth-card h1{font-family:var(--font-display);font-size:1.4rem;text-align:center;color:var(--color-text)}.auth-footer{text-align:center;font-size:.88rem;color:var(--color-text-muted)}.auth-footer a{color:var(--color-primary);font-weight:600}.auth-footer a:hover{text-decoration:underline}.pagination{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:24px}.pagination-info{font-size:.85rem;color:var(--color-text-muted);padding:0 8px}.search-bar{position:relative;display:flex;align-items:center;margin-bottom:12px}.search-bar-icon{position:absolute;left:12px;font-size:1rem;pointer-events:none;opacity:.5}.search-bar-input{width:100%;padding-left:38px;padding-right:38px}.search-bar-clear{position:absolute;right:4px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-size:.75rem;color:var(--color-text-muted);transition:background .15s,color .15s}.search-bar-clear:hover{background:#0000000f;color:var(--color-text)}.search-bar-clear:active{background:#0000001a}.search-toolbar{display:flex;align-items:flex-start;gap:8px;margin-bottom:16px}.search-result-count{font-size:.88rem;margin-bottom:12px}.filter-panel{flex:1;min-width:0}.filter-header{display:flex;align-items:center;gap:8px}.filter-section--actions{display:flex;align-items:center;align-self:flex-end;gap:8px;margin-left:auto}.filter-clear-btn{white-space:nowrap;font-size:.8rem;padding:5px 10px;min-height:unset}.filter-clear-btn--hidden{visibility:hidden}.filter-toggle{display:inline-flex;align-items:center;gap:6px;position:relative}.filter-dot{width:7px;height:7px;border-radius:50%;background:var(--color-primary);flex-shrink:0}.filter-chevron{font-size:.6rem;line-height:1}.filter-body{display:none;flex-direction:column;gap:16px;padding:16px;margin-top:10px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);overflow:visible}.filter-body--open{display:flex}.filter-clear-row{display:flex;justify-content:flex-end;width:100%}.filter-section{border:none;padding:0;margin:0}.filter-label{font-size:.82rem;font-weight:650;color:var(--color-text);margin-bottom:8px}.filter-segments{display:flex;flex-wrap:wrap;gap:6px}.filter-seg{padding:6px 14px;min-height:34px;font-size:.8rem;font-weight:500;border-radius:var(--radius-sm);border:1px solid var(--color-border);color:var(--color-text-muted);background:var(--color-surface);transition:all .15s;white-space:nowrap}.filter-seg:hover{border-color:var(--color-primary-light);color:var(--color-primary)}.filter-seg--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.filter-seg--active:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff}.filter-chips{display:flex;flex-wrap:wrap;gap:6px;max-width:100%;overflow:hidden}.filter-chip{cursor:pointer;transition:all .15s;gap:4px}.filter-chip:hover{border-color:var(--color-primary-light)}.filter-chip--active{background:var(--color-primary);color:#fff}.filter-chip--active:hover{background:var(--color-primary-dark)}.filter-chip-count{font-size:.65rem;opacity:.7}.filter-chip-remove{font-size:.65rem;margin-left:2px;opacity:.7;line-height:1}.filter-chip-remove:hover{opacity:1}.ingredient-search{position:relative}.ingredient-search .form-input{width:100%}.ingredient-dropdown{position:absolute;top:100%;left:0;right:0;z-index:100;margin-top:4px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);box-shadow:var(--shadow-md);max-height:180px;overflow-y:auto}.ingredient-option{display:block;width:100%;text-align:left;padding:10px 14px;min-height:44px;font-size:.88rem;color:var(--color-text);transition:background .1s}.ingredient-option:hover{background:var(--color-primary-bg);color:var(--color-primary-dark)}.recipe-card--compact{min-width:240px;max-width:280px;flex-shrink:0}.recipe-card-desc--clamp{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.home-page{display:flex;flex-direction:column;gap:28px}.home-hero,.home-hero .page-title{margin-bottom:4px}.home-subtitle-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.home-plan-link{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:var(--color-primary-bg);color:var(--color-primary);text-decoration:none;font-size:.82rem;font-weight:600;white-space:nowrap;transition:background .15s}.home-plan-link:hover{background:var(--color-primary);color:#fff}.meal-section__header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:12px}.meal-section__title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--color-text);letter-spacing:-.01em;display:flex;align-items:center;gap:.4rem}.meal-section__icon{display:inline-flex;color:var(--color-primary);opacity:.8}.meal-section__link{font-size:.82rem;font-weight:500;color:var(--color-text-muted);white-space:nowrap;text-transform:uppercase;letter-spacing:.04em}.meal-section__link:hover{color:var(--color-primary)}.scroll-row{display:flex;gap:14px;overflow-x:auto;padding-bottom:8px;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:var(--color-border) transparent}.scroll-row::-webkit-scrollbar{height:6px}.scroll-row::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.scroll-row>*{scroll-snap-align:start}.skeleton{background:var(--color-border);border-radius:var(--radius-sm);animation:skeleton-pulse 1.5s ease-in-out infinite}.skeleton--line{height:14px;border-radius:4px}.skeleton--title{height:18px;width:70%;border-radius:4px}.skeleton--text{height:14px;width:100%;border-radius:4px}.skeleton--short{width:60%}.skeleton--badge{height:22px;width:64px;border-radius:12px}.skeleton--rect{border-radius:var(--radius-md)}.skeleton--circle{border-radius:50%}.skeleton--hero{height:200px;border-radius:var(--radius-md);margin-bottom:16px}.skeleton--block{height:18px;margin-bottom:12px;border-radius:4px}.skeleton-card .recipe-card-body{gap:10px}.recipe-card--skeleton{pointer-events:none;min-height:160px}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}.recipe-detail{max-width:720px;margin:0 auto}.rd-hero{margin-bottom:20px}.rd-title{font-family:var(--font-display);font-size:1.55rem;font-weight:700;line-height:1.3;color:var(--color-text);margin-bottom:8px;letter-spacing:-.02em}.rd-description{font-size:.95rem;color:var(--color-text-muted);line-height:1.6;margin-bottom:12px}.rd-badges{display:flex;flex-wrap:wrap;gap:8px}.rd-info-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:12px;margin-bottom:20px;padding:16px;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.rd-info-item{display:flex;flex-direction:column;align-items:center;text-align:center;gap:2px}.rd-info-icon{font-size:1.1rem;display:flex;align-items:center;justify-content:center;color:var(--color-text-muted)}.rd-info-label{font-size:.72rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.rd-info-value{font-size:.95rem;font-weight:700;color:var(--color-text)}.rd-servings-adjuster{position:relative}.rd-servings-control{display:inline-flex;align-items:center;gap:2px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:2px}.rd-servings-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--color-primary);font-size:16px;font-weight:600;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s;line-height:1}.rd-servings-btn:hover:not(:disabled){background:var(--color-primary-light, rgba(22, 163, 74, .1))}.rd-servings-btn:disabled{opacity:.3;cursor:default}.rd-servings-value{min-width:28px;text-align:center;font-weight:600;font-size:15px;color:var(--color-text)}.rd-servings-reset{position:absolute;top:-4px;right:-8px;width:20px;height:20px;border-radius:50%;border:1px solid var(--color-border);background:var(--color-surface);display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--color-text-muted);padding:0;transition:color .15s}.rd-servings-reset:hover{color:var(--color-primary)}.rd-nutrition{padding:20px;margin-bottom:20px}.rd-nutrition-extra{margin-top:12px;border-top:1px solid var(--color-border);padding-top:8px}.rd-nutrition-extra-toggle{cursor:pointer;font-size:.85rem;color:var(--color-text-muted);padding:4px 0;list-style:none;display:flex;align-items:center;gap:4px}.rd-nutrition-extra-toggle:before{content:"▸";transition:transform .2s}details[open]>.rd-nutrition-extra-toggle:before{transform:rotate(90deg)}.rd-macro-grid--extra{margin-top:8px}.rd-macro-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(80px,1fr));gap:16px;margin-top:14px}.rd-macro{display:flex;flex-direction:column;align-items:center;text-align:center;gap:2px}.rd-macro-icon{font-size:1.2rem;display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.rd-macro-value{font-size:1.1rem;font-weight:700;color:var(--color-text)}.rd-macro-label{font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em}.rd-section{margin-bottom:24px}.rd-section-title{font-size:.82rem;font-weight:600;margin-bottom:12px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em}.rd-ingredients{display:flex;flex-direction:column;gap:2px}.rd-ingredient{padding:10px 12px;border-radius:var(--radius-sm);transition:background .15s}.rd-ingredient:hover{background:#00000006}.rd-ingredient--done{opacity:.5}.rd-ingredient--done span{text-decoration:line-through}.rd-ingredient-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.95rem}.rd-checkbox{width:20px;height:20px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.rd-steps{display:flex;flex-direction:column;gap:16px;counter-reset:none}.rd-step{display:flex;gap:14px;align-items:flex-start}.rd-step-number{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;background:var(--color-primary-bg);color:var(--color-primary);font-size:.78rem;font-weight:600;border-radius:50%}.rd-step-text{font-size:.95rem;line-height:1.65;color:var(--color-text);padding-top:4px}.rd-tags{display:flex;flex-wrap:wrap;gap:8px}.camera-page{display:flex;flex-direction:column;gap:16px}.camera-mode-toggle{display:flex;background:var(--color-border);border-radius:var(--radius-sm);padding:3px;gap:2px}.camera-mode-btn{flex:1;padding:8px 12px;min-height:40px;font-size:.82rem;font-weight:500;border-radius:var(--radius-sm);color:var(--color-text-muted);transition:all .2s var(--ease-out);-webkit-tap-highlight-color:transparent}.camera-mode-btn:active:not(.camera-mode-btn--active){background:#0000000a}.camera-mode-btn--active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm)}.camera-capture{display:flex;flex-direction:column;gap:12px}.camera-viewfinder{position:relative;border-radius:var(--radius-lg);overflow:hidden;background:#000}.camera-video{width:100%;height:100%;object-fit:contain;display:block}.camera-controls{display:flex;align-items:center;justify-content:center;gap:12px;padding:8px 0}.camera-controls--overlay{position:absolute;bottom:0;left:0;right:0;padding:16px 0 20px;background:linear-gradient(transparent,#00000073)}.camera-shutter{width:64px;height:64px;border-radius:50%;background:#ffffff4d;border:3px solid #fff;display:flex;align-items:center;justify-content:center;transition:transform .15s,background .15s;-webkit-tap-highlight-color:transparent}.camera-shutter:active{transform:scale(.9);background:#ffffff80}.camera-shutter-inner{width:50px;height:50px;border-radius:50%;background:#fff;transition:background .15s}.camera-shutter:active .camera-shutter-inner{background:#e5e7eb}.camera-preview-wrapper{border-radius:var(--radius-lg);overflow:hidden;background:#000}.camera-preview-img{width:100%;display:block;border-radius:var(--radius-lg)}.camera-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;aspect-ratio:4 / 3;background:var(--color-surface);border-radius:var(--radius-lg);border:2px dashed var(--color-border)}.camera-file-input{display:none}.camera-upload-label{cursor:pointer}.camera-error-banner{padding:10px 14px;background:#fef2f2;color:var(--color-danger);border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;display:flex;align-items:center;gap:6px}.camera-results{display:flex;flex-direction:column;gap:16px;animation:fadeIn .25s var(--ease-out)}.camera-section-title{font-size:1.05rem;font-weight:650;margin-bottom:10px;color:var(--color-text)}.camera-chip-list{display:flex;flex-wrap:wrap;gap:8px}.camera-ingredients{padding:16px;background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border)}.calorie-estimate{display:flex;flex-direction:column;gap:14px;animation:fadeIn .25s var(--ease-out)}.calorie-image-wrapper{border-radius:var(--radius-lg);overflow:hidden;max-height:260px}.calorie-image{width:100%;height:100%;object-fit:cover;display:block}.calorie-desc-card{padding:16px}.calorie-description{font-size:.95rem;line-height:1.6;color:var(--color-text)}.calorie-card{padding:20px;display:flex;flex-direction:column;gap:18px}.calorie-card:hover{transform:none}.calorie-card-title{font-size:1.05rem;font-weight:650;text-align:center}.calorie-ring-row{display:flex;justify-content:center}.calorie-ring{position:relative;width:140px;height:140px}.calorie-ring-svg{width:100%;height:100%;transform:rotate(-90deg)}.calorie-ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.calorie-ring-number{font-size:1.6rem;font-weight:700;line-height:1;color:var(--color-text)}.calorie-ring-unit{font-size:.72rem;color:var(--color-text-muted);font-weight:500;margin-top:2px}.calorie-macros{display:flex;flex-direction:column;gap:12px}.calorie-macro-row{display:flex;align-items:center;gap:10px}.calorie-macro-label{display:flex;align-items:center;gap:6px;font-size:.84rem;font-weight:500;min-width:90px;color:var(--color-text)}.calorie-macro-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.calorie-macro-bar-track{flex:1;height:8px;background:var(--color-border);border-radius:var(--radius-full);overflow:hidden}.calorie-macro-bar-fill{height:100%;border-radius:var(--radius-full);transition:width .5s var(--ease-out)}.calorie-macro-value{font-size:.84rem;font-weight:600;min-width:60px;text-align:right;color:var(--color-text)}.calorie-legend{display:flex;justify-content:center;gap:14px;font-size:.78rem;font-weight:500}@media(min-width:640px){.main-content{padding:28px 24px calc(var(--tab-bar-height) + var(--safe-bottom) + 28px)}.recipe-grid{grid-template-columns:repeat(2,1fr);gap:18px}.page-title{font-size:1.65rem}.filter-segments{gap:4px}.toast-container{left:auto;right:20px;align-items:flex-end}}@media(min-width:768px){.rd-info-row,.rd-macro-grid{grid-template-columns:repeat(4,1fr)}.calorie-ring{width:160px;height:160px}}@media(min-width:1024px){.main-content{padding-bottom:40px}.navbar-desktop-nav{display:flex;align-items:center;gap:2px}.navbar-desktop-nav .tab-item{flex:0 0 auto;flex-direction:row;gap:6px;padding:6px 14px;border-radius:var(--radius-sm);font-size:.82rem}.navbar-desktop-nav .tab-active{background:var(--color-primary-bg)}.navbar-desktop-nav .tab-icon svg{width:16px;height:16px}.navbar-bottom{display:none}.recipe-grid{grid-template-columns:repeat(3,1fr)}.filter-toggle{display:none}.filter-body{display:flex;flex-direction:row;flex-wrap:wrap;gap:20px;padding:14px 16px;margin-top:0;overflow:visible}.filter-section{flex:0 0 auto;max-width:100%}.filter-section:nth-last-child(-n+2){flex:1 1 100%}}.empty-state-title{font-size:1.1rem;font-weight:650;color:var(--color-text);margin-bottom:6px}.empty-state-inline{display:flex;align-items:center;gap:10px;padding:16px;color:var(--color-text-muted);font-size:.88rem}.empty-state-inline-icon{flex-shrink:0;display:flex;align-items:center;color:var(--color-text-muted)}.error-state{text-align:center;padding:40px 16px}.error-state-icon{margin-bottom:12px;display:flex;align-items:center;justify-content:center}.error-state-title{font-size:1.15rem;font-weight:650;color:var(--color-text);margin-bottom:6px}.error-state-message{font-size:.9rem;color:var(--color-text-muted);max-width:360px;margin:0 auto;line-height:1.5}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:60px 20px;gap:12px}.error-boundary-icon{margin-bottom:8px;display:flex;align-items:center;justify-content:center}.error-boundary-title{font-size:1.3rem;font-weight:700;color:var(--color-text)}.error-boundary-message{font-size:.95rem;color:var(--color-text-muted);max-width:400px;line-height:1.5;margin-bottom:8px}.toast-container{position:fixed;top:calc(var(--navbar-height) + 12px);right:16px;left:16px;z-index:9999;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}.toast{display:flex;align-items:center;gap:10px;padding:12px 16px;background:var(--color-surface);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);border:1px solid var(--color-border);font-size:.88rem;font-weight:500;color:var(--color-text);pointer-events:auto;max-width:420px;width:100%;animation:toastIn .3s var(--ease-out)}.toast--success{border-left:4px solid var(--color-primary)}.toast--error{border-left:4px solid var(--color-danger)}.toast--info{border-left:4px solid var(--color-warning)}.toast-icon{flex-shrink:0;width:22px;height:22px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.7rem;font-weight:700;color:#fff}.toast--success .toast-icon{background:var(--color-primary)}.toast--error .toast-icon{background:var(--color-danger)}.toast--info .toast-icon{background:var(--color-warning)}.toast-message{flex:1;min-width:0}.toast-close{flex-shrink:0;width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);font-size:.7rem;color:var(--color-text-muted);transition:background .15s,color .15s}.toast-close:hover{background:#0000000f;color:var(--color-text)}@keyframes toastIn{0%{opacity:0;transform:translateY(-10px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}@media print{.navbar-top,.navbar-bottom,.toast-container,.btn-ghost{display:none!important}body{background:#fff;color:#000;font-size:12pt}.main-content{padding:0;margin:0;max-width:100%}.recipe-detail{max-width:100%}.card,.rd-nutrition,.rd-info-row{box-shadow:none;border:1px solid #ccc;break-inside:avoid}.rd-ingredients,.rd-steps,.rd-step{break-inside:avoid}a{color:inherit;text-decoration:none}}.admin-page{max-width:640px;margin:0 auto;padding:1rem}.admin-title{font-size:1.5rem;font-weight:700;margin-bottom:1.5rem}.admin-section{margin-bottom:1rem}.admin-section-title{font-size:.95rem;font-weight:600;margin-bottom:.5rem;display:flex;align-items:center;gap:.5rem}.admin-count{background:var(--color-primary-bg);color:var(--color-primary);font-size:.82rem;padding:.1rem .5rem;border-radius:var(--radius-sm)}.admin-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem;box-shadow:var(--shadow-sm)}.admin-setting-row{display:flex;align-items:center;justify-content:space-between;gap:1rem}.admin-setting-info{display:flex;flex-direction:column;gap:.25rem}.admin-setting-label{font-weight:600;font-size:.95rem}.admin-setting-description{font-size:.85rem;color:var(--color-text-muted)}.admin-status-badge{margin-top:.75rem;padding:.4rem .75rem;border-radius:var(--radius-sm);font-size:.85rem;font-weight:500;text-align:center}.status-open{background:var(--color-primary-bg);color:var(--color-primary)}.status-closed{background:#fef2f2;color:var(--color-danger)}.toggle-switch{position:relative;width:52px;height:28px;border-radius:var(--radius-full);border:none;cursor:pointer;transition:background .2s ease;flex-shrink:0;padding:0}.toggle-on{background:var(--color-primary)}.toggle-off{background:#d1d5db}.toggle-switch:disabled{opacity:.5;cursor:not-allowed}.toggle-knob{position:absolute;top:3px;width:22px;height:22px;background:#fff;border-radius:50%;transition:left .2s ease;box-shadow:0 1px 3px #00000026}.toggle-on .toggle-knob{left:27px}.toggle-off .toggle-knob{left:3px}.admin-user-list{display:flex;flex-direction:column}.admin-user-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem 0;border-bottom:1px solid var(--color-border);gap:.5rem}.admin-user-row:last-child{border-bottom:none}.admin-user-info{display:flex;flex-direction:column;gap:.1rem;min-width:0}.admin-user-name{font-weight:600;font-size:.95rem}.admin-user-email{font-size:.8rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-user-meta{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.admin-user-date{font-size:.75rem;color:var(--color-text-muted)}.nav-active{color:var(--color-primary)!important}.settings-page{max-width:600px;margin:0 auto;padding:.75rem}.profile-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:14px 16px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.profile-avatar{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:50%;background:var(--color-primary);color:#fff;font-size:1.2rem;font-weight:700;flex-shrink:0}.profile-info{display:flex;flex-direction:column;gap:1px}.profile-name{font-size:1rem;font-weight:700;color:var(--color-text);margin:0}.profile-email{font-size:.78rem;color:var(--color-text-muted)}.language-options{display:flex;gap:8px;flex-wrap:wrap}.language-btn{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-surface);cursor:pointer;font-size:.85rem;transition:border-color .2s,background .2s,box-shadow .2s;min-width:0}.language-btn:hover{border-color:var(--color-primary-light)}.language-btn--active{border-color:var(--color-primary);background:var(--color-primary-bg);box-shadow:0 0 0 2px #3d5a471f}.language-flag{display:flex;align-items:center}.language-label{font-weight:500}.rd-top-bar{display:flex;justify-content:space-between;align-items:center}.rd-image-gallery{display:flex;gap:10px;overflow-x:auto;padding-bottom:8px;margin-bottom:12px;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}.rd-img-wrap{position:relative;background:var(--color-border);border-radius:var(--radius-md);overflow:hidden;aspect-ratio:16 / 10;max-width:400px;min-width:260px;scroll-snap-align:start;flex-shrink:0}.rd-img-wrap:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,var(--color-border) 0%,var(--color-surface) 100%);z-index:1;transition:opacity .4s ease}.rd-img-wrap.rd-img--loaded:before{opacity:0;pointer-events:none}.rd-gallery-img{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .4s ease}.rd-img--loaded .rd-gallery-img{opacity:1}.recipe-edit-page{max-width:720px;margin:0 auto;padding:16px}.re-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px;margin-bottom:20px}.re-header-actions{display:flex;gap:8px}.re-locale-tabs{display:flex;gap:4px;margin-bottom:16px;border-bottom:2px solid var(--color-border);padding-bottom:0}.re-locale-tab{padding:8px 16px;font-size:.9rem;font-weight:500;border:none;background:none;color:var(--color-text-muted);cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s}.re-locale-tab:hover{color:var(--color-text)}.re-locale-tab--active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.re-en-ref{font-size:.8rem;color:var(--color-text-muted);font-weight:400}.re-en-ref--inline{flex:0 0 auto;min-width:100px;max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.82rem;padding:6px 0}.re-en-ref--block{font-size:.8rem;color:var(--color-text-muted);padding:4px 0;line-height:1.3}.re-step-tr{flex:1;display:flex;flex-direction:column;gap:4px}.re-input--readonly{background:var(--color-bg);opacity:.7;pointer-events:none}.re-section{background:var(--color-surface, #fff);border-radius:var(--radius, 12px);padding:16px;margin-bottom:16px}.re-section-title{font-size:1rem;font-weight:600;margin-bottom:12px}.re-field{margin-bottom:12px}.re-field--half{flex:1;min-width:120px}.re-field--third{flex:1;min-width:90px}.re-field--quarter{flex:1;min-width:80px}.re-label{display:block;font-size:.82rem;font-weight:600;color:var(--color-text-muted, #6b7280);margin-bottom:4px;text-transform:uppercase;letter-spacing:.03em}.re-input,.re-select,.re-textarea{width:100%;padding:8px 10px;border:1.5px solid var(--color-border, #e2e8f0);border-radius:8px;font-size:.95rem;background:var(--color-bg, #f8fafb);color:var(--color-text, #1e293b);transition:border-color .15s;box-sizing:border-box}.re-input:focus,.re-select:focus,.re-textarea:focus{border-color:var(--color-primary, #0f766e);outline:none;box-shadow:0 0 0 3px #0f766e1a}.re-textarea{resize:vertical;font-family:inherit}.re-textarea--step{min-height:50px}.re-row{display:flex;gap:12px;flex-wrap:wrap}.re-hint{display:block;font-size:.78rem;color:var(--color-text-muted, #6b7280);margin-top:4px}.re-list{display:flex;flex-direction:column;gap:8px;margin-bottom:8px}.re-list-row{display:flex;gap:8px;align-items:center}.re-input--grow{flex:2}.re-input--sm{flex:1;max-width:120px}.re-step-row{align-items:flex-start}.re-step-num{min-width:24px;font-weight:700;color:var(--color-primary, #0f766e);padding-top:8px}.re-remove-btn{color:var(--color-danger, #dc2626);flex-shrink:0;padding:4px 8px}.re-image-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:10px;margin-bottom:12px}.re-image-card{position:relative;border-radius:8px;overflow:hidden;border:1px solid var(--color-border, #e2e8f0)}.re-image-thumb{width:100%;height:110px;object-fit:cover;display:block}.re-image-delete{position:absolute;top:4px;right:4px;background:#0009;color:#fff;border-radius:6px;font-size:.72rem;padding:2px 6px}.re-image-delete:hover{background:var(--color-danger, #dc2626)}.re-upload-area{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.re-file-input{display:none}.re-bottom-bar{display:flex;justify-content:flex-end;gap:8px;padding:12px 0;border-top:1px solid var(--color-border, #e2e8f0);margin-top:8px}.btn-disabled{opacity:.6;pointer-events:none}.fav-btn{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;cursor:pointer;padding:4px;border-radius:50%;color:var(--color-text-muted);transition:color .2s,transform .15s}.fav-btn:hover,.fav-btn--active{color:#b45650}.fav-btn:active{transform:scale(.9)}.fav-btn--card{position:absolute;top:0;right:0}.fav-btn--detail{padding:6px}.rd-top-bar-actions{display:flex;align-items:center;gap:4px}.rd-share-btn{display:inline-flex;align-items:center;gap:4px;color:var(--color-text-muted)}.rd-share-btn:hover{color:var(--color-primary)}.filter-fav-toggle{display:inline-flex;align-items:center;gap:6px;width:auto}.filter-fav-icon{display:inline-flex;line-height:1}.admin-search-input{width:100%;padding:10px 12px;margin-bottom:12px;border:1px solid var(--border);border-radius:8px;font-size:.95rem;background:var(--surface);color:var(--text);box-sizing:border-box}.admin-search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb, 99,102,241),.15)}.admin-pagination{display:flex;align-items:center;justify-content:center;gap:12px;margin-top:16px;padding-top:12px;border-top:1px solid var(--border)}.admin-pagination-info{font-size:.85rem;color:var(--text-muted);min-width:120px;text-align:center}.admin-off-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:1rem}.admin-off-stat{background:var(--color-background);border-radius:8px;padding:12px;text-align:center}.admin-off-stat-label{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);margin-bottom:4px}.admin-off-stat-value{display:block;font-family:Georgia,serif;font-size:1.15rem;font-weight:600;color:var(--color-text)}.admin-off-empty{color:var(--color-text-muted);font-style:italic;margin-bottom:1rem}.admin-off-progress{margin-bottom:1rem}.admin-off-progress-label{font-weight:500;margin-bottom:4px}.admin-off-progress-count{font-size:.85rem;color:#666;margin-bottom:6px}.admin-off-progress-bar{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.admin-off-progress-bar-fill{height:100%;background:var(--primary-green, #3d5a47);border-radius:3px}.admin-off-progress-bar-indeterminate{width:40%;animation:off-progress-slide 1.5s ease-in-out infinite}@keyframes off-progress-slide{0%{transform:translate(-100%)}50%{transform:translate(150%)}to{transform:translate(-100%)}}.admin-off-history{margin-top:1.5rem;border-top:1px solid #e0ddd8;padding-top:1rem}.admin-off-history-title{font-family:Georgia,serif;font-size:1rem;font-weight:600;margin-bottom:.75rem;color:var(--text-color, #2c2c2c)}.admin-off-history-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-off-history-table th{text-align:left;font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);padding:6px 8px;border-bottom:1px solid var(--color-border)}.admin-off-history-table td{padding:8px;border-bottom:1px solid var(--color-border);vertical-align:middle}.admin-off-history-badge{display:inline-block;width:20px;text-align:center;font-weight:700;border-radius:50%;margin-right:4px}.admin-off-history-done{color:#3d5a47}.admin-off-history-error{color:#c0392b}.admin-off-history-running{color:#e67e22}.admin-off-history-error[title]{font-weight:400;font-size:.8rem;color:#c0392b}.password-form{display:flex;flex-direction:column;gap:10px;max-width:400px}.password-form .btn{align-self:flex-start;margin-top:4px}.tracker-page{display:flex;flex-direction:column;align-items:center;gap:20px;padding-bottom:100px}.tracker-date-nav{display:flex;align-items:center;gap:12px;width:100%;justify-content:center}.tracker-date-label{font-family:var(--font-display);font-size:1.05rem;font-weight:600;color:var(--color-text);background:none;border:none;cursor:pointer;padding:4px 12px;border-radius:var(--radius-sm)}.tracker-date-label:hover{background:var(--color-border)}.tracker-gauge{position:relative;width:180px;height:180px}.tracker-gauge-svg{width:100%;height:100%;transform:rotate(-90deg)}.tracker-gauge-fill{transition:stroke-dashoffset .6s var(--ease-out),stroke .4s}.tracker-gauge-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center}.tracker-gauge-number{font-family:var(--font-display);font-size:2rem;font-weight:700;line-height:1;color:var(--color-text)}.tracker-gauge-unit{font-size:.75rem;color:var(--color-text-muted);margin-top:2px}.tracker-gauge-label{font-size:.72rem;color:var(--color-text-muted);margin-top:4px}.tracker-goal-label{display:flex;align-items:center;gap:5px;font-size:.82rem;color:var(--color-text-muted)}.tracker-macros{width:100%;max-width:400px;padding:16px 20px;display:flex;flex-direction:column;gap:10px}.tracker-macro-header{display:flex;align-items:center;gap:8px}.tracker-macro-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.tracker-macro-label{font-size:.85rem;color:var(--color-text);flex:1}.tracker-macro-value{font-size:.85rem;font-weight:600;color:var(--color-text)}.tracker-logs{width:100%;max-width:500px}.tracker-section-title{font-family:var(--font-display);font-size:.9rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;color:var(--color-text-muted);margin-bottom:10px}.tracker-empty{font-size:.85rem;text-align:center;padding:20px 0}.tracker-log-list{display:flex;flex-direction:column;gap:6px}.tracker-log-item{display:flex;flex-direction:column;padding:10px 14px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm)}.tracker-log-header{display:flex;align-items:center;justify-content:space-between;width:100%}.tracker-log-info{display:flex;align-items:center;gap:10px;min-width:0}.tracker-log-time{font-size:.75rem;color:var(--color-text-muted);white-space:nowrap}.tracker-log-desc{font-size:.88rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tracker-log-meta{display:flex;align-items:center;gap:8px;flex-shrink:0}.tracker-log-kcal{font-size:.82rem;font-weight:600;color:var(--color-text);white-space:nowrap}.tracker-log-chevron{font-size:.6rem;color:var(--color-text-muted)}.tracker-log-details{padding-top:10px;margin-top:10px;border-top:1px solid var(--color-border)}.tracker-log-macros{display:flex;gap:16px;font-size:.8rem;color:var(--color-text-muted);margin-bottom:8px}.tracker-macro strong{color:var(--color-text)}.tracker-items-table{width:100%;font-size:.78rem;border-collapse:collapse}.tracker-items-table th{text-align:left;font-weight:600;color:var(--color-text-muted);padding:4px 6px;border-bottom:1px solid var(--color-border)}.tracker-items-table th:not(:first-child){text-align:right}.tracker-items-table td{padding:4px 6px;color:var(--color-text)}.tracker-items-table td:not(:first-child){text-align:right;font-variant-numeric:tabular-nums}.weekly-rings{display:flex;align-items:center;justify-content:center;gap:4px;margin-bottom:12px}.weekly-rings-nav{padding:4px;min-width:auto}.weekly-rings-row{display:flex;align-items:center;gap:6px}.weekly-ring{display:flex;flex-direction:column;align-items:center;gap:2px;background:none;border:none;padding:2px;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s}.weekly-ring:hover:not(:disabled){background:var(--color-surface)}.weekly-ring--active{background:var(--color-surface)}.weekly-ring--future{opacity:.3;cursor:default}.weekly-ring-svg{width:28px;height:28px}.weekly-ring--active .weekly-ring-svg{width:34px;height:34px}.weekly-ring-label{font-size:.6rem;color:var(--color-text-muted);line-height:1}.weekly-ring--active .weekly-ring-label{color:var(--color-text);font-weight:600}.nutrition-trend{margin-bottom:16px}.nutrition-trend-header{font-size:.85rem;font-weight:600;color:var(--color-text);margin-bottom:8px}.nutrition-trend-title{font-family:var(--font-sans)}.nutrition-trend-content{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:10px}.nutrition-trend-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.nutrition-trend-svg{width:100%;max-width:400px;display:block;margin:0 auto}.nutrition-trend-dot{cursor:pointer;transition:r .15s}.nutrition-trend-dot:hover{r:5}.nutrition-trend-legend{display:flex;justify-content:center;gap:12px;margin-top:6px;font-size:.68rem;color:var(--color-text-muted)}.legend-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:3px;vertical-align:middle}.stats-page{max-width:600px;margin:0 auto;padding:16px}.stats-day-card{padding:14px}.stats-day-totals{display:flex;justify-content:space-around;text-align:center;margin-bottom:12px}.stats-day-total-item{display:flex;flex-direction:column;gap:2px}.stats-day-total-value{font-size:1.1rem;font-weight:700;color:var(--color-text);font-variant-numeric:tabular-nums}.stats-day-total-label{font-size:.7rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.stats-goal-bar{position:relative;height:20px;background:var(--color-border);border-radius:10px;overflow:hidden;margin-bottom:12px}.stats-goal-bar-fill{height:100%;border-radius:10px;transition:width .4s var(--ease-out)}.stats-goal-bar-label{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.68rem;font-weight:600;color:var(--color-text)}.stats-day-meals{display:flex;flex-direction:column;gap:6px;padding-top:10px;border-top:1px solid var(--color-border)}.stats-day-meal{display:flex;align-items:center;gap:8px;font-size:.8rem}.stats-day-meal-time{color:var(--color-text-muted);font-size:.72rem;white-space:nowrap}.stats-day-meal-desc{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-day-meal-kcal{font-weight:600;white-space:nowrap;font-variant-numeric:tabular-nums}.tracker-add-btn{display:inline-flex;align-items:center;gap:6px;align-self:center}.tracker-add-form{width:100%;max-width:500px;padding:16px;display:flex;flex-direction:column;gap:10px}.tracker-add-macros{display:grid;grid-template-columns:1fr 1fr;gap:8px}.tracker-add-macros .form-input{font-size:.85rem}.tracker-add-actions{display:flex;gap:8px}.tracker-widget{display:flex;align-items:center;gap:16px;width:100%;padding:14px 18px;cursor:pointer}.tracker-widget:hover{transform:none}.tracker-widget-ring{position:relative;width:56px;height:56px;flex-shrink:0}.tracker-widget-ring svg{width:100%;height:100%;transform:rotate(-90deg)}.tracker-widget-ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--color-text)}.tracker-widget-info{display:flex;flex-direction:column;gap:2px}.tracker-widget-title{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--color-text)}.tracker-widget-sub{font-size:.78rem;color:var(--color-text-muted)}@media(min-width:768px){.tracker-gauge{width:220px;height:220px}.tracker-gauge-number{font-size:2.4rem}}.barcode-scanner-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--color-bg);display:flex;flex-direction:column;padding:16px}.barcode-scanner-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.barcode-scanner-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--color-text)}.barcode-scanner-hint{text-align:center;margin-bottom:12px;font-size:.88rem}.barcode-scanner-viewport{position:relative;flex:1;min-height:250px}.barcode-scanner-viewfinder{width:100%;height:100%;border-radius:var(--radius-md);overflow:hidden}.barcode-scanner-guide{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:75%;height:100px;border:2px solid rgba(255,255,255,.7);border-radius:12px;box-shadow:0 0 0 2000px #00000040;pointer-events:none;z-index:10}.barcode-scanner-guide:before,.barcode-scanner-guide:after{content:"";position:absolute;width:24px;height:24px;border-color:#fff;border-style:solid}.barcode-scanner-guide:before{top:-2px;left:-2px;border-width:3px 0 0 3px;border-radius:8px 0 0}.barcode-scanner-guide:after{bottom:-2px;right:-2px;border-width:0 3px 3px 0;border-radius:0 0 8px}.barcode-cancel-btn{margin-top:16px;width:100%;padding:14px;font-size:1rem}.barcode-scanner-viewfinder video{width:100%!important;height:100%!important;object-fit:cover;border-radius:var(--radius-md)}.food-search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--color-bg);display:flex;flex-direction:column;padding:16px;padding-top:calc(var(--navbar-height) + 8px);padding-right:max(16px,env(safe-area-inset-right));padding-bottom:max(16px,env(safe-area-inset-bottom));padding-left:max(16px,env(safe-area-inset-left));overflow-y:auto}.food-search-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.food-search-title{font-family:var(--font-display);font-size:1.1rem;font-weight:600;color:var(--color-text)}.food-search-form{display:flex;flex-direction:column;gap:10px;margin-bottom:16px}.food-search-form .btn{width:100%}.food-search-input-wrap{position:relative}.food-search-input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-muted);display:flex}.food-search-input{padding-left:38px!important;width:100%}.food-search-empty{text-align:center;padding:16px 0}.food-search-results{display:flex;flex-direction:column;gap:6px}.food-search-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;width:100%;transition:background .15s}.food-search-item:hover{background:var(--color-border)}.food-search-item-img{width:40px;height:40px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.food-search-item-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.food-search-item-name{font-size:.92rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.food-search-item-brand{font-size:.8rem;color:var(--color-text-muted)}.food-search-item-kcal{font-size:.85rem;font-weight:600;color:var(--color-primary);white-space:nowrap;flex-shrink:0}.food-detail{display:flex;flex-direction:column;gap:16px}.food-detail-back{display:inline-flex;align-items:center;gap:4px;align-self:flex-start;font-size:.85rem;padding:4px 8px}.food-detail-img-wrap{display:flex;justify-content:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:12px}.food-detail-img{max-width:100%;max-height:200px;object-fit:contain;border-radius:var(--radius-sm)}.food-detail-header{display:flex;flex-direction:column;gap:2px}.food-detail-name{font-family:var(--font-display);font-size:1.15rem;font-weight:600;color:var(--color-text);margin:0;line-height:1.3}.food-detail-brand{font-size:.85rem;color:var(--color-text-muted)}.food-detail-quantity{font-size:.8rem;color:var(--color-text-muted)}.food-detail-badges{display:flex;gap:12px;flex-wrap:wrap;align-items:center}.food-detail-badge{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:6px 10px}.food-detail-nutriscore{display:inline-flex;align-items:center;justify-content:center;min-width:26px;width:26px;height:26px;border-radius:50%;color:#fff;font-weight:700;font-size:.8rem;line-height:1;flex-shrink:0}.food-detail-nutrition{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:14px}.food-detail-nutrition-title{font-size:.85rem;font-weight:600;color:var(--color-text);margin:0 0 10px}.food-detail-table{width:100%;border-collapse:collapse}.food-detail-table td{padding:6px 0;font-size:.85rem;border-bottom:1px solid var(--color-border)}.food-detail-table tr:last-child td{border-bottom:none}.food-detail-table-label{color:var(--color-text-muted)}.food-detail-table-value{text-align:right;font-weight:500;color:var(--color-text)}.food-detail-select{width:100%;margin-top:4px}.portion-selector{display:flex;flex-direction:column;gap:16px;padding:20px;width:100%;max-width:440px}.portion-product-header{display:flex;align-items:center;gap:12px}.portion-product-img{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover}.portion-product-info{display:flex;flex-direction:column;gap:2px}.portion-product-name{font-weight:600;font-size:1rem;color:var(--color-text)}.portion-product-brand{font-size:.85rem;color:var(--color-text-muted)}.portion-input-row{display:flex;align-items:center;gap:12px}.portion-input-row label{font-size:.9rem;font-weight:500;white-space:nowrap}.portion-input-row input{width:100px}.portion-nutrition{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;text-align:center}.portion-nutrition-item{display:flex;flex-direction:column;gap:2px;padding:8px 4px;background:var(--color-bg);border-radius:var(--radius-sm);border:1px solid var(--color-border)}.portion-nutrition-value{font-size:1.1rem;font-weight:600;color:var(--color-text)}.portion-nutrition-label{font-size:.75rem;color:var(--color-text-muted)}.portion-actions{display:flex;gap:10px;width:100%}.portion-actions .btn{flex:1}.tracker-add-buttons{display:flex;gap:8px;width:100%;max-width:400px;flex-wrap:wrap;justify-content:center}.tracker-add-buttons .btn{flex:1;min-width:0;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:.88rem}.item-breakdown{display:flex;flex-direction:column;gap:6px;margin-top:12px}.item-breakdown-title{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--color-text);margin-bottom:4px}.item-breakdown-row{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--color-bg);border-radius:var(--radius-sm);border:1px solid var(--color-border);font-size:.88rem}.item-breakdown-name{flex:1;font-weight:500}.item-breakdown-portion{color:var(--color-text-muted);font-size:.82rem}.item-breakdown-kcal{font-weight:600;color:var(--color-primary);white-space:nowrap}.item-breakdown-source{font-size:.72rem;padding:1px 6px;border-radius:8px;white-space:nowrap}.item-breakdown-source--off{background:#e0f0e6;color:#2d5a3a}.item-breakdown-source--llm{background:#f0e6d0;color:#6a5630}.home-quick-links{display:flex;gap:10px;margin-bottom:12px}.home-quick-link{display:flex;align-items:center;gap:8px;padding:10px 16px;text-decoration:none;color:var(--color-text);cursor:pointer;transition:background .15s}.home-quick-link:hover{background:var(--color-primary-bg)}.home-quick-link-icon{color:var(--color-primary);display:flex}.home-quick-link-label{font-size:.9rem;font-weight:600}.meal-plan-page{display:flex;flex-direction:column;gap:16px}.meal-plan-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.meal-plan-header .btn{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.meal-plan-week-nav{display:flex;align-items:center;justify-content:center;gap:12px}.meal-plan-week-label{font-size:.9rem;font-weight:600;color:var(--color-text);min-width:140px;text-align:center}.meal-plan-grid{display:flex;flex-direction:column;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden;background:var(--color-surface)}.meal-plan-grid-header{display:grid;grid-template-columns:56px repeat(7,1fr);background:var(--color-primary-bg);border-bottom:1px solid var(--color-border)}.meal-plan-grid-corner{padding:8px 4px}.meal-plan-day-header{display:flex;flex-direction:column;align-items:center;padding:6px 2px;gap:1px}.meal-plan-day-header--today{background:var(--color-primary);color:#fff;border-radius:var(--radius-sm) var(--radius-sm) 0 0}.meal-plan-day-name{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.03em}.meal-plan-day-date{font-size:.8rem;font-weight:700}.meal-plan-row{display:grid;grid-template-columns:56px repeat(7,1fr);border-bottom:1px solid var(--color-border);min-height:52px}.meal-plan-row:last-child{border-bottom:none}.meal-plan-row-label{display:flex;align-items:center;justify-content:center;padding:4px;font-size:.6rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.03em;background:var(--color-primary-bg);border-right:1px solid var(--color-border);writing-mode:vertical-rl;text-orientation:mixed;transform:rotate(180deg)}.meal-plan-cell{display:flex;flex-direction:column;gap:3px;padding:3px;border-right:1px solid var(--color-border);min-height:48px;position:relative}.meal-plan-cell:last-child{border-right:none}.meal-plan-cell--today{background:#3d5a470a}[data-theme=dark] .meal-plan-cell--today{background:#5a8a6414}.meal-plan-entry{position:relative;background:var(--color-primary-bg);border-radius:3px;padding:3px 14px 3px 4px;font-size:.6rem;line-height:1.3}.meal-plan-entry-title{display:block;font-weight:500;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.meal-plan-entry-kcal{color:var(--color-text-muted);font-size:.55rem}.meal-plan-entry-remove{position:absolute;top:0;right:0;width:14px;height:14px;font-size:.6rem;border:none;background:none;color:var(--color-text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:50%}.meal-plan-entry-remove:hover{background:var(--color-danger);color:#fff}.meal-plan-add-btn{display:flex;align-items:center;justify-content:center;border:1px dashed var(--color-border);border-radius:3px;background:none;color:var(--color-text-muted);font-size:.8rem;cursor:pointer;flex:1;min-height:24px;transition:all .15s}.meal-plan-add-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:var(--color-primary-bg)}.meal-plan-row--totals{background:var(--color-primary-bg);min-height:32px}.meal-plan-cell--total{display:flex;align-items:center;justify-content:center}.meal-plan-total-value{font-size:.7rem;font-weight:700;color:var(--color-text)}.meal-plan-picker-results{display:flex;flex-direction:column;gap:6px}.meal-plan-picker-item{display:flex;align-items:center;gap:12px;padding:10px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;width:100%;transition:background .15s}.meal-plan-picker-item:hover{background:var(--color-primary-bg)}.meal-plan-picker-item-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.meal-plan-picker-item-name{font-size:.92rem;font-weight:500;color:var(--color-text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.meal-plan-picker-item-meta{font-size:.78rem;color:var(--color-text-muted)}.shopping-list{display:flex;flex-direction:column;gap:4px}.shopping-list-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);cursor:pointer;text-align:left;width:100%;transition:all .15s}.shopping-list-item--checked{opacity:.5}.shopping-list-item--checked .shopping-list-name{text-decoration:line-through}.shopping-list-check{width:22px;height:22px;border:2px solid var(--color-border);border-radius:4px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:.75rem;font-weight:700;color:var(--color-primary)}.shopping-list-item--checked .shopping-list-check{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.shopping-list-name{flex:1;font-size:.9rem;color:var(--color-text);font-weight:500}.shopping-list-qty{font-size:.8rem;color:var(--color-text-muted);white-space:nowrap}.diet-wizard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1100;background:var(--color-background);display:flex;flex-direction:column;overflow-y:auto;-webkit-overflow-scrolling:touch}.diet-wizard{display:flex;flex-direction:column;min-height:100%;max-width:480px;margin:0 auto;width:100%}.diet-wizard-header{padding:16px 20px 12px;position:relative}.diet-wizard-close{position:absolute;right:16px;top:16px;background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:4px}.diet-wizard-step-label{font-size:.8rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.diet-wizard-progress{height:4px;background:var(--color-border);border-radius:2px;margin-top:8px;overflow:hidden}.diet-wizard-progress-fill{height:100%;background:var(--color-primary);border-radius:2px;transition:width .3s ease}.diet-wizard-body{flex:1;padding:0 20px 24px}.diet-wizard-content{animation:wizardFadeIn .2s ease}@keyframes wizardFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.diet-wizard-title{font-family:Georgia,serif;font-size:1.4rem;font-weight:600;margin-bottom:1.2rem;color:var(--color-text)}.diet-wizard-footer{display:flex;align-items:center;gap:12px;padding:16px 20px;padding-bottom:calc(16px + env(safe-area-inset-bottom));border-top:1px solid var(--color-border)}.diet-wizard-footer-spacer{flex:1}.diet-choice-group{margin-bottom:1.2rem}.diet-choice-label,.diet-input-label{display:block;font-size:.85rem;font-weight:600;color:var(--color-text-muted);margin-bottom:6px}.diet-choice-row{display:flex;gap:8px}.diet-choice-btn{flex:1;padding:10px 16px;border:2px solid var(--color-border);border-radius:8px;background:var(--color-surface, #fff);color:var(--color-text);font-size:.9rem;font-weight:500;cursor:pointer;transition:border-color .15s,background .15s}.diet-choice-btn--active{border-color:var(--color-primary);background:var(--color-primary-bg);color:var(--color-primary)}.diet-input-group{margin-bottom:1rem}.diet-input-group .form-input{width:100%}.diet-option-list{display:flex;flex-direction:column;gap:8px}.diet-option{display:flex;flex-direction:column;align-items:flex-start;padding:14px 16px;border:2px solid var(--color-border);border-radius:10px;background:var(--color-surface, #fff);cursor:pointer;transition:border-color .15s,background .15s;text-align:left}.diet-option:hover{border-color:var(--color-primary-light, var(--color-primary))}.diet-option--active{border-color:var(--color-primary);background:var(--color-primary-bg)}.diet-option-name{font-size:.95rem;font-weight:600;color:var(--color-text)}.diet-option--active .diet-option-name{color:var(--color-primary)}.diet-option-desc{font-size:.8rem;color:var(--color-text-muted);margin-top:2px}.diet-day-grid{display:flex;gap:6px;flex-wrap:wrap;margin-top:8px}.diet-day-btn{width:44px;height:44px;border-radius:50%;border:2px solid var(--color-border);background:var(--color-surface, #fff);color:var(--color-text);font-size:.8rem;font-weight:600;cursor:pointer;transition:border-color .15s,background .15s}.diet-day-btn--active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.diet-wizard-result{display:flex;flex-direction:column;align-items:center;text-align:center;padding-top:2rem}.diet-result-cal{font-family:Georgia,serif;font-size:3.5rem;font-weight:700;color:var(--color-primary);line-height:1}.diet-result-unit{font-size:.9rem;color:var(--color-text-muted);margin-top:4px;margin-bottom:1.2rem}.diet-result-summary{font-size:.85rem;color:var(--color-text-muted);margin-bottom:.8rem}.diet-result-type{margin-bottom:.6rem}.diet-result-window{font-size:.85rem;color:var(--color-text-muted)}.fasting-card{display:flex;align-items:center;gap:14px;padding:14px 16px;border-radius:12px;margin-bottom:16px;border-left:4px solid}.fasting-card--eating{border-left-color:var(--color-primary);color:var(--color-primary)}.fasting-card--fasting{border-left-color:var(--color-warning);color:var(--color-warning)}.fasting-card-ring{position:relative;width:64px;height:64px;flex-shrink:0}.fasting-card-ring svg{display:block}.fasting-card-ring-icon{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:1.3rem}.fasting-card-info{flex:1;min-width:0}.fasting-card-status{font-size:.95rem;font-weight:600;color:var(--color-text)}.fasting-card-remaining{font-size:.8rem;color:var(--color-text-muted);margin-top:2px}.diet-plan-card{padding:12px;border-radius:12px;background:var(--color-surface, #fff);border:1px solid var(--color-border)}.diet-plan-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}.diet-plan-card-title{font-size:.9rem;font-weight:600;color:var(--color-text)}.diet-plan-card-body{font-size:.82rem;color:var(--color-text-muted);line-height:1.45}.diet-plan-card-goal{font-family:Georgia,serif;font-size:1.15rem;font-weight:700;color:var(--color-primary);margin-bottom:2px}.diet-plan-card-meta{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.diet-plan-empty{text-align:center;padding:24px 16px}.diet-plan-empty-text{font-size:.85rem;color:var(--color-text-muted);margin-bottom:12px}.water-goal-row{display:flex;align-items:center;gap:12px}.water-goal-slider{flex:1;accent-color:var(--color-primary);height:6px}.water-goal-value{min-width:80px;text-align:right;font-weight:600;font-size:.95rem;font-variant-numeric:tabular-nums}.water-card{display:flex;align-items:center;gap:16px;padding:14px 18px}.water-card-ring{position:relative;width:56px;height:56px;flex-shrink:0;color:#5b9bd5}.water-card--done .water-card-ring{color:var(--color-primary)}.water-card-ring svg{width:100%;height:100%}.water-card-ring-fill{transition:stroke-dashoffset .4s ease}.water-card-ring-center{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:.72rem;font-weight:700;color:var(--color-text)}.water-card-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.water-card-row{display:flex;align-items:center;gap:8px}.water-card-title{font-family:var(--font-display);font-size:.95rem;font-weight:600;color:var(--color-text)}.water-card-sub{font-size:.78rem;color:var(--color-text-muted)}.water-card--done .water-card-sub{color:var(--color-primary)}.water-card-actions{display:flex;gap:4px;margin-left:auto;flex-shrink:0}.water-card-btn{padding:4px 10px;border:1px solid var(--color-border);border-radius:20px;background:var(--color-surface, #fff);color:#5b9bd5;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .15s,border-color .15s;white-space:nowrap}.water-card-btn:hover{background:#eaf2fb;border-color:#5b9bd5}.water-card-btn--undo{color:var(--color-text-muted);padding:4px 6px;display:inline-flex;align-items:center;justify-content:center}[data-theme=dark] .water-card-btn:hover{background:#1e2e3a}.ptr-indicator{display:flex;align-items:flex-end;justify-content:center;overflow:hidden;transition:height .2s ease;flex-shrink:0}.ptr-spinner{font-size:24px;color:var(--color-primary);transition:transform .1s linear;padding-bottom:8px}.ptr-spinner--active{animation:ptr-spin .8s linear infinite}@keyframes ptr-spin{to{transform:rotate(360deg)}}.cm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1000;background:var(--color-bg, #ffffff);display:flex;flex-direction:column;overflow:hidden}[data-theme=dark] .cm-overlay{background:var(--color-bg, #121212)}.cm-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border);flex-shrink:0}.cm-step-counter{font-weight:600;font-size:.95rem;color:var(--color-text)}.cm-close,.cm-ingredients-toggle{padding:8px}.cm-progress{height:3px;background:var(--color-border);flex-shrink:0}.cm-progress-bar{height:100%;background:var(--color-primary);transition:width .3s ease;border-radius:2px}.cm-content{flex:1;display:flex;align-items:center;justify-content:center;padding:32px 24px;overflow-y:auto}.cm-step-text{font-size:1.35rem;line-height:1.7;text-align:center;color:var(--color-text);max-width:600px}.cm-timer-section{padding:12px 24px;display:flex;justify-content:center;flex-shrink:0}.cm-timer-active{display:flex;align-items:center;gap:12px}.cm-timer-display{font-size:1.8rem;font-weight:700;font-variant-numeric:tabular-nums;color:var(--color-primary)}.cm-timer-picker{display:flex;align-items:center;gap:8px}.cm-timer-input{width:60px;text-align:center}.cm-timer-unit{font-size:.85rem;color:var(--color-text-muted)}.cm-timer-btn{display:inline-flex;align-items:center;gap:6px}.cm-timer-done{display:flex;align-items:center;gap:12px;color:var(--color-primary);font-weight:600;animation:cm-pulse 1s ease-in-out infinite}@keyframes cm-pulse{0%,to{opacity:1}50%{opacity:.5}}.cm-nav{display:flex;gap:12px;padding:16px 24px;padding-bottom:max(16px,env(safe-area-inset-bottom));border-top:1px solid var(--color-border);flex-shrink:0}.cm-nav-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:14px 16px;font-size:1rem}.cm-start-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:14px;font-size:1rem;margin-top:8px;margin-bottom:16px}.cm-drawer-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:1001;background:#0006;display:flex;align-items:flex-end}.cm-drawer{background:var(--color-surface);border-radius:var(--radius-lg, 16px) var(--radius-lg, 16px) 0 0;width:100%;max-height:60vh;overflow-y:auto;padding:20px 24px;padding-bottom:max(20px,env(safe-area-inset-bottom))}.cm-drawer-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.cm-drawer-header h3{font-size:1.1rem;font-weight:600;margin:0}.cm-drawer-list{list-style:none;padding:0;margin:0}.cm-drawer-item{padding:10px 0;border-bottom:1px solid var(--color-border);font-size:.95rem}.cm-drawer-item:last-child{border-bottom:none}.tracker-recent-scans{margin:12px 0}.tracker-recent-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.tracker-recent-list{display:flex;flex-direction:column;gap:6px}.tracker-recent-item{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;text-align:left;width:100%;transition:border-color .15s}.tracker-recent-item:hover{border-color:var(--color-primary)}.tracker-recent-img{width:36px;height:36px;object-fit:contain;border-radius:var(--radius-sm);flex-shrink:0}.tracker-recent-info{flex:1;min-width:0;display:flex;flex-direction:column}.tracker-recent-name{font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--color-text)}.tracker-recent-brand{font-size:.78rem;color:var(--color-text-muted)}.tracker-recent-cal{font-size:.85rem;font-weight:600;color:var(--color-text-muted);white-space:nowrap}.tracker-recent-toggle{margin-top:6px;width:100%;text-align:center}.offline-banner{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#fef3c7;border:1px solid #f59e0b;border-radius:var(--radius-md);color:#92400e;font-size:.85rem;font-weight:500;margin-bottom:16px}[data-theme=dark] .offline-banner{background:#451a03;border-color:#b45309;color:#fbbf24}.stats-export{margin-top:24px;padding:20px}.stats-export-row{display:flex;flex-direction:column;gap:12px}.stats-export-dates{display:flex;gap:12px}.stats-export-label{flex:1;display:flex;flex-direction:column;gap:4px;font-size:.85rem;color:var(--color-text-muted)}.stats-export-label .form-input{font-size:.9rem}.stats-export-btn{display:inline-flex;align-items:center;gap:6px;align-self:flex-start}.notif-settings{display:flex;flex-direction:column;gap:12px}.notif-toggle-row{display:flex;align-items:center}.notif-toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.95rem}.notif-toggle-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--color-primary)}.notif-actions{display:flex;gap:8px;margin-top:4px}
