.nav-header{background:#fff;box-shadow:0 2px 12px #00000012;position:sticky;top:0;z-index:100}.nav-inner{max-width:1100px;margin:0 auto;padding:0 20px;height:64px;display:flex;align-items:center;gap:16px}.nav-logo{display:flex;align-items:center;gap:8px;text-decoration:none;flex-shrink:0}.nav-logo-icon{font-size:1.6rem}.nav-logo-text{font-size:1.1rem;font-weight:800;color:var(--primary-dark);letter-spacing:-.3px}.nav-links{display:flex;list-style:none;gap:4px;flex:1;overflow-x:auto;scrollbar-width:none}.nav-links::-webkit-scrollbar{display:none}.nav-link{display:flex;align-items:center;gap:5px;padding:6px 12px;border-radius:8px;text-decoration:none;color:var(--text-secondary);font-weight:500;font-size:.88rem;transition:all .2s;white-space:nowrap}.nav-link:hover{background:var(--surface-2);color:var(--text);text-decoration:none}.nav-link.active{background:var(--primary-light);color:var(--primary-dark);font-weight:600}.nav-link-icon{font-size:1rem}.nav-user{display:flex;align-items:center;gap:8px;flex-shrink:0}.nav-profile-btn{display:flex;align-items:center;gap:8px;text-decoration:none;padding:4px 10px;border-radius:20px;transition:background .2s}.nav-profile-btn:hover{background:var(--surface-2);text-decoration:none}.nav-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.9rem}.nav-username{font-weight:600;font-size:.9rem;color:var(--text)}.nav-auth{display:flex;gap:8px}.nav-logout{white-space:nowrap}.nav-mobile{display:none;position:fixed;bottom:0;left:0;right:0;background:#fff;border-top:1px solid var(--border);padding:0;padding-bottom:env(safe-area-inset-bottom,0px);z-index:100;box-shadow:0 -2px 12px #00000012}.nav-mobile-item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;flex:1;padding:10px 4px;text-decoration:none;color:var(--text-secondary);font-size:.7rem;font-weight:500;transition:color .2s}.nav-mobile-item:hover,.nav-mobile-item.active{color:var(--primary);text-decoration:none}.nav-mobile-icon{font-size:1.3rem}.nav-mobile-label{line-height:1}@media (max-width: 768px){.nav-inner{display:none}.nav-mobile{display:flex}main{padding-bottom:calc(70px + env(safe-area-inset-bottom,0px))}}@media (max-width: 900px){.nav-username,.nav-link-label,.nav-logo-text{display:none}}.bowl-card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;transition:box-shadow .2s}.bowl-card:hover{box-shadow:var(--shadow-lg)}.bowl-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px;gap:12px}.bowl-card-title{font-size:1.15rem;font-weight:700;color:var(--text);margin:0;line-height:1.3}.bowl-card-creator{font-size:.8rem;color:var(--text-muted);margin-top:2px}.bowl-card-actions{display:flex;gap:6px;flex-shrink:0}.btn-save-active{background:none;border:none;cursor:pointer;font-size:1.3rem}.bowl-card-badges{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px}.btn-toggle-ingredients{background:none;border:none;color:var(--primary);font-size:.85rem;font-weight:600;cursor:pointer;padding:4px 0;margin-bottom:10px}.bowl-card-ingredients{display:flex;flex-direction:column;gap:10px}.ingredient-group-label{font-size:.78rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;display:block;margin-bottom:4px}.ingredient-list{display:flex;flex-direction:column;gap:3px}.ingredient-item{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;border-radius:6px;background:var(--surface-2);font-size:.88rem}.ingredient-item.in-fridge{background:#e8f5e9}.ingredient-item.missing{background:#fff8e1}.ingredient-name{font-weight:500;color:var(--text)}.ingredient-amount{color:var(--text-secondary);font-size:.83rem}.ingredient-missing-badge{font-size:.72rem;background:#fff3e0;color:#e65100;padding:1px 6px;border-radius:4px;font-weight:700}.bowl-card-rating{margin-top:16px;padding-top:16px;border-top:1px solid var(--border)}.rating-label{font-size:.88rem;color:var(--text-secondary);margin-bottom:8px;font-weight:500}.hero{background:linear-gradient(135deg,#f1f8e9,#e8f5e9,#e3f2fd);padding:60px 20px}.hero-inner{max-width:1100px;margin:0 auto;display:flex;align-items:center;gap:40px}.hero-content{flex:1}.hero-title{font-size:2.8rem;font-weight:900;line-height:1.2;color:var(--text);margin-bottom:16px}.hero-highlight{background:linear-gradient(135deg,var(--primary),var(--secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:1.1rem;color:var(--text-secondary);margin-bottom:28px;max-width:480px;line-height:1.7}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.hero-spin-btn{font-size:1.1rem!important}.hero-illustration{flex-shrink:0;display:flex;align-items:center;justify-content:center}.hero-bowl-emoji{font-size:9rem;animation:float 3s ease-in-out infinite;-webkit-user-select:none;user-select:none}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-12px)}}.features-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:40px 0}.feature-card{background:var(--surface);border-radius:var(--radius);padding:24px 20px;text-decoration:none;color:var(--text);box-shadow:var(--shadow);transition:all .2s;text-align:center;display:flex;flex-direction:column;align-items:center;gap:10px}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);text-decoration:none;color:var(--text)}.feature-icon{font-size:2.4rem}.feature-card h3{font-size:1.05rem;font-weight:700}.feature-card p{font-size:.85rem;color:var(--text-secondary);line-height:1.5}.cta-section{margin-top:20px}.cta-card{text-align:center}.cta-card h2{font-size:1.6rem;font-weight:700;margin-bottom:8px}.cta-card p{color:var(--text-secondary)}.cta-card>div{justify-content:center}@media (max-width: 1000px){.features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 700px){.hero-title{font-size:1.9rem}.hero-illustration{display:none}.hero{padding:40px 20px}.features-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.hero{padding:28px 16px}.hero-title{font-size:1.6rem}.hero-subtitle{font-size:1rem}.hero-actions{flex-direction:column}.hero-actions .btn{width:100%;justify-content:center}.features-grid{grid-template-columns:1fr;gap:10px}.feature-card{padding:16px;flex-direction:row;text-align:left;gap:14px}.feature-icon{font-size:2rem;flex-shrink:0}.cta-card h2{font-size:1.3rem}}.auth-page{display:flex;justify-content:center;padding-top:48px}.auth-card{width:100%;max-width:440px;text-align:center}.auth-logo{font-size:3rem;margin-bottom:12px}.auth-title{font-size:1.7rem;font-weight:800;color:var(--text);margin-bottom:6px}.auth-subtitle{color:var(--text-secondary);font-size:.95rem;margin-bottom:24px}.auth-form{display:flex;flex-direction:column;gap:16px;text-align:left}.auth-submit{width:100%;justify-content:center;margin-top:4px}.auth-footer{margin-top:20px;font-size:.9rem;color:var(--text-secondary)}.diet-options{display:flex;flex-direction:column;gap:8px}.diet-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;font-weight:500}.diet-option:hover{border-color:var(--primary);background:var(--primary-light)}.diet-option input{display:none}.diet-option.selected{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark)}.diet-option-icon{font-size:1.3rem}@media (max-width: 480px){.auth-page{padding-top:24px}.auth-title{font-size:1.4rem}.auth-logo{font-size:2.4rem}}.profile-header{display:flex;align-items:center;gap:24px;flex-wrap:wrap;margin-bottom:24px}.profile-avatar-section{display:flex;align-items:center;gap:16px;flex:1;min-width:200px}.profile-avatar{width:72px;height:72px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:2rem;font-weight:700;flex-shrink:0}.profile-username{font-size:1.5rem;font-weight:800;color:var(--text);margin-bottom:2px}.profile-display-name{color:var(--text-secondary);font-size:.95rem;margin-bottom:6px}.profile-badges{display:flex;gap:6px;flex-wrap:wrap}.profile-stats{display:flex;gap:24px}.stat{text-align:center}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text)}.stat-label{font-size:.78rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.edit-form{margin-bottom:24px}.edit-form h3{margin-bottom:16px}.diet-toggles,.privacy-toggles{display:flex;flex-direction:column}@media (max-width: 600px){.profile-header{flex-direction:column;align-items:flex-start}.profile-stats{gap:16px}.profile-username{font-size:1.2rem}}@media (max-width: 480px){.profile-avatar{width:56px;height:56px;font-size:1.5rem}.profile-stats{gap:12px}.stat-value{font-size:1.2rem}.profile-avatar-section{gap:12px}}.spin-wheel-container{display:flex;flex-direction:column;align-items:center;gap:28px;padding:20px}.spin-wheel-wrapper{position:relative;filter:drop-shadow(0 8px 24px rgba(0,0,0,.18));transition:transform .3s ease}.spin-wheel-wrapper:hover{transform:scale(1.02)}.spin-canvas{display:block;border-radius:50%}.random-layout{display:grid;grid-template-columns:auto 1fr;gap:28px;align-items:start}.wheel-section{text-align:center;position:sticky;top:90px}.result-loading,.result-empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:48px;text-align:center;color:var(--text-secondary)}.result-actions-top{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}.result-actions{display:flex;gap:12px;margin-top:20px;flex-wrap:wrap}.save-hint{color:var(--text-secondary);font-size:.9rem;display:flex;align-items:center}@media (max-width: 800px){.random-layout{grid-template-columns:1fr;gap:20px}.wheel-section{position:static}}@media (max-width: 480px){.result-actions-top{gap:10px}.result-actions{gap:8px}.result-actions .btn{flex:1;justify-content:center}.result-loading,.result-empty{padding:32px 16px}}.custom-layout{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:start}.steps-sidebar{position:sticky;top:80px;display:flex;flex-direction:column;gap:6px}.step-item{display:flex;align-items:center;gap:8px;padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;font-size:.88rem;font-weight:500;color:var(--text-secondary);transition:all .2s;text-align:left}.step-item:hover{border-color:var(--primary);color:var(--text)}.step-item.active{border-color:var(--primary);background:var(--primary-light);color:var(--primary-dark);font-weight:600}.step-item.done{border-color:#a5d6a7}.step-icon{font-size:1.1rem}.step-label{flex:1}.step-check{color:var(--primary);font-weight:700}.bowl-preview{margin-top:16px;display:flex;flex-wrap:wrap;gap:4px}.step-header{margin-bottom:20px}.step-number{font-size:.8rem;color:var(--text-muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.step-title{font-size:1.4rem;font-weight:700;margin:4px 0 6px}.step-desc{color:var(--text-secondary);font-size:.9rem}.ingredient-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:10px;margin:16px 0}.ingredient-option{position:relative;padding:12px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;text-align:left;transition:all .2s;display:flex;flex-direction:column;gap:4px}.ingredient-option:hover,.ingredient-option.selected{border-color:var(--primary);background:var(--primary-light)}.ing-name{font-weight:600;font-size:.92rem;color:var(--text)}.ing-amount{font-size:.78rem;color:var(--text-muted)}.ing-badges{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px}.ing-selected-check{position:absolute;top:8px;right:8px;color:var(--primary);font-weight:700;font-size:1rem}.step-nav{display:flex;justify-content:space-between;align-items:center;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);gap:12px;flex-wrap:wrap}.final-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;flex:1;justify-content:flex-end}.custom-bowl-saved{max-width:600px}.saved-ingredients{display:flex;flex-wrap:wrap;gap:8px;margin:16px 0}.saved-rating{margin:20px 0}.saved-rating p{font-weight:500;margin-bottom:8px}.saved-actions{margin-top:20px;display:flex;gap:12px}@media (max-width: 800px){.custom-layout{grid-template-columns:1fr}.steps-sidebar{position:static;flex-direction:row;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none;padding-bottom:4px}.steps-sidebar::-webkit-scrollbar{display:none}.step-item{flex-shrink:0}.bowl-preview{display:none}}@media (max-width: 480px){.ingredient-grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:8px}.ingredient-option{padding:10px}.step-title{font-size:1.2rem}.step-nav{flex-direction:column;align-items:stretch}.step-nav>.btn{width:100%;justify-content:center}.final-actions{justify-content:stretch}.final-actions>.btn{flex:1;justify-content:center}}.fridge-layout{display:grid;grid-template-columns:320px 1fr;gap:20px;align-items:start}.fridge-add h3{font-size:1rem;font-weight:700;margin-bottom:12px}.search-wrapper{position:relative}.search-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);z-index:10;max-height:280px;overflow-y:auto}.search-empty{padding:12px 16px;color:var(--text-muted);font-size:.9rem}.search-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:10px 16px;background:none;border:none;border-bottom:1px solid var(--border);cursor:pointer;font-size:.9rem;transition:background .15s;text-align:left}.search-item:last-child{border-bottom:none}.search-item:hover{background:var(--primary-light)}.search-item-name{font-weight:500;color:var(--text)}.search-item-cat{font-size:.78rem;color:var(--text-muted)}.fridge-items h3{font-size:1rem;font-weight:700;margin-bottom:12px}.fridge-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.fridge-header h3{margin:0}.fridge-groups{display:flex;flex-direction:column;gap:14px}.fridge-group-label{font-size:.78rem;font-weight:700;text-transform:uppercase;color:var(--text-muted);letter-spacing:.5px;margin-bottom:6px}.fridge-chips{display:flex;flex-wrap:wrap;gap:6px}.fridge-chip{cursor:pointer}.chip-remove{font-size:1rem;opacity:.6;margin-left:2px}.fridge-chip:hover .chip-remove{opacity:1;color:var(--danger)}.suggestions-toolbar{display:flex;align-items:center;gap:12px;margin-bottom:20px}.sort-label{font-weight:600;font-size:.9rem;color:var(--text-secondary)}.sort-buttons{display:flex;gap:6px}.suggestions-grid{display:flex;flex-direction:column;gap:16px}.suggestion-meta{display:flex;gap:8px;margin-bottom:8px}@media (max-width: 800px){.fridge-layout{grid-template-columns:1fr}}@media (max-width: 480px){.suggestions-toolbar{flex-wrap:wrap;gap:8px}.sort-buttons{flex-wrap:wrap}.fridge-header{flex-wrap:wrap;gap:8px}}.create-form{margin-bottom:24px}.create-form h3{margin-bottom:16px}.party-layout{display:grid;grid-template-columns:280px 1fr;gap:20px;align-items:start}.party-list h3{margin-bottom:14px}.party-item{display:flex;flex-direction:column;gap:6px;width:100%;padding:12px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);background:var(--surface);cursor:pointer;text-align:left;transition:all .2s;margin-bottom:8px}.party-item:hover{border-color:var(--primary)}.party-item.active{border-color:var(--primary);background:var(--primary-light)}.party-item-name{font-weight:600;font-size:.95rem;color:var(--text)}.party-item-meta{display:flex;gap:8px;flex-wrap:wrap;font-size:.78rem;color:var(--text-secondary);align-items:center}.party-detail{display:flex;flex-direction:column;gap:16px}.party-detail-header h2{font-size:1.4rem;font-weight:700;margin-bottom:6px}.party-notes{color:var(--text-secondary);font-size:.9rem;margin-top:8px}.party-diet-summary{display:flex;gap:8px;margin-top:10px;flex-wrap:wrap}.member-list{display:flex;flex-direction:column;gap:8px;margin-bottom:16px}.member-item{display:flex;justify-content:space-between;align-items:center;padding:8px 12px;background:var(--surface-2);border-radius:var(--radius-sm)}.member-info{display:flex;align-items:center;gap:10px}.member-avatar{width:32px;height:32px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.85rem;flex-shrink:0}.member-name{font-weight:600;font-size:.9rem}.add-member-form{border-top:1px solid var(--border);padding-top:16px}.add-member-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.add-member-row .input{min-width:120px}.generate-section h3{margin-bottom:6px}.generate-section p{color:var(--text-secondary);font-size:.9rem}.assignment-group{margin-bottom:14px;padding:12px;border-radius:var(--radius-sm);background:var(--surface-2);border:1px solid var(--border)}.assignment-group.my-assignments{background:var(--primary-light);border-color:var(--primary)}.assignment-name{font-weight:700;font-size:.95rem;margin-bottom:8px;display:flex;align-items:center;gap:8px}.assignment-items{display:flex;flex-direction:column;gap:4px}.assignment-item{display:flex;justify-content:space-between;font-size:.88rem;padding:3px 0}.assignment-amount{color:var(--text-secondary)}@media (max-width: 900px){.party-layout{grid-template-columns:1fr}}@media (max-width: 480px){.add-member-row{flex-direction:column}.add-member-row .input{min-width:0;width:100%}.add-member-row .btn{width:100%;justify-content:center}.member-item{flex-wrap:wrap;gap:8px}.party-detail-header h2{font-size:1.2rem}}.community-grid{display:flex;flex-direction:column;gap:16px}.search-users{max-width:600px}.search-users .form-group{margin-bottom:16px}.user-list{display:flex;flex-direction:column;gap:10px}.user-card{display:flex;justify-content:space-between;align-items:center;gap:16px}.user-info{display:flex;align-items:center;gap:12px}.user-avatar{width:44px;height:44px;background:linear-gradient(135deg,var(--primary),var(--secondary));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.1rem;flex-shrink:0}.user-name{font-weight:700;font-size:.95rem}.user-display{color:var(--text-secondary);font-size:.85rem}.user-badges{display:flex;gap:4px;margin-top:4px}@media (max-width: 480px){.user-card{flex-wrap:wrap}.user-card>.btn{width:100%;justify-content:center}.user-avatar{width:36px;height:36px;font-size:.95rem}}:root{--primary: #4caf50;--primary-dark: #388e3c;--primary-light: #e8f5e9;--secondary: #ff9800;--secondary-dark: #f57c00;--accent: #2196f3;--danger: #f44336;--warning: #ffc107;--bg: #f7f9f7;--surface: #ffffff;--surface-2: #f0f4f0;--border: #e0e0e0;--text: #1a2e1a;--text-secondary: #6b7c6b;--text-muted: #9aab9a;--shadow: 0 2px 12px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .12);--radius: 12px;--radius-sm: 8px;--radius-lg: 20px;--transition: .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;background:var(--bg);color:var(--text);line-height:1.6;min-height:100vh}a{color:var(--primary);text-decoration:none}a:hover{text-decoration:underline}img{max-width:100%}.btn{display:inline-flex;align-items:center;gap:6px;padding:10px 20px;border:none;border-radius:var(--radius-sm);font-size:.95rem;font-weight:600;cursor:pointer;transition:all var(--transition);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--primary-dark);transform:translateY(-1px)}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){background:var(--border)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#d32f2f}.btn-outline{background:transparent;color:var(--primary);border:2px solid var(--primary)}.btn-outline:hover:not(:disabled){background:var(--primary-light)}.btn-sm{padding:6px 14px;font-size:.85rem}.btn-lg{padding:14px 28px;font-size:1.05rem}.btn-icon{padding:8px;border-radius:50%}.btn-spin{background:linear-gradient(135deg,var(--secondary),var(--primary));color:#fff;font-size:1.2rem;padding:16px 40px;border-radius:50px;box-shadow:0 4px 20px #ff980066;transition:all .3s ease}.btn-spin:hover:not(:disabled){transform:translateY(-2px) scale(1.03);box-shadow:0 6px 28px #ff980080}.btn-spin:disabled{background:var(--border);box-shadow:none;color:var(--text-muted)}.card{background:var(--surface);border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;transition:box-shadow var(--transition)}.card:hover{box-shadow:var(--shadow-lg)}.card-sm{padding:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-weight:600;font-size:.9rem;color:var(--text)}.input{padding:10px 14px;border:2px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;background:var(--surface);color:var(--text);transition:border-color var(--transition);width:100%}.input:focus{outline:none;border-color:var(--primary)}.input::placeholder{color:var(--text-muted)}textarea.input{resize:vertical;min-height:80px}select.input{cursor:pointer}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}@media (max-width: 600px){.form-row{grid-template-columns:1fr}}.page{max-width:1100px;margin:0 auto;padding:24px 20px}.page-narrow{max-width:560px}.page-header{margin-bottom:32px}.page-header h1{font-size:2rem;font-weight:800;color:var(--text)}.page-header p{color:var(--text-secondary);margin-top:6px;font-size:1.05rem}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}@media (max-width: 900px){.grid-3{grid-template-columns:1fr 1fr}}@media (max-width: 600px){.grid-2,.grid-3{grid-template-columns:1fr}}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:20px;font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.4px}.badge-vegan{background:#e8f5e9;color:#2e7d32}.badge-vegetarian{background:#f3e5f5;color:#7b1fa2}.badge-lowcarb{background:#fff3e0;color:#e65100}.badge-default{background:var(--surface-2);color:var(--text-secondary)}.badge-star{background:#fff8e1;color:#f9a825}.chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:var(--primary-light);color:var(--primary-dark);border-radius:20px;font-size:.85rem;font-weight:500;cursor:pointer;border:2px solid transparent;transition:all var(--transition)}.chip:hover{border-color:var(--primary)}.chip.selected{background:var(--primary);color:#fff}.chip.in-fridge{background:#e3f2fd;color:#1565c0}.chip.missing{background:#fff3e0;color:#e65100}.stars{display:flex;gap:4px}.star{font-size:1.4rem;cursor:pointer;transition:transform var(--transition);line-height:1}.star:hover{transform:scale(1.2)}.alert{padding:12px 16px;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:16px}.alert-error{background:#ffebee;color:#c62828;border:1px solid #ffcdd2}.alert-success{background:#e8f5e9;color:#1b5e20;border:1px solid #c8e6c9}.alert-info{background:#e3f2fd;color:#0d47a1;border:1px solid #bbdefb}.spinner{width:40px;height:40px;border:4px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite;margin:40px auto}@keyframes spin{to{transform:rotate(360deg)}}.loading-center{display:flex;justify-content:center;align-items:center;padding:60px}.section{margin-bottom:40px}.section-title{font-size:1.3rem;font-weight:700;color:var(--text);margin-bottom:16px;display:flex;align-items:center;gap:8px}.divider{height:1px;background:var(--border);margin:24px 0}.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0}.toggle-row label{font-weight:500;color:var(--text)}.toggle{position:relative;width:48px;height:26px;flex-shrink:0}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;top:0;right:0;bottom:0;left:0;background:var(--border);border-radius:26px;cursor:pointer;transition:background var(--transition)}.toggle-slider:before{content:"";position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:#fff;border-radius:50%;transition:transform var(--transition);box-shadow:0 2px 4px #0003}.toggle input:checked+.toggle-slider{background:var(--primary)}.toggle input:checked+.toggle-slider:before{transform:translate(22px)}.empty-state{text-align:center;padding:60px 20px;color:var(--text-secondary)}.empty-state .empty-icon{font-size:3.5rem;margin-bottom:16px}.empty-state h3{font-size:1.2rem;color:var(--text);margin-bottom:8px}.empty-state p{font-size:.95rem}.tabs{display:flex;gap:4px;border-bottom:2px solid var(--border);margin-bottom:24px}.tab{padding:10px 20px;border:none;background:none;font-size:.95rem;font-weight:600;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;margin-bottom:-2px;transition:all var(--transition)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab:hover:not(.active){color:var(--text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;animation:fadeIn .2s ease}.modal{background:var(--surface);border-radius:var(--radius-lg);padding:32px;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.modal-header h2{font-size:1.4rem;font-weight:700}.modal-close{background:var(--surface-2);border:none;border-radius:50%;width:36px;height:36px;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition)}.modal-close:hover{background:var(--border)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 768px){.page{padding:16px}.page-header h1{font-size:1.5rem}.page-header p{font-size:.95rem}.card{padding:16px}.modal{padding:20px}.section-title{font-size:1.1rem}.tabs{overflow-x:auto;scrollbar-width:none}.tabs::-webkit-scrollbar{display:none}.tab{padding:10px 14px;font-size:.88rem;white-space:nowrap}.empty-state{padding:40px 16px}}@media (max-width: 480px){.page{padding:12px}.card{padding:14px}.btn{padding:9px 16px;font-size:.9rem}.btn-lg{padding:12px 22px;font-size:1rem}.btn-spin{padding:14px 28px;font-size:1.05rem}.modal-overlay{padding:0;align-items:flex-end}.modal{border-radius:var(--radius-lg) var(--radius-lg) 0 0;max-height:85vh;padding:20px 16px}.page-header h1{font-size:1.3rem}.section-title{font-size:1rem}}
