/*! tailwindcss v4.2.1 | MIT License | https://tailwindcss.com */
@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-translate-x:0;--tw-translate-y:0;--tw-translate-z:0;--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-space-y-reverse:0;--tw-border-style:solid;--tw-leading:initial;--tw-font-weight:initial;--tw-tracking:initial;--tw-shadow:0 0 #0000;--tw-shadow-color:initial;--tw-shadow-alpha:100%;--tw-inset-shadow:0 0 #0000;--tw-inset-shadow-color:initial;--tw-inset-shadow-alpha:100%;--tw-ring-color:initial;--tw-ring-shadow:0 0 #0000;--tw-inset-ring-color:initial;--tw-inset-ring-shadow:0 0 #0000;--tw-ring-inset:initial;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-offset-shadow:0 0 #0000;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial;--tw-duration:initial;--tw-space-x-reverse:0}}}@layer theme{:root,:host{--font-sans:"Inter", system-ui, sans-serif;--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--color-black:#000;--spacing:.25rem;--container-lg:32rem;--text-sm:.875rem;--text-sm--line-height:calc(1.25 / .875);--text-lg:1.125rem;--text-lg--line-height:calc(1.75 / 1.125);--font-weight-semibold:600;--tracking-tight:-.025em;--radius-sm:.25rem;--radius-lg:.5rem;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono);--color-primary:#c4451a;--color-primary-hover:#a33815;--color-accent:#2d6a4f;--color-danger:#c0392b;--color-background:#f5efe6;--color-muted-foreground:#8b7355;--color-ring:#c4451a;--font-heading:"Cormorant Garamond", Georgia, serif}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.visible{visibility:visible}.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.inset-0{inset:calc(var(--spacing) * 0)}.end{inset-inline-end:var(--spacing)}.top-4{top:calc(var(--spacing) * 4)}.top-\[50\%\]{top:50%}.right-4{right:calc(var(--spacing) * 4)}.left-\[50\%\]{left:50%}.z-50{z-index:50}.container{width:100%}@media (width>=40rem){.container{max-width:40rem}}@media (width>=48rem){.container{max-width:48rem}}@media (width>=64rem){.container{max-width:64rem}}@media (width>=80rem){.container{max-width:80rem}}@media (width>=96rem){.container{max-width:96rem}}.flex{display:flex}.grid{display:grid}.h-4{height:calc(var(--spacing) * 4)}.w-4{width:calc(var(--spacing) * 4)}.w-full{width:100%}.max-w-lg{max-width:var(--container-lg)}.translate-x-\[-50\%\]{--tw-translate-x:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.translate-y-\[-50\%\]{--tw-translate-y:-50%;translate:var(--tw-translate-x) var(--tw-translate-y)}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.flex-col{flex-direction:column}.flex-col-reverse{flex-direction:column-reverse}.gap-4{gap:calc(var(--spacing) * 4)}:where(.space-y-1\.5>:not(:last-child)){--tw-space-y-reverse:0;margin-block-start:calc(calc(var(--spacing) * 1.5) * var(--tw-space-y-reverse));margin-block-end:calc(calc(var(--spacing) * 1.5) * calc(1 - var(--tw-space-y-reverse)))}.rounded-sm{border-radius:var(--radius-sm)}.border{border-style:var(--tw-border-style);border-width:1px}.bg-background{background-color:var(--color-background)}.bg-black\/80{background-color:#000c}@supports (color:color-mix(in lab, red, red)){.bg-black\/80{background-color:color-mix(in oklab, var(--color-black) 80%, transparent)}}.p-6{padding:calc(var(--spacing) * 6)}.text-center{text-align:center}.text-lg{font-size:var(--text-lg);line-height:var(--tw-leading,var(--text-lg--line-height))}.text-sm{font-size:var(--text-sm);line-height:var(--tw-leading,var(--text-sm--line-height))}.leading-none{--tw-leading:1;line-height:1}.font-semibold{--tw-font-weight:var(--font-weight-semibold);font-weight:var(--font-weight-semibold)}.tracking-tight{--tw-tracking:var(--tracking-tight);letter-spacing:var(--tracking-tight)}.text-muted-foreground{color:var(--color-muted-foreground)}.opacity-70{opacity:.7}.shadow-lg{--tw-shadow:0 10px 15px -3px var(--tw-shadow-color,#0000001a), 0 4px 6px -4px var(--tw-shadow-color,#0000001a);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.ring-offset-background{--tw-ring-offset-color:var(--color-background)}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition-opacity{transition-property:opacity;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.duration-200{--tw-duration:.2s;transition-duration:.2s}@media (hover:hover){.hover\:opacity-100:hover{opacity:1}}.focus\:ring-2:focus{--tw-ring-shadow:var(--tw-ring-inset,) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color,currentcolor);box-shadow:var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.focus\:ring-ring:focus{--tw-ring-color:var(--color-ring)}.focus\:ring-offset-2:focus{--tw-ring-offset-width:2px;--tw-ring-offset-shadow:var(--tw-ring-inset,) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color)}.focus\:outline-none:focus{--tw-outline-style:none;outline-style:none}.disabled\:pointer-events-none:disabled{pointer-events:none}.data-\[state\=open\]\:bg-accent[data-state=open]{background-color:var(--color-accent)}.data-\[state\=open\]\:text-muted-foreground[data-state=open]{color:var(--color-muted-foreground)}@media (width>=40rem){.sm\:flex-row{flex-direction:row}.sm\:justify-end{justify-content:flex-end}:where(.sm\:space-x-2>:not(:last-child)){--tw-space-x-reverse:0;margin-inline-start:calc(calc(var(--spacing) * 2) * var(--tw-space-x-reverse));margin-inline-end:calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-x-reverse)))}.sm\:rounded-lg{border-radius:var(--radius-lg)}.sm\:text-left{text-align:left}}}:root{--color-bg:#f5efe6;--color-surface:#fff;--color-border:#e8ddd0;--color-text:#1c1209;--color-text-muted:#6b5a45;--color-primary:#c4451a;--color-primary-hover:#a33815;--color-accent:#2d6a4f;--color-accent-light:#e8f5ee;--color-danger:#c0392b;--color-selected:#fff0e8;--color-selected-border:#c4451a;--font-body:"Inter", system-ui, sans-serif;--font-heading:"Cormorant Garamond", Georgia, serif;--radius:8px;--shadow:0 1px 3px #00000014}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);line-height:1.6}h1,h2,h3{font-family:var(--font-heading)}a{color:inherit;text-decoration:none}.navbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);z-index:100;justify-content:space-between;align-items:center;height:56px;padding:0 2rem;display:flex;position:sticky;top:0;box-shadow:0 1px 4px #00000014}.navbar-brand{color:var(--color-primary);font-size:1.2rem;font-weight:700;font-family:var(--font-heading)}.navbar-links{align-items:center;gap:1.5rem;display:flex}.nav-link{color:var(--color-text-muted);align-items:center;gap:6px;font-size:.95rem;display:flex}.nav-link.active{color:var(--color-primary);font-weight:600}.nav-link:hover{color:var(--color-text)}.badge{background:var(--color-primary);color:#fff;border-radius:99px;padding:1px 7px;font-size:.75rem;font-weight:600}.main-content{max-width:900px;margin:0 auto;padding:2rem 1.5rem}.page{flex-direction:column;gap:1.5rem;display:flex}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;display:flex}.page-header h1{font-size:1.75rem}.page-header-actions{align-items:center;gap:1rem;display:flex}.btn-primary{background:var(--color-primary);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:4px;padding:.5rem 1.1rem;font-size:.9rem;font-weight:600;display:inline-flex}.btn-primary:hover{background:var(--color-primary-hover)}.btn-secondary{color:var(--color-text-muted);border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;background:0 0;padding:.5rem 1.1rem;font-size:.9rem}.btn-secondary:hover{background:var(--color-border)}.btn-toggle{border-radius:var(--radius);cursor:pointer;border:none;align-self:flex-start;margin-top:.5rem;padding:.45rem 1rem;font-size:.85rem;font-weight:600}.btn-add{background:var(--color-primary);color:#fff}.btn-add:hover{background:var(--color-primary-hover)}.btn-remove{color:var(--color-danger);background:#fee2e2}.btn-remove:hover{background:#fecaca}.btn-small{padding:.3rem .75rem;font-size:.8rem}.link-back{color:var(--color-text-muted);font-size:.9rem}.link-back:hover{color:var(--color-text)}.recipe-grid{grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.25rem;display:grid}.recipe-detail-header{border-bottom:1px solid var(--color-border);flex-direction:column;gap:.75rem;padding-bottom:1.5rem;display:flex}.recipe-detail-header h1{font-size:2rem}.recipe-description{color:var(--color-text-muted);font-size:1rem}.recipe-meta{color:var(--color-text-muted);gap:1.5rem;font-size:.88rem;display:flex}.recipe-detail-body{grid-template-columns:1fr 2fr;gap:2rem;display:grid}@media (width<=600px){.recipe-detail-body{grid-template-columns:1fr}}.recipe-ingredients h2,.recipe-steps h2{margin-bottom:.75rem;font-size:1.1rem;font-weight:700}.recipe-ingredients ul{flex-direction:column;gap:.4rem;list-style:none;display:flex}.recipe-ingredients li{font-size:.92rem}.recipe-steps ol{flex-direction:column;gap:.75rem;padding-left:1.25rem;display:flex}.recipe-steps li{font-size:.92rem}.meal-plan-list{flex-direction:column;gap:.75rem;list-style:none;display:flex}.meal-plan-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.meal-plan-name{flex:1;font-weight:600}.meal-plan-meta{color:var(--color-text-muted);gap:1rem;font-size:.82rem;display:flex}.shopping-subtitle{color:var(--color-text-muted);font-size:.9rem}.shopping-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.shopping-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);min-height:56px;padding:1rem 1.25rem}.empty-state{text-align:center;color:var(--color-text-muted);flex-direction:column;align-items:center;gap:1rem;padding:3rem 1rem;display:flex}.empty-section{color:var(--color-text-muted);padding:.5rem 0;font-size:.9rem;font-style:italic}.navbar-user{align-items:center;gap:.75rem;display:flex}.navbar-avatar{background:var(--color-primary);color:#fff;cursor:default;width:28px;height:28px;font-size:.8rem;font-weight:600;font-family:var(--font-body);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.btn-logout{border:1px solid var(--color-border);border-radius:var(--radius);cursor:pointer;color:var(--color-text-muted);background:0 0;padding:.3rem .75rem;font-size:.82rem}.btn-logout:hover{background:var(--color-border);color:var(--color-text)}.login-wrapper{justify-content:center;align-items:center;min-height:calc(100vh - 56px);padding:2rem 1rem;display:flex}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);width:100%;max-width:380px;box-shadow:var(--shadow);flex-direction:column;gap:.5rem;padding:2.5rem 2rem;display:flex}.login-title{color:var(--color-primary);text-align:center;font-size:1.6rem;font-weight:700}.login-subtitle{color:var(--color-text-muted);text-align:center;margin-bottom:1rem;font-size:.88rem}.login-form{flex-direction:column;gap:1rem;margin-top:.5rem;display:flex}.form-group{flex-direction:column;gap:.35rem;display:flex}.form-group label{font-size:.88rem;font-weight:600}.form-group input,.form-group textarea,.form-group select{border:1px solid var(--color-border);border-radius:var(--radius);font-size:.95rem;font-family:var(--font-body);background:var(--color-surface);width:100%;padding:.55rem .75rem}.form-group input:focus,.form-group textarea:focus,.form-group select:focus{outline:2px solid var(--color-primary);outline-offset:1px;border-color:#0000}.login-error{color:var(--color-danger);font-size:.88rem}.btn-full{justify-content:center;width:100%;padding:.65rem;font-size:1rem}.spinner-wrapper{justify-content:center;align-items:center;min-height:calc(100vh - 56px);display:flex}.spinner{border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;width:40px;height:40px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.not-found{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:1rem;min-height:calc(100vh - 56px);padding:2rem;display:flex}.not-found-icon{font-size:3.5rem}.not-found h1{font-size:2rem}.not-found p{color:var(--color-text-muted)}.login-brand{justify-content:center;align-items:center;gap:.5rem;margin-bottom:.25rem;display:flex}.login-brand-icon{font-size:1.8rem}.login-brand-logo{width:180px;height:auto}.login-card{border-radius:12px;box-shadow:0 4px 24px #1c12091a}.navbar-brand{align-items:center;gap:.4rem;display:flex}.navbar-brand-icon{font-size:1.2rem}.nav-link.active{position:relative}.nav-link.active:after{content:"";background:var(--color-primary);border-radius:2px;height:2px;position:absolute;bottom:-18px;left:0;right:0}.bottom-nav{background:var(--color-surface);border-top:1px solid var(--color-border);z-index:100;height:auto;min-height:60px;padding-bottom:env(safe-area-inset-bottom);display:none;position:fixed;bottom:0;left:0;right:0}.bottom-nav-item{color:var(--color-text-muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:2px;padding:.5rem 0;font-size:.72rem;font-weight:500;display:flex;position:relative}.bottom-nav-item.active{color:var(--color-primary)}.bottom-nav-item.active:before{content:"";background:var(--color-primary);border-radius:0 0 3px 3px;width:24px;height:3px;position:absolute;top:0;left:50%;transform:translate(-50%)}.bottom-nav-icon{justify-content:center;align-items:center;line-height:1;display:flex;position:relative}.bottom-nav-badge{background:var(--color-primary);color:#fff;border-radius:99px;padding:0 5px;font-size:.65rem;font-weight:700;line-height:1.4;position:absolute;top:-6px;right:-10px}.bottom-nav-label{line-height:1}@media (width<=768px){.bottom-nav{display:flex}.navbar-links-desktop{display:none}.main-content{padding-bottom:calc(60px + env(safe-area-inset-bottom))}}.recipe-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);flex-direction:column;padding:0;transition:border-color .15s,box-shadow .15s;display:flex;overflow:hidden}.recipe-card:hover{border-color:var(--color-primary);box-shadow:0 2px 8px #c4451a1f}.recipe-card.selected{background:var(--color-selected);border-color:var(--color-selected-border)}.recipe-card-banner{aspect-ratio:16/9;flex-shrink:0;justify-content:center;align-items:center;display:flex;position:relative}.recipe-card-banner-icon{filter:drop-shadow(0 2px 4px #0003);font-size:2.5rem}.recipe-card-selected-badge{color:#fff;background:#00000059;border-radius:99px;padding:2px 8px;font-size:.72rem;font-weight:600;position:absolute;top:8px;right:8px}.recipe-card-photo-wrapper{aspect-ratio:16/9;width:100%;position:relative;overflow:hidden}.recipe-card-photo{object-fit:cover;width:100%;height:100%;display:block}.recipe-card-body{flex-direction:column;flex:1;padding:1rem 1.25rem .75rem;display:flex}.recipe-card-title{font-size:1.1rem;font-weight:700;font-family:var(--font-heading);-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:2.6em;margin-bottom:.35rem;display:-webkit-box;overflow:hidden}.recipe-card-description{color:var(--color-text-muted);-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:2.4em;margin-bottom:.6rem;font-size:.85rem;display:-webkit-box;overflow:hidden}.recipe-card-meta{color:var(--color-text-muted);gap:1rem;margin-top:auto;margin-bottom:.25rem;font-size:.8rem;display:flex}.btn-card-full{border-top:1px solid var(--color-border);text-align:center;border-radius:0;justify-content:center;width:100%;margin-top:0;padding:.65rem;font-size:.875rem}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}.skeleton-line,.skeleton-banner,.skeleton-pill,.skeleton-btn{background:linear-gradient(90deg,#e8ddd0 25%,#f5efe6 50%,#e8ddd0 75%) 0 0/400px 100%;border-radius:4px;animation:1.4s ease-in-out infinite shimmer}.recipe-card-skeleton{pointer-events:none}.skeleton-banner{aspect-ratio:16/9;border-radius:0}.skeleton-title{width:75%;height:18px;margin-bottom:.6rem}.skeleton-line{width:100%;height:13px;margin-bottom:.4rem}.skeleton-short{width:55%}.skeleton-meta{gap:.75rem;margin-top:.5rem;padding:0 1.25rem .75rem;display:flex}.skeleton-pill{border-radius:99px;width:70px;height:13px}.skeleton-btn{border-top:1px solid var(--color-border);border-radius:0;height:40px;margin-top:auto}.recipe-hero{border-radius:var(--radius);flex-direction:column;gap:.75rem;padding:2rem 2rem 1.5rem;display:flex;position:relative;overflow:hidden}.recipe-hero-photo{object-fit:cover;z-index:0;width:100%;height:100%;position:absolute;inset:0}.recipe-hero:has(.recipe-hero-photo):after{content:"";z-index:1;background:linear-gradient(#0000 0%,#0003 40%,#000000b3 100%);position:absolute;inset:0}.recipe-hero-title,.recipe-hero-meta,.recipe-hero-actions{z-index:2;position:relative}.recipe-hero-title{color:#fff;text-shadow:0 2px 8px #00000040;font-size:2.2rem;line-height:1.2}.recipe-hero-actions{gap:.5rem;margin-top:.25rem;display:flex}.recipe-hero-actions .btn-secondary,.recipe-hero-actions .btn-danger{border-radius:var(--radius);color:#fff;cursor:pointer;border:1px solid #fff9;align-items:center;padding:.3rem .75rem;font-size:.8rem;font-weight:600;display:inline-flex}.recipe-hero-actions .btn-secondary{background:#ffffff26}.recipe-hero-actions .btn-secondary:hover{background:#ffffff47}.recipe-hero-actions .btn-danger{background:#c0392bd9}.recipe-hero-actions .btn-danger:hover{background:#a93225f2}.recipe-hero-meta{color:#ffffffe6;flex-wrap:wrap;gap:1rem;font-size:.88rem;display:flex}.recipe-ingredient-item{padding:.2rem 0;font-size:.92rem}.ingredient-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.6rem;transition:opacity .15s;display:flex}.ingredient-label.checked{opacity:.45;text-decoration:line-through}.ingredient-checkbox{appearance:none;border:2px solid var(--color-border);background:var(--color-surface);cursor:pointer;border-radius:4px;flex-shrink:0;width:18px;height:18px;transition:background .15s,border-color .15s;position:relative}.ingredient-checkbox:checked{background:var(--color-primary);border-color:var(--color-primary)}.ingredient-checkbox:checked:after{content:"✓";color:#fff;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex;position:absolute;inset:0}.recipe-steps-list{flex-direction:column;gap:1rem;padding:0;list-style:none;display:flex}.recipe-step-item{align-items:flex-start;gap:1rem;display:flex}.step-circle{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;margin-top:.1rem;font-size:.9rem;font-weight:700;display:flex}.recipe-step-item p{padding-top:.2rem;font-size:.95rem;line-height:1.6}.dialog-paprika{color:var(--color-text);background:var(--color-surface)!important;border:1px solid var(--color-border)!important;border-radius:12px!important;gap:1.25rem!important;max-width:420px!important;padding:2rem!important;box-shadow:0 8px 32px #1c12092e!important}.dialog-paprika h2{color:var(--color-text);font-size:1.2rem}.dialog-paprika p{color:var(--color-text-muted);font-size:.9rem;line-height:1.5}.dialog-paprika>[class*=flex]{gap:.75rem}.meal-plan-summary{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;overflow:hidden}.summary-stat{border-right:1px solid var(--color-border);flex-direction:column;flex:1;align-items:center;gap:.25rem;padding:1.25rem 1rem;display:flex}.summary-stat:last-child{border-right:none}.summary-stat-value{font-size:1.75rem;font-weight:700;font-family:var(--font-heading);color:var(--color-primary);line-height:1}.summary-stat-label{color:var(--color-text-muted);text-align:center;font-size:.78rem}.meal-plan-color-dot{border-radius:50%;flex-shrink:0;width:12px;height:12px}.meal-plan-thumbnail{object-fit:cover;border-radius:6px;flex-shrink:0;width:56px;height:56px}.btn-remove-icon{cursor:pointer;color:var(--color-text-muted);background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;padding:.25rem;transition:color .15s,background .15s;display:flex}.btn-remove-icon:hover{color:var(--color-danger);background:#fee2e2}.btn-danger{background:var(--color-danger);color:#fff;border-radius:var(--radius);cursor:pointer;border:none;padding:.5rem 1.1rem;font-size:.9rem;font-weight:600}.btn-danger:hover{background:#a93225}.shopping-progress{z-index:10;background:var(--color-border);border-radius:0;height:4px;position:sticky;top:56px;overflow:hidden;box-shadow:0 2px 6px #00000014}.shopping-progress-bar{background:var(--color-accent);border-radius:2px;height:100%;transition:width .3s}.shopping-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;display:flex}.shopping-item{transition:opacity .15s,background-color .15s}.shopping-item.checked{opacity:.7;background-color:var(--color-accent-light)}.shopping-item.checked .shopping-item-text{color:var(--color-text-muted);text-decoration:line-through}.shopping-label{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:.75rem;width:100%;display:flex}.shopping-checkbox{appearance:none;border:2px solid var(--color-border);background:var(--color-surface);cursor:pointer;border-radius:6px;flex-shrink:0;width:28px;height:28px;transition:background .15s,border-color .15s;position:relative}.shopping-checkbox:checked{background:var(--color-accent);border-color:var(--color-accent)}.shopping-checkbox:checked:after{content:"✓";color:#fff;justify-content:center;align-items:center;font-size:.85rem;font-weight:700;display:flex;position:absolute;inset:0}.shopping-item-text{font-size:1rem}.shopping-category-group{margin-bottom:1.5rem}.shopping-category-title{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);margin-bottom:.5rem;padding:0 0 .5rem;font-size:.75rem;font-weight:600}.recipe-form{flex-direction:column;gap:2rem;display:flex}.form-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-direction:column;gap:1rem;padding:1.5rem;display:flex}.form-section-title{color:var(--color-text);border-bottom:1px solid var(--color-border);margin-bottom:.25rem;padding-bottom:.5rem;font-size:1.05rem;font-weight:600}.form-row{flex-wrap:wrap;align-items:flex-start;gap:.75rem;display:flex}.form-row .form-group{flex:1;min-width:120px}.form-ingredient-row input,.form-ingredient-row select{border:1px solid var(--color-border);border-radius:var(--radius);height:38px;font-size:.95rem;font-family:var(--font-body);background:var(--color-surface);color:var(--color-text);box-sizing:border-box;min-width:0;padding:0 .75rem}.form-ingredient-row input:focus,.form-ingredient-row select:focus{outline:2px solid var(--color-primary);outline-offset:1px;border-color:#0000}.form-ingredient-row input{flex:0 0 90px}.form-ingredient-row select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238B7355' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right .6rem center;background-repeat:no-repeat;flex:0 0 110px;padding-right:1.8rem}.form-step-row{align-items:flex-start}.form-step-row textarea{resize:vertical;font-family:var(--font-body);flex:1}.step-number{color:var(--color-primary);min-width:1.5rem;padding-top:.6rem;font-weight:600}.form-error{color:var(--color-danger);font-size:.85rem}input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{appearance:textfield}.input-error{border-color:var(--color-danger)!important;outline-color:var(--color-danger)!important}.stepper{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);align-items:center;display:flex;overflow:hidden}.stepper.input-error{border-color:var(--color-danger)}.stepper-btn{width:36px;height:36px;color:var(--color-text-muted);cursor:pointer;background:0 0;border:none;flex-shrink:0;justify-content:center;align-items:center;font-size:1.1rem;transition:background .1s,color .1s;display:flex}.stepper-btn:hover:not(:disabled){background:var(--color-border);color:var(--color-text)}.stepper-btn:disabled{opacity:.35;cursor:default}.stepper-input{text-align:center;color:var(--color-text);width:0;min-width:2rem;font-size:.95rem;font-weight:600;font-family:var(--font-body);background:0 0;border:none;flex:1;padding:0}.stepper-input:focus{outline:none}.input-with-unit{border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);align-items:center;display:flex;overflow:hidden}.input-with-unit.input-error{border-color:var(--color-danger)}.input-with-unit input{font-size:.95rem;font-family:var(--font-body);color:var(--color-text);background:0 0;border:none;flex:1;width:0;min-width:0;padding:.55rem .6rem}.input-with-unit input:focus{outline:none}.input-unit{color:var(--color-text-muted);border-left:1px solid var(--color-border);background:var(--color-bg);white-space:nowrap;align-self:stretch;align-items:center;padding:0 .6rem;font-size:.82rem;display:flex}.btn-spinner{vertical-align:middle;border:2px solid #fff6;border-top-color:#fff;border-radius:50%;width:14px;height:14px;margin-right:4px;animation:.6s linear infinite spin;display:inline-block}.combobox-wrapper{flex:1;min-width:140px;position:relative}.combobox-input{border:1px solid var(--color-border);border-radius:var(--radius);width:100%;font-size:.95rem;font-family:var(--font-body);background:var(--color-surface);color:var(--color-text);padding:.55rem .75rem}.combobox-input:focus{outline:2px solid var(--color-primary);outline-offset:1px;border-color:#0000}.combobox-list{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);z-index:200;max-height:220px;padding:.25rem 0;list-style:none;position:absolute;top:calc(100% + 4px);left:0;right:0;overflow-y:auto;box-shadow:0 4px 16px #1c12091f}.combobox-item{cursor:pointer;color:var(--color-text);padding:.5rem .75rem;font-size:.9rem}.combobox-item:hover,.combobox-item.active{background:var(--color-selected);color:var(--color-primary)}@media (width<=480px){.page-header{flex-direction:column;align-items:flex-start}.page-header-actions{width:100%}.page-header-actions .btn-primary,.page-header-actions .btn-secondary{text-align:center;flex:1;justify-content:center}.meal-plan-summary{flex-direction:column}.summary-stat{border-right:none;border-bottom:1px solid var(--color-border);padding:1rem}.summary-stat:last-child{border-bottom:none}.form-row{flex-direction:column}.form-ingredient-row{flex-wrap:wrap}.combobox-wrapper{min-width:100%}.recipe-hero-title{font-size:1.6rem}.meal-plan-item{flex-wrap:wrap;gap:.5rem}.meal-plan-meta{width:100%}}@keyframes routeFadeIn{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.route-fade{animation:.15s ease-out routeFadeIn}.recipe-fab{display:none}@media (width<=768px){.recipe-fab{z-index:90;cursor:pointer;border:none;border-radius:99px;justify-content:center;align-items:center;padding:.7rem 1.25rem;font-size:.9rem;font-weight:600;transition:opacity .15s,transform .15s;display:flex;position:fixed;bottom:calc(60px + 1rem);right:1rem;box-shadow:0 4px 12px #0000002e}.recipe-fab:active{transform:scale(.96)}.recipe-detail-basket-desktop{display:none}[data-sonner-toaster][data-y-position=bottom]{bottom:70px!important}}.fridge-list{flex-direction:column;gap:.5rem;list-style:none;display:flex}.fridge-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);flex-wrap:wrap;align-items:center;gap:1rem;padding:.75rem 1rem;display:flex}.fridge-item-name{flex:1;min-width:120px;font-size:.95rem;font-weight:600}.fridge-item-qty{color:var(--color-text-muted);white-space:nowrap;font-size:.88rem}.fridge-item-actions{flex-shrink:0;gap:.5rem;display:flex}.fridge-dialog-form{flex-direction:column;gap:1rem;display:flex}@media (width<=480px){.fridge-item{gap:.5rem}.fridge-item-actions{width:100%}.fridge-item-actions .btn-secondary,.fridge-item-actions .btn-danger{text-align:center;flex:1;justify-content:center}}.nav-fridge-toggle{border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-muted);background:0 0;border-radius:6px;padding:5px 12px;font-size:.9rem;transition:background .15s,color .15s}.nav-fridge-toggle:hover:not(:disabled){background:var(--color-border);color:var(--color-text)}.nav-fridge-toggle.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.nav-fridge-toggle.active:hover:not(:disabled){background:var(--color-primary-hover);border-color:var(--color-primary-hover);color:#fff}.nav-fridge-toggle:disabled{opacity:.4;cursor:not-allowed}.fridge-badge{border-radius:12px;margin-top:6px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.fridge-badge-ok{color:#065f46;background:#d1fae5}.fridge-badge-missing{color:#92400e;background:#fed7aa}.bottom-nav-item.fridge-on .bottom-nav-label{color:var(--color-accent,#2d6a4f)}.bottom-nav-fridge-dot{background:var(--color-accent,#2d6a4f);border-radius:50%;width:8px;height:8px;position:absolute;top:-2px;right:-2px}.fridge-covered-section{border-top:1px solid var(--color-border);margin-top:2rem;padding-top:1.5rem}.fridge-covered-title{color:var(--color-text-muted);margin-bottom:.75rem;font-size:1rem;font-weight:600}.fridge-covered-list{flex-direction:column;gap:.5rem;margin:0;padding:0;list-style:none;display:flex}.fridge-covered-item{color:var(--color-text-muted);opacity:.75;align-items:center;gap:.5rem;font-size:.95rem;display:flex}.fridge-covered-check{color:var(--color-accent);flex-shrink:0;font-weight:700}.photo-dropzone{border:2px dashed var(--color-border);border-radius:var(--radius);text-align:center;cursor:pointer;background:var(--color-surface);padding:2rem;transition:border-color .2s,background .2s}.photo-dropzone:hover{border-color:var(--color-primary);background:var(--color-selected)}.photo-dropzone--has-photo{border-style:solid;padding:0;overflow:hidden}.photo-dropzone-preview{object-fit:cover;width:100%;max-height:300px;display:block}.photo-dropzone-placeholder{flex-direction:column;align-items:center;display:flex}.photo-dropzone-icon{color:var(--color-text-muted);margin-bottom:.75rem}.photo-dropzone-text{color:var(--color-text);margin-bottom:.25rem;font-size:.95rem;font-weight:500;display:block}.photo-dropzone-hint{color:var(--color-text-muted);font-size:.8rem;display:block}.form-hint{color:var(--color-text-muted);margin-top:.25rem;font-size:.8rem}@property --tw-translate-x{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-y{syntax:"*";inherits:false;initial-value:0}@property --tw-translate-z{syntax:"*";inherits:false;initial-value:0}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-space-y-reverse{syntax:"*";inherits:false;initial-value:0}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-leading{syntax:"*";inherits:false}@property --tw-font-weight{syntax:"*";inherits:false}@property --tw-tracking{syntax:"*";inherits:false}@property --tw-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-shadow-color{syntax:"*";inherits:false}@property --tw-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-inset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-shadow-color{syntax:"*";inherits:false}@property --tw-inset-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-ring-color{syntax:"*";inherits:false}@property --tw-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-inset-ring-color{syntax:"*";inherits:false}@property --tw-inset-ring-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-ring-inset{syntax:"*";inherits:false}@property --tw-ring-offset-width{syntax:"<length>";inherits:false;initial-value:0}@property --tw-ring-offset-color{syntax:"*";inherits:false;initial-value:#fff}@property --tw-ring-offset-shadow{syntax:"*";inherits:false;initial-value:0 0 #0000}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}@property --tw-duration{syntax:"*";inherits:false}@property --tw-space-x-reverse{syntax:"*";inherits:false;initial-value:0}
