:root{font-family:Space Grotesk,system-ui,sans-serif;color:#1f1b16;background-color:#f9f4ef;--charcoal: #1b1713;--smoke: #2b2520;--cream: #f9f4ef;--sand: #efe4d6;--paprika: #d96a3a;--tamarind: #b1452e;--sage: #4b6b5a;--gold: #f1b85b;--white: #ffffff;--forest: #2d6a4f;--danger: #dc3545;--radius-xl: 28px;--radius-lg: 20px;--radius-md: 14px;--shadow: 0 30px 60px rgba(27, 23, 19, .15)}*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}html{scroll-behavior:smooth}body{margin:0;background:radial-gradient(circle at top left,#f1e7d7,#f9f4ef 45%),radial-gradient(circle at 80% -10%,#f6d6c8,#f9f4ef 60%);min-height:100vh;overscroll-behavior-y:none}.app{position:relative;padding:36px clamp(20px,5vw,64px) 64px;min-height:100vh}.app:before,.app:after{content:"";position:absolute;border-radius:999px;filter:blur(0px);z-index:0;opacity:.35}.app:before{width:420px;height:420px;background:#f1b85b;top:-140px;right:-120px}.app:after{width:320px;height:320px;background:#cfe3d6;bottom:60px;left:-160px}.topbar{position:relative;z-index:10}main,.footer{position:relative;z-index:1}.topbar{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:12px 0 32px}.brand{display:flex;align-items:center;gap:14px}.brand-mark{display:grid;place-items:center;width:48px;height:48px;border-radius:16px;background:var(--charcoal);color:var(--cream);font-family:Fraunces,serif;font-size:26px}.brand-name{margin:0;font-weight:700;font-size:18px}.brand-subtitle{margin:0;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:#1f1b16a6}.nav{display:flex;gap:10px;flex-wrap:wrap}.nav-link{border:none;background:#ffffffb3;font-size:14px;font-weight:600;color:var(--smoke);cursor:pointer;padding:10px 18px;border-radius:999px;box-shadow:inset 0 0 0 1px #1f1b1614;transition:all .2s ease;text-decoration:none}.actions{display:flex;align-items:center;gap:12px}button,.primary,.secondary,.ghost,.danger{font-family:inherit;border:none;border-radius:999px;padding:12px 20px;font-weight:600;font-size:15px;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,opacity .15s ease,background .15s ease;will-change:transform;outline:none;position:relative;overflow:hidden}button:hover:not(:disabled),.primary:hover:not(:disabled),.secondary:hover:not(:disabled),.ghost:hover:not(:disabled),.danger:hover:not(:disabled){transform:translateY(-1px)}button:active:not(:disabled),.primary:active:not(:disabled),.secondary:active:not(:disabled),.ghost:active:not(:disabled),.danger:active:not(:disabled){transform:scale(.96);transition-duration:.06s}button:focus-visible,.primary:focus-visible,.secondary:focus-visible,.ghost:focus-visible,.danger:focus-visible{outline:2px solid var(--paprika);outline-offset:2px}button:disabled,.primary:disabled,.secondary:disabled,.ghost:disabled,.danger:disabled{opacity:.55;cursor:not-allowed;transform:none}.primary{background:linear-gradient(135deg,var(--paprika),var(--tamarind));color:var(--white);box-shadow:0 14px 30px #d96a3a59}.primary:hover:not(:disabled){box-shadow:0 16px 34px #d96a3a66}.primary:active:not(:disabled){box-shadow:0 6px 16px #d96a3a4d}.secondary{background:var(--charcoal);color:var(--cream);box-shadow:0 12px 24px #1b171333}.secondary:hover:not(:disabled){background:var(--smoke);box-shadow:0 14px 28px #1b171340}.secondary:active:not(:disabled){box-shadow:0 4px 12px #1b171333}.ghost{background:transparent;color:var(--smoke);box-shadow:inset 0 0 0 1px #1f1b1626}.ghost:hover:not(:disabled){background:#1f1b160a;box-shadow:inset 0 0 0 1px #1f1b1633}.ghost:active:not(:disabled){background:#1f1b1614}.danger{background:#dc3545;color:var(--white);box-shadow:0 12px 24px #dc35454d}.danger:hover:not(:disabled){background:#c82333;box-shadow:0 14px 28px #dc354559}.danger:active:not(:disabled){box-shadow:0 4px 12px #dc35454d}.hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:32px;align-items:center;padding:40px 0 64px}.hero-copy h1{font-family:Fraunces,serif;font-size:clamp(36px,4vw,56px);margin:8px 0 16px}.eyebrow{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#1f1b1699}.hero-lede{font-size:18px;max-width:560px;line-height:1.6}.hero-cta{display:flex;flex-wrap:wrap;gap:12px;margin:24px 0 30px}.hero-stats{display:flex;gap:28px}.hero-stats h3{margin:0;font-size:28px}.hero-stats p{margin:4px 0 0;color:#1f1b16a6}.hero-card{background:#fffc;padding:28px;border-radius:var(--radius-xl);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:grid;gap:16px}.badge{display:inline-flex;padding:6px 14px;border-radius:999px;background:#d96a3a1f;color:var(--paprika);font-weight:600;font-size:12px}.meta{display:flex;gap:18px;font-size:14px;color:#1f1b16b3}.progress{display:grid;gap:8px}.progress-bar{height:8px;border-radius:999px;background:linear-gradient(90deg,var(--paprika),var(--gold))}.section{padding:48px 0;display:grid;gap:24px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:16px}.section-header h2{margin:0;font-family:Fraunces,serif;font-size:28px}.card-grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(240px,300px))}.recipe-card{background:var(--white);border-radius:var(--radius-lg);padding:20px;display:grid;gap:12px;box-shadow:0 16px 30px #1b17131f}.card-top h3{margin:0;font-size:18px}.card-top p{margin:6px 0 0;color:#1f1b16b3}.card-meta{display:flex;justify-content:space-between;font-size:13px;color:#1f1b1699}.tag-row{display:flex;flex-wrap:wrap;gap:8px}.tag-row span{background:#1f1b1614;padding:4px 10px;border-radius:999px;font-size:12px}.split{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));align-items:start}.tech-grid{display:grid;gap:16px;margin-top:20px}.tech-card{padding:18px;border-radius:var(--radius-md);background:#1f1b160a;display:grid;gap:8px}.tech-card span{font-size:12px;color:var(--paprika);font-weight:600}.pantry{background:var(--charcoal);color:var(--cream);padding:28px;border-radius:var(--radius-xl);display:grid;gap:16px;box-shadow:0 20px 40px #1b171340}.pantry-list{display:grid;gap:12px}.pantry-item{background:#ffffff14;padding:12px 14px;border-radius:14px}.latest-grid{display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.latest-card{background:var(--sand);border-radius:var(--radius-lg);padding:18px;display:grid;gap:18px}.latest-meta{display:flex;justify-content:space-between;font-size:13px;color:#1f1b1699}.menu{background:#ffffffbf;border-radius:var(--radius-xl);padding:32px;box-shadow:var(--shadow)}.menu-grid{display:grid;gap:12px;margin-top:20px}.menu-card{display:grid;grid-template-columns:48px 1fr;gap:12px;align-items:center;background:#1f1b160f;border-radius:16px;padding:12px 16px}.menu-day{display:grid;place-items:center;width:48px;height:48px;border-radius:14px;background:var(--paprika);color:var(--white);font-weight:700}.footer{margin-top:40px;padding:28px;border-radius:var(--radius-lg);background:var(--smoke);color:var(--cream);display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px}.footer h3{margin:0 0 6px;font-family:Fraunces,serif}@media (max-width: 900px){.topbar{flex-direction:column;align-items:flex-start}.hero-stats{flex-wrap:wrap}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.section-header button{align-self:stretch;width:100%}.section{padding-bottom:80px}}@media (max-width: 640px){.actions{width:100%;justify-content:flex-start}.kebab-menu{right:auto;left:0}.hero{padding-top:20px}.slot-label{font-size:12px}.slot-meal{font-size:14px}.meal-cook-count{font-size:13px}.meal-card-meta{font-size:14px}.filter-row{gap:12px}.empty-state-icon{font-size:48px}.menu{padding:24px}}.nav-active{background:var(--charcoal);color:var(--cream);box-shadow:0 2px 8px #1b171326}.nav-user{display:flex;align-items:center;gap:8px;font-weight:600;font-size:14px;color:var(--smoke)}.kebab-wrapper{position:relative}.kebab-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;width:48px;height:48px;border-radius:999px;background:transparent;border:none;cursor:pointer;padding:0;box-shadow:none;transition:background .15s ease}.kebab-btn:hover{background:#1f1b1614}.kebab-btn:active{transform:none}.kebab-dot{width:5px;height:5px;border-radius:999px;background:var(--smoke)}.kebab-menu{position:absolute;top:calc(100% + 8px);right:0;background:var(--white);border-radius:var(--radius-lg);box-shadow:0 16px 40px #1b17132e;min-width:180px;padding:8px 0;z-index:100;animation:kebab-fade-in .15s ease}@keyframes kebab-fade-in{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.kebab-menu-user{padding:10px 18px 8px;font-size:13px;font-weight:700;color:#1f1b1680;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid rgba(31,27,22,.08);margin-bottom:4px}.kebab-menu-item{display:block;width:100%;padding:10px 18px;font-size:15px;font-weight:500;color:var(--smoke);background:transparent;border:none;border-radius:0;box-shadow:none;text-align:left;text-decoration:none;cursor:pointer;font-family:inherit;transition:background .12s ease}.kebab-menu-item:hover{background:#1f1b160d}.kebab-menu-item:active{transform:none}.kebab-menu-signout{color:var(--tamarind)}.recipe-card-img{width:100%;height:160px;object-fit:cover;border-radius:var(--radius-md)}.recipe-card-imgwrap{width:100%;height:160px;border-radius:var(--radius-md);background:var(--sand);overflow:hidden}.search-bar{display:flex;gap:12px;margin-bottom:8px}.search-input{flex:1;border:1px solid rgba(31,27,22,.12);border-radius:999px;padding:12px 20px;font-family:inherit;font-size:16px;background:var(--white);color:var(--charcoal);outline:none;transition:border-color .15s ease}.search-input:focus{border-color:var(--paprika)}.search-input::placeholder{color:#1f1b1666}.filter-row{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.filter-label{font-size:13px;font-weight:600;color:#1f1b1699;margin-right:4px}.filter-chip{border:none;background:#1f1b1612;color:var(--smoke);padding:6px 14px;border-radius:999px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .15s ease,color .15s ease}.filter-chip:hover{background:#1f1b161f}.filter-chip:active{transform:none}.filter-active{background:var(--paprika);color:var(--white)}.filter-active:hover{background:var(--tamarind)}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:12px}.page-info{font-size:14px;color:#1f1b16a6}.loading-text{text-align:center;color:#1f1b168c;padding:40px 0;font-size:16px}.recipe-detail-header{display:flex;flex-direction:column;gap:12px}.recipe-detail-header h2{font-family:Fraunces,serif;font-size:32px;margin:0}.recipe-hero-img{width:100%;max-height:400px;object-fit:cover;border-radius:var(--radius-xl);animation:imgFadeIn .4s ease}@keyframes shimmer{0%{background-position:-600px 0}to{background-position:600px 0}}@keyframes imgFadeIn{0%{opacity:0}to{opacity:1}}.recipe-hero-shimmer{width:100%;height:260px;border-radius:var(--radius-xl);background:linear-gradient(90deg,#1f1b160f 25%,#1f1b161f,#1f1b160f 75%);background-size:600px 100%;animation:shimmer 1.5s infinite ease-in-out}.meal-card-img-shimmer{width:100%;height:180px;background:linear-gradient(90deg,#1f1b160f 25%,#1f1b161f,#1f1b160f 75%);background-size:600px 100%;animation:shimmer 1.5s infinite ease-in-out}.recipe-detail-info{display:flex;flex-wrap:wrap;gap:16px;margin-top:4px}.recipe-detail-info .badge{font-size:13px}.recipe-detail-body{display:grid;grid-template-columns:1fr 2fr;gap:32px;margin-top:16px}.recipe-desc{font-size:16px;line-height:1.6;color:#1f1b16cc;margin:0}.recipe-author{font-size:13px;color:#1f1b168c}.ingredients-panel{background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:0 12px 24px #1b171314;align-self:start}.ingredients-panel h3{margin:0 0 16px;font-family:Fraunces,serif;font-size:20px}.ingredient-list{list-style:none;padding:0;margin:0;display:grid;gap:8px}.ingredient-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:var(--radius-md);cursor:pointer;transition:background .15s ease;font-size:14px}.ingredient-item:hover{background:#1f1b160a}.ingredient-checked{text-decoration:line-through;color:#1f1b1666}.ingredient-check{width:28px;height:28px;min-width:28px;border-radius:6px;border:2px solid rgba(31,27,22,.2);display:grid;place-items:center;font-size:14px;flex-shrink:0;transition:border-color .15s ease,background .15s ease}@media (max-width: 640px){.ingredient-item{padding:14px 16px}}.ingredient-checked .ingredient-check{border-color:var(--sage);background:var(--sage);color:var(--white)}.steps-panel h3{margin:0 0 16px;font-family:Fraunces,serif;font-size:20px}.step-list{list-style:none;padding:0;margin:0;display:grid;gap:16px}.step-item{display:flex;gap:16px;padding:16px;background:var(--white);border-radius:var(--radius-lg);box-shadow:0 8px 16px #1b17130f}.step-number{width:36px;height:36px;border-radius:999px;background:var(--paprika);color:var(--white);display:grid;place-items:center;font-weight:700;font-size:14px;flex-shrink:0}.step-content{flex:1}.step-content p{margin:0;font-size:15px;line-height:1.6}.step-timer{display:inline-flex;align-items:center;gap:4px;margin-top:8px;padding:4px 10px;border-radius:999px;background:#f1b85b26;color:#b8860b;font-size:12px;font-weight:600}.back-link{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;color:var(--paprika);text-decoration:none;margin-bottom:8px;transition:color .15s ease}.back-link:hover{color:var(--tamarind)}.tech-link{font-size:13px;font-weight:600;color:var(--paprika);text-decoration:none}.tech-link:hover{color:var(--tamarind)}.auth-page{display:grid;place-items:center;min-height:50vh;padding:48px 0}.auth-card{background:var(--white);border-radius:var(--radius-xl);padding:36px;width:100%;max-width:420px;box-shadow:0 20px 40px #1b17131a;display:grid;gap:12px}.auth-card h2{margin:0;font-family:Fraunces,serif;font-size:24px}.auth-card p{margin:0;color:#1f1b16a6;font-size:14px}.auth-card form{display:grid;gap:12px;margin-top:8px}.auth-input{width:100%;border:1px solid rgba(31,27,22,.12);border-radius:var(--radius-md);padding:12px 16px;font-family:inherit;font-size:16px;background:var(--cream);color:var(--charcoal);outline:none;transition:border-color .15s ease}.auth-input:focus{border-color:var(--paprika)}.pw-input-wrap{position:relative;width:100%}.pw-input-wrap .auth-input{padding-right:44px}.pw-eye-btn{position:absolute;right:4px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;padding:12px;min-width:44px;min-height:44px;color:#1f1b1666;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:color .15s}.pw-eye-btn:hover{color:var(--paprika)}.auth-submit{width:100%;margin-top:4px}.auth-error{background:#d96a3a1a;color:var(--tamarind);padding:10px 14px;border-radius:var(--radius-md);font-size:14px;font-weight:500}.auth-link{text-align:center;font-size:14px}.auth-link a{color:var(--paprika);font-weight:600;text-decoration:none}.auth-link a:hover{color:var(--tamarind)}.auth-hint{font-size:12px;color:#1f1b1680;text-align:center}.remember-row{display:flex;align-items:center;gap:8px;font-size:14px;color:#1f1b16b3;cursor:pointer;-webkit-user-select:none;user-select:none}.remember-row input[type=checkbox]{width:18px;height:18px;accent-color:var(--paprika);cursor:pointer}.create-plan-form{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.create-plan-form .auth-input{width:auto;flex:0 0 auto}.week-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(31,27,22,.2) transparent;position:relative}@media (max-width: 900px){.week-grid:after{content:"→";position:absolute;right:8px;top:50%;transform:translateY(-50%);font-size:24px;color:#1f1b164d;pointer-events:none;animation:scroll-hint 2s ease-in-out 3}@keyframes scroll-hint{0%,to{opacity:.3;transform:translateY(-50%) translate(0)}50%{opacity:.6;transform:translateY(-50%) translate(4px)}}}.week-day{background:var(--white);border-radius:var(--radius-lg);padding:14px;box-shadow:0 8px 16px #1b17130f;min-width:140px}.week-day-header{font-weight:700;font-size:14px;text-align:center;padding:6px;margin-bottom:8px;background:var(--paprika);color:var(--white);border-radius:var(--radius-md)}.week-slot{margin-bottom:10px}.slot-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#1f1b1680;display:block;margin-bottom:4px}.slot-meal{display:flex;align-items:center;justify-content:space-between;gap:4px;padding:6px 8px;background:#d96a3a14;border-radius:8px;font-size:12px;margin-bottom:4px}.slot-meal span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.slot-remove{background:transparent;border:none;color:var(--tamarind);font-size:14px;font-weight:700;cursor:pointer;padding:8px 12px;min-width:44px;min-height:44px;border-radius:4px;line-height:1;display:inline-flex;align-items:center;justify-content:center}.slot-remove:hover{background:#b1452e1a}.slot-remove:active{transform:none}.slot-add{background:transparent;border:1px dashed rgba(31,27,22,.15);color:#1f1b1666;font-size:16px;font-weight:700;cursor:pointer;padding:4px;border-radius:8px;width:100%;text-align:center;transition:border-color .15s ease,color .15s ease}.slot-add:hover{border-color:var(--paprika);color:var(--paprika)}.slot-add:active{transform:none}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1b171366;display:grid;place-items:center;z-index:900;pointer-events:auto}@keyframes modal-overlay-fade-in{0%{opacity:0}to{opacity:1}}.modal-content{background:var(--white);border-radius:var(--radius-xl);padding:28px;width:100%;max-width:420px;box-shadow:0 30px 60px #1b171340;display:grid;gap:12px}.modal-content h3{margin:0;font-family:Fraunces,serif;font-size:20px}.shopping-item-list{list-style:none;padding:0;margin:0;display:grid;gap:6px}.shopping-item{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--white);border-radius:var(--radius-md);box-shadow:0 4px 8px #1b17130a;cursor:pointer;transition:background .15s ease;-webkit-user-select:none;user-select:none}.shopping-item:hover{background:#f9f4efe6}.shopping-checked{opacity:.5}.shopping-checked .shopping-name{text-decoration:line-through}.shopping-check{font-size:18px;width:24px;text-align:center;flex-shrink:0}.shopping-name{flex:1;font-size:15px;font-weight:500}.shopping-qty{font-size:13px;color:#1f1b168c;white-space:nowrap}.shopping-edit-input{flex:1;font-size:15px;font-weight:500;font-family:inherit;padding:4px 8px;border:1.5px solid var(--paprika);border-radius:var(--radius-sm);outline:none;background:var(--cream)}.difficulty-easy{color:var(--sage)}.difficulty-medium{color:var(--gold)}.difficulty-hard{color:var(--tamarind)}@media (max-width: 900px){.recipe-detail-body{grid-template-columns:1fr}.week-grid{grid-template-columns:repeat(3,1fr)}}@media (max-width: 640px){.search-bar{flex-direction:column}.week-grid{grid-template-columns:1fr 1fr}.recipe-detail-header h2{font-size:24px}.section{padding:24px 0;gap:16px}.section-header h2{font-size:22px}}.meal-card{background:var(--white);border-radius:var(--radius-lg);padding:0;display:grid;gap:0;overflow:hidden;box-shadow:0 16px 30px #1b17131f;transition:transform .2s ease,box-shadow .2s ease;will-change:transform}.meal-card-img{width:100%;height:180px;object-fit:cover;display:block;animation:imgFadeIn .4s ease}.meal-card-img-placeholder{width:100%;height:180px;display:flex;align-items:center;justify-content:center;font-size:48px;background:#1f1b160d}.meal-card-body{padding:16px 24px 20px;display:grid;gap:10px}.meal-card:hover{transform:translateY(-3px);box-shadow:0 20px 40px #1b17132e}.meal-card:active{transform:scale(.97);box-shadow:0 8px 20px #1b17131f;transition-duration:.08s}.meal-card-top h3{margin:0;font-size:18px}.meal-nickname{margin:4px 0 0;font-size:13px;color:#1f1b168c;font-style:italic}.meal-card-meta{display:flex;align-items:center;gap:12px}.meal-recipe-badge{font-size:12px;padding:3px 10px;border-radius:999px;background:#1f1b1614;color:#1f1b168c}.meal-recipe-badge.has-recipe{background:#4b6b5a1f;color:var(--sage)}.meal-type-badge{font-size:11px;padding:2px 10px;border-radius:999px;background:#f1b85b26;color:#b8860b;font-weight:600;text-transform:capitalize}.meal-cook-count{margin:0;font-size:12px;color:#1f1b1680}.star-rating{display:inline-flex;gap:2px}.star-filled{color:var(--gold)}.star-empty{color:#1f1b1633}.add-meal-form{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.scan-label{display:inline-flex;align-items:center;justify-content:center;border-radius:999px;padding:12px 20px;font-weight:600;font-size:inherit;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease;-webkit-tap-highlight-color:transparent}.scan-progress{display:flex;align-items:center;gap:12px;padding:16px 20px;background:#d96a3a0f;border-radius:var(--radius-lg);margin-bottom:12px}.scan-progress p{margin:0;font-size:14px;color:var(--charcoal)}.scan-spinner{width:20px;height:20px;border:3px solid rgba(217,106,58,.2);border-top-color:var(--paprika);border-radius:50%;animation:spin .8s linear infinite;flex-shrink:0}.button-spinner{display:inline-block;width:14px;height:14px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite;margin-right:8px;vertical-align:middle}@keyframes spin{to{transform:rotate(360deg)}}.substitution{font-size:12px;color:var(--sage);font-style:italic}.rating-form{background:var(--white);border-radius:var(--radius-lg);padding:24px;box-shadow:0 12px 24px #1b171314;display:grid;gap:12px;max-width:420px;margin-top:12px}.rating-form h3{margin:0;font-family:Fraunces,serif;font-size:18px}.cook-log-list{display:grid;gap:8px}.cook-log-item{padding:12px 16px;background:var(--white);border-radius:var(--radius-md);box-shadow:0 4px 8px #1b17130a}.cook-log-item>div{display:flex;align-items:center;gap:12px;font-size:14px;font-weight:500}.cook-log-item p{margin:6px 0 0;font-size:13px;color:#1f1b1699}.quick-actions{display:flex;gap:16px;flex-wrap:wrap}.quick-action-card{display:flex;align-items:center;gap:12px;padding:18px 24px;background:var(--white);border-radius:var(--radius-lg);box-shadow:0 12px 24px #1b171314;text-decoration:none;color:inherit;font-weight:600;font-size:16px;transition:transform .15s ease,box-shadow .15s ease}.quick-action-card:hover{transform:translateY(-2px);box-shadow:0 16px 32px #1b17131f}.quick-icon{font-size:28px}.most-cooked-card{background:var(--white);border-radius:var(--radius-lg);padding:18px;box-shadow:0 12px 24px #1b171314;transition:transform .15s ease}.most-cooked-card:hover{transform:translateY(-2px)}.most-cooked-card h4{margin:0 0 8px;font-size:16px}.most-cooked-meta{display:flex;align-items:center;gap:12px;font-size:13px;color:#1f1b1699}.wcim-input-row{display:flex;gap:12px}.ingredient-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:999px;background:var(--paprika);color:var(--white);font-size:13px;font-weight:600;cursor:pointer;transition:opacity .15s ease}.ingredient-chip:hover{opacity:.85}.match-card{background:var(--white);border-radius:var(--radius-lg);padding:20px;box-shadow:0 12px 24px #1b171314;transition:transform .15s ease}.match-card:hover{transform:translateY(-2px)}.match-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.match-header h3{margin:0;font-size:17px}.match-pct{font-size:20px;font-weight:700;color:var(--sage)}.match-info{margin:8px 0 0;font-size:13px;color:#1f1b168c}.cooking-mode{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px;background:var(--charcoal);color:var(--cream)}.cooking-header{text-align:center;margin-bottom:40px;width:100%;max-width:600px}.cooking-header h2{margin:0;font-family:Fraunces,serif;font-size:24px}.cooking-progress{margin:8px 0;font-size:14px;opacity:.65}.cooking-progress-bar{width:100%;height:6px;border-radius:999px;background:#ffffff26;overflow:hidden}.cooking-progress-fill{height:100%;border-radius:999px;background:linear-gradient(90deg,var(--paprika),var(--gold));transition:width .3s ease}.cooking-step{text-align:center;max-width:600px;width:100%}.cooking-step-number{display:inline-grid;place-items:center;width:56px;height:56px;border-radius:999px;background:linear-gradient(135deg,var(--paprika),var(--tamarind));color:var(--white);font-weight:700;font-size:22px;margin-bottom:20px}.cooking-instruction{font-size:clamp(20px,3.5vw,28px);line-height:1.5;margin:0}.cooking-timer{display:inline-flex;align-items:center;gap:6px;margin-top:16px;padding:8px 18px;border-radius:999px;background:#f1b85b33;color:var(--gold);font-weight:600;font-size:16px}.cooking-nav{display:flex;gap:16px;margin-top:48px}.cooking-loading{text-align:center;color:#1f1b168c;padding:60px 0;font-size:16px}@media (max-width: 640px){.cooking-mode{padding:24px 16px}.cooking-nav{width:100%;justify-content:space-between}.wcim-input-row{flex-direction:column}}.stopwatch-page{display:flex;flex-direction:column;align-items:center;text-align:center}.stopwatch-page h2{font-family:Fraunces,serif;font-size:24px;margin-bottom:24px}.stopwatch-display{font-family:Space Grotesk,monospace;font-size:64px;font-weight:700;letter-spacing:-1px;color:var(--charcoal);padding:32px 0;font-variant-numeric:tabular-nums}.stopwatch-controls{display:flex;gap:20px;justify-content:center;align-items:center;margin-bottom:32px}.stopwatch-btn{width:80px;height:80px;border-radius:50%;border:none;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;font-family:Space Grotesk,sans-serif}.stopwatch-btn:active{transform:scale(.95)}.stopwatch-btn-start{background:var(--paprika);color:var(--white);box-shadow:0 4px 16px #d96a3a4d}.stopwatch-btn-start:hover{box-shadow:0 6px 20px #d96a3a66}.stopwatch-btn-pause{background:var(--gold);color:var(--charcoal);box-shadow:0 4px 16px #f1b85b4d}.stopwatch-btn-lap{background:#1f1b1614;color:var(--charcoal)}.stopwatch-btn-lap:hover{background:#1f1b1624}.stopwatch-btn-reset{background:transparent;color:var(--smoke);box-shadow:inset 0 0 0 2px #1f1b161f}.stopwatch-btn-reset:hover{background:#1f1b160a}.stopwatch-laps{width:100%;max-width:420px;border-top:1px solid rgba(31,27,22,.1)}.stopwatch-lap-header{display:grid;grid-template-columns:1fr 1fr 1fr;padding:12px 16px;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--smoke)}.stopwatch-lap-item{display:grid;grid-template-columns:1fr 1fr 1fr;padding:10px 16px;font-size:15px;font-variant-numeric:tabular-nums;border-top:1px solid rgba(31,27,22,.06)}.stopwatch-lap-num{font-weight:600;color:var(--charcoal)}.stopwatch-lap-split{color:var(--paprika);font-weight:500}.stopwatch-lap-total{color:var(--smoke)}@media (max-width: 640px){.stopwatch-display{font-size:48px;padding:24px 0}.stopwatch-btn{width:72px;height:72px;font-size:14px}}.settings-card{background:var(--white);border-radius:var(--radius-xl);padding:28px;box-shadow:0 12px 24px #1b171314;display:grid;gap:16px}.settings-card h3{margin:0;font-family:Fraunces,serif;font-size:20px}.settings-form{display:grid;gap:16px}.settings-field{display:grid;gap:6px}.settings-field label{font-size:13px;font-weight:600;color:#1f1b1699;text-transform:uppercase;letter-spacing:.05em}.settings-textarea{resize:vertical;min-height:80px;border-radius:var(--radius-md)!important}.settings-meta,.settings-hint{margin:0;font-size:14px;color:#1f1b168c}.settings-error{margin:0;font-size:14px;color:var(--tamarind);font-weight:500}.settings-success{margin:0;font-size:14px;color:var(--sage);font-weight:500}.dietary-grid{display:flex;flex-wrap:wrap;gap:8px}.settings-app-row{display:flex;gap:12px;flex-wrap:wrap}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-top:16px}.stat-card{background:var(--cream);border-radius:var(--radius-lg);padding:20px;text-align:center}.stat-card h4{margin:0 0 12px;font-size:13px;font-weight:600;color:#1f1b1699;text-transform:uppercase;letter-spacing:.05em}.stat-number{margin:0;font-family:Fraunces,serif;font-size:32px;font-weight:700;color:var(--paprika);line-height:1}.stat-label{margin:4px 0 12px;font-size:13px;color:#1f1b168c}.stat-cost{margin:0;font-size:15px;font-weight:600;color:var(--sage)}.landing{display:grid;gap:64px;padding-bottom:48px}.landing-hero{text-align:center;padding:48px 0 32px;max-width:640px;margin:0 auto}.landing-hero-title{font-family:Fraunces,serif;font-size:clamp(40px,6vw,64px);line-height:1.1;margin:12px 0 20px}.landing-hero-lede{font-size:18px;line-height:1.7;color:#1f1b16b3;max-width:520px;margin:0 auto 28px}.landing-section{display:grid;gap:24px}.landing-section-title{font-family:Fraunces,serif;font-size:clamp(24px,3.5vw,36px);margin:0;text-align:center}.landing-feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}.landing-feature-card{background:var(--white);border-radius:var(--radius-xl);padding:28px;box-shadow:0 16px 30px #1b171314;display:grid;gap:8px;transition:transform .2s ease,box-shadow .2s ease}.landing-feature-card:hover{transform:translateY(-4px);box-shadow:0 24px 48px #1b17131f}.landing-feature-icon{font-size:32px;line-height:1}.landing-feature-card h3{margin:4px 0 0;font-size:17px}.landing-feature-card p{margin:0;font-size:14px;line-height:1.6;color:#1f1b1699}.landing-steps{display:grid;gap:20px;max-width:560px;margin:0 auto}.landing-step{display:flex;gap:20px;align-items:flex-start;background:var(--white);border-radius:var(--radius-xl);padding:24px 28px;box-shadow:0 12px 24px #1b17130f}.landing-step-num{width:48px;height:48px;border-radius:999px;background:linear-gradient(135deg,var(--paprika),var(--tamarind));color:var(--white);display:grid;place-items:center;font-weight:700;font-size:20px;flex-shrink:0}.landing-step h3{margin:0 0 4px;font-size:17px}.landing-step p{margin:0;font-size:14px;line-height:1.6;color:#1f1b1699}.landing-highlights{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;padding:32px;background:var(--charcoal);border-radius:var(--radius-xl);text-align:center;color:var(--cream)}.landing-highlight h3{margin:0;font-size:28px;font-family:Fraunces,serif}.landing-highlight p{margin:6px 0 0;font-size:13px;opacity:.65}.landing-cta{text-align:center;padding:48px 24px;background:#ffffffbf;border-radius:var(--radius-xl);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.landing-cta h2{font-family:Fraunces,serif;font-size:clamp(28px,4vw,40px);margin:0 0 12px}.landing-cta p{font-size:16px;color:#1f1b16a6;max-width:460px;margin:0 auto 24px;line-height:1.6}@media (max-width: 640px){.landing{gap:48px}.landing-hero{padding:24px 0 16px}.landing-highlights{grid-template-columns:1fr 1fr;padding:24px}.landing-step{padding:20px}.settings-card{padding:20px 16px;border-radius:var(--radius-lg)}.settings-card h3{font-size:18px}.settings-field label{font-size:12px}.auth-input,.settings-textarea{font-size:16px;padding:10px 14px}.dietary-grid{gap:6px}.dietary-grid .filter-chip{font-size:12px;padding:5px 12px}.settings-app-row{flex-direction:column}.settings-app-row button{width:100%}}.toast-container{position:fixed;top:max(80px,env(safe-area-inset-top,80px));right:max(20px,env(safe-area-inset-right,20px));z-index:10000;display:flex;flex-direction:column;gap:12px;max-width:400px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:16px 20px;background:var(--white);border-radius:var(--radius-md);box-shadow:0 8px 24px #1b171326,0 0 0 1px #1b171314;font-size:14px;line-height:1.4;opacity:0;transform:translate(400px);transition:all .3s cubic-bezier(.4,0,.2,1);pointer-events:auto;cursor:pointer;min-width:300px}.toast-visible{opacity:1;transform:translate(0)}.toast-icon{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:50%;font-weight:600;font-size:14px}.toast-message{flex:1;color:var(--charcoal)}.toast-close{flex-shrink:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--smoke);font-size:20px;line-height:1;cursor:pointer;opacity:.5;transition:opacity .2s;padding:0}.toast-close:hover{opacity:1}.toast-success .toast-icon{background:#d4edda;color:#155724}.toast-error .toast-icon{background:#f8d7da;color:#721c24}.toast-warning .toast-icon{background:#fff3cd;color:#856404}.toast-info .toast-icon{background:#d1ecf1;color:#0c5460}@media (max-width: 600px){.toast-container{right:max(16px,env(safe-area-inset-right,16px));left:max(16px,env(safe-area-inset-left,16px));max-width:none}.toast{min-width:0}}.confirm-modal{position:relative;z-index:901;background:var(--white);border-radius:var(--radius-lg);padding:32px;max-width:480px;width:calc(100vw - 32px);min-width:280px;box-shadow:0 20px 60px #1b171333;animation:modal-slide-up .3s cubic-bezier(.4,0,.2,1);pointer-events:auto;touch-action:manipulation}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@media (max-width: 640px){.confirm-modal{z-index:901!important}.confirm-modal-actions{z-index:902!important}.confirm-modal-actions button{z-index:903!important}}@media (max-width: 360px){.confirm-modal{padding:20px;width:calc(100vw - 24px)}}.confirm-modal-title{margin:0 0 16px;font-size:20px;font-weight:600;color:var(--charcoal)}.confirm-modal-message{margin:0 0 24px;font-size:15px;line-height:1.6;color:var(--smoke);white-space:pre-line}.confirm-modal-actions{display:flex;gap:12px;justify-content:flex-end;position:relative;z-index:2}.confirm-modal-actions button{min-width:100px;position:relative;z-index:3;pointer-events:auto;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:rgba(0,0,0,.1)}.skeleton{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:skeleton-loading 1.5s ease-in-out infinite}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.empty-state{text-align:center;padding:64px 20px;max-width:480px;margin:0 auto}.empty-state-icon{font-size:64px;margin-bottom:16px;opacity:.3}.empty-state h3{font-size:20px;font-weight:600;margin:0 0 8px;color:var(--charcoal)}.empty-state p{font-size:15px;line-height:1.6;color:var(--smoke);opacity:.7;margin:0 0 24px}.empty-state-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}@media (max-width: 640px){button,.primary,.secondary,.ghost,.danger{min-height:44px;padding:12px 20px}.filter-chip{min-height:40px;padding:8px 16px}.auth-input,.search-input{min-height:48px;font-size:16px}.card-grid{gap:16px}.toast-close{min-width:32px;min-height:32px}}.meal-card,.most-cooked-card,.landing-feature-card,.quick-action-card{transition:all .3s cubic-bezier(.4,0,.2,1);will-change:transform,box-shadow}.meal-card:hover,.most-cooked-card:hover,.landing-feature-card:hover,.quick-action-card:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 24px 48px #1b171329}.meal-card:active,.most-cooked-card:active,.landing-feature-card:active,.quick-action-card:active{transform:translateY(-2px) scale(.99);transition-duration:.1s}.meal-card-img{transition:opacity .3s ease,transform .3s ease}.meal-card:hover .meal-card-img{transform:scale(1.05)}.auth-input:focus,.search-input:focus{outline:none;box-shadow:0 0 0 2px var(--paprika),0 12px 24px #d96a3a26;border-color:var(--paprika);transform:translateY(-1px);transition:all .2s ease}.filter-chip{transition:all .2s cubic-bezier(.4,0,.2,1);will-change:transform,background,box-shadow}.filter-chip:hover{transform:translateY(-1px);box-shadow:0 4px 12px #1b17131a}.filter-chip:active{transform:scale(.96)}.filter-active{background:linear-gradient(135deg,var(--paprika),var(--tamarind));color:var(--white);box-shadow:0 8px 16px #d96a3a4d}.primary:after,.secondary:after,.danger:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;background:#ffffff4d;opacity:0;transition:opacity .3s ease;pointer-events:none}.primary:active:after,.secondary:active:after,.danger:active:after{opacity:1;transition-duration:0s}.page-enter{animation:page-fade-in .3s ease-out}@keyframes page-fade-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.empty-state{animation:fade-in-up .4s ease-out}@keyframes fade-in-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.empty-state-icon{animation:gentle-float 3s ease-in-out infinite}@keyframes gentle-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}a:not(.nav-link):not(.meal-card):not(.quick-action-card):not(.most-cooked-card):not(.landing-feature-card){transition:color .2s ease}a:not(.nav-link):not(.meal-card):not(.quick-action-card):not(.most-cooked-card):not(.landing-feature-card):hover{color:var(--paprika)}@media (hover: none) and (pointer: coarse){.meal-card:hover,.most-cooked-card:hover,.landing-feature-card:hover,.quick-action-card:hover,.filter-chip:hover{transform:none;box-shadow:initial;background:initial}.meal-card:active,.most-cooked-card:active{transform:scale(.98)}}.empty-state-suggestions{list-style:none;padding:0;margin:16px auto 24px;display:grid;gap:8px;text-align:left;max-width:320px}.empty-state-suggestions li{padding:8px 12px 8px 32px;font-size:14px;color:var(--smoke);background:#fff9;border-radius:var(--radius-md);position:relative}.empty-state-suggestions li:before{content:"→";position:absolute;left:12px;color:var(--paprika);font-weight:600}.meal-card>div:not(.meal-card-img):not(.meal-card-img-placeholder):not(.meal-card-img-shimmer),.hero-card>*,.stat-card>*,.settings-card>*{padding-left:24px;padding-right:24px}.meal-card>div:first-child:is(.meal-card-img,.meal-card-img-placeholder,.meal-card-img-shimmer)+div{padding-left:24px;padding-right:24px}.shopping-item-list{padding-left:24px;padding-right:24px}@media (max-width: 640px){.meal-card-body{padding-left:20px;padding-right:20px}}
