@import"https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;0,14..32,800;0,14..32,900&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,SF Pro Text,Inter,Segoe UI,system-ui,sans-serif;background:var(--bg);color:var(--label);min-height:100dvh;overflow-x:hidden}button{font-family:inherit;cursor:pointer;border:none;background:none;padding:0}input,textarea,select{font-family:inherit}a{color:inherit;text-decoration:none}img{display:block}:root{color-scheme:light;--bg: #F2F2F7;--card: #FFFFFF;--elevated: #FFFFFF;--label: #000000;--second-label: #8E8E93;--third-label: #C7C7CC;--separator: rgba(60,60,67,.12);--fill: rgba(120,120,128,.08);--fill-2: rgba(120,120,128,.16);--gray4: #D1D1D6;--gray5: #E5E5EA;--accent: #2D9A4F;--accent-bg: #E6F4EB;--red: #FF3B30;--orange: #FF9500;--green: #34C759;--blue: #007AFF;--warn-bg: #FFF8EE;--danger-bg: #FFF0F0;--success-bg: #E6F4EB;--tab-bar: rgba(249,249,249,.92);--label-inv: #FFFFFF;--overlay: rgba(0,0,0,.3);--r-xs: 8px;--r-sm: 12px;--r-md: 16px;--r-lg: 20px;--r-xl: 24px;--r-card: 20px;--r-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 2px 10px rgba(0,0,0,.09), 0 1px 3px rgba(0,0,0,.05);--shadow-lg: 0 6px 24px rgba(0,0,0,.12), 0 2px 6px rgba(0,0,0,.06);--sidebar-w: 256px}[data-theme=dark]{color-scheme:dark;--bg: #000000;--card: #1C1C1E;--elevated: #2C2C2E;--label: #FFFFFF;--second-label: #8E8E93;--third-label: #48484A;--separator: rgba(84,84,88,.36);--fill: #2C2C2E;--fill-2: #3A3A3C;--gray4: #3A3A3C;--gray5: #2C2C2E;--accent: #4ADE6F;--accent-bg: #1A2E22;--red: #FF453A;--orange: #FF9F0A;--green: #30D158;--blue: #0A84FF;--warn-bg: #2E261A;--danger-bg: #2E1A1A;--success-bg: #1A2E22;--tab-bar: rgba(28,28,30,.92);--label-inv: #000000;--overlay: rgba(0,0,0,.5)}.app-root{display:flex;width:100%;min-height:100dvh;background:var(--bg)}.sidebar{width:var(--sidebar-w);flex-shrink:0;height:100dvh;position:sticky;top:0;display:flex;flex-direction:column;background:var(--tab-bar);backdrop-filter:blur(24px) saturate(180%);-webkit-backdrop-filter:blur(24px) saturate(180%);border-right:1px solid var(--separator);overflow:hidden;z-index:100}.sidebar-logo{display:flex;align-items:center;gap:11px;padding:20px 18px 16px;border-bottom:1px solid var(--separator);flex-shrink:0}.sidebar-logo-icon{width:34px;height:34px;border-radius:10px;display:block;flex-shrink:0;object-fit:contain}.sidebar-logo-text{font-size:19px;font-weight:700;color:var(--label);letter-spacing:-.4px}.sidebar-nav{flex:1;padding:10px;display:flex;flex-direction:column;gap:1px;overflow-y:auto}.sidebar-nav-item{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:var(--r-md);font-size:15px;font-weight:500;color:var(--second-label);background:none;border:none;cursor:pointer;width:100%;text-align:left;transition:background .14s,color .14s;position:relative}.sidebar-nav-item:hover{background:var(--fill);color:var(--label)}.sidebar-nav-item.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.nav-icon{font-size:19px;width:24px;text-align:center;flex-shrink:0}.nav-label{flex:1}.nav-badge{background:var(--red);color:#fff;border-radius:var(--r-full);font-size:11px;font-weight:700;min-width:19px;height:19px;display:flex;align-items:center;justify-content:center;padding:0 5px}.nav-badge-red{background:var(--red)}.sidebar-footer{padding:10px 10px 14px;border-top:1px solid var(--separator);display:flex;gap:6px;align-items:center;flex-shrink:0}.sidebar-meta-btn{flex:1;height:36px;border-radius:var(--r-sm);background:var(--fill);border:none;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;color:var(--second-label);transition:background .14s,color .14s}.sidebar-meta-btn:hover{background:var(--fill-2);color:var(--label)}.main-content{flex:1;min-width:0;height:100dvh;overflow-y:auto;display:flex;flex-direction:column;background:var(--bg)}.topbar{display:none;align-items:center;justify-content:space-between;padding:14px 18px;background:var(--tab-bar);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--separator);position:sticky;top:0;z-index:50;flex-shrink:0}.topbar-title{font-size:17px;font-weight:700;color:var(--label)}.topbar-actions{display:flex;gap:6px}.screen-container{flex:1;display:flex;flex-direction:column;align-items:stretch;padding:0}.screen{width:100%;max-width:800px;padding:28px 36px 100px;flex:1;margin:0 auto}.screen-title{font-size:34px;font-weight:800;color:var(--label);letter-spacing:-.5px;margin-bottom:20px;line-height:1.1}.expiry-alert{padding:11px 20px;font-size:14px;font-weight:600;cursor:pointer;text-align:center;flex-shrink:0}.expiry-alert-critical{background:var(--danger-bg);color:var(--red)}.expiry-alert-warn{background:var(--warn-bg);color:var(--orange)}.bottom-nav{display:none;position:fixed;bottom:0;left:0;right:0;height:72px;background:var(--tab-bar);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-top:1px solid var(--separator);z-index:100;align-items:center;justify-content:space-around;padding:0 4px env(safe-area-inset-bottom,8px)}.bottom-nav-item{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 14px;border-radius:12px;background:none;border:none;cursor:pointer;color:var(--second-label);font-size:10px;font-weight:500;transition:color .14s;position:relative}.bottom-nav-item.active{color:var(--accent)}.bottom-nav-icon{font-size:23px}.bottom-nav-label{font-size:10px;font-weight:500}.bottom-badge{position:absolute;top:2px;right:8px;background:var(--red);color:#fff;border-radius:var(--r-full);font-size:9px;font-weight:700;min-width:16px;height:16px;display:flex;align-items:center;justify-content:center;padding:0 3px}.bottom-badge-red{background:var(--red)}.fab{position:fixed;bottom:28px;right:28px;width:56px;height:56px;border-radius:18px;background:var(--accent);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:24px;box-shadow:0 6px 20px #2d9a4f61;z-index:90;transition:transform .18s cubic-bezier(.34,1.56,.64,1),box-shadow .18s;animation:breathe 3.2s ease-in-out infinite}.fab:hover{transform:scale(1.1);box-shadow:0 8px 28px #2d9a4f80}.fab:active{transform:scale(.94)}[data-theme=dark] .fab{box-shadow:0 6px 20px #4ade6f47}.card{background:var(--card);border-radius:var(--r-card);box-shadow:var(--shadow-sm);padding:16px;margin-bottom:10px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;padding:12px 20px;border-radius:var(--r-md);font-size:15px;font-weight:600;cursor:pointer;transition:opacity .14s,transform .1s;border:none;line-height:1;white-space:nowrap}.btn:active:not(:disabled){transform:scale(.97)}.btn:disabled{opacity:.45;cursor:default}.btn-primary{background:var(--accent);color:#fff;box-shadow:0 3px 10px #2d9a4f47}.btn-secondary{background:var(--label);color:var(--label-inv)}.btn-ghost{background:var(--fill);color:var(--label)}.btn-danger{background:var(--red);color:#fff}.btn-accent{background:var(--accent-bg);color:var(--accent)}.btn-primary:hover:not(:disabled){opacity:.87}.btn-secondary:hover:not(:disabled){opacity:.84}.btn-ghost:hover:not(:disabled){background:var(--fill-2)}[data-theme=dark] .btn-secondary{background:var(--elevated);color:var(--label)}[data-theme=dark] .btn-secondary:hover:not(:disabled){background:var(--fill-2)}.btn-sm{padding:7px 13px;font-size:13px;border-radius:var(--r-sm)}.btn-lg{padding:15px 22px;font-size:16px}.btn-icon{width:36px;height:36px;padding:0;border-radius:var(--r-sm);font-size:16px}.btn-row{display:flex;gap:10px;align-items:stretch}a.btn{text-decoration:none}.input{width:100%;background:var(--fill);border:1.5px solid transparent;border-radius:var(--r-sm);padding:11px 14px;font-size:15px;color:var(--label);outline:none;transition:border-color .15s,background .15s;line-height:1.4;-webkit-appearance:none;-moz-appearance:none;appearance:none}.input:focus{background:var(--card);border-color:var(--accent)}.input::placeholder{color:var(--second-label)}textarea.input{resize:vertical;min-height:44px}[data-theme=dark] .input{background:var(--fill);color:var(--label)}[data-theme=dark] .input:focus{background:var(--elevated)}.pill{display:inline-flex;align-items:center;gap:5px;padding:7px 14px;border-radius:var(--r-full);font-size:14px;font-weight:500;cursor:pointer;border:none;background:var(--fill);color:var(--second-label);transition:background .14s,color .14s;white-space:nowrap}.pill:hover{background:var(--fill-2);color:var(--label)}.pill-active{background:var(--label)!important;color:var(--label-inv)!important;font-weight:600}[data-theme=dark] .pill-active{background:var(--accent)!important;color:#000!important}.pill-badge{background:var(--red);color:#fff;border-radius:var(--r-full);font-size:10px;font-weight:700;min-width:17px;height:17px;display:flex;align-items:center;justify-content:center;padding:0 4px}.tag{display:inline-flex;align-items:center;padding:3px 8px;border-radius:7px;font-size:11px;font-weight:600}.toolbar{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;align-items:center;flex-wrap:nowrap;margin-bottom:10px}.toolbar::-webkit-scrollbar{display:none}.toolbar-sep{width:1px;height:20px;background:var(--separator);flex-shrink:0}.chip{display:inline-flex;align-items:center;gap:5px;padding:8px 14px;border-radius:var(--r-full);background:var(--fill);border:1.5px solid transparent;font-size:13px;font-weight:600;color:var(--second-label);cursor:pointer;white-space:nowrap;transition:background .14s,color .14s,border-color .14s}.chip:hover{background:var(--fill-2);color:var(--label)}.chip-active{background:var(--label);color:var(--label-inv);border-color:var(--label)}[data-theme=dark] .chip-active{background:var(--accent);color:#000;border-color:var(--accent)}.chip-danger{background:var(--danger-bg);color:var(--red);border-color:#ff3b304d}.chip-wrap{display:flex;flex-wrap:wrap;gap:8px}.chip-row{display:flex;flex-wrap:wrap;gap:6px}.checkbox{width:24px;height:24px;border-radius:12px;border:2px solid var(--gray4);background:transparent;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:12px;font-weight:700;color:#fff;flex-shrink:0;transition:background .14s,border-color .14s,transform .1s}.checkbox:active{transform:scale(.88)}.checkbox-checked{background:var(--accent);border-color:var(--accent)}.field{margin-bottom:16px}.field-label{display:block;font-size:12px;font-weight:600;color:var(--second-label);text-transform:uppercase;letter-spacing:.5px;margin-bottom:7px}.label-xs{display:block;font-size:12px;font-weight:600;color:var(--second-label);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.banner{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--r-md);margin-bottom:10px;font-size:14px;font-weight:500;cursor:pointer;border:none;width:100%;text-align:left}.banner-warn{background:var(--warn-bg);color:var(--orange)}.banner-accent{background:var(--accent-bg);color:var(--accent)}.banner-card{background:var(--card);color:var(--label);box-shadow:var(--shadow-sm)}.spinner{display:inline-block;width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:currentColor;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}.empty-state{display:flex;flex-direction:column;align-items:center;padding:40px 24px 24px;text-align:center}.empty-icon{width:76px;height:76px;border-radius:24px;background:var(--fill);display:flex;align-items:center;justify-content:center;font-size:36px;margin-bottom:16px}.empty-title{font-size:19px;font-weight:700;color:var(--label);margin-bottom:8px}.empty-subtitle{font-size:14px;color:var(--second-label);line-height:1.5;max-width:260px}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:500;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .16s ease}.sheet{background:var(--card);border-radius:var(--r-xl) var(--r-xl) 0 0;width:100%;max-width:580px;max-height:92dvh;overflow-y:auto;animation:slideUp .26s cubic-bezier(.34,1.2,.64,1);padding:0 20px}.sheet-handle{width:36px;height:5px;background:var(--gray4);border-radius:3px;margin:10px auto 16px}.sheet-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.sheet-title{font-size:22px;font-weight:700;color:var(--label)}.sheet-close{width:30px;height:30px;border-radius:15px;background:var(--fill);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:13px;color:var(--second-label);transition:background .14s}.sheet-close:hover{background:var(--fill-2)}.sheet-body{padding-bottom:36px}.search-bar{display:flex;align-items:center;gap:8px;background:var(--fill);border-radius:var(--r-sm);padding:0 12px;height:40px}.search-icon{font-size:15px;color:var(--second-label);flex-shrink:0}.search-input{flex:1;border:none;background:transparent;font-size:15px;color:var(--label);outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.search-input::placeholder{color:var(--second-label)}.search-clear{font-size:13px;color:var(--second-label);cursor:pointer;background:none;border:none;padding:2px}.toast{position:fixed;top:20px;left:50%;transform:translate(-50%) translateY(-60px);background:#1c1c1e;color:#fff;padding:11px 22px;border-radius:var(--r-full);font-size:14px;font-weight:500;z-index:9999;pointer-events:none;box-shadow:0 4px 20px #00000047;transition:transform .26s cubic-bezier(.34,1.56,.64,1),opacity .2s;opacity:0;white-space:nowrap;animation:toastIn .28s cubic-bezier(.34,1.56,.64,1) forwards,toastOut .22s ease 2.6s forwards}[data-theme=dark] .toast{background:#3a3a3c}.quick-add-row{display:flex;align-items:center;gap:14px;padding:12px 14px;background:var(--card);border-radius:var(--r-md);margin-bottom:8px;box-shadow:var(--shadow-sm);cursor:pointer;border:none;width:100%;text-align:left;transition:transform .12s,box-shadow .12s}.quick-add-row:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.quick-add-icon{width:40px;height:40px;border-radius:12px;background:var(--fill);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.quick-add-plus{font-size:20px;color:var(--accent)}.item-list{margin-top:6px}.pantry-item{background:var(--card);border-radius:var(--r-card);box-shadow:var(--shadow-sm);margin-bottom:10px;overflow:hidden;transition:transform .14s,box-shadow .14s}.pantry-item:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.pantry-item-selected{outline:2px solid var(--accent);outline-offset:-2px}.pantry-item>.pantry-item-row{display:flex;align-items:center;gap:12px;padding:14px}.pantry-item-icon{width:44px;height:44px;border-radius:14px;background:var(--fill);display:flex;align-items:center;justify-content:center;font-size:22px;flex-shrink:0}.pantry-item-info{flex:1;min-width:0}.pantry-item-name{font-size:16px;font-weight:600;color:var(--label);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pantry-item-qty{font-size:14px;color:var(--second-label);margin-top:1px}.pantry-item-notes{font-size:12px;color:var(--third-label);margin-top:2px}.pantry-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:5px;flex-shrink:0}.pantry-item-date{font-size:11px;color:var(--third-label)}.pantry-item-actions{display:flex;gap:6px;align-items:center}.expiry-badge{padding:4px 10px;border-radius:8px;font-size:12px;font-weight:600}.expiry-expired{background:var(--danger-bg);color:var(--red)}.expiry-soon{background:var(--warn-bg);color:var(--orange)}.expiry-ok{background:var(--success-bg);color:var(--accent)}.expiry-bar{height:3px;width:100%;background:var(--fill)}.expiry-bar-fill{height:3px;border-radius:2px}.expiry-bar-red{background:var(--red)}.expiry-bar-orange{background:var(--orange)}.expiry-bar-green{background:var(--accent)}.confirm-row{display:flex;gap:8px;padding:10px 14px;border-top:.5px solid var(--separator)}.skeleton-card{background:var(--card);border-radius:var(--r-card);padding:18px;margin-bottom:12px;animation:shimmer 1.5s ease-in-out infinite}.skeleton-row{display:flex;gap:12px;margin-bottom:14px;align-items:flex-start}.skeleton-block{background:var(--fill);border-radius:6px}.recipe-card{background:var(--card);border-radius:var(--r-card);box-shadow:var(--shadow-sm);margin-bottom:12px;overflow:hidden;transition:transform .14s,box-shadow .14s}.recipe-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.recipe-card-header{display:flex;align-items:flex-start;padding:16px;gap:14px;cursor:pointer}.recipe-emoji{width:48px;height:48px;border-radius:14px;background:var(--fill);display:flex;align-items:center;justify-content:center;font-size:24px;flex-shrink:0}.recipe-expand{padding:14px 16px 16px;border-top:.5px solid var(--separator)}.servings-row{display:flex;align-items:center;gap:8px;background:var(--fill);padding:10px 12px;border-radius:var(--r-sm);margin-bottom:14px}.servings-btn{width:32px;height:32px;border-radius:8px;background:var(--card);border:none;cursor:pointer;font-size:18px;font-weight:500;color:var(--label);display:flex;align-items:center;justify-content:center;transition:background .12s}.servings-btn:hover{background:var(--fill-2)}.ing-chip{display:inline-flex;align-items:center;padding:5px 10px;border-radius:8px;font-size:13px;font-weight:500}.ing-chip-have{background:var(--accent-bg);color:var(--accent)}.ing-chip-miss{background:var(--warn-bg);color:var(--orange)}.step-row{display:flex;gap:10px;margin-bottom:10px;align-items:flex-start}.step-num{width:22px;height:22px;border-radius:11px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0;margin-top:2px}.timer-bar{display:flex;align-items:center;gap:10px;padding:11px 14px;background:var(--elevated);border-radius:var(--r-md);color:var(--label);margin-bottom:12px;border:1px solid var(--separator)}.timer-count{font-size:22px;font-weight:700;color:var(--accent)}.shopping-item{background:var(--card);border-radius:var(--r-md);box-shadow:var(--shadow-sm);padding:11px 14px;display:flex;align-items:center;gap:10px;margin-bottom:8px;transition:opacity .2s}.shopping-item-done{opacity:.45}.shopping-item-name{font-size:16px;color:var(--label);line-height:1.3}.shopping-item-done .shopping-item-name{text-decoration:line-through;color:var(--second-label)}.shopping-item-from{font-size:12px;color:var(--third-label);margin-top:2px}.qty-ctrl{display:flex;align-items:center;gap:3px;background:var(--fill);border-radius:10px;padding:3px;flex-shrink:0}.qty-btn{width:28px;height:28px;border-radius:7px;background:var(--card);border:none;cursor:pointer;font-size:16px;font-weight:500;color:var(--label);display:flex;align-items:center;justify-content:center;transition:background .1s}.qty-btn:hover{background:var(--fill-2)}.qty-val{font-size:13px;font-weight:600;color:var(--label);min-width:22px;text-align:center}.week-strip{display:flex;gap:5px;overflow-x:auto;padding-bottom:12px;scrollbar-width:none}.week-strip::-webkit-scrollbar{display:none}.day-chip{display:flex;flex-direction:column;align-items:center;padding:9px 12px;border-radius:var(--r-md);cursor:pointer;border:none;background:var(--fill);color:var(--second-label);min-width:52px;transition:background .14s,color .14s;position:relative}.day-chip:hover{background:var(--fill-2);color:var(--label)}.day-chip-active{background:var(--label);color:var(--label-inv)}[data-theme=dark] .day-chip-active{background:var(--accent);color:#000}.day-chip-today{outline:2px solid var(--accent);outline-offset:-2px}.day-chip-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.day-chip-date{font-size:18px;font-weight:700;margin-top:2px}.day-chip-dot{width:5px;height:5px;border-radius:3px;background:var(--accent);margin-top:4px}.meal-card{background:var(--card);border-radius:var(--r-lg);padding:14px 16px;margin-bottom:10px;border:1.5px solid var(--separator);box-shadow:var(--shadow-sm);transition:border-color .2s}.meal-card-filled{border-color:color-mix(in srgb,var(--accent) 40%,transparent)}.meal-card-header{display:flex;align-items:center;gap:10px;margin-bottom:8px}.meal-emoji{font-size:21px}.meal-label{font-size:14px;font-weight:700;color:var(--label);flex:1}.meal-actions{display:flex;gap:3px}.meal-action-btn{width:30px;height:30px;border-radius:8px;background:var(--fill);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:background .14s}.meal-action-btn:hover{background:var(--fill-2)}.meal-content{min-height:34px;cursor:pointer;padding:2px 0}.meal-text{font-size:14px;color:var(--label);line-height:1.5}.meal-placeholder{font-size:14px;color:var(--second-label);font-style:italic}.ing-check-panel{margin-top:10px;padding-top:10px;border-top:.5px solid var(--separator)}.ai-panel{position:fixed;right:0;top:0;bottom:0;width:380px;background:var(--card);border-left:1px solid var(--separator);display:flex;flex-direction:column;z-index:300;box-shadow:-6px 0 32px #0000001a;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1)}.ai-panel-open{transform:translate(0)}.ai-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--overlay);z-index:299;animation:fadeIn .18s ease}.ai-header{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid var(--separator);flex-shrink:0}.ai-avatar{width:38px;height:38px;border-radius:19px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}.ai-title{font-size:16px;font-weight:600;color:var(--label)}.ai-status{display:flex;align-items:center;gap:5px;margin-top:2px}.ai-subtitle{font-size:12px;color:var(--second-label)}.status-dot{width:7px;height:7px;border-radius:4px;background:var(--accent);flex-shrink:0}.status-dot-typing{background:var(--green);animation:breathe 1.2s ease-in-out infinite}.ai-messages{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:2px}.msg-row{display:flex;gap:7px;align-items:flex-end;margin-bottom:6px}.msg-row-user{flex-direction:row-reverse}.msg-avatar{width:26px;height:26px;border-radius:13px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}.msg-bubble{max-width:80%;padding:9px 13px;border-radius:18px;font-size:15px;line-height:1.5}.msg-bubble-ai{background:var(--elevated);color:var(--label);border-bottom-left-radius:4px;box-shadow:var(--shadow-sm);border:1px solid var(--separator)}.msg-bubble-user{background:var(--accent);color:#fff;border-bottom-right-radius:4px}.typing-dots{padding:4px 6px}.typing-dots span{width:7px;height:7px;border-radius:50%;background:var(--accent);display:inline-block;margin:0 2px;animation:bounce 1.1s ease-in-out infinite}.typing-dots span:nth-child(2){animation-delay:.18s}.typing-dots span:nth-child(3){animation-delay:.36s}.video-row{display:flex;gap:8px;overflow-x:auto;padding:4px 0 10px 34px;scrollbar-width:none}.video-row::-webkit-scrollbar{display:none}.video-card{width:170px;background:var(--card);border-radius:var(--r-sm);overflow:hidden;box-shadow:var(--shadow-sm);flex-shrink:0;text-decoration:none;color:inherit;display:block}.video-thumb{width:170px;height:96px;object-fit:cover}.video-title{padding:7px 8px 8px;font-size:11px;font-weight:500;color:var(--label);line-height:1.4}.video-fallback{display:inline-flex;align-items:center;gap:6px;margin-left:34px;background:var(--card);padding:7px 13px;border-radius:var(--r-full);box-shadow:var(--shadow-sm);font-size:13px;color:var(--accent);font-weight:500;text-decoration:none}.video-loading{display:flex;align-items:center;gap:6px;margin-left:34px;margin-bottom:8px;font-size:13px;color:var(--second-label)}.video-search-btn{display:inline-flex;align-items:center;gap:6px;margin-left:34px;margin-bottom:8px;background:var(--fill);padding:7px 13px;border-radius:var(--r-full);font-size:13px;color:var(--second-label);font-weight:500;border:none;cursor:pointer;transition:background .14s}.video-search-btn:hover{background:var(--fill-2)}.ai-suggestions{display:flex;gap:6px;padding:8px 12px;overflow-x:auto;border-top:1px solid var(--separator);flex-shrink:0;scrollbar-width:none}.ai-suggestions::-webkit-scrollbar{display:none}.suggestion-chip{padding:6px 13px;border-radius:var(--r-full);background:var(--fill);border:none;cursor:pointer;font-size:13px;font-weight:500;color:var(--second-label);white-space:nowrap;transition:background .14s,color .14s}.suggestion-chip:hover{background:var(--fill-2);color:var(--label)}.ai-input-row{display:flex;gap:8px;padding:8px 12px 16px;flex-shrink:0}.ai-input{flex:1;background:var(--fill);border:1.5px solid transparent;border-radius:var(--r-lg);padding:10px 14px;font-size:15px;color:var(--label);outline:none;resize:none;max-height:100px;line-height:1.4;transition:border-color .15s,background .15s;-webkit-appearance:none;-moz-appearance:none;appearance:none}.ai-input:focus{background:var(--card);border-color:var(--accent)}.ai-input::placeholder{color:var(--second-label)}[data-theme=dark] .ai-input{background:var(--fill);color:var(--label)}[data-theme=dark] .ai-input:focus{background:var(--elevated)}.ai-send{width:42px;height:42px;border-radius:21px;background:var(--fill);border:none;cursor:pointer;font-size:18px;color:var(--second-label);display:flex;align-items:center;justify-content:center;align-self:flex-end;transition:background .15s,color .15s}.ai-send-active{background:var(--accent);color:#fff}.ai-send:disabled{opacity:.45;cursor:default}.profile-user-card{display:flex;align-items:center;gap:14px}.profile-avatar{width:56px;height:56px;border-radius:28px;object-fit:cover;flex-shrink:0}.profile-avatar-initial{width:56px;height:56px;border-radius:28px;background:var(--accent);display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;color:#fff;flex-shrink:0}.profile-name{font-size:19px;font-weight:700;color:var(--label)}.profile-email{font-size:14px;color:var(--second-label);margin-top:2px}.stats-row{display:flex;gap:8px;margin-bottom:10px}.stat-card{flex:1;background:var(--card);border-radius:var(--r-card);padding:14px 10px;text-align:center;box-shadow:var(--shadow-sm)}.stat-num{font-size:26px;font-weight:800}.stat-label{font-size:10px;font-weight:600;color:var(--second-label);text-transform:uppercase;letter-spacing:.4px;margin-top:3px}.waste-bar-track{height:8px;background:var(--fill);border-radius:4px;overflow:hidden;margin-bottom:8px}.waste-bar-fill{height:8px;border-radius:4px;width:0}.toggle{width:48px;height:28px;border-radius:14px;background:var(--gray4);border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}.toggle:after{content:"";position:absolute;width:22px;height:22px;border-radius:11px;background:#fff;top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 4px #0003}.toggle-on{background:var(--accent)}.toggle-on:after{transform:translate(20px)}.login-screen{min-height:100dvh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:24px}.login-card{background:var(--card);border-radius:var(--r-xl);padding:48px 44px;max-width:400px;width:100%;box-shadow:var(--shadow-lg);text-align:center}.login-logo{margin-bottom:18px;display:flex;align-items:center;justify-content:center}.login-title{font-size:36px;font-weight:800;color:var(--label);letter-spacing:-.6px;margin-bottom:6px}.login-tagline{font-size:15px;color:var(--second-label);margin-bottom:32px}.login-features{margin-bottom:28px;text-align:left}.login-feature{display:flex;align-items:center;gap:14px;margin-bottom:14px;font-size:15px;color:var(--label);line-height:1.3}.login-feature-icon{width:44px;height:44px;border-radius:13px;background:var(--accent-bg);display:flex;align-items:center;justify-content:center;font-size:21px;flex-shrink:0}.login-error{font-size:13px;color:var(--red);margin-top:10px}.login-note{font-size:12px;color:var(--third-label);margin-top:16px}.diet-editor{padding:4px 0 16px}.diet-section-title{font-size:14px;font-weight:700;color:var(--label);margin-bottom:10px;margin-top:18px}.cal-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}@media (max-width: 768px){.sidebar{display:none}.topbar,.bottom-nav{display:flex}.main-content{padding-bottom:0}.screen{padding:16px 16px 90px}.screen-title{font-size:28px;margin-bottom:14px}.fab{bottom:86px;right:16px}.ai-panel{width:100%;left:0;border-left:none;top:auto;height:88dvh;border-radius:var(--r-xl) var(--r-xl) 0 0;transform:translateY(100%);border-top:1px solid var(--separator)}.ai-panel-open{transform:translateY(0)}.ai-overlay{display:none}.login-card{padding:36px 24px}}@media (min-width: 1440px){.screen{max-width:900px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(36px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes scaleIn{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-6px)}}@keyframes breathe{0%,to{box-shadow:0 6px 20px #2d9a4f52}50%{box-shadow:0 8px 28px #2d9a4f85}}@keyframes shimmer{0%,to{opacity:.5}50%{opacity:1}}@keyframes toastIn{0%{transform:translate(-50%) translateY(-50px);opacity:0}to{transform:translate(-50%) translateY(0);opacity:1}}@keyframes toastOut{0%{opacity:1}to{opacity:0}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--gray4);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--second-label)}
