:root{--bg:#faf6ee;--surface:#fff;--border:#e8decb;--text:#2b2419;--text-muted:#7d7261;--accent:#c2632e;--accent-hover:#a14f22;--accent-bg:#c2632e1a;--accent-gradient:linear-gradient(135deg, #dd8141 0%, #b2531f 100%);--secondary:#2c6b6f;--secondary-hover:#204e51;--secondary-bg:#2c6b6f1a;--secondary-gradient:linear-gradient(135deg, #3d8c87 0%, #1f4d50 100%);--info:#3d6680;--info-bg:#3d66801a;--success:#3f7d52;--success-bg:#3f7d521a;--warning:#c2933f;--danger:#ad3a2e;--danger-bg:#ad3a2e14;--radius:14px;--shadow:0 1px 2px #28190a0a, 0 6px 18px #28190a0f;--sans:"Plus Jakarta Sans", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;--serif:"Fraunces", Georgia, "Times New Roman", serif;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:var(--text);background:var(--bg);font:16px/1.5 var(--sans);-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0}#root{min-height:100svh}h1,h2,h3{letter-spacing:-.01em;margin:0;font-weight:600}button{font:inherit;cursor:pointer}input,select,textarea{font:inherit}a{color:var(--accent);text-decoration:none}.btn{cursor:pointer;white-space:nowrap;border:none;border-radius:999px;justify-content:center;align-items:center;gap:8px;padding:12px 22px;font-size:14px;font-weight:600;text-decoration:none;transition:transform .15s,box-shadow .2s,background .15s,border-color .15s,opacity .15s;display:inline-flex}.btn:hover{transform:translateY(-1px)}.btn:active{transform:translateY(0)}.btn:disabled{opacity:.55;cursor:default;transform:none}.btn-sm{padding:8px 14px;font-size:13px}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 10px #b253204d}.btn-primary:hover{box-shadow:0 8px 20px #b2532061}.btn-secondary{background:var(--secondary-gradient);color:#fff;box-shadow:0 2px 10px #204f514d}.btn-secondary:hover{box-shadow:0 8px 20px #204f515c}.btn-ghost{background:var(--surface);color:var(--text);border:1px solid var(--border)}.btn-ghost:hover{background:var(--bg);border-color:var(--text-muted)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#8a2e24}.btn-text{color:var(--secondary);background:0 0;border:none;padding:0;font-weight:600}.btn-text:hover{color:var(--secondary-hover)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}.card-hover{transition:transform .2s,box-shadow .2s,border-color .2s}.card-hover:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:0 10px 26px #28190a1a}.text-input{border:1px solid var(--border);background:var(--bg);border-radius:10px;outline:none;width:100%;padding:11px 14px;font-size:14px;transition:border-color .15s,box-shadow .15s}.text-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-bg)}.static-field{border:1px solid var(--border);background:var(--bg);width:100%;color:var(--text-muted);border-radius:10px;align-items:center;padding:11px 14px;font-size:14px;font-weight:600;display:flex}.field-label{color:var(--text-muted);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.link-muted{color:var(--text-muted);transition:color .15s}.link-muted:hover{color:var(--text)}.gradient-text{background-image:linear-gradient(100deg, var(--accent) 0%, #e3934f 25%, var(--secondary) 55%, var(--accent) 85%);color:#0000;background-size:250%;-webkit-background-clip:text;background-clip:text;animation:9s infinite gradientTextMove}@keyframes gradientTextMove{0%{background-position:0%}50%{background-position:100%}to{background-position:0%}}.page-fade-in{animation:.4s both pageFadeIn}@keyframes pageFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media (prefers-reduced-motion:reduce){.gradient-text,.page-fade-in{animation:none}}.calendar-week-slide-next{animation:.32s cubic-bezier(.22,1,.36,1) both calendarSlideNext}.calendar-week-slide-prev{animation:.32s cubic-bezier(.22,1,.36,1) both calendarSlidePrev}@keyframes calendarSlideNext{0%{transform:translate(28px)}to{transform:translate(0)}}@keyframes calendarSlidePrev{0%{transform:translate(-28px)}to{transform:translate(0)}}@media (prefers-reduced-motion:reduce){.calendar-week-slide-next,.calendar-week-slide-prev{animation:none}}.calendar-week-nav{justify-content:center;align-items:center;gap:10px;margin-top:28px;display:flex}.calendar-nav-btn{cursor:pointer;border:1px solid #0000;border-radius:999px;align-items:center;gap:6px;padding:10px 18px;font-size:13px;font-weight:600;transition:transform .15s,box-shadow .2s,background .15s,color .15s,opacity .15s;display:inline-flex}.calendar-nav-btn:active:not(:disabled){transform:translateY(0)scale(.97)}.calendar-nav-btn--solid{background:var(--accent-gradient);color:#fff;box-shadow:0 2px 10px #b253204d}.calendar-nav-btn--solid:hover{transform:translateY(-1px);box-shadow:0 8px 18px #b2532066}.calendar-nav-btn--soft{background:var(--accent-bg);color:var(--accent);border-color:#b2532038}.calendar-nav-btn--soft:hover:not(:disabled){background:var(--accent-gradient);color:#fff;border-color:#0000;transform:translateY(-1px)}.calendar-nav-btn--soft:disabled{opacity:.45;cursor:default}.settings-avatar-button{background:var(--accent-gradient);cursor:pointer;border:none;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:72px;height:72px;padding:0;display:flex;position:relative;overflow:hidden}.settings-avatar-img{object-fit:cover;width:100%;height:100%;display:block}.settings-avatar-fallback{color:#fff;font-size:26px;font-weight:700}.settings-avatar-edit{color:#fff;text-transform:uppercase;letter-spacing:.4px;opacity:0;background:#140e068c;padding:4px 0;font-size:10px;font-weight:600;transition:opacity .15s;position:absolute;inset:auto 0 0}.settings-avatar-button:hover .settings-avatar-edit,.settings-avatar-button:focus-visible .settings-avatar-edit{opacity:1}.settings-stepper{border:1px solid var(--border);background:var(--surface);border-radius:50%;width:28px;height:28px;font-size:15px}.settings-stepper:hover{border-color:var(--accent);color:var(--accent)}.nav-link{color:var(--text-muted);border-radius:10px;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:background .15s,color .15s,transform .15s;display:flex}.nav-link:hover{background:var(--accent-bg);color:var(--accent);transform:translate(2px)}.nav-link.active{background:var(--accent-bg);color:var(--accent);font-weight:600}.dashboard-hero{position:relative}.dashboard-gradient{background:var(--accent-gradient);opacity:.12;filter:blur(40px);z-index:-1;border-radius:0 0 60% 60%/0 0 100% 100%;height:280px;position:absolute;top:-32px;left:-32px;right:-32px}.dashboard-greeting{padding:8px 0 28px}.dashboard-greeting-sub{text-transform:uppercase;letter-spacing:.6px;color:var(--text-muted);margin-bottom:6px;font-size:13px;font-weight:600}.dashboard-greeting-headline{letter-spacing:-.5px;margin:0;font-size:clamp(28px,4vw,42px);font-weight:800}.dashboard-greeting-actions{flex-wrap:wrap;gap:12px;margin-top:20px;display:flex}.dashboard-members-card{padding:22px}.dashboard-card-heading{text-transform:uppercase;letter-spacing:.5px;color:var(--accent);align-items:baseline;gap:8px;margin-bottom:14px;font-size:13px;font-weight:700;display:flex}.dashboard-card-count{background:var(--accent-bg);color:var(--accent);border-radius:999px;padding:1px 9px;font-size:11px}.dashboard-member-list{flex-direction:column;display:flex}.dashboard-member-row{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:11px 4px;display:flex}.dashboard-member-row:last-child{border-bottom:none}.dashboard-member-avatar{background:var(--accent-gradient);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:14px;font-weight:700;display:flex;overflow:hidden}.dashboard-member-avatar img{object-fit:cover;width:100%;height:100%}.dashboard-member-name{text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.dashboard-member-email{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}.prep-layout{grid-template-columns:220px 1fr;align-items:start;gap:24px;display:grid}@media (width<=860px){.prep-layout{grid-template-columns:1fr}}.prep-picker{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;gap:6px;padding:14px;display:flex}.prep-picker-day{justify-content:space-between;align-items:center;padding:6px 4px;display:flex}.prep-picker-day-label{text-transform:uppercase;color:var(--text-muted);width:36px;font-size:13px;font-weight:600}.prep-picker-slots{gap:6px;display:flex}.prep-slot-btn{border:1px solid var(--border);background:var(--bg);opacity:.45;border-radius:10px;justify-content:center;align-items:center;width:34px;height:34px;font-size:15px;transition:transform .15s,opacity .15s,border-color .15s,background .15s;display:flex}.prep-slot-btn.filled{opacity:1;background:var(--accent-bg)}.prep-slot-btn:hover{border-color:var(--accent);transform:translateY(-1px)}.prep-slot-btn.selected{background:var(--accent-gradient);opacity:1;border-color:#0000;box-shadow:0 4px 12px #b2532059}.prep-detail{min-width:0}.prep-recipe-card{padding:28px}.prep-recipe-header{border-bottom:1px solid var(--border);margin-bottom:20px;padding-bottom:20px}.prep-stat-grid{grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:24px;display:grid}.prep-stat{background:var(--bg);text-align:center;border-radius:10px;padding:10px 6px}.prep-two-col{grid-template-columns:1.1fr 1fr;gap:32px;display:grid}@media (width<=640px){.prep-two-col{grid-template-columns:1fr;gap:24px}.prep-stat-grid{grid-template-columns:repeat(2,1fr)}}.prep-ingredient-row{border-bottom:1px solid var(--border);justify-content:space-between;gap:12px;padding:8px 0;font-size:13px;display:flex}.prep-ingredient-meta{white-space:nowrap;color:var(--text-muted);flex-shrink:0;align-items:center;gap:8px;font-weight:600;display:flex}.prep-store-pill{background:var(--secondary-bg);color:var(--secondary);border-radius:999px;padding:2px 8px;font-size:11px;font-weight:600}.prep-cost-summary{border-top:1px solid var(--border);margin-top:16px;padding-top:14px}.prep-cost-row{color:var(--text-muted);justify-content:space-between;padding:3px 0;font-size:13px;display:flex}.prep-cost-row.accent{color:var(--accent);font-weight:600}.prep-instructions{flex-direction:column;gap:12px;margin:10px 0 0;padding-left:20px;font-size:14px;line-height:1.5;display:flex}.prep-instructions li{padding-left:4px}.recipe-options-grid{grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:16px;margin-top:24px;display:grid}.recipe-option-card{flex-direction:column;padding:0;display:flex;overflow:hidden}.recipe-option-image{object-fit:cover;background:var(--bg);width:100%;height:140px;display:block}.recipe-option-body{flex-direction:column;flex:1;padding:16px 18px 18px;display:flex}.recipe-option-title{flex:1;margin-bottom:10px;font-size:16px;font-weight:700;line-height:1.3}.btn-icon{cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:2px;display:inline-flex}.btn-icon:hover{background:var(--bg)}.btn-icon:disabled{cursor:default}.recipe-option-stats{grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:14px;display:grid}.recipe-option-stat{background:var(--bg);text-align:center;border-radius:8px;padding:7px 4px}.recipe-option-stat strong{font-size:13px;display:block}.recipe-option-stat span{color:var(--text-muted);font-size:10px}.recipe-option-ingredients{color:var(--text-muted);max-height:92px;margin-bottom:14px;font-size:12.5px;line-height:1.5;overflow-y:auto}.recipe-option-ingredients div{overflow-wrap:anywhere;padding:2px 0}.recipe-option-cost{border-top:1px solid var(--border);justify-content:space-between;align-items:baseline;margin-top:auto;margin-bottom:14px;padding-top:12px;display:flex}.recipe-option-cost-per{color:var(--accent);font-size:18px;font-weight:700}.recipe-option-cost-total{color:var(--text-muted);font-size:12px}.landing-page{isolation:isolate;flex-direction:column;min-height:100svh;display:flex;position:relative;overflow-x:hidden}.landing-gradient{z-index:-1;filter:blur(60px);background-image:radial-gradient(closest-side,#c2632e52,#0000),radial-gradient(closest-side,#2c6b6f3d,#0000),radial-gradient(closest-side,#e3934f42,#0000);background-position:10% 20%,85% 15%,60% 80%;background-repeat:no-repeat;background-size:55% 55%,50% 50%,45% 45%;animation:22s ease-in-out infinite alternate landingGradientMove;position:fixed;inset:-10%}@keyframes landingGradientMove{0%{background-position:80% 10%,10% 90%}50%{background-position:65% 30%,25% 70%}to{background-position:85% 5%,15% 95%}}@media (prefers-reduced-motion:reduce){.landing-gradient{animation:none}}.landing-header{justify-content:space-between;align-items:center;width:100%;max-width:1080px;margin:0 auto;padding:24px 20px;display:flex}.landing-logo-link{text-decoration:none;display:inline-flex}.landing-signin-btn{color:var(--accent);-webkit-backdrop-filter:blur(10px);background:#fffcf68c;border:1px solid #b253204d;border-radius:999px;align-items:center;padding:10px 20px;font-size:14px;font-weight:600;text-decoration:none;transition:background .15s,color .15s,box-shadow .2s,transform .15s;display:inline-flex}.landing-signin-btn:hover{background:var(--accent-gradient);color:#fff;border-color:#0000;transform:translateY(-1px);box-shadow:0 6px 16px #b2532052}.landing-hero{flex:1;justify-content:center;align-items:center;padding:40px 20px 100px;display:flex}.landing-hero-inner{text-align:center;max-width:720px;margin:0 auto}.landing-headline{font-family:var(--sans);letter-spacing:-.02em;margin:0;padding-bottom:.08em;font-size:clamp(38px,6.6vw,64px);font-weight:800;line-height:1.2}.landing-subhead{color:var(--text-muted);max-width:480px;margin:22px auto 0;font-size:18px}.landing-cta-row{justify-content:center;margin-top:48px;display:flex}.landing-footer{text-align:center;color:var(--text-muted);padding:0 20px 48px;font-size:13px}.cta-splotch{justify-content:center;align-items:center;width:210px;height:210px;text-decoration:none;display:inline-flex;position:relative}.cta-splotch-shape{filter:drop-shadow(0 14px 28px #b2532066);width:100%;height:100%;transition:transform .25s,filter .25s;position:absolute;inset:0}.cta-splotch:hover .cta-splotch-shape{filter:drop-shadow(0 18px 36px #b253207a);transform:scale(1.06)rotate(-2deg)}.cta-splotch:active .cta-splotch-shape{transform:scale(.97)rotate(0)}.cta-splotch-text{z-index:2;letter-spacing:-.01em;text-align:center;background:linear-gradient(#fff 0%,#ffe9d3 100%);color:#0000;text-shadow:0 1px #ffffff80,0 -1px 1px #782d0a4d,0 3px 5px #5a1e0566;-webkit-background-clip:text;background-clip:text;max-width:110px;font-size:17px;font-weight:700;line-height:1.15;position:relative}@media (width<=480px){.cta-splotch{width:172px;height:172px}}.auth-shell{grid-template-columns:minmax(0,1fr) minmax(0,1fr);min-height:100svh;display:grid}.auth-brand-side{background:var(--accent-gradient);color:#fff8ee;isolation:isolate;flex-direction:column;justify-content:space-between;padding:48px;display:flex;position:relative;overflow:hidden}.auth-brand-side:before{content:"";z-index:-1;background-image:radial-gradient(closest-side,#ffffff29,#0000),radial-gradient(closest-side,#2c6b6f66,#0000);background-position:80% 10%,10% 90%;background-repeat:no-repeat;background-size:60% 60%,50% 50%;animation:22s ease-in-out infinite alternate landingGradientMove;position:absolute;inset:-30%}.auth-form-side{justify-content:center;align-items:center;padding:32px;display:flex}@media (prefers-reduced-motion:reduce){.auth-brand-side:before{animation:none}}@media (width<=760px){.auth-shell{grid-template-columns:1fr}.auth-brand-side{min-height:220px;padding:32px 28px}}.app-shell{min-height:100svh;display:flex}.app-sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;gap:4px;width:220px;padding:24px 16px;display:flex}.app-sidebar-logo{color:inherit;width:fit-content;padding:0 10px 24px;text-decoration:none;display:block}.app-sidebar-plan{color:var(--text-muted);text-overflow:ellipsis;white-space:nowrap;padding:0 10px 18px;font-size:13px;overflow:hidden}.app-sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding-top:16px}.app-main{flex:1;min-width:0;padding:36px 40px 64px}@media (width<=760px){.app-shell{flex-direction:column}.app-sidebar{border-right:none;border-bottom:1px solid var(--border);flex-direction:row;align-items:center;gap:6px;width:100%;padding:14px 16px;overflow-x:auto}.app-sidebar-logo{padding:0 10px 0 0}.app-sidebar-plan{display:none}.app-sidebar-footer{border-top:none;margin-top:0;margin-left:auto;padding-top:0}.app-main{padding:24px 18px 48px}}
