@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-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;--glow:0}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-sm:.25rem;--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@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;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{.sr-only{clip-path:inset(50%);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.static{position:static}.container{width:100%}@media(min-width:40rem){.container{max-width:40rem}}@media(min-width:48rem){.container{max-width:48rem}}@media(min-width:64rem){.container{max-width:64rem}}@media(min-width:80rem){.container{max-width:80rem}}@media(min-width:96rem){.container{max-width:96rem}}.block{display:block}.grid{display:grid}.hidden{display:none}.rounded{border-radius:.25rem}.shadow{--tw-shadow:0 1px 3px 0 var(--tw-shadow-color,#0000001a), 0 1px 2px -1px 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)}}@property --glow{syntax:"<number>";inherits:false;initial-value:0}:root{color-scheme:light;--surface:#f0fdf4;--surface-2:#dcfce7;--panel:#fff;--panel-alt:#f7fef9;--ink:#052e16;--muted:#166534;--faint:#4ade80;--line:#052e161a;--line-strong:#052e1638;--jade:#059669;--jade-dark:#047857;--jade-light:#6ee7b7;--gold:#d97706;--gold-light:#fbbf24;--forest:#14532d;--font-display:"Georgia", "Iowan Old Style", "Times New Roman", serif;--font-sans:ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", sans-serif;--font-num:"SF Mono", ui-monospace, "Cascadia Code", "JetBrains Mono", monospace;--radius:18px;--radius-sm:12px;--shadow:0 20px 44px -26px #054e1e73;--shadow-sm:0 8px 20px -14px #054e1e61}*{box-sizing:border-box;margin:0;padding:0}html{font-family:var(--font-sans);background:var(--surface);color:var(--ink);scroll-behavior:smooth;height:100%}body{background:var(--surface);min-block-size:100dvh}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border:0;block-size:1px;inline-size:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}:focus-visible{outline:2px solid var(--jade);outline-offset:2px}.app{flex-direction:column;min-block-size:100dvh;display:flex}.topbar{background:var(--forest);color:#fff;z-index:10;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex;position:sticky;top:0;box-shadow:0 2px 8px #052e1666}.topbar__brand{align-items:center;gap:.75rem;display:flex}.topbar__mark{font-size:1.75rem;line-height:1}.topbar__copy{flex-direction:column;gap:.1rem;display:flex}.topbar__title{font-family:var(--font-display);letter-spacing:-.01em;color:var(--jade-light);font-size:1.25rem;font-weight:700;line-height:1.1}.topbar__sub{color:#ffffffa6;letter-spacing:.03em;font-size:.7rem}.topbar__cart{color:var(--jade-light);cursor:pointer;background:#6ee7b72e;border:1px solid #6ee7b766;border-radius:999px;align-items:center;gap:.4rem;padding:.5rem .9rem;font-size:.85rem;font-weight:600;transition:background .15s,transform .1s;display:flex}.topbar__cart:hover{background:#6ee7b747}.topbar__cart:active{transform:scale(.97)}#shopping-count{background:var(--gold);color:#fff;block-size:1.25rem;min-inline-size:1.25rem;font-size:.7rem;font-weight:700;font-family:var(--font-num);border-radius:999px;justify-content:center;align-items:center;padding:0 .3rem;display:inline-flex}#shopping-count[hidden]{display:none}.layout{flex:1;grid-template-columns:280px 1fr;min-block-size:0;display:grid;overflow:hidden}@media(max-width:720px){.layout{grid-template-columns:1fr;overflow:auto}}.sidebar{background:var(--panel);border-inline-end:1px solid var(--line);flex-direction:column;gap:1rem;padding:1.25rem .75rem;display:flex;overflow-y:auto}.sidebar__head{border-bottom:1px solid var(--line);padding:0 .5rem .75rem}.sidebar__eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--jade);font-size:.65rem;font-weight:600}.sidebar__title{font-family:var(--font-display);color:var(--forest);margin-top:.15rem;font-size:1.1rem}#recipe-list{flex-direction:column;gap:1rem;list-style:none;display:flex}.recipe-section{flex-direction:column;gap:.35rem;display:flex}.section-heading{text-transform:uppercase;letter-spacing:.08em;color:var(--jade);padding:0 .25rem;font-size:.65rem;font-weight:700}.recipe-card{border-radius:var(--radius-sm);cursor:pointer;text-align:start;background:0 0;border:1px solid #0000;align-items:center;gap:.65rem;inline-size:100%;padding:.55rem .65rem;transition:background .12s,border-color .12s;display:flex}.recipe-card:hover{background:var(--surface-2)}.recipe-card.is-active{border-color:var(--jade);background:#ecfdf5}.recipe-thumb{background:var(--surface-2);border-radius:10px;flex-shrink:0;block-size:48px;inline-size:48px;overflow:hidden}.recipe-info{flex-direction:column;gap:.15rem;display:flex;overflow:hidden}.recipe-title{color:var(--forest);white-space:nowrap;text-overflow:ellipsis;font-size:.83rem;font-weight:600;overflow:hidden}.recipe-meta{color:var(--muted);font-size:.68rem}.detail{background:var(--panel-alt);flex-direction:column;gap:0;display:flex;overflow-y:auto}.hero{background:var(--surface-2);block-size:220px;position:relative;overflow:hidden}#hero-canvas{block-size:100%;inline-size:100%;display:block}#detail-category{background:var(--jade);color:#fff;letter-spacing:.06em;text-transform:uppercase;top:.75rem;border-radius:999px;padding:.25rem .75rem;font-size:.68rem;font-weight:700;position:absolute;inset-inline-start:.75rem}.detail__head{border-bottom:1px solid var(--line);padding:1rem 1.5rem .75rem}#detail-title{font-family:var(--font-display);color:var(--forest);font-size:1.5rem;line-height:1.2}#detail-subtitle{color:var(--muted);margin-top:.3rem;font-size:.85rem;line-height:1.4}#detail-meta{color:var(--muted);margin-top:.4rem;font-size:.75rem}.servings{border-bottom:1px solid var(--line);background:var(--surface);justify-content:space-between;align-items:center;padding:.9rem 1.5rem;display:flex}.servings__label{flex-direction:column;gap:.1rem;display:flex}.servings__title{color:var(--forest);text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;font-weight:600}#servings-base{color:var(--muted);font-size:.7rem}.servings__stepper{align-items:center;gap:.75rem;display:flex}#servings-dec,#servings-inc{border:1.5px solid var(--jade);block-size:2rem;inline-size:2rem;color:var(--jade-dark);cursor:pointer;background:#fff;border-radius:50%;justify-content:center;align-items:center;font-size:1.1rem;font-weight:700;transition:background .12s,color .12s;display:flex}#servings-dec:hover,#servings-inc:hover{background:var(--jade);color:#fff}#servings-dec:disabled,#servings-inc:disabled{opacity:.35;cursor:not-allowed}#servings-value{font-family:var(--font-num);color:var(--forest);text-align:center;min-inline-size:2ch;font-size:1.25rem;font-weight:700}.panels{flex:1;grid-template-columns:1fr 1fr;gap:0;display:grid}@media(max-width:960px){.panels{grid-template-columns:1fr}}.panel{border-inline-end:1px solid var(--line);padding:1.25rem 1.5rem}.panel:last-child{border-inline-end:none}.panel__head{justify-content:space-between;align-items:center;margin-bottom:.9rem;display:flex}.panel__title{font-family:var(--font-display);color:var(--forest);text-transform:uppercase;letter-spacing:.04em;font-size:.95rem;font-weight:700}#ingredients-list{flex-direction:column;gap:1rem;display:flex}.ingredient-group{flex-direction:column;gap:.35rem;display:flex}.ingredient-section{text-transform:uppercase;letter-spacing:.08em;color:var(--jade);font-size:.65rem;font-weight:700}.ingredient-list{flex-direction:column;gap:.25rem;list-style:none;display:flex}.ingredient-list li{border-bottom:1px solid var(--line);align-items:baseline;gap:.5rem;padding:.2rem 0;display:flex}.ing-amount{font-family:var(--font-num);color:var(--jade-dark);flex-shrink:0;min-inline-size:6ch;font-size:.78rem;font-weight:600}.ing-name{color:var(--ink);font-size:.82rem}#steps-list{flex-direction:column;gap:1.1rem;display:flex}.step{grid-template-rows:auto auto;grid-template-columns:2rem 1fr;gap:.25rem .75rem;display:grid}.step-num{background:var(--jade);color:#fff;block-size:2rem;inline-size:2rem;font-family:var(--font-num);border-radius:50%;flex-shrink:0;grid-row:1/3;justify-content:center;align-self:start;align-items:center;margin-top:.1rem;font-size:.78rem;font-weight:700;display:flex}.step-text{color:var(--ink);grid-column:2;font-size:.85rem;line-height:1.55}.step-timer{border-radius:var(--radius-sm);background:#ecfdf5;border:1px solid #05966933;grid-column:2;align-items:center;gap:.6rem;margin-top:.35rem;padding:.5rem .75rem;display:flex}.timer-clock{font-family:var(--font-num);color:var(--jade-dark);letter-spacing:.03em;font-size:1rem;font-weight:700}.timer-btn{background:var(--jade);color:#fff;cursor:pointer;border:none;border-radius:6px;padding:.3rem .75rem;font-size:.75rem;font-weight:600;transition:background .12s}.timer-btn:hover{background:var(--jade-dark)}.timer-btn:disabled{opacity:.45;cursor:not-allowed}.timer-btn--reset{color:var(--muted);border:1px solid var(--line-strong);background:0 0}.timer-btn--reset:hover{background:var(--surface-2);color:var(--forest)}.btn{cursor:pointer;border:none;border-radius:8px;padding:.5rem 1rem;font-size:.8rem;font-weight:600;transition:background .12s,transform .1s}.btn:active{transform:scale(.97)}.btn--accent{background:var(--jade);color:#fff}.btn--accent:hover{background:var(--jade-dark)}.btn--ghost{border:1.5px solid var(--line-strong);color:var(--ink);background:0 0}.btn--ghost:hover{background:var(--surface-2)}.btn--danger{color:#991b1b;background:#fee2e2;border:1px solid #fca5a5}.btn--danger:hover{background:#fecaca}#shopping-dialog{border:1px solid var(--line);border-radius:var(--radius);max-block-size:80dvh;inline-size:min(520px,92vw);box-shadow:var(--shadow);background:var(--panel);flex-direction:column;padding:0;display:flex;overflow:hidden}#shopping-dialog::backdrop{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#052e1673}@starting-style{#shopping-dialog[open]{opacity:0;transform:translateY(12px)scale(.97)}}#shopping-dialog[open]{opacity:1;transition:opacity .2s,transform .2s;transform:none}.shopping__head{border-bottom:1px solid var(--line);flex-shrink:0;justify-content:space-between;align-items:flex-start;padding:1.25rem 1.5rem 1rem;display:flex}.shopping__heading{font-family:var(--font-display);color:var(--forest);font-size:1.1rem}#shopping-summary{color:var(--muted);margin-top:.2rem;font-size:.75rem}.shopping__close{block-size:2rem;inline-size:2rem;color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:1rem;transition:background .12s;display:flex}.shopping__close:hover{background:var(--surface-2);color:var(--ink)}#shopping-empty{text-align:center;color:var(--muted);padding:2rem 1.5rem;font-size:.85rem;line-height:1.5}#shopping-items{flex:1;padding:.5rem 0;list-style:none;overflow-y:auto}#shopping-items li{border-bottom:1px solid var(--line);align-items:baseline;gap:.6rem;padding:.5rem 1.5rem;display:flex}.s-amount{font-family:var(--font-num);color:var(--jade-dark);flex-shrink:0;min-inline-size:7ch;font-size:.78rem;font-weight:600}.s-name{color:var(--ink);font-size:.85rem}.shopping__actions{border-top:1px solid var(--line);flex-shrink:0;gap:.75rem;padding:1rem 1.5rem;display:flex}@media(prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}@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}
