.join-family-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.join-family-card{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0000001a;padding:40px;max-width:500px;width:100%;text-align:center}.join-family-header{margin-bottom:30px}.join-family-logo{height:80px;margin-bottom:10px}.join-family-loading,.join-family-success,.join-family-error{display:flex;flex-direction:column;align-items:center;gap:15px}.join-family-loading h2,.join-family-success h2,.join-family-error h2{color:#333;margin:10px 0;font-size:24px}.join-family-loading p,.join-family-success p,.join-family-error p{color:#666;margin:5px 0}.success-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700;animation:scaleIn .5s ease-out}@keyframes scaleIn{0%{transform:scale(0);opacity:0}to{transform:scale(1);opacity:1}}.redirect-message{color:#999!important;font-style:italic;margin-top:10px}.error-icon{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#f5576c,#f093fb);color:#fff;display:flex;align-items:center;justify-content:center;font-size:48px;font-weight:700}.error-message{color:#d32f2f;font-weight:500;padding:15px;background:#ffebee;border-radius:8px;margin:10px 0}.error-actions{width:100%;margin-top:20px}.error-help{background:#fff3e0;color:#e65100;padding:15px;border-radius:8px;margin-bottom:20px;line-height:1.6;font-size:14px}.spinner{border:3px solid #f3f3f3;border-top:3px solid #667eea;border-radius:50%;width:50px;height:50px;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.btn{padding:12px 24px;border:none;border-radius:8px;font-size:16px;font-weight:500;cursor:pointer;transition:all .2s;width:100%}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media(max-width:768px){.join-family-card{padding:30px 20px}.join-family-logo{height:60px}.join-family-loading h2,.join-family-success h2,.join-family-error h2{font-size:20px}.success-icon,.error-icon{width:60px;height:60px;font-size:36px}}:root{--color-coral: #E8735A;--color-coral-light: #FAECE7;--color-coral-border: #F0997B;--color-coral-dark: #993C1D;--color-purple: #5B4AE8;--color-cream: #FDF9F2;--color-deep-brown: #2A1F14;--color-body-brown: #5A4A3A;--color-muted: #B8A090;--color-hint: #C4B4A0;--color-white: #FFFFFF;--color-border: #EDE0D0;--color-border-light: #F5EFE8;--color-hover-cream: #FFF4EE;--color-equip-bg: #EDF4FB;--color-equip-rule: #378ADD;--color-equip-label: #0C447C;--color-allerg-bg: #FAECE7;--color-allerg-rule: #D85A30;--color-allerg-label: #712B13;--chip-cuisine-bg: #FAECE7;--chip-cuisine-text: #993C1D;--chip-diff-bg: #F1EFE8;--chip-diff-text: #5F5E5A;--chip-time-bg: #EAF3DE;--chip-time-text: #3B6D11;--chip-cost-bg: #FAEEDA;--chip-cost-text: #633806;--font-display: "Fraunces", Georgia, serif;--font-ui: "DM Sans", system-ui, sans-serif;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 10px;--radius-xl: 14px;--radius-pill: 20px;--primary: var(--color-coral);--primary-dark: var(--color-coral-dark);--primary-light: var(--color-coral-light);--secondary: #F5A962;--secondary-dark: #E59952;--accent: #F9C882;--success: #51CF66;--danger: var(--color-coral);--warning: #F5A962;--white: var(--color-white);--off-white: var(--color-cream);--light-gray: #F5F5F5;--medium-gray: var(--color-border);--dark-gray: #6C757D;--text-primary: var(--color-deep-brown);--text-secondary: var(--color-body-brown);--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--spacing-2xl: 3rem;--radius-full: 9999px;--shadow-sm: none;--shadow-md: none;--shadow-lg: none;--shadow-xl: none;--transition: all .2s ease-in-out}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-ui);color:var(--color-body-brown);background-color:var(--color-cream);line-height:1.6}#root{min-height:100vh;display:flex;flex-direction:column}h1{font-size:2rem;font-weight:700;line-height:1.2;margin-bottom:var(--spacing-md)}h2{font-size:1.5rem;font-weight:600;line-height:1.3;margin-bottom:var(--spacing-md)}h3{font-size:1.25rem;font-weight:600;line-height:1.4;margin-bottom:var(--spacing-sm)}h4{font-size:1.125rem;font-weight:600;line-height:1.4;margin-bottom:var(--spacing-sm)}p{margin-bottom:var(--spacing-md)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--spacing-md)}.spinner{width:48px;height:48px;border:4px solid var(--medium-gray);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.spinner-small{width:24px;height:24px;border:3px solid var(--medium-gray);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.message{padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md);font-weight:500}.message.success,.success-message{background-color:#d3f9d8;color:#2b8a3e;border:1px solid #51CF66}.message.error,.error-message{background-color:#ffe3e3;color:#c92a2a;border:1px solid #FF6B6B}.info-badge{display:inline-block;padding:var(--spacing-sm) var(--spacing-md);background-color:var(--accent);color:var(--text-primary);border-radius:var(--radius-full);font-size:.875rem;font-weight:500;margin-bottom:var(--spacing-md)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-secondary);font-size:1rem}.empty-state-small{text-align:center;padding:var(--spacing-md);color:var(--text-secondary);font-size:.875rem}.help-text{color:var(--text-secondary);font-size:.875rem;margin-bottom:var(--spacing-md)}button{font-family:inherit;font-size:1rem;cursor:pointer;border:none;transition:var(--transition)}.btn-primary{background-color:var(--primary);color:var(--white);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:600;box-shadow:var(--shadow-sm)}.btn-primary:hover:not(:disabled){background-color:var(--primary-dark);box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background-color:var(--white);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);border:2px solid var(--medium-gray);font-weight:600}.btn-secondary:hover:not(:disabled){border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.btn-danger{background-color:var(--danger);color:var(--white);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--radius-md);font-weight:600}.btn-danger:hover:not(:disabled){background-color:#e85555;transform:translateY(-1px)}.btn-icon{background:none;padding:var(--spacing-xs);font-size:1.25rem;opacity:.7}.btn-icon:hover{opacity:1;transform:scale(1.1)}.btn-back{background:none;color:var(--primary);padding:var(--spacing-sm);font-weight:600;display:flex;align-items:center;gap:var(--spacing-xs)}.btn-back:hover{color:var(--primary-dark)}.link-button{background:none;color:var(--primary);padding:0;font-weight:600;text-decoration:underline}.link-button:hover{color:var(--primary-dark)}.button-group{display:flex;gap:var(--spacing-md);flex-wrap:wrap}.form-group{margin-bottom:var(--spacing-md)}.form-group label{display:block;font-weight:600;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--medium-gray);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;transition:var(--transition)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b6b1a}.form-group input:disabled,.form-group select:disabled,.form-group textarea:disabled{background-color:var(--light-gray);cursor:not-allowed}textarea{resize:vertical;min-height:80px}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--spacing-md);background:linear-gradient(135deg,#ffe5e5,#fff5e6)}.auth-card{background:var(--white);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--spacing-2xl);width:100%;max-width:420px}.auth-header{text-align:center;margin-bottom:var(--spacing-xl)}.auth-header h1{color:var(--primary);margin-bottom:var(--spacing-sm)}.auth-header p{color:var(--text-secondary);margin-bottom:0}.auth-logo{width:200px;height:auto;margin:0 auto var(--spacing-md);display:block}.invitation-notice{background:linear-gradient(135deg,#ffe5e5,#fff5e6);border:2px solid var(--primary-light);border-radius:var(--radius-lg);padding:var(--spacing-lg);margin-bottom:var(--spacing-lg);text-align:center}.invitation-notice p{margin:0;color:var(--text-primary)}.invitation-notice p:first-child{font-weight:600;font-size:1.1rem;margin-bottom:var(--spacing-sm)}.auth-form h2{margin-bottom:var(--spacing-lg);text-align:center}.auth-toggle{text-align:center;margin-top:var(--spacing-lg);color:var(--text-secondary)}.app{display:flex;flex-direction:column;min-height:100vh}.header{background-color:var(--color-cream);border-bottom:1px solid var(--color-border);position:sticky;top:0;z-index:100}.header-content{max-width:1200px;margin:0 auto;padding:0 14px;height:44px;display:flex;justify-content:space-between;align-items:center}.header-title{font-family:var(--font-display);font-size:22px;font-weight:700;font-style:italic;margin:0;color:var(--color-coral);letter-spacing:-.02em}.header-brand{display:flex;align-items:center}.header-logo{height:40px;width:auto;display:block}.btn-logout{background-color:var(--light-gray);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-md);font-weight:600;font-size:.875rem}.btn-logout:hover{background-color:var(--medium-gray)}.navigation,.bottom-nav{position:fixed;bottom:10px;left:50%;transform:translate(-50%);width:calc(100% - 24px);max-width:420px;background:var(--color-deep-brown);border-radius:var(--radius-pill);padding:8px 0;display:flex;justify-content:space-around;align-items:center;z-index:100}.nav-item,.nav-button{display:flex;flex-direction:column;align-items:center;gap:3px;padding:2px 12px;cursor:pointer;background:none;border:none;color:transparent}.nav-item svg,.nav-button svg{width:17px;height:17px;stroke:#ffffff4d;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;transition:stroke .15s}.nav-item.active svg,.nav-button.active svg{stroke:var(--color-coral)}.nav-dot{width:3px;height:3px;border-radius:50%;background:transparent}.nav-item.active .nav-dot,.nav-button.active .nav-dot{background:var(--color-coral)}.nav-emoji,.nav-text{display:none}.main-content{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:var(--spacing-lg) var(--spacing-md);padding-bottom:72px}.footer{background-color:var(--white);border-top:1px solid var(--medium-gray);padding:var(--spacing-lg);text-align:center;color:var(--text-secondary);margin-top:auto}.footer p{margin:0;font-size:.875rem}.profile-container{max-width:800px;margin:0 auto}.profile-settings-list{display:none;flex-direction:column;gap:2px;background:var(--light-gray);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--spacing-lg)}.profile-settings-list.hidden{display:none!important}.profile-settings-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--white);border:none;text-align:left;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--light-gray)}.profile-settings-item:last-child{border-bottom:none}.profile-settings-item:hover,.profile-settings-item:focus{background:#f5f5f7}.profile-settings-item.visited{background:#f0f4ff}.settings-item-icon{font-size:1.4rem;width:2rem;text-align:center;flex-shrink:0}.settings-item-label{flex:1;font-size:1rem;font-weight:500;color:var(--text-primary)}.settings-item-chevron{color:var(--text-secondary);font-size:1.4rem;line-height:1}.profile-back-btn{display:none;align-items:center;gap:var(--spacing-sm);background:none;border:none;color:var(--primary);font-size:.9rem;font-weight:600;padding:var(--spacing-sm) 0;margin-bottom:var(--spacing-md);cursor:pointer}.profile-back-btn:hover{text-decoration:underline}.tabs-select{display:none}.tabs{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-lg);border-bottom:2px solid var(--medium-gray);overflow-x:auto}.tab{background:none;color:var(--text-secondary);padding:var(--spacing-md) var(--spacing-lg);border:none;border-bottom:3px solid transparent;font-weight:600;white-space:nowrap;transition:var(--transition)}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--primary);border-bottom-color:var(--primary)}.tab-content{animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.profile-form{background-color:var(--white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:var(--spacing-md);margin-bottom:var(--spacing-lg)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-sm);cursor:pointer;padding:var(--spacing-sm);border-radius:var(--radius-md);transition:var(--transition)}.checkbox-label:hover{background-color:var(--light-gray)}.checkbox-label input[type=checkbox]{width:20px;height:20px;cursor:pointer;accent-color:var(--primary)}.household-members,.pantry-items{background-color:var(--white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.member-form,.pantry-form{background-color:var(--light-gray);padding:var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.members-list,.items-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.member-card,.item-card{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-md);background-color:var(--white);border:2px solid var(--medium-gray);border-radius:var(--radius-md);transition:var(--transition)}.member-card:hover,.item-card:hover{border-color:var(--primary);box-shadow:var(--shadow-sm)}.member-info h4,.item-info h4{margin:0;font-size:1rem}.member-info p,.item-category{margin:0;color:var(--text-secondary);font-size:.875rem}.member-actions,.item-actions{display:flex;gap:var(--spacing-sm)}.filter-section{margin-bottom:var(--spacing-lg);display:flex;align-items:center;gap:var(--spacing-md)}.filter-section label{font-weight:600;white-space:nowrap}.filter-section select{flex:1;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--medium-gray);border-radius:var(--radius-md);font-family:inherit}.dietary-restrictions,.cuisine-preferences{background-color:var(--white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.recipe-list-container{max-width:1200px;margin:0 auto}.recipe-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.recipe-header h2{margin:0}.search-bar{margin-bottom:var(--spacing-lg)}.search-bar input{width:100%;padding:var(--spacing-md);border:2px solid var(--medium-gray);border-radius:var(--radius-lg);font-size:1rem;transition:var(--transition)}.search-bar input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b6b1a}.recipe-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-lg)}.recipe-card{background-color:var(--white);border-radius:var(--radius-lg);padding:var(--spacing-lg);box-shadow:var(--shadow-md);cursor:pointer;transition:var(--transition);position:relative}.recipe-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-xl)}.recipe-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm)}.recipe-card-header h3{margin:0;flex:1;padding-right:var(--spacing-sm)}.recipe-card-actions{display:flex;gap:var(--spacing-xs)}.recipe-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:var(--spacing-md);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.recipe-meta{display:flex;gap:var(--spacing-sm);flex-wrap:wrap}.recipe-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--light-gray);color:var(--text-secondary);border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.recipe-source-badge{display:inline-block;padding:var(--spacing-xs) var(--spacing-sm);background-color:var(--accent);color:var(--text-primary);border-radius:var(--radius-full);font-size:.75rem;font-weight:600;margin-top:var(--spacing-sm)}.recipe-detail-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);overflow-y:auto}.recipe-detail{max-width:800px;width:100%;max-height:90vh;overflow-y:auto;margin:auto;background-color:var(--white);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-xl)}@media(max-width:768px){.recipe-detail-overlay{padding:0}.recipe-detail{max-width:100%;max-height:100vh;border-radius:0;padding:var(--spacing-md)}}.recipe-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg);flex-wrap:wrap;gap:var(--spacing-md)}.recipe-actions{display:flex;gap:var(--spacing-sm)}.recipe-detail h1{margin-bottom:var(--spacing-sm)}.recipe-detail-description{color:var(--text-secondary);font-size:1.125rem;margin-bottom:var(--spacing-lg)}.recipe-section{margin-bottom:var(--spacing-2xl)}.recipe-section h2{color:var(--primary);border-bottom:2px solid var(--medium-gray);padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-md)}.ingredients-list,.steps-list{padding-left:var(--spacing-lg)}.ingredients-list li,.steps-list li{margin-bottom:var(--spacing-sm);line-height:1.6}.nutrition-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--spacing-md)}.nutrition-item{background-color:var(--light-gray);padding:var(--spacing-md);border-radius:var(--radius-md);text-align:center}.nutrition-label{display:block;font-size:.875rem;color:var(--text-secondary);margin-bottom:var(--spacing-xs)}.nutrition-value{display:block;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.recipe-form-container{max-width:800px;margin:0 auto}.recipe-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-lg)}.recipe-form-header h2{margin:0}.recipe-form{background-color:var(--white);border-radius:var(--radius-lg);padding:var(--spacing-xl);box-shadow:var(--shadow-md)}.form-section{margin-bottom:var(--spacing-xl);padding:var(--spacing-lg);background-color:var(--light-gray);border-radius:var(--radius-md)}.form-section h3{margin-bottom:var(--spacing-md);color:var(--primary)}.ingredient-row{display:grid;grid-template-columns:1fr 1fr 2fr auto;gap:var(--spacing-sm);margin-bottom:var(--spacing-sm);align-items:center}.ingredient-row input,.ingredient-row select{padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--medium-gray);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;transition:var(--transition)}.ingredient-row input:focus,.ingredient-row select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b6b1a}.step-row{display:grid;grid-template-columns:auto 1fr auto;gap:var(--spacing-sm);margin-bottom:var(--spacing-md);align-items:start}.step-number{font-weight:700;color:var(--primary);padding-top:var(--spacing-sm)}.nutrition-inputs{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.form-actions{display:flex;gap:var(--spacing-md);margin-top:var(--spacing-xl);flex-wrap:wrap}.weekly-calendar{max-width:1200px;margin:0 auto}.calendar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-xl);background-color:var(--white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.week-info h2{margin:0 0 var(--spacing-sm) 0}.btn-nav{background-color:var(--primary);color:var(--white);width:48px;height:48px;border-radius:var(--radius-full);font-size:1.5rem;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-sm)}.btn-nav:hover{background-color:var(--primary-dark);transform:scale(1.05)}.btn-today{background-color:var(--secondary);color:var(--white);padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:600}.btn-today:hover{background-color:var(--secondary-dark)}.days-container{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--spacing-md)}.day-view{background-color:var(--white);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-md);transition:var(--transition)}.day-view:hover{box-shadow:var(--shadow-lg)}.day-view.today{border:3px solid var(--primary)}.day-header{background-color:var(--primary);color:var(--white);padding:var(--spacing-md);text-align:center}.day-view.today .day-header{background-color:var(--secondary)}.day-meals{display:flex;flex-direction:column;gap:4px}.btn-add-meal-day{display:block;width:100%;padding:var(--spacing-sm) var(--spacing-md);background:transparent;color:var(--primary);border:2px dashed var(--primary);border-radius:var(--radius-md);font-size:.85rem;font-weight:600;cursor:pointer;transition:var(--transition);margin-top:auto}.btn-add-meal-day:hover{background:rgba(var(--primary-rgb, 74, 144, 226),.06)}.meal-type-picker{padding:var(--spacing-sm);border-top:1px solid var(--light-gray)}.picker-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-xs);border-bottom:1px solid var(--light-gray)}.picker-title{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.3px}.meal-type-options{display:flex;flex-direction:column;gap:4px}.meal-type-btn{display:flex;align-items:center;gap:var(--spacing-sm);width:100%;padding:var(--spacing-sm) var(--spacing-md);background:var(--light-gray);border:none;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;cursor:pointer;transition:background .15s;text-align:left}.meal-type-btn:hover{background:var(--medium-gray)}.btn-back-small{background:none;border:none;color:var(--primary);font-size:.85rem;font-weight:600;cursor:pointer;padding:0}.btn-back-small:hover{text-decoration:underline}.error-text{color:var(--danger, #e53e3e);font-size:.8rem;margin:var(--spacing-xs) 0}.day-name{display:block;font-weight:700;font-size:.875rem;text-transform:uppercase;letter-spacing:.5px}.day-date{display:block;font-size:1.5rem;font-weight:700}.meal-slot{padding:var(--spacing-md);min-height:120px;display:flex;flex-direction:column;justify-content:center}.meal-slot.loading{align-items:center;justify-content:center}.meal-slot.empty{background-color:var(--light-gray)}.btn-add-meal{background-color:transparent;color:var(--text-secondary);padding:var(--spacing-md);border:2px dashed var(--medium-gray);border-radius:var(--radius-md);width:100%;font-weight:600;transition:var(--transition)}.btn-add-meal:hover{border-color:var(--primary);color:var(--primary);background-color:#ff6b6b0d}.meal-slot.filled{position:relative;min-height:auto;padding:0;border-bottom:1px solid var(--light-gray)}.meal-slot.filled:last-child{border-bottom:none}.meal-type-badge{display:flex;align-items:center;gap:5px;padding:5px var(--spacing-md);background:var(--light-gray);border-bottom:1px solid var(--medium-gray)}.meal-type-badge-emoji{font-size:.85rem}.meal-type-badge-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.meal-content.clickable{display:flex;flex-direction:column;gap:2px;padding:var(--spacing-sm) var(--spacing-md);padding-right:2.5rem;cursor:pointer;transition:background .15s}.meal-content.clickable:hover{background:#00000008}.meal-recipe-name{font-size:.875rem;font-weight:600;line-height:1.3;color:var(--text-primary)}.meal-cal{font-size:.75rem;color:var(--text-secondary)}.meal-meta{color:var(--text-secondary);font-size:.75rem;margin:0}.btn-remove{position:absolute;bottom:var(--spacing-sm);right:var(--spacing-sm);background-color:#ffffffe6;width:26px;height:26px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;font-size:.8rem;opacity:.6;box-shadow:var(--shadow-sm)}.btn-remove:hover{opacity:1;background-color:var(--danger);color:var(--white)}.meal-slot.selector{background-color:var(--white);padding:var(--spacing-sm)}.selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-sm);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--medium-gray)}.selector-header h4{margin:0;font-size:.875rem}.btn-close{background:none;font-size:1.25rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;opacity:.7}.btn-close:hover{opacity:1}.recipe-selector-list{max-height:200px;overflow-y:auto;display:flex;flex-direction:column;gap:var(--spacing-xs)}.recipe-selector-item{background-color:var(--light-gray);color:var(--text-primary);padding:var(--spacing-sm);border-radius:var(--radius-sm);text-align:left;font-size:.875rem;transition:var(--transition)}.recipe-selector-item:hover{background-color:var(--primary);color:var(--white)}@media(max-width:768px){h1{font-size:1.5rem}h2,.header-title{font-size:1.25rem}.auth-card{padding:var(--spacing-lg)}.navigation{gap:var(--spacing-xs);padding:var(--spacing-sm);justify-content:space-around}.nav-button{padding:var(--spacing-md);min-width:auto;flex:1;display:flex;justify-content:center;align-items:center}.nav-text{display:none}.nav-emoji{font-size:1.5rem}.tabs,.tabs-select{display:none}.profile-settings-list{display:flex}.tab-content.mobile-content-hidden{display:none}.profile-back-btn{display:flex}.tab{padding:var(--spacing-sm) var(--spacing-md);font-size:.875rem}.profile-form,.household-members,.pantry-items,.dietary-restrictions,.cuisine-preferences{padding:var(--spacing-md)}.checkbox-grid,.recipe-grid,.days-container{grid-template-columns:1fr}.ingredient-row{grid-template-columns:1fr 1fr;gap:var(--spacing-xs)}.ingredient-row input:nth-child(3){grid-column:1 / -1}.nutrition-inputs{grid-template-columns:1fr 1fr}.calendar-header{padding:var(--spacing-md)}.btn-nav{width:40px;height:40px;font-size:1.25rem}}@media(max-width:480px){.main-content{padding:var(--spacing-md) var(--spacing-sm)}.recipe-detail,.recipe-form,.form-section{padding:var(--spacing-md)}}.menu-generator-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md)}.menu-generator-modal{background-color:var(--white);border-radius:var(--radius-xl);max-width:600px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl)}.menu-generator-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-xl);border-bottom:1px solid var(--medium-gray)}.menu-generator-header h2{margin:0 0 2px}.generator-subtitle{margin:0;font-size:.85rem;color:var(--text-secondary)}.label-optional{font-size:.8rem;font-weight:400;color:var(--text-secondary)}.menu-generator-form{padding:var(--spacing-xl)}.meal-count-list{display:flex;flex-direction:column;gap:2px;background:var(--light-gray);border-radius:var(--radius-lg);overflow:hidden;margin-top:var(--spacing-sm);margin-bottom:var(--spacing-md)}.meal-count-row{display:flex;align-items:center;padding:var(--spacing-md) var(--spacing-lg);background:var(--white);gap:var(--spacing-md);transition:background .15s}.meal-count-row.zero{background:#fafafa}.meal-count-info{display:flex;align-items:center;gap:var(--spacing-sm);flex:1}.meal-count-emoji{font-size:1.4rem;width:2rem;text-align:center;flex-shrink:0}.meal-count-label{font-size:1rem;font-weight:500;color:var(--text-primary);transition:color .15s}.meal-count-row.zero .meal-count-label{color:var(--text-secondary)}.meal-stepper{display:flex;align-items:center;gap:var(--spacing-md)}.stepper-btn{width:44px;height:44px;border-radius:50%;background:var(--primary);color:var(--white);border:none;font-size:1.3rem;font-weight:700;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .1s;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.stepper-btn:hover:not(:disabled){background:var(--secondary);transform:scale(1.08)}.stepper-btn:active:not(:disabled){transform:scale(.95)}.stepper-btn:disabled{background:var(--medium-gray);color:var(--text-secondary);cursor:not-allowed;transform:none}.stepper-count{font-size:1.3rem;font-weight:700;min-width:2rem;text-align:center;color:var(--text-primary);tabular-nums:unset;font-variant-numeric:tabular-nums}.meal-count-summary{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-sm) var(--spacing-xs);font-size:.9rem}.summary-total{font-weight:600;color:var(--text-primary)}.summary-cost{color:var(--text-secondary);font-size:.85rem}.summary-empty{color:var(--text-secondary);font-style:italic;font-size:.85rem}.btn-ai-generate{background:linear-gradient(135deg,#ff6b6b,#ffe66d);color:var(--text-primary);padding:var(--spacing-sm) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:700;box-shadow:var(--shadow-sm);transition:var(--transition)}.btn-ai-generate:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.week-actions{display:flex;gap:var(--spacing-sm);flex-wrap:wrap;justify-content:center}.generating-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:1001;padding:var(--spacing-md)}.generating-modal{background-color:var(--white);border-radius:var(--radius-xl);padding:var(--spacing-2xl);max-width:500px;width:100%;text-align:center}.generating-spinner{margin-bottom:var(--spacing-xl)}.generating-spinner .spinner{width:64px;height:64px;margin:0 auto}.generating-modal h2{color:var(--primary);margin-bottom:var(--spacing-xl)}.generating-steps{display:flex;flex-direction:column;gap:var(--spacing-lg);margin-bottom:var(--spacing-xl)}.generating-step{display:flex;align-items:center;gap:var(--spacing-md);text-align:left}.step-icon{font-size:2rem;flex-shrink:0}.generating-time{color:var(--text-secondary);font-size:.875rem;margin-bottom:var(--spacing-lg)}.recipe-feedback-form{background-color:var(--light-gray);padding:var(--spacing-xl);border-radius:var(--radius-lg);margin-top:var(--spacing-lg)}.recipe-feedback-form h3{margin-bottom:var(--spacing-md)}.star-rating{display:flex;gap:var(--spacing-xs);margin-bottom:var(--spacing-sm)}.star{background:none;border:none;font-size:2rem;color:var(--medium-gray);cursor:pointer;transition:var(--transition);padding:0}.star.filled{color:gold}.star:hover{transform:scale(1.1)}.recipe-rating-display{display:flex;align-items:center;gap:var(--spacing-md);margin-bottom:var(--spacing-md)}.rating-stars{font-size:1.5rem;color:gold}.rating-text{color:var(--text-secondary);font-size:.875rem}.feedback-list{margin-top:var(--spacing-lg)}.feedback-list h3{margin-bottom:var(--spacing-md)}.feedback-item{background-color:var(--light-gray);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.feedback-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-sm);flex-wrap:wrap;gap:var(--spacing-sm)}.feedback-rating{color:gold;font-size:1.25rem}.feedback-meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--spacing-xs)}.feedback-author{font-weight:600;color:var(--text-primary);font-size:.875rem}.feedback-date{color:var(--text-secondary);font-size:.75rem}.feedback-notes{color:var(--text-primary);line-height:1.6;margin:0}.feedback-actions{margin-top:var(--spacing-lg)}.advanced-settings{max-width:900px;margin:0 auto}.advanced-settings h2{margin-bottom:var(--spacing-sm);color:var(--primary)}.section-description{color:var(--text-secondary);margin-bottom:var(--spacing-xl)}.settings-grid{display:grid;gap:var(--spacing-xl)}.setting-group{background:var(--white);padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid var(--medium-gray)}.setting-group.full-width{grid-column:1 / -1}.setting-label{display:block;font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs);font-size:1rem}.setting-description{color:var(--text-secondary);font-size:.875rem;margin-bottom:var(--spacing-md);line-height:1.5}.setting-select,.setting-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:1px solid var(--medium-gray);border-radius:var(--radius-md);font-size:1rem;background:var(--white);transition:border-color .2s ease}.setting-select:focus,.setting-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b6b1a}.budget-input-wrapper{position:relative;display:inline-block;width:200px}.currency-symbol{position:absolute;left:var(--spacing-md);top:50%;transform:translateY(-50%);color:var(--text-secondary);font-weight:600}.budget-input{padding-left:calc(var(--spacing-md) + 20px)}.equipment-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:var(--spacing-md);margin-top:var(--spacing-md)}.equipment-checkbox{display:flex;align-items:center;padding:var(--spacing-sm);border:1px solid var(--medium-gray);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;background:var(--white)}.equipment-checkbox:hover{border-color:var(--primary);background:#ff6b6b0d}.equipment-checkbox input[type=checkbox]{margin-right:var(--spacing-sm);cursor:pointer}.equipment-checkbox span{font-size:.875rem}.toggle-group{display:flex;flex-direction:column;gap:var(--spacing-md);margin-top:var(--spacing-md)}.toggle-option{display:flex;align-items:flex-start;padding:var(--spacing-md);border:1px solid var(--medium-gray);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease;background:var(--white)}.toggle-option:hover{border-color:var(--primary);background:#ff6b6b0d}.toggle-option input[type=checkbox]{margin-right:var(--spacing-md);margin-top:4px;cursor:pointer}.toggle-option span{flex:1}.toggle-option strong{display:block;margin-bottom:var(--spacing-xs);color:var(--text-primary)}.toggle-option small{display:block;color:var(--text-secondary);font-size:.875rem;line-height:1.5}.settings-footer{margin-top:var(--spacing-xl);padding:var(--spacing-lg);background:#ff6b6b0d;border-radius:var(--radius-md);border-left:4px solid var(--primary)}.info-note{margin:0;color:var(--text-secondary);font-size:.875rem;line-height:1.6}.recipe-metadata-badges{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);margin-bottom:var(--spacing-lg)}.info-badge{display:inline-flex;align-items:center;padding:var(--spacing-xs) var(--spacing-md);border-radius:var(--radius-full);font-size:.875rem;font-weight:600;white-space:nowrap}.ai-badge{background:linear-gradient(135deg,#667eea,#764ba2);color:var(--white)}.cuisine-badge,.difficulty-badge{background:var(--light-gray);color:var(--text-primary)}.time-badge{background:#34d3991a;color:#047857}.cost-badge{background:#fbbf241a;color:#d97706}.recipe-equipment{padding:var(--spacing-md);background:#3b82f60d;border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border-left:4px solid #3b82f6}.recipe-equipment strong{color:#1e40af}.recipe-allergens{padding:var(--spacing-md);background:#ef44440d;border-radius:var(--radius-md);margin-bottom:var(--spacing-lg);border-left:4px solid #ef4444}.recipe-allergens strong{color:#991b1b}.spice-adaptations-section{background:#fb923c0d;padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid rgba(251,146,60,.2)}.spice-adaptations-section h2{color:#c2410c}.spice-base-version{padding:var(--spacing-md);background:var(--white);border-radius:var(--radius-md);margin-bottom:var(--spacing-md)}.spice-adaptation-points h3{font-size:1rem;margin-bottom:var(--spacing-md);color:var(--text-primary)}.adaptation-point{background:var(--white);padding:var(--spacing-md);border-radius:var(--radius-md);margin-bottom:var(--spacing-sm)}.adaptation-point p{margin-bottom:var(--spacing-xs)}.adaptation-point ul{margin:var(--spacing-xs) 0;padding-left:var(--spacing-lg)}.adaptation-point .target-level{color:#c2410c;font-weight:600;margin-top:var(--spacing-sm)}.cultural-context-section{background:#8b5cf60d;padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid rgba(139,92,246,.2)}.cultural-context-section h2{color:#6d28d9}.cultural-context-text{line-height:1.8;color:var(--text-primary);font-size:1rem}.cooking-science-section{background:#10b9810d;padding:var(--spacing-lg);border-radius:var(--radius-lg);border:1px solid rgba(16,185,129,.2)}.cooking-science-section h2{color:#047857}.cooking-science-text{line-height:1.8;color:var(--text-primary);font-size:1rem}@media(max-width:768px){.menu-generator-modal{max-height:95vh}.menu-generator-header,.menu-generator-form{padding:var(--spacing-md)}.generating-modal{padding:var(--spacing-lg)}.week-actions{flex-direction:column;width:100%}.btn-ai-generate{width:100%}}.family-selector{position:relative;display:inline-block}.family-selector-button{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--white);border:2px solid var(--medium-gray);border-radius:var(--radius-md);cursor:pointer;font-size:.95rem;font-weight:500;color:var(--text-primary);transition:var(--transition)}.family-selector-button:hover{border-color:var(--primary);background:var(--light-gray)}.family-selector-label{display:flex;align-items:center;gap:var(--spacing-sm)}.family-name{font-weight:600}.family-role-badge{display:inline-block;padding:.15rem .5rem;font-size:.75rem;font-weight:600;text-transform:uppercase;border-radius:var(--radius-sm);letter-spacing:.5px}.family-role-badge.creator{background:#ffe5e5;color:#d63031}.family-role-badge.approver{background:#e3f2fd;color:#1976d2}.family-role-badge.viewer{background:#f3e5f5;color:#7b1fa2}.family-selector-arrow{font-size:.7rem;color:var(--dark-gray)}.family-dropdown{position:absolute;top:calc(100% + .5rem);right:0;min-width:300px;background:var(--white);border:1px solid var(--medium-gray);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:1000;max-height:400px;overflow-y:auto}.family-option{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--spacing-md);border:none;background:none;cursor:pointer;text-align:left;transition:var(--transition);border-bottom:1px solid var(--light-gray)}.family-option:hover{background:var(--light-gray)}.family-option.active{background:#fff5f5}.family-option-content{flex:1}.family-option-name{display:block;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.family-option-desc{display:block;font-size:.85rem;color:var(--text-secondary)}.family-option-meta{display:flex;align-items:center;gap:var(--spacing-sm);margin-top:.25rem}.family-member-count{font-size:.8rem;color:var(--text-secondary)}.family-option-check{color:var(--success);font-size:1.2rem;font-weight:700}.family-option.create-family-option{border-bottom:none;color:var(--primary);font-weight:600}.family-option.create-family-option:hover{background:#fff5f5}.family-option-icon{font-size:1.5rem;margin-right:var(--spacing-sm)}.family-dropdown-divider{height:1px;background:var(--medium-gray);margin:.5rem 0}.header-actions{display:flex;align-items:center;gap:var(--spacing-md)}.family-settings{max-width:800px;margin:0 auto}.family-settings-header{margin-bottom:var(--spacing-xl)}.family-settings-subtitle{color:var(--text-secondary);margin-top:var(--spacing-sm)}.family-settings-section{background:var(--white);padding:var(--spacing-xl);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl)}.family-settings-section.family-settings-danger{border:2px solid var(--danger)}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-lg)}.family-members-list{display:flex;flex-direction:column;gap:var(--spacing-md)}.family-member-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:var(--light-gray);border-radius:var(--radius-md)}.family-member-info{flex:1}.family-member-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.family-member-email{color:var(--text-secondary);font-size:.9rem;margin-bottom:.5rem}.family-member-meta{display:flex;align-items:center;gap:var(--spacing-md);font-size:.85rem}.family-member-date{color:var(--text-secondary)}.pending-invitations{display:flex;flex-direction:column;gap:var(--spacing-md)}.invitation-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-md);background:#fff9e6;border:1px solid var(--warning);border-radius:var(--radius-md)}.invitation-info{flex:1}.invitation-email{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.invitation-meta{display:flex;align-items:center;gap:var(--spacing-md);font-size:.85rem}.invitation-date,.invitation-expires{color:var(--text-secondary)}.invitation-actions{display:flex;gap:var(--spacing-sm)}.btn-sm{padding:.4rem .8rem;font-size:.85rem}.shopping-list-container{max-width:900px;margin:0 auto}.shopping-list-header{margin-bottom:var(--spacing-xl);text-align:center}.shopping-list-subtitle{color:var(--text-secondary);font-size:1.1rem;margin-top:var(--spacing-sm)}.week-selector{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg);background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl)}.week-nav-button{padding:var(--spacing-sm) var(--spacing-md);background:var(--white);border:2px solid var(--medium-gray);border-radius:var(--radius-md);cursor:pointer;font-weight:500;color:var(--text-primary);transition:var(--transition)}.week-nav-button:hover{background:var(--primary);color:var(--white);border-color:var(--primary)}.week-display{font-weight:600;font-size:1.1rem;color:var(--text-primary)}.shopping-list-empty{text-align:center;padding:var(--spacing-2xl);background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.shopping-list-actions{display:flex;gap:var(--spacing-md);justify-content:center;margin-bottom:var(--spacing-xl)}.shopping-list-progress{background:var(--white);padding:var(--spacing-lg);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);margin-bottom:var(--spacing-xl)}.progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md)}.progress-text{font-weight:600;color:var(--text-primary)}.progress-percentage{font-weight:700;font-size:1.2rem;color:var(--success)}.progress-bar-container{height:12px;background:var(--light-gray);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:linear-gradient(90deg,var(--success),var(--secondary));border-radius:var(--radius-full);transition:width .3s ease}.shopping-categories{display:flex;flex-direction:column;gap:var(--spacing-lg)}.shopping-category{background:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);overflow:hidden}.shopping-category-header{padding:var(--spacing-lg);background:var(--light-gray);cursor:pointer;-webkit-user-select:none;user-select:none;transition:var(--transition)}.shopping-category-header:hover{background:var(--medium-gray)}.shopping-category-title{display:flex;align-items:center;gap:var(--spacing-sm);font-size:1.2rem;font-weight:600;margin-bottom:var(--spacing-sm)}.category-icon{font-size:.8rem;color:var(--dark-gray)}.category-count{margin-left:auto;font-size:.95rem;color:var(--text-secondary);font-weight:500}.shopping-category-progress{height:6px;background:var(--white);border-radius:var(--radius-full);overflow:hidden}.shopping-category-progress-bar{height:100%;background:var(--success);border-radius:var(--radius-full);transition:width .3s ease}.shopping-category-items{padding:var(--spacing-md)}.shopping-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);border-bottom:1px solid var(--light-gray);transition:var(--transition)}.shopping-item:last-child{border-bottom:none}.shopping-item.purchased{opacity:.5}.shopping-item.purchased .shopping-item-name{text-decoration:line-through}.shopping-item-checkbox{width:20px;height:20px;cursor:pointer;flex-shrink:0;margin-top:.2rem}.shopping-item-details{flex:1}.shopping-item-name{font-size:1rem;color:var(--text-primary);margin-bottom:.25rem}.shopping-item-recipes{display:flex;flex-wrap:wrap;gap:var(--spacing-xs);margin-top:var(--spacing-xs)}.shopping-item-recipe-tag{display:inline-block;padding:.15rem .5rem;font-size:.75rem;background:var(--light-gray);color:var(--text-secondary);border-radius:var(--radius-sm)}.alert{padding:var(--spacing-lg);border-radius:var(--radius-md);margin-bottom:var(--spacing-lg)}.alert-info{background:#e3f2fd;color:#1976d2;border:1px solid #1976D2}.alert-error{background:#ffebee;color:#c62828;border:1px solid #C62828}.alert-success{background:#e8f5e9;color:#2e7d32;border:1px solid #2E7D32}.alert h3{margin-bottom:var(--spacing-sm)}.form-help-text{font-size:.85rem;color:var(--text-secondary);margin-top:.25rem}.invite-info{margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--medium-gray)}.info-text{font-size:.9rem;color:var(--text-secondary)}@media(max-width:768px){.family-dropdown{min-width:280px;right:-1rem}.week-selector{flex-direction:column;text-align:center}.week-nav-button{width:100%}.shopping-list-actions{flex-direction:column}.shopping-list-actions button{width:100%}.family-member-item,.invitation-item{flex-direction:column;align-items:flex-start;gap:var(--spacing-md)}.invitation-actions{width:100%;justify-content:flex-end}}.modal-overlay.meal-modal-overlay{align-items:flex-end;padding:0}@media(min-width:640px){.modal-overlay.meal-modal-overlay{align-items:center;padding:var(--spacing-lg)}}.meal-add-modal{background:var(--white);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:480px;max-height:85vh;overflow-y:auto;box-shadow:0 -4px 30px #00000026;animation:slideUpModal .25s cubic-bezier(.32,.72,0,1)}@media(min-width:640px){.meal-add-modal{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);animation:fadeIn .2s ease}}@keyframes slideUpModal{0%{transform:translateY(24px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--spacing-lg);border-bottom:1px solid var(--light-gray)}.modal-title{font-size:1.1rem;font-weight:700;margin:0 0 2px;color:var(--text-primary)}.modal-subtitle{font-size:.85rem;color:var(--text-secondary);margin:0}.meal-add-type-list{display:flex;flex-direction:column;gap:1px;padding:var(--spacing-sm);background:var(--light-gray)}.meal-add-type-item{display:flex;align-items:center;gap:var(--spacing-md);width:100%;padding:var(--spacing-md) var(--spacing-lg);background:var(--white);border:none;border-radius:var(--radius-md);cursor:pointer;transition:background .15s;text-align:left}.meal-add-type-item:hover,.meal-add-type-item:focus{background:#f5f5f7}.meal-add-recipes{padding:var(--spacing-md)}.modal-section-header{display:flex;align-items:center;gap:var(--spacing-md);padding-bottom:var(--spacing-sm);margin-bottom:var(--spacing-sm);border-bottom:1px solid var(--light-gray)}.modal-type-label{font-size:1rem;font-weight:600;color:var(--text-primary)}.meal-add-recipe-list{display:flex;flex-direction:column;gap:4px}.meal-add-recipe-item{display:flex;justify-content:space-between;align-items:center;width:100%;padding:var(--spacing-md) var(--spacing-md);background:var(--light-gray);border:none;border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:background .15s;gap:var(--spacing-md)}.meal-add-recipe-item:hover{background:var(--medium-gray)}.meal-add-recipe-item:disabled{opacity:.6;cursor:not-allowed}.recipe-item-name{font-size:.95rem;font-weight:500;flex:1;color:var(--text-primary)}.recipe-item-meta{font-size:.8rem;color:var(--text-secondary);white-space:nowrap}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--spacing-md);animation:fadeIn .2s ease-in-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--white);border-radius:var(--radius-xl);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-xl);animation:slideUp .3s ease-out;position:relative}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-xl);border-bottom:2px solid var(--light-gray);background:linear-gradient(135deg,#ffe5e5,#fff5e6);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.modal-header h2{margin:0;color:var(--primary);font-size:1.5rem}.modal-close-button{background:var(--white);border:none;color:var(--text-secondary);font-size:2rem;width:36px;height:36px;border-radius:var(--radius-full);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:var(--transition);line-height:1;padding:0;box-shadow:var(--shadow-sm)}.modal-close-button:hover{background-color:var(--danger);color:var(--white);transform:rotate(90deg)}.modal-body{padding:var(--spacing-xl)}.modal-actions{display:flex;gap:var(--spacing-md);justify-content:flex-end;margin-top:var(--spacing-lg);padding-top:var(--spacing-lg);border-top:1px solid var(--light-gray)}.modal-actions button{min-width:120px}.create-family-modal,.invite-member-modal{max-width:550px}.dialog-modal{max-width:450px}.dialog-modal .modal-header{padding:var(--spacing-lg) var(--spacing-xl)}.dialog-modal .modal-body{padding:var(--spacing-lg) var(--spacing-xl);font-size:1rem;line-height:1.6;color:var(--text-primary)}.dialog-modal.dialog-error .modal-header{background:linear-gradient(135deg,#ffebee,#ffcdd2)}.dialog-modal.dialog-error .modal-header h2{color:var(--danger)}.dialog-modal.dialog-success .modal-header{background:linear-gradient(135deg,#e8f5e9,#c8e6c9)}.dialog-modal.dialog-success .modal-header h2{color:var(--success)}.dialog-modal.dialog-warning .modal-header{background:linear-gradient(135deg,#fff9e6,#ffe5b4)}.dialog-modal.dialog-warning .modal-header h2{color:var(--warning)}.dialog-modal.dialog-confirm .modal-header{background:linear-gradient(135deg,#e3f2fd,#bbdefb)}.dialog-modal.dialog-confirm .modal-header h2{color:#1976d2}.dialog-icon{font-size:3rem;text-align:center;margin-bottom:var(--spacing-md)}.dialog-icon.error{color:var(--danger)}.dialog-icon.success{color:var(--success)}.dialog-icon.warning{color:var(--warning)}.dialog-icon.info{color:#1976d2}.dialog-input-group{margin-top:var(--spacing-lg)}.dialog-input-group label{display:block;font-weight:600;margin-bottom:var(--spacing-sm);color:var(--text-primary)}.dialog-input-group input{width:100%;padding:var(--spacing-sm) var(--spacing-md);border:2px solid var(--medium-gray);border-radius:var(--radius-md);font-family:inherit;font-size:1rem;transition:var(--transition)}.dialog-input-group input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #ff6b6b1a}@media(max-width:768px){.modal-overlay{padding:0}.modal-content{max-width:100%;max-height:100vh;border-radius:0;animation:slideUp .3s ease-out}.modal-header{border-radius:0;padding:var(--spacing-lg)}.modal-body{padding:var(--spacing-lg)}.modal-actions{flex-direction:column-reverse}.modal-actions button{width:100%}}.social-login-buttons{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.btn-social{display:flex;align-items:center;justify-content:center;gap:10px;padding:11px 16px;border-radius:8px;border:1px solid var(--border);background:#fff;font-size:14px;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s;color:#333}.btn-social:hover:not(:disabled){background:#f5f5f5;border-color:#bbb}.btn-social:disabled{opacity:.5;cursor:not-allowed}.social-icon{width:18px;height:18px;flex-shrink:0}.btn-apple{background:#111;color:#fff;border-color:#111}.btn-apple:hover:not(:disabled){background:#333;border-color:#333}.auth-divider{text-align:center;margin:16px 0;position:relative;color:#999;font-size:13px}.auth-divider:before,.auth-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:var(--border)}.auth-divider:before{left:0}.auth-divider:after{right:0}.view-mode-toggle{display:flex;gap:4px;background:var(--surface);border-radius:8px;padding:4px;margin-bottom:8px}.btn-view-mode{padding:6px 14px;border:none;border-radius:6px;background:transparent;font-size:13px;cursor:pointer;color:var(--text-secondary);transition:all .2s}.btn-view-mode.active{background:#fff;color:var(--primary);font-weight:600;box-shadow:0 1px 4px #0000001a}.custom-date-range{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.custom-date-range label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.custom-date-range input[type=date]{padding:6px 10px;border:1px solid var(--border);border-radius:6px;font-size:13px}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-recipe-card{padding:16px;background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014}.skeleton-image{width:100%;height:180px;border-radius:8px;margin-bottom:12px}.skeleton-badge{width:80px;height:20px;margin-bottom:8px}.skeleton-title{height:22px;margin-bottom:8px}.skeleton-text{height:15px;margin-bottom:6px}.skeleton-text-short{width:60%}.skeleton-footer{height:18px;width:40%;margin-top:12px}.update-notification{position:fixed;bottom:80px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--spacing-md);background-color:var(--white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-sm) var(--spacing-md);box-shadow:var(--shadow-lg);z-index:9999;white-space:nowrap}.update-notification__message{font-size:var(--text-sm);color:var(--color-text)}.update-notification__btn{background-color:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);padding:var(--spacing-xs) var(--spacing-md);font-size:var(--text-sm);font-weight:600;cursor:pointer}.update-notification__btn:hover{opacity:.9}.pwa-install-prompt{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:flex;align-items:flex-end;justify-content:center}.prompt-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#00000080}.prompt-card{position:relative;background:#fff;border-radius:20px 20px 0 0;padding:32px 24px 24px;max-width:500px;width:100%;box-shadow:0 -4px 20px #00000026}.prompt-close-btn{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:4px 8px;line-height:1}.prompt-icon{font-size:48px;text-align:center;margin-bottom:12px}.prompt-card h3{margin:0 0 8px;font-size:20px;text-align:center;color:var(--text-primary)}.prompt-card p{margin:0 0 20px;text-align:center;color:var(--text-secondary);font-size:14px}.prompt-features{display:flex;justify-content:space-around;margin-bottom:20px;padding:16px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}.prompt-feature{display:flex;flex-direction:column;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.prompt-actions{display:flex;gap:10px}.prompt-actions button{flex:1;padding:12px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer}@media(min-width:768px){.prompt-card{border-radius:20px;margin-bottom:40px}}.error-boundary-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.error-boundary-content{text-align:center;max-width:400px}.error-boundary-icon{font-size:64px;margin-bottom:16px}.error-boundary-content h1{margin:0 0 12px;font-size:24px;color:var(--text-primary)}.error-boundary-content p{color:var(--text-secondary);margin-bottom:24px}.error-boundary-actions{display:flex;gap:12px;justify-content:center}.error-boundary-details{margin-top:24px;text-align:left;background:#f5f5f5;padding:16px;border-radius:8px}.error-boundary-details pre{font-size:12px;overflow:auto;white-space:pre-wrap;word-break:break-all}.auto-generation-settings,.meal-configuration{padding:4px 0}.auto-generation-settings h3,.meal-configuration h3{margin:0 0 6px;font-size:18px;color:var(--text-primary)}.setting-description{color:var(--text-secondary);font-size:14px;margin:0 0 20px;line-height:1.5}.toggle-label{display:flex;align-items:center;gap:10px;cursor:pointer}.toggle-text{font-size:15px;font-weight:500}.schedule-settings{margin-top:20px;padding:20px;background:var(--surface);border-radius:10px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.meal-options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-bottom:16px}.meal-option{cursor:pointer}.meal-option input[type=checkbox]{position:absolute;opacity:0;pointer-events:none}.meal-option-content{display:flex;align-items:center;gap:12px;padding:16px;border:2px solid var(--border);border-radius:10px;background:#fff;transition:border-color .2s,background .2s}.meal-option.selected .meal-option-content{border-color:var(--primary);background:#e975680d}.meal-emoji{font-size:28px}.meal-info{flex:1;display:flex;flex-direction:column;gap:2px}.meal-label{font-size:15px;font-weight:600;color:var(--text-primary)}.meal-description{font-size:12px;color:var(--text-secondary)}.meal-checkmark{font-size:18px;color:var(--primary);font-weight:700}@media print{.header,.navigation,.footer,.btn-primary,.btn-secondary,.btn-danger,.btn-icon,.btn-back,.btn-nav,.btn-today,.week-nav-button,.shopping-list-actions{display:none}.main-content{max-width:100%}.shopping-item-checkbox{print-color-adjust:exact;-webkit-print-color-adjust:exact}}.logo-image{height:32px;width:auto;display:block}.app-logo{display:flex;flex-direction:column;gap:2px}@media(max-width:768px){.logo-image{height:28px}}.header-logo,.app-logo-text{font-family:var(--font-display);font-size:22px;font-weight:700;font-style:italic;color:var(--color-coral);letter-spacing:-.02em}.week-navigator-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:10px 14px;margin:0 0 14px}.week-navigator-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.week-range-label{font-family:var(--font-ui);font-size:9px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-muted)}.week-planned-count{font-family:var(--font-ui);font-size:10px;font-weight:500;color:var(--color-coral)}.week-nav-arrow{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:none;border:none;border-radius:50%;cursor:pointer;color:var(--color-muted);transition:color .15s ease,background .15s ease;padding:0;flex-shrink:0}.week-nav-arrow:hover{color:var(--color-coral);background:#e8735a14}.week-nav-arrow:active{background:#e8735a29}.week-day-strip{display:flex;justify-content:space-between;align-items:flex-start}.week-day-circle-wrapper{display:flex;flex-direction:column;align-items:center;gap:4px}.week-day-letter{font-family:var(--font-ui);font-size:8px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--color-hint)}.week-day-circle{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--color-border);background:var(--color-white);display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:12px;font-weight:600;color:var(--color-body-brown)}.week-day-circle.selected{background:var(--color-coral);border-color:var(--color-coral);color:var(--color-white)}.week-day-circle.planned{border-color:var(--color-coral-border)}.week-day-dot{width:4px;height:4px;border-radius:50%;background:var(--color-border)}.week-day-dot.has-meal{background:var(--color-coral)}.week-toggle{display:flex;background:var(--color-cream);border-radius:var(--radius-md);padding:2px;gap:2px;margin-bottom:10px}.week-toggle-option{font-family:var(--font-ui);font-size:10px;font-weight:500;padding:4px 14px;border-radius:6px;color:var(--color-hint);cursor:pointer;background:none;border:none;transition:background .12s}.week-toggle-option.active{background:var(--color-white);color:var(--color-coral);font-weight:600}.calendar-header{display:flex;justify-content:center;align-items:center;margin-bottom:14px;background:transparent;padding:0;box-shadow:none}.week-info{text-align:center;flex:1}.week-actions{display:flex;gap:8px;justify-content:center;align-items:center;flex-wrap:wrap}.btn-today{background:var(--color-hover-cream);color:var(--color-coral);border:1px solid var(--color-coral-border);border-radius:var(--radius-md);padding:6px 12px;font-family:var(--font-ui);font-weight:600;font-size:11px;cursor:pointer}.btn-today:hover{background:var(--color-coral-light)}.btn-ai-generate{background:var(--color-purple);border-radius:var(--radius-lg);padding:11px 16px;display:flex;align-items:center;justify-content:center;gap:7px;color:#fff;font-family:var(--font-ui);font-size:12px;font-weight:600;border:none;cursor:pointer}.btn-ai-generate:hover{opacity:.9}.day-section-header{display:flex;align-items:flex-end;padding:0 0 8px;margin-bottom:8px;border-bottom:1px solid var(--color-border)}.day-left-rule{border-left:2.5px solid var(--color-coral);padding-left:8px;display:flex;flex-direction:column;gap:0}.day-name{font-family:var(--font-ui);font-weight:700;font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--color-coral);line-height:1}.day-numeral{font-family:var(--font-display);font-weight:700;font-style:italic;font-size:34px;color:var(--color-deep-brown);letter-spacing:-.02em;line-height:1;margin-top:1px}.day-month{font-family:var(--font-ui);font-weight:400;font-size:11px;color:var(--color-hint);margin-left:auto;padding-bottom:3px}.day-view{background:transparent;border-radius:0;overflow:hidden;box-shadow:none;border:none;margin-bottom:14px;min-width:0}.day-view:hover{box-shadow:none}.day-view.today{border:none}.day-view.today .day-numeral{color:var(--color-coral)}.day-header{display:none}.btn-add-meal-day{border:1.5px dashed #E8C8BC;border-radius:var(--radius-md);padding:8px;text-align:center;font-family:var(--font-ui);font-weight:500;font-size:10px;color:var(--color-coral);background:transparent;cursor:pointer;transition:background .12s ease;display:block;width:100%;margin-top:8px}.btn-add-meal-day:hover{background:var(--color-hover-cream)}.meal-slot.filled{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:11px 12px;display:flex;align-items:center;gap:10px;cursor:pointer;transition:border-color .12s ease;margin-bottom:6px}.meal-slot.filled:hover{border-color:var(--color-coral-border)}.meal-type-badge{flex-shrink:0}.meal-type-badge-emoji{display:none}.meal-type-badge-label{font-family:var(--font-ui);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--color-hint)}.meal-content{flex:1;min-width:0}.meal-recipe-name{font-family:var(--font-ui);font-weight:600;font-size:12px;color:var(--color-deep-brown);white-space:normal;word-break:break-word;display:block;margin-bottom:4px;line-height:1.3}.meal-cal{display:inline-block;background:var(--chip-diff-bg);color:var(--chip-diff-text);padding:2px 7px;border-radius:var(--radius-pill);font-family:var(--font-ui);font-size:9px;font-weight:500}.menu-generator-modal{background:var(--color-white);border-radius:var(--radius-xl)}.menu-generator-modal h2{font-family:var(--font-display);font-size:18px;font-weight:700;font-style:italic;color:var(--color-deep-brown);letter-spacing:-.02em;margin-bottom:2px}.generator-subtitle{font-family:var(--font-ui);font-size:12px;color:var(--color-muted);margin:0;font-style:normal}.btn-primary.btn-generate,.menu-generator-form .btn-primary{background:var(--color-purple);border-radius:var(--radius-lg);font-family:var(--font-ui);font-weight:600;font-size:13px;border:none}.menu-generator-form .btn-secondary{background:var(--color-white);border:1px solid var(--color-border);color:var(--color-deep-brown);border-radius:var(--radius-md)}.summary-total{font-family:var(--font-ui);font-size:13px;font-weight:700;color:var(--color-deep-brown)}.summary-cost{display:none}.section-rule{display:flex;align-items:center;gap:8px;margin-bottom:12px}.section-rule-label{font-family:var(--font-display);font-weight:700;font-style:italic;font-size:13px;color:var(--color-coral);white-space:nowrap}.section-rule-line{flex:1;border:none;border-top:1px solid var(--color-border)}.recipe-detail-modal h1,.recipe-detail h2:first-of-type,.recipe-name-heading{font-family:var(--font-display);font-weight:700;font-style:italic;font-size:22px;color:var(--color-deep-brown);letter-spacing:-.02em;line-height:1.15}.star-filled,.star-icon.filled{fill:var(--color-coral)!important;color:var(--color-coral)!important}.star-empty,.star-icon.empty{fill:var(--color-border)!important;color:var(--color-border)!important}.chip{padding:4px 10px;border-radius:var(--radius-pill);font-family:var(--font-ui);font-size:10px;font-weight:500;display:inline-flex;align-items:center;gap:4px}.chip-cuisine{background:var(--chip-cuisine-bg);color:var(--chip-cuisine-text)}.chip-diff{background:var(--chip-diff-bg);color:var(--chip-diff-text)}.chip-time{background:var(--chip-time-bg);color:var(--chip-time-text)}.chip-cost{background:var(--chip-cost-bg);color:var(--chip-cost-text)}.info-banner{border-radius:0 var(--radius-md) var(--radius-md) 0;padding:9px 12px;display:flex;align-items:flex-start;gap:8px;border-left:2.5px solid transparent;margin-bottom:8px}.info-banner.equipment{background:var(--color-equip-bg);border-left-color:var(--color-equip-rule)}.info-banner.allergen{background:var(--color-allerg-bg);border-left-color:var(--color-allerg-rule)}.info-banner .banner-label{font-family:var(--font-ui);font-weight:600;font-size:11px}.info-banner.equipment .banner-label{color:var(--color-equip-label)}.info-banner.allergen .banner-label{color:var(--color-allerg-label)}.info-banner .banner-value{font-family:var(--font-ui);font-size:11px;color:var(--color-body-brown);margin-left:4px}.ingredient-list{list-style:none;padding:0;margin:0}.ingredient-item{display:flex;align-items:baseline;gap:8px;padding:8px 0;border-bottom:1px solid var(--color-border-light)}.ingredient-item:last-child{border-bottom:none}.ingredient-qty{font-family:var(--font-ui);font-weight:700;font-size:11px;color:var(--color-deep-brown);min-width:42px;flex-shrink:0}.ingredient-name{font-family:var(--font-ui);font-weight:400;font-size:11px;color:var(--color-body-brown);line-height:1.4}.btn-recipe-edit{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:5px 12px;font-family:var(--font-ui);font-size:11px;font-weight:500;color:var(--color-deep-brown);cursor:pointer}.btn-recipe-delete{background:var(--color-coral-light);border:1px solid var(--color-coral-border);border-radius:var(--radius-md);padding:5px 12px;font-family:var(--font-ui);font-size:11px;font-weight:500;color:var(--color-coral-dark);cursor:pointer}.btn-recipe-back{display:flex;align-items:center;gap:4px;font-family:var(--font-ui);font-size:11px;font-weight:500;color:var(--color-coral);background:none;border:none;cursor:pointer;text-decoration:none}.shopping-category-title{font-family:var(--font-display);font-weight:700;font-style:italic;font-size:13px;color:var(--color-coral);white-space:nowrap}.shopping-item-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:10px 14px}.shopping-item-card.checked{color:var(--color-muted);text-decoration:line-through}.profile-form{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg)}.profile-settings-item{background:var(--color-white);border-bottom:1px solid var(--color-border-light);border-radius:0}.profile-settings-item.ai-row{background:var(--color-coral-light);border-left:2.5px solid var(--color-coral)}.auth-container{background:var(--color-cream)}.invitation-notice{background:var(--color-coral-light);border-color:var(--color-coral-border)}.btn-add-recipe{background:var(--color-purple);color:#fff;border:none;border-radius:var(--radius-lg);padding:8px 16px;font-family:var(--font-ui);font-size:12px;font-weight:600;cursor:pointer;transition:opacity .12s}.btn-add-recipe:hover{opacity:.88}.search-bar input{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-family:var(--font-ui);font-size:12px;color:var(--color-body-brown);padding:8px 12px;width:100%;box-sizing:border-box}.search-bar input::placeholder{color:var(--color-muted)}.settings-item-icon{display:flex;align-items:center;color:var(--color-coral);flex-shrink:0}.settings-item-chevron{display:flex;align-items:center;color:var(--color-hint);margin-left:auto}.profile-back-btn{display:flex;align-items:center;gap:4px;background:none;border:none;color:var(--color-coral);font-family:var(--font-ui);font-size:12px;font-weight:500;cursor:pointer;padding:0;margin-bottom:12px}.week-nav-button{display:flex;align-items:center;justify-content:center;background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:6px 10px;color:var(--color-body-brown);cursor:pointer;transition:border-color .12s}.week-nav-button:hover{border-color:var(--color-coral-border);color:var(--color-coral)}.menu-review-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#2a1f1480;z-index:1100;display:flex;align-items:stretch;justify-content:flex-end}.menu-review-panel{background:var(--color-white);width:100%;max-width:680px;display:flex;flex-direction:column;overflow:hidden;box-shadow:-4px 0 32px #2a1f1426}.review-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-md);padding:var(--spacing-lg) var(--spacing-xl);border-bottom:1px solid var(--color-border);background:var(--color-white);flex-shrink:0}.review-header__title{font-size:1.25rem;font-weight:700;margin:0;color:var(--color-deep-brown);font-family:var(--font-display)}.review-header__subtitle{font-size:.875rem;color:var(--color-body-brown);margin-top:2px}.review-header__right{display:flex;align-items:center;gap:var(--spacing-sm);flex-shrink:0}.regen-cap-badge{font-size:.75rem;font-weight:600;background:var(--color-border-light);color:var(--color-body-brown);border-radius:var(--radius-pill);padding:.25rem .625rem;white-space:nowrap}.regen-cap-badge--exhausted{background:#fff3cd;color:#856404}.regen-cap-banner{background:#fff3cd;color:#664d03;border-left:4px solid var(--warning);padding:var(--spacing-sm) var(--spacing-lg);font-size:.875rem;flex-shrink:0}.review-refine-error{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-sm);margin:var(--spacing-sm) var(--spacing-lg) 0;border-radius:var(--radius-md)}.btn-close--small{font-size:.75rem;width:1.5rem;height:1.5rem;flex-shrink:0}.review-recipe-list{flex:1;overflow-y:auto;padding:var(--spacing-md) var(--spacing-lg);display:flex;flex-direction:column;gap:var(--spacing-md)}.review-footer{border-top:1px solid var(--color-border);padding:var(--spacing-md) var(--spacing-xl);background:var(--color-cream);flex-shrink:0}.review-footer__summary{font-size:.875rem;color:var(--color-body-brown);margin-bottom:var(--spacing-sm)}.review-footer__actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end}.finalize-btn:disabled{opacity:.5;cursor:not-allowed}.recipe-review-card{background:var(--color-white);border:2px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-md);position:relative;transition:border-color .2s ease}.recipe-review-card--approved{border-color:var(--success);background:#f6fff8}.recipe-review-card--rejected{border-color:var(--danger);background:var(--color-coral-light);opacity:.7}.recipe-review-card--refining{pointer-events:none}.recipe-review-card__loading{position:absolute;top:0;right:0;bottom:0;left:0;background:#ffffffd9;border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);z-index:2;font-size:.875rem;color:var(--color-body-brown)}.spinner--small{width:20px;height:20px;border-width:2px}.recipe-review-card__header{display:flex;flex-direction:column;gap:4px;margin-bottom:var(--spacing-sm)}.recipe-review-card__title-row{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--spacing-sm)}.recipe-review-card__name{font-size:1rem;font-weight:600;margin:0;color:var(--color-deep-brown);font-family:var(--font-display);line-height:1.3}.recipe-review-card__cuisine{font-size:.75rem;color:var(--color-body-brown);text-transform:capitalize}.recipe-review-card__meta{display:flex;flex-wrap:wrap;gap:var(--spacing-sm);font-size:.8125rem;color:var(--color-body-brown)}.recipe-review-card__description{font-size:.875rem;color:var(--color-body-brown);line-height:1.5;margin-bottom:var(--spacing-sm);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.review-status-badge{font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em;border-radius:var(--radius-pill);padding:.2rem .6rem;white-space:nowrap;flex-shrink:0}.review-status-badge--pending{background:var(--color-border-light);color:var(--color-body-brown)}.review-status-badge--approved{background:#d1fae5;color:#065f46}.review-status-badge--rejected{background:var(--color-coral-light);color:var(--color-coral-dark)}.review-actions{display:flex;gap:var(--spacing-xs);flex-wrap:wrap;margin-top:var(--spacing-sm)}.review-action-btn{display:inline-flex;align-items:center;gap:4px;font-size:.8125rem;font-weight:500;border:none;border-radius:var(--radius-md);padding:.375rem .75rem;cursor:pointer;transition:var(--transition);font-family:var(--font-ui)}.review-action-btn:disabled{opacity:.4;cursor:not-allowed}.review-action-btn--approve{background:#d1fae5;color:#065f46}.review-action-btn--approve:not(:disabled):hover{background:#a7f3d0}.review-action-btn--modify{background:#dbeafe;color:#1e40af}.review-action-btn--modify:not(:disabled):hover{background:#bfdbfe}.review-action-btn--replace{background:var(--color-coral-light);color:var(--color-coral-dark)}.review-action-btn--replace:not(:disabled):hover{background:#f0c9bd}.review-feedback-area{margin-top:var(--spacing-sm);background:var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-sm) var(--spacing-md)}.review-feedback-area__label{font-size:.8125rem;font-weight:600;color:var(--color-deep-brown);margin-bottom:var(--spacing-xs)}.review-feedback-area__input{width:100%;padding:var(--spacing-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:.875rem;font-family:var(--font-ui);resize:vertical;background:var(--color-white);color:var(--color-deep-brown)}.review-feedback-area__input:focus{outline:none;border-color:var(--color-coral);box-shadow:0 0 0 2px var(--color-coral-light)}.review-feedback-area__actions{display:flex;gap:var(--spacing-sm);margin-top:var(--spacing-sm)}.regen-cap-inline{font-size:.75rem;color:#856404;background:#fff3cd;border-radius:var(--radius-sm);padding:.25rem .5rem;margin-top:var(--spacing-xs)}.btn-sm{font-size:.8125rem;padding:.375rem .75rem}@media(max-width:640px){.menu-review-overlay{align-items:flex-end}.menu-review-panel{max-width:100%;max-height:92vh;border-radius:var(--radius-xl) var(--radius-xl) 0 0}.review-header{padding:var(--spacing-md)}.review-recipe-list,.review-footer{padding:var(--spacing-sm) var(--spacing-md)}}.onboarding-shell{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-cream);overflow-y:auto;z-index:200;padding:var(--spacing-xl) var(--spacing-md)}.onboarding-card{background:var(--color-white);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:520px;margin:0 auto;padding:var(--spacing-2xl) var(--spacing-xl)}.onboarding-header{text-align:center;margin-bottom:var(--spacing-xl)}.onboarding-logo{height:32px;width:auto}.onboarding-progress{display:flex;justify-content:center;gap:8px;margin-bottom:var(--spacing-xl)}.onboarding-dot{width:10px;height:10px;border-radius:50%;background:var(--color-border);transition:background .2s ease}.onboarding-dot.active{background:var(--color-coral);transform:scale(1.2)}.onboarding-dot.done{background:var(--color-coral-border)}.onboarding-body{min-height:320px}.onboarding-step{display:flex;flex-direction:column;gap:var(--spacing-lg)}.onboarding-title{font-family:var(--font-display);font-size:1.75rem;color:var(--color-deep-brown);margin-bottom:0}.onboarding-subtitle{color:var(--color-body-brown);margin-bottom:0}.onboarding-form{display:flex;flex-direction:column;gap:var(--spacing-lg)}.form-section-label{display:block;font-weight:600;color:var(--color-deep-brown);margin-bottom:var(--spacing-xs)}.form-hint{font-size:.875rem;color:var(--color-muted);margin-bottom:var(--spacing-sm)}.form-row{display:flex;gap:var(--spacing-md)}.form-row .form-group{flex:1}.form-input-narrow{max-width:100px}.onboarding-actions{display:flex;gap:var(--spacing-sm);justify-content:flex-end;margin-top:var(--spacing-md)}.onboarding-actions .btn-secondary{min-width:80px}.onboarding-skip{text-align:center;margin-top:var(--spacing-sm)}.btn-link{background:none;border:none;color:var(--color-coral);cursor:pointer;font-size:.875rem;text-decoration:underline;padding:0}.btn-link:disabled{opacity:.5;cursor:not-allowed}.btn-icon{background:none;border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-muted);cursor:pointer;padding:0 var(--spacing-sm);font-size:.75rem;height:38px;line-height:1;flex-shrink:0}.btn-icon:hover{background:var(--color-border-light);color:var(--color-body-brown)}.invite-row{display:flex;gap:var(--spacing-sm);align-items:center}.invite-row .form-input{flex:1}.input-error{border-color:var(--color-coral)!important}.form-error{color:var(--color-coral);font-size:.875rem;margin:0}.optional{font-weight:400;color:var(--color-muted);font-size:.875em}.celebration-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-cream);display:flex;align-items:center;justify-content:center;z-index:300}.celebration-content{text-align:center;padding:var(--spacing-2xl)}.celebration-icon{font-size:4rem;margin-bottom:var(--spacing-lg);animation:celebrate-pop .4s ease-out}.celebration-title{font-family:var(--font-display);font-size:2.25rem;color:var(--color-deep-brown);margin-bottom:var(--spacing-md)}.celebration-subtitle{color:var(--color-body-brown);font-size:1.1rem}@keyframes celebrate-pop{0%{transform:scale(.5);opacity:0}70%{transform:scale(1.15)}to{transform:scale(1);opacity:1}}@media(prefers-reduced-motion:reduce){.celebration-icon{animation:none}.onboarding-dot{transition:none}}
