*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg:#FFF8F0;--bg-card:#FFFFFF;--bg-elevated:#FFF3E8;--bg-input:#FFFFFF;--bg-overlay:rgba(45,41,38,.55);--bg-sheet:#FFFFFF;--text:#2D2926;--text-secondary:#7A7067;--text-tertiary:#A89E95;--border:#EDE5DC;--border-light:#F5EDE5;--accent:#C4704B;--accent-hover:#B05E39;--accent-light:rgba(196,112,75,.1);--accent-soft:rgba(196,112,75,.06);--accent-text:#FFFFFF;--green:#7B9E6B;--green-light:rgba(123,158,107,.12);--red:#C45B5B;--red-light:rgba(196,91,91,.1);--gold:#D4A84B;--gold-light:rgba(212,168,75,.12);--tag-bg:#F5EDE5;--tag-text:#7A7067;--shadow-sm:0 1px 4px rgba(45,41,38,.06);--shadow-md:0 4px 16px rgba(45,41,38,.08);--shadow-lg:0 8px 32px rgba(45,41,38,.12);--shadow-glow:0 0 0 3px rgba(196,112,75,.15);--radius-sm:10px;--radius-md:16px;--radius-lg:24px;--radius-full:999px;--tab-active:var(--accent);--tab-inactive:var(--text-tertiary);--skeleton:linear-gradient(90deg,var(--bg-elevated) 25%,var(--border-light) 50%,var(--bg-elevated) 75%);--sidebar-width:240px;font-family:DM Sans,sans-serif;color:var(--text);background:var(--bg)}[data-theme=dark]{--bg:#1C1612;--bg-card:#28211A;--bg-elevated:#332A21;--bg-input:#332A21;--bg-overlay:rgba(10,8,6,.7);--bg-sheet:#28211A;--text:#F5EBE0;--text-secondary:#BFB0A0;--text-tertiary:#7A6D60;--border:#3D3228;--border-light:#332A21;--accent:#D88A60;--accent-hover:#E89E78;--accent-light:rgba(216,138,96,.15);--accent-soft:rgba(216,138,96,.06);--accent-text:#1C1612;--green:#95C483;--green-light:rgba(149,196,131,.15);--red:#D47070;--red-light:rgba(212,112,112,.12);--gold:#E0B85C;--gold-light:rgba(224,184,92,.15);--tag-bg:#332A21;--tag-text:#BFB0A0;--shadow-sm:0 1px 4px rgba(0,0,0,.2);--shadow-md:0 4px 16px rgba(0,0,0,.25);--shadow-lg:0 8px 32px rgba(0,0,0,.35);--skeleton:linear-gradient(90deg,var(--bg-elevated) 25%,var(--border) 50%,var(--bg-elevated) 75%) }html{scroll-behavior:smooth}body{font-family:DM Sans,sans-serif;background:var(--bg);color:var(--text);min-height:100dvh;-webkit-font-smoothing:antialiased;transition:background .35s,color .35s}h1,h2,h3,h4{font-family:Playfair Display,serif;font-weight:600;line-height:1.2}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.app-shell{max-width:480px;margin:0 auto;min-height:100dvh;display:flex;flex-direction:column;position:relative}.app-content{flex:1;padding:0 16px 110px;overflow-x:hidden;overflow-y:auto;-webkit-overflow-scrolling:touch}.app-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 10px;position:sticky;top:0;background:var(--bg);z-index:100;transition:background .35s}.app-title{font-family:Playfair Display,serif;font-size:26px;font-weight:700;display:flex;align-items:center;gap:10px}.header-actions{display:flex;align-items:center;gap:6px}.desktop-layout{display:flex;min-height:100dvh;width:100%}.desktop-sidebar{width:var(--sidebar-width);background:var(--bg-card);border-right:1px solid var(--border);display:flex;flex-direction:column;position:fixed;top:0;bottom:0;left:0;padding:24px 0;z-index:200;transition:background .35s}.desktop-main{flex:1;margin-left:var(--sidebar-width);min-height:100dvh;display:flex;flex-direction:column}.desktop-main .app-header{position:sticky;top:0;padding:20px 32px 12px;background:var(--bg);z-index:100;border-bottom:1px solid var(--border-light);display:flex;align-items:center;justify-content:space-between}.desktop-main .app-content{flex:1;padding:24px 32px 40px;overflow-y:auto;max-width:none}.sidebar-logo{display:flex;align-items:center;gap:10px;padding:0 24px 24px;font-family:Playfair Display,serif;font-size:24px;font-weight:700}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:2px;padding:0 12px}.sidebar-item{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:14px;font-weight:500;color:var(--text-secondary);transition:all .15s;border:none;background:none;width:100%;text-align:left;font-family:DM Sans,sans-serif}.sidebar-item:hover{background:var(--bg-elevated);color:var(--text)}.sidebar-item.active{background:var(--accent-light);color:var(--accent);font-weight:600}.sidebar-item svg{width:20px;height:20px}.sidebar-footer{padding:16px 24px;border-top:1px solid var(--border-light)}.sidebar-footer a{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-tertiary);text-decoration:none}.sidebar-footer a:hover{color:var(--accent)}.sidebar-footer img{width:24px;height:24px;border-radius:5px}.desktop-main .recipe-grid{grid-template-columns:repeat(3,1fr);gap:20px}@media(min-width:1200px){.desktop-main .recipe-grid{grid-template-columns:repeat(4,1fr)}}.desktop-main .search-bar{max-width:480px}.desktop-main .filters{max-width:100%}.desktop-main .seasonal-banner{max-width:640px}.desktop-main .url-import{max-width:520px}.desktop-main .shop-add{max-width:480px}.desktop-main .staples-section{max-width:520px}.desktop-main .form-container{max-width:560px}.desktop-main .servings-slider{max-width:400px}.desktop-main .meal-cards{flex-direction:row;gap:16px}.desktop-main .meal-card{flex:1}.desktop-main .day-tab{min-width:80px;padding:12px 8px}.desktop-main .planner-extras{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.desktop-main .planner-extras>*{margin-top:0!important}.desktop-main .nutrition-days{height:120px}.desktop-main .prep-stats{gap:12px}.desktop-main~.detail-overlay,.desktop-layout .detail-overlay{max-width:560px;margin:0;right:0;left:auto;box-shadow:-4px 0 32px #0000001a;border-left:1px solid var(--border)}.desktop-layout .detail-hero{aspect-ratio:16/9}.desktop-layout .detail-body{padding:24px 28px 40px}.desktop-layout .sheet-overlay{align-items:center}.desktop-layout .sheet{border-radius:var(--radius-lg);max-width:520px;max-height:80vh;animation:modalIn .25s ease}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}.desktop-layout .onboarding-overlay{max-width:520px;left:50%;top:50%;bottom:auto;right:auto;transform:translate(-50%,-50%);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--border);min-height:520px;height:auto}.icon-btn{width:40px;height:40px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s;flex-shrink:0}.icon-btn:hover{border-color:var(--accent);color:var(--accent)}.icon-btn svg{width:18px;height:18px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 24px;border-radius:var(--radius-full);font-family:DM Sans,sans-serif;font-weight:600;font-size:14px;border:none;cursor:pointer;transition:all .2s}.btn:active{transform:scale(.97)}.btn-primary{background:var(--accent);color:var(--accent-text)}.btn-primary:hover{background:var(--accent-hover);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-elevated);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);color:var(--accent)}.btn-danger{background:var(--red-light);color:var(--red)}.btn-small{padding:8px 16px;font-size:13px}.btn-xs{padding:5px 12px;font-size:12px}.btn svg{width:16px;height:16px}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);object-fit:cover;border:2px solid var(--border);cursor:pointer;transition:border-color .2s}.user-avatar:hover{border-color:var(--accent)}.tab-bar{position:fixed;bottom:0;left:50%;transform:translate(-50%);width:100%;max-width:480px;display:flex;background:var(--bg-card);border-top:1px solid var(--border);padding:4px 0 env(safe-area-inset-bottom,8px);z-index:200;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px)}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:8px 0;cursor:pointer;background:none;border:none;color:var(--tab-inactive);font-size:10px;font-family:DM Sans,sans-serif;font-weight:500;transition:color .15s;position:relative}.tab-item svg{width:22px;height:22px;transition:all .15s}.tab-item.active{color:var(--tab-active);font-weight:600}.tab-item.active svg{stroke-width:2.2}.tab-item.active:after{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2.5px;border-radius:2px;background:var(--accent)}.input,.textarea{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-input);color:var(--text);font-family:DM Sans,sans-serif;font-size:14px;transition:border-color .2s,box-shadow .2s;outline:none}.input:focus,.textarea:focus{border-color:var(--accent);box-shadow:var(--shadow-glow)}.input::placeholder,.textarea::placeholder{color:var(--text-tertiary)}.textarea{resize:vertical;min-height:80px}.search-bar{position:relative;margin-bottom:16px}.search-bar>svg{position:absolute;left:14px;top:50%;transform:translateY(-50%);width:18px;height:18px;color:var(--text-tertiary);pointer-events:none}.search-bar input{padding-left:42px;padding-right:48px}.search-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);width:36px;height:36px;border-radius:var(--radius-sm);background:var(--accent);color:#fff;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s}.search-btn:hover{background:var(--accent-hover)}.search-btn svg{width:16px;height:16px}.filters{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px;margin-bottom:16px;scrollbar-width:none}.filters::-webkit-scrollbar{display:none}.filter-chip{padding:7px 14px;border-radius:var(--radius-full);font-size:13px;font-weight:500;white-space:nowrap;border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);cursor:pointer;transition:all .2s;font-family:DM Sans,sans-serif;display:inline-flex;align-items:center;gap:5px}.filter-chip:active{transform:scale(.96)}.filter-chip.active{background:var(--accent);color:var(--accent-text);border-color:var(--accent)}.recipe-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.recipe-card{background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm);cursor:pointer;transition:transform .25s ease,box-shadow .25s ease;border:1px solid var(--border-light);position:relative;opacity:0;animation:cardFadeIn .4s ease forwards}.recipe-card:hover{transform:translateY(-3px);box-shadow:var(--shadow-md)}.recipe-card:active{transform:translateY(-1px) scale(.99)}@keyframes cardFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.recipe-card-img-wrap{position:relative;width:100%;aspect-ratio:16/10;overflow:hidden;background:var(--bg-elevated)}.recipe-card-img{width:100%;height:100%;object-fit:cover;transition:transform .4s ease}.recipe-card:hover .recipe-card-img{transform:scale(1.04)}.recipe-card-img-wrap:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(transparent,#0003);pointer-events:none}.card-fav{position:absolute;top:8px;right:8px;width:30px;height:30px;border-radius:50%;background:#ffffffd9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:2;transition:all .2s;color:var(--text-tertiary)}.card-fav:hover{transform:scale(1.1)}.card-fav.active{color:var(--red);background:#fffffff2}.card-fav svg{width:16px;height:16px}.recipe-card-body{padding:11px 13px 13px}.recipe-card-title{font-family:Playfair Display,serif;font-size:14px;font-weight:600;margin-bottom:5px;line-height:1.25;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-card-meta{display:flex;align-items:center;gap:10px;font-size:11px;color:var(--text-secondary)}.recipe-card-meta svg{width:12px;height:12px;flex-shrink:0}.recipe-card-meta span{display:flex;align-items:center;gap:3px}.recipe-tags{display:flex;gap:4px;margin-top:6px;flex-wrap:wrap}.tag{font-size:10px;padding:2px 7px;border-radius:var(--radius-full);background:var(--tag-bg);color:var(--tag-text);font-weight:600}.tag.saved{background:var(--green-light);color:var(--green)}.tag.discover{background:var(--accent-light);color:var(--accent)}.tag.fav{background:var(--gold-light);color:var(--gold)}.tag.manual{background:var(--bg-elevated);color:var(--text-tertiary);border:1px dashed var(--border)}.history-badge{font-size:11px;padding:3px 8px;border-radius:var(--radius-full);font-weight:600;background:var(--gold-light);color:var(--gold)}.skeleton{background:var(--bg-elevated);background-image:var(--skeleton);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite;border-radius:var(--radius-sm)}.skeleton-card{background:var(--bg-card);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-light)}.skeleton-img{aspect-ratio:16/10;border-radius:0}.skeleton-text{height:14px;margin:8px 14px;border-radius:4px}.skeleton-text.short{width:60%}.skeleton-text.tiny{height:10px;width:40%;margin-top:10px}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg-overlay);z-index:300;display:flex;align-items:flex-end;justify-content:center;animation:fadeIn .2s ease}.sheet{background:var(--bg-sheet);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:480px;max-height:85dvh;overflow-y:auto;padding:20px 16px 32px;animation:slideUp .3s cubic-bezier(.32,.72,0,1)}.sheet-handle{width:40px;height:4px;border-radius:2px;background:var(--border);margin:0 auto 16px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:250;overflow-y:auto;animation:slideInRight .35s cubic-bezier(.32,.72,0,1);max-width:480px;margin:0 auto}@keyframes slideInRight{0%{transform:translate(100%);opacity:.8}to{transform:translate(0);opacity:1}}.detail-hero{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden}.detail-hero img{width:100%;height:100%;object-fit:cover}.detail-hero-gradient{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(transparent 35%,#0000008c)}.detail-info-bar{position:absolute;bottom:0;left:0;right:0;padding:14px 16px;background:#0000004d;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);display:flex;gap:18px;align-items:center;color:#fff;font-size:13px;font-weight:500;z-index:5}.detail-info-bar span{display:flex;align-items:center;gap:5px}.detail-info-bar svg{width:15px;height:15px;opacity:.85}.detail-back,.detail-action-btn{position:absolute;top:16px;width:40px;height:40px;border-radius:var(--radius-full);background:#ffffffe6;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;color:#2d2926;z-index:10;transition:transform .15s}.detail-back:active,.detail-action-btn:active{transform:scale(.92)}.detail-back{left:16px}.detail-action-btn.active{background:var(--accent);color:#fff}.detail-action-btn.fav-active{background:var(--red);color:#fff}.detail-body{padding:20px 16px 80px}.detail-title{font-size:26px;margin-bottom:12px}.detail-tags{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px}.servings-slider{background:var(--bg-elevated);border-radius:var(--radius-md);padding:14px 18px;margin-bottom:24px}.servings-slider label{display:flex;align-items:center;justify-content:space-between;font-weight:600;font-size:14px;margin-bottom:10px}.servings-slider input[type=range]{width:100%;accent-color:var(--accent);height:6px}.ingredient-list{list-style:none;margin-bottom:28px}.ingredient-list li{padding:11px 0;border-bottom:1px solid var(--border-light);font-size:14px;display:flex;align-items:center;gap:10px}.ingredient-list li:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--accent);flex-shrink:0}.ingredient-amount{font-weight:600;color:var(--accent);min-width:72px;font-variant-numeric:tabular-nums}.step-list{margin-bottom:28px}.step-item{display:flex;gap:14px;margin-bottom:18px;font-size:14px;line-height:1.65}.step-num{width:28px;height:28px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0;margin-top:2px}.section-title{font-family:Playfair Display,serif;font-size:20px;font-weight:600;margin-bottom:14px}.section-subtitle{font-size:14px;color:var(--text-secondary);margin-bottom:16px}.planner-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.planner-nav h3{font-size:16px;font-family:Playfair Display,serif}.day-tabs{display:flex;gap:4px;margin-bottom:16px;overflow-x:auto;scrollbar-width:none;scroll-behavior:smooth}.day-tabs::-webkit-scrollbar{display:none}.day-tab{flex:1;min-width:52px;padding:8px 4px;text-align:center;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-card);cursor:pointer;transition:all .2s;font-family:DM Sans,sans-serif}.day-tab:active{transform:scale(.96)}.day-tab .day-name{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.day-tab .day-num{font-size:18px;font-weight:700;color:var(--text);margin-top:2px}.day-tab.active{border-color:var(--accent);background:var(--accent-light)}.day-tab.active .day-name,.day-tab.active .day-num{color:var(--accent)}.day-tab.today:not(.active){border-color:var(--green)}.day-tab.today:not(.active) .day-num{color:var(--green)}.meal-cards{display:flex;flex-direction:column;gap:12px}.meal-card{background:var(--bg-card);border:1.5px solid var(--border);border-radius:var(--radius-md);padding:14px 16px;cursor:pointer;transition:all .2s;min-height:72px}.meal-card:hover{border-color:var(--accent);box-shadow:var(--shadow-sm)}.meal-card:active{transform:scale(.99)}.meal-card.filled{border-color:#c4704b4d;background:var(--accent-soft)}.meal-card.dragging{opacity:.5;border-style:dashed}.meal-card.drag-over{border-color:var(--accent);background:var(--accent-light);box-shadow:var(--shadow-glow)}.meal-card-header{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.8px;color:var(--text-tertiary);margin-bottom:6px}.meal-card-content{display:flex;align-items:center;gap:12px}.meal-card-img{width:50px;height:50px;border-radius:var(--radius-sm);object-fit:cover;flex-shrink:0}.meal-card-title{font-weight:600;font-size:15px}.meal-card-sub{font-size:12px;color:var(--text-secondary);margin-top:2px}.meal-card-empty{display:flex;align-items:center;gap:8px;color:var(--text-tertiary);font-size:14px}.meal-card-empty svg{width:20px;height:20px}.meal-action{display:flex;flex-direction:column;gap:4px}.meal-action-item{display:flex;align-items:center;gap:12px;padding:14px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s;font-size:15px;font-weight:500;border:none;background:none;width:100%;text-align:left;color:var(--text);font-family:DM Sans,sans-serif}.meal-action-item:hover{background:var(--bg-elevated)}.meal-action-item svg{width:20px;height:20px;color:var(--text-secondary)}.meal-action-item.danger{color:var(--red)}.meal-action-item.danger svg{color:var(--red)}.prep-summary,.nutrition-bar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:16px;margin-top:16px}.planner-extras{display:flex;flex-direction:column}.prep-summary h4,.nutrition-bar h4{font-family:Playfair Display,serif;font-size:16px;margin-bottom:12px;display:flex;align-items:center;gap:8px}.prep-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:12px}.prep-stat{text-align:center;padding:10px 8px;background:var(--bg-elevated);border-radius:var(--radius-sm)}.prep-stat-value{font-size:22px;font-weight:700;color:var(--accent)}.prep-stat-label{font-size:11px;color:var(--text-secondary);margin-top:2px}.shared-ingredients{font-size:13px;color:var(--text-secondary);padding:8px 0;border-top:1px solid var(--border-light)}.nutrition-days{display:flex;gap:4px;align-items:flex-end;height:100px;position:relative}.nutrition-day{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.nutrition-day-bar{width:100%;border-radius:4px 4px 0 0;background:var(--accent-light);transition:height .4s ease;min-height:4px}.nutrition-day-bar.has-data{background:var(--accent)}.nutrition-day-bar.over{background:var(--red)}.nutrition-day-bar.under{background:var(--green)}.nutrition-day-label{font-size:10px;color:var(--text-tertiary);font-weight:600}.nutrition-day-cal{font-size:9px;color:var(--text-secondary);font-weight:500}.calorie-target-line{position:absolute;left:0;right:0;border-top:2px dashed var(--red);opacity:.5;pointer-events:none;z-index:1}.calorie-target-line span{position:absolute;right:0;top:-16px;font-size:9px;color:var(--red);font-weight:600}.shop-item{display:flex;align-items:center;gap:12px;padding:13px 0;border-bottom:1px solid var(--border-light);cursor:pointer;transition:opacity .2s;-webkit-user-select:none;user-select:none}.shop-item:active{opacity:.7}.shop-item.checked{opacity:.35}.shop-item.checked .shop-item-text{text-decoration:line-through}.shop-checkbox{width:24px;height:24px;border-radius:7px;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s}.shop-checkbox.checked{background:var(--green);border-color:var(--green)}.shop-checkbox.checked svg{color:#fff}.shop-item-text{font-size:14px;flex:1}.aisle-header{font-family:Playfair Display,serif;font-size:14px;font-weight:600;color:var(--accent);padding:14px 0 6px;border-bottom:1px solid var(--border);margin-top:8px;display:flex;align-items:center;gap:6px}.aisle-header svg{width:16px;height:16px}.shop-add{display:flex;gap:8px;margin-bottom:16px}.shop-add input{flex:1}.shop-actions{display:flex;gap:8px;justify-content:center;margin-top:20px;flex-wrap:wrap}.staples-section{background:var(--bg-elevated);border-radius:var(--radius-md);padding:12px 14px;margin-bottom:16px}.staples-section summary{font-size:13px;font-weight:600;color:var(--text-secondary);cursor:pointer;list-style:none;display:flex;align-items:center;gap:6px}.staples-section summary::-webkit-details-marker{display:none}.staples-list{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px}.staple-chip{font-size:12px;padding:3px 10px;border-radius:var(--radius-full);background:var(--bg-card);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;transition:all .15s;font-family:DM Sans,sans-serif}.staple-chip.excluded{background:var(--red-light);color:var(--red);border-color:transparent;text-decoration:line-through}.auth-page{min-height:100dvh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;text-align:center;position:relative;overflow:hidden}.auth-bg{position:absolute;top:0;right:0;bottom:0;left:0;z-index:0;background:radial-gradient(ellipse at 20% 50%,rgba(196,112,75,.12) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(123,158,107,.1) 0%,transparent 50%),radial-gradient(ellipse at 50% 100%,rgba(212,168,75,.08) 0%,transparent 50%),var(--bg)}.auth-bg:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23C4704B' fill-opacity='0.04'%3E%3Cpath d='M36 34v-4h-2v4h-4v2h4v4h2v-4h4v-2h-4zm0-30V0h-2v4h-4v2h4v4h2V6h4V4h-4zM6 34v-4H4v4H0v2h4v4h2v-4h4v-2H6zM6 4V0H4v4H0v2h4v4h2V6h4V4H6z'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");opacity:.6}.auth-content{position:relative;z-index:1;width:100%;max-width:340px}.auth-logo{font-family:Playfair Display,serif;font-size:52px;font-weight:700;display:flex;align-items:center;justify-content:center;gap:14px;margin-bottom:8px}.auth-logo img{animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}.auth-tagline{font-family:Caveat,cursive;font-size:24px;color:var(--text-secondary);margin-bottom:40px}.google-btn{display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 36px;border-radius:var(--radius-full);border:1.5px solid var(--border);background:var(--bg-card);font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;color:var(--text);cursor:pointer;transition:all .25s;box-shadow:var(--shadow-sm);width:100%}.google-btn:hover{box-shadow:var(--shadow-lg);border-color:var(--accent);transform:translateY(-2px)}.google-btn:active{transform:translateY(0)}.google-btn svg{width:20px;height:20px}.auth-divider{display:flex;align-items:center;gap:12px;margin:20px 0;color:var(--text-tertiary);font-size:13px}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border)}.auth-form{display:flex;flex-direction:column;gap:10px;width:100%}.auth-form .input{text-align:left}.auth-toggle{font-size:13px;color:var(--text-secondary);margin-top:12px}.auth-toggle button{background:none;border:none;color:var(--accent);font-weight:600;cursor:pointer;font-family:DM Sans,sans-serif;font-size:13px}.auth-error{background:var(--red-light);color:var(--red);padding:8px 12px;border-radius:var(--radius-sm);font-size:13px;text-align:left;margin-bottom:8px}.onboarding-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--bg);z-index:400;display:flex;flex-direction:column;max-width:480px;margin:0 auto}.onboarding-slide{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 32px;text-align:center}.onboarding-icon{width:80px;height:80px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin-bottom:24px}.onboarding-icon svg{width:40px;height:40px}.onboarding-title{font-family:Playfair Display,serif;font-size:28px;font-weight:700;margin-bottom:12px}.onboarding-desc{font-size:16px;line-height:1.6;color:var(--text-secondary);max-width:320px}.onboarding-dots{display:flex;gap:8px;justify-content:center;margin-bottom:20px}.onboarding-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:all .3s}.onboarding-dot.active{background:var(--accent);width:24px;border-radius:4px}.onboarding-footer{padding:16px 24px 32px;display:flex;justify-content:space-between;align-items:center}.url-import{background:var(--bg-elevated);border:1.5px dashed var(--border);border-radius:var(--radius-md);padding:16px;margin-bottom:20px;transition:border-color .2s}.url-import:focus-within{border-color:var(--accent)}.url-import-label{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.url-import-row{display:flex;gap:8px}.form-group{margin-bottom:16px}.form-label{display:block;font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:6px;text-transform:uppercase;letter-spacing:.5px}.ingredient-row{display:flex;gap:6px;margin-bottom:8px;align-items:center}.ingredient-row .input{flex:1}.ingredient-row .input.amount-input{max-width:64px}.ingredient-row .input.unit-input{max-width:72px}.remove-btn{width:30px;height:30px;border-radius:50%;border:none;background:var(--red-light);color:var(--red);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.remove-btn:hover{background:var(--red);color:#fff}.empty-state{text-align:center;padding:40px 24px;color:var(--text-tertiary)}.empty-state svg{width:48px;height:48px;margin-bottom:12px;opacity:.3}.empty-state h3{font-size:17px;color:var(--text-secondary);margin-bottom:6px}.empty-state p{font-size:14px;line-height:1.5}.error-banner{background:var(--red-light);color:var(--red);padding:10px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:12px;display:flex;align-items:center;gap:8px}.error-banner svg{width:16px;height:16px;flex-shrink:0}.setup-banner{background:var(--gold-light);color:var(--gold);padding:12px 14px;border-radius:var(--radius-sm);font-size:13px;margin-bottom:16px;display:flex;align-items:center;gap:8px;line-height:1.4}.toast-container{position:fixed;top:72px;left:50%;transform:translate(-50%);z-index:500;display:flex;flex-direction:column;gap:8px;max-width:440px;width:calc(100% - 32px);pointer-events:none}.toast{padding:12px 16px;border-radius:var(--radius-sm);font-size:14px;font-weight:500;animation:toastIn .3s ease,toastOut .3s ease 2.7s forwards;box-shadow:var(--shadow-lg);display:flex;align-items:center;gap:8px;pointer-events:auto;font-family:DM Sans,sans-serif}.toast svg{width:16px;height:16px;flex-shrink:0}.toast.success{background:var(--green);color:#fff}.toast.info{background:var(--accent);color:#fff}.toast.error{background:var(--red);color:#fff}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes toastOut{to{opacity:0;transform:translateY(-12px)}}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100dvh;padding:40px 24px;text-align:center}.error-boundary h2{font-size:24px;margin-bottom:8px}.error-boundary p{color:var(--text-secondary);margin-bottom:24px}.dropdown-menu{position:absolute;top:100%;right:0;margin-top:8px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:8px;box-shadow:var(--shadow-lg);min-width:200px;z-index:150}.dropdown-menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 12px;background:none;border:none;border-radius:var(--radius-sm);color:var(--text);cursor:pointer;font-size:14px;font-family:DM Sans,sans-serif;transition:background .15s;text-align:left}.dropdown-menu-item:hover{background:var(--bg-elevated)}.dropdown-menu-item svg{width:16px;height:16px;color:var(--text-secondary)}.dropdown-menu-item.danger{color:var(--red)}.dropdown-menu-item.danger svg{color:var(--red)}.dropdown-divider{height:1px;background:var(--border-light);margin:4px 0}.dropdown-header{padding:6px 12px;font-size:12px;color:var(--text-tertiary);font-weight:500}.app-footer{text-align:center;padding:24px 16px 16px;border-top:1px solid var(--border-light);margin-top:auto}.app-footer a{display:inline-flex;align-items:center;gap:8px;color:var(--text-secondary);font-size:12px;text-decoration:none}.app-footer a:hover{color:var(--accent);text-decoration:none}.app-footer img{width:28px;height:28px;border-radius:6px}.spinner{width:28px;height:28px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite;margin:32px auto}@keyframes spin{to{transform:rotate(360deg)}}::-webkit-scrollbar{width:4px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:2px}.flex-between{display:flex;align-items:center;justify-content:space-between}.flex-center{display:flex;align-items:center;justify-content:center}.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.mt-8{margin-top:8px}.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.settings-section{margin-bottom:8px}.settings-section-header{display:flex;align-items:center;gap:8px;font-family:Playfair Display,serif;font-size:16px;font-weight:600;margin-bottom:8px}.settings-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;cursor:pointer;transition:opacity .15s}.settings-row:active{opacity:.7}.settings-row-left{display:flex;align-items:center;gap:12px;flex:1}.settings-row-title{font-weight:600;font-size:14px}.settings-row-desc{font-size:12px;color:var(--text-secondary);margin-top:1px}.settings-divider{height:1px;background:var(--border-light);margin:12px 0}.household-card{background:var(--bg-elevated);border-radius:var(--radius-md);padding:16px;border:1px solid var(--border)}.household-card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.household-code-row{display:flex;align-items:center;gap:8px;padding:8px 0}.household-code{font-family:monospace;font-size:18px;font-weight:700;letter-spacing:3px;color:var(--accent);background:var(--bg-card);padding:4px 12px;border-radius:var(--radius-sm);border:1px solid var(--border)}.household-badge{display:flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--accent);background:var(--accent-light);padding:4px 10px;border-radius:var(--radius-full);white-space:nowrap}.collection-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-card)}.collection-picker{display:flex;flex-wrap:wrap;gap:6px;margin-top:10px}.collection-pick-item{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--bg-card);cursor:pointer;font-size:13px;font-weight:500;font-family:DM Sans,sans-serif;color:var(--text-secondary);transition:all .2s}.collection-pick-item:hover{border-color:var(--accent)}.collection-pick-item.active{background:var(--accent-light);border-color:var(--accent);color:var(--accent)}.seasonal-banner{background:var(--green-light);border:1px solid rgba(123,158,107,.2);border-radius:var(--radius-md);padding:14px 16px;margin-bottom:16px;position:relative}.seasonal-banner-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;font-size:14px}.seasonal-tip{font-size:13px;color:var(--text-secondary);margin-bottom:10px;line-height:1.45}.seasonal-chips{display:flex;flex-wrap:wrap;gap:6px}.seasonal-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:var(--radius-full);border:1px solid rgba(123,158,107,.3);background:var(--bg-card);font-size:12px;font-weight:500;color:var(--green);cursor:pointer;font-family:DM Sans,sans-serif;transition:all .2s}.seasonal-chip:hover{background:var(--green);color:#fff;border-color:var(--green)}
