/* ============================================================
   Cookbook — shared design system
   Extracted verbatim from boeuf-bourguignon_3.html, then extended
   with the two-pane pantry layout (see "PANTRY HOME" block at end).
   ============================================================ */
:root{
  --paper:#EDE4D3; --card:#F8F2E5; --ink:#241C17; --ink-soft:#6F6354;
  --wine:#6A1322; --wine-bright:#94283A; --brass:#A9823F; --line:#D8CBB2;
  --serif:"Palatino Linotype","Book Antiqua",Palatino,"Iowan Old Style",Georgia,serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);line-height:1.55;
  background-image:radial-gradient(circle at 18% 12%,rgba(106,19,34,.04),transparent 45%),radial-gradient(circle at 85% 80%,rgba(169,130,63,.05),transparent 50%);}
.wrap{max-width:760px;margin:0 auto;padding:0 18px 90px}

.topbar{position:sticky;top:0;z-index:30;display:flex;align-items:center;gap:12px;
  background:rgba(237,228,211,.93);backdrop-filter:blur(6px);margin:0 -18px;padding:10px 18px;border-bottom:1px solid var(--line)}
.topbar .mc{font-family:var(--serif);font-size:.95rem;font-weight:700;color:var(--wine);white-space:nowrap}
.minitrack{flex:1;height:6px;background:#e0d4ba;border-radius:6px;overflow:hidden}
#miniFill{height:100%;width:0;background:linear-gradient(90deg,var(--wine),var(--wine-bright));border-radius:6px;transition:width .4s ease}
.reset{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;background:none;border:1px solid var(--line);color:var(--ink-soft);padding:6px 10px;border-radius:20px;cursor:pointer}
.reset:hover{border-color:var(--wine);color:var(--wine)}

header{padding:32px 0 8px;text-align:center}
.eyebrow{font-size:.72rem;letter-spacing:.32em;text-transform:uppercase;color:var(--brass);font-weight:600;margin-bottom:14px}
h1{font-family:var(--serif);font-weight:700;line-height:1.02;margin:0;font-size:clamp(2.5rem,11vw,4.2rem);letter-spacing:-.01em}
h1 .oe{font-style:italic}
.dek{max-width:38ch;margin:14px auto 0;color:var(--ink-soft);font-size:1.02rem}
.chefnote{font-family:var(--serif);font-style:italic;color:var(--wine);margin:16px auto 0;max-width:42ch;font-size:1.02rem}

.glasspanel{display:flex;align-items:center;justify-content:center;gap:22px;margin:24px 0 8px;background:var(--card);border:1px solid var(--line);border-radius:16px;padding:18px}
.glasswrap{width:90px;flex:none}.glasswrap svg{display:block;width:100%;height:auto}
.glassread .gnum{font-family:var(--serif);font-size:1.5rem;font-weight:700;line-height:1.1}
.glassread .glabel{font-size:.76rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.glassread .gphrase{margin-top:6px;font-family:var(--serif);font-style:italic;color:var(--wine);font-size:1rem}

section{margin-top:40px}
.sechead{display:flex;align-items:baseline;gap:12px;border-bottom:2px solid var(--ink);padding-bottom:8px;margin-bottom:16px}
.sechead .sk{font-family:var(--serif);font-size:.95rem;color:var(--brass);font-weight:700}
.sechead h2{font-family:var(--serif);font-size:clamp(1.45rem,5.5vw,2rem);margin:0;font-weight:700;letter-spacing:-.01em}
.lead{color:var(--ink-soft);margin:-2px 0 16px}

.callout{background:#f4ecdb;border-left:3px solid var(--brass);border-radius:0 10px 10px 0;padding:12px 15px;margin-top:14px;font-size:.92rem}
.callout b{color:var(--wine)}

/* scale controls */
.scalebar{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:16px}
.scalebar .srow{display:flex;flex-wrap:wrap;align-items:center;gap:10px}
.scalebar .slab{font-size:.74rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.scalebtns{display:inline-flex;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:var(--paper)}
.scalebtns button{font-family:var(--serif);font-size:.95rem;border:none;background:none;padding:7px 15px;cursor:pointer;color:var(--ink-soft)}
.scalebtns button.on{background:var(--wine);color:#fff}
.servings{font-family:var(--serif);color:var(--wine);font-weight:700;margin-left:auto}
.units{display:inline-flex;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:var(--paper)}
.units button{font-size:.82rem;border:none;background:none;padding:7px 14px;cursor:pointer;color:var(--ink-soft)}
.units button[aria-pressed="true"]{background:var(--ink);color:var(--paper)}
.scalebar .hint{font-size:.8rem;color:var(--ink-soft);margin-top:10px}

/* ingredient table */
.ing{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.ing .row{display:grid;grid-template-columns:1fr auto;gap:6px 14px;padding:12px 16px;border-bottom:1px solid var(--line);align-items:center}
.ing .row:last-child{border-bottom:none}
.ing .name{font-weight:600}
.ing .sub{display:block;font-size:.82rem;color:var(--ink-soft);font-weight:400;margin-top:2px}
.ing .amt{font-family:var(--serif);text-align:right;white-space:nowrap;justify-self:end;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;justify-content:flex-end}
.ing .amt .alt{color:var(--ink-soft);font-size:.9em}
.qin{font-family:var(--serif);font-size:16px;width:4.2em;text-align:right;border:1px solid var(--line);border-radius:8px;padding:5px 7px;background:#fff;color:var(--ink)}
.qin:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:var(--brass)}
.u{font-family:var(--serif);color:var(--ink-soft);font-size:.92em}
.conv{color:var(--ink-soft);font-size:.88em;font-family:var(--serif)}
.ing .grp{background:#f1ead9;padding:8px 16px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);font-weight:700}

.equip{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.equip span{background:var(--card);border:1px solid var(--line);border-radius:20px;padding:6px 13px;font-size:.86rem}

/* timeline */
.timeline{display:grid;gap:12px}
.tl{display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:start;background:var(--card);border:1px solid var(--line);border-radius:12px;padding:14px 16px}
.tl .when{font-family:var(--serif);font-weight:700;color:var(--wine);white-space:nowrap}
.tl .what small{display:block;color:var(--ink-soft);font-size:.84rem;margin-top:2px}

/* steps */
.dayhdr{font-family:var(--serif);font-style:italic;color:var(--wine);font-size:1.15rem;margin:24px 0 12px;display:flex;align-items:center;gap:10px}
.dayhdr::after{content:"";flex:1;height:1px;background:var(--line)}
.step{background:var(--card);border:1px solid var(--line);border-radius:14px;margin-bottom:14px;overflow:hidden;transition:background .3s,border-color .3s}
.step-head{display:flex;align-items:center;gap:14px;padding:16px;cursor:pointer;user-select:none}
.tick{appearance:none;-webkit-appearance:none;flex:none;width:26px;height:26px;border:2px solid var(--wine);border-radius:50%;cursor:pointer;position:relative;background:transparent;transition:background .2s}
.tick:focus-visible{outline:3px solid var(--brass);outline-offset:2px}
.tick:checked{background:var(--wine)}
.tick:checked::after{content:"";position:absolute;left:8px;top:3.5px;width:6px;height:12px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}
.num{font-family:var(--serif);font-size:1.7rem;font-weight:700;color:var(--wine);line-height:1;flex:none;width:1.2em;text-align:center}
.title{font-family:var(--serif);font-size:1.18rem;font-weight:700;flex:1}
.step-body{padding:0 16px 18px 56px}
.step-body ul{margin:0;padding:0;list-style:none}
.step-body li{position:relative;padding:5px 0 5px 18px}
.step-body li::before{content:"";position:absolute;left:0;top:13px;width:6px;height:6px;border-radius:50%;background:var(--brass)}
.step-body b.amt-strong,.step-body strong{font-family:var(--serif)}
.step-body .alt{color:var(--ink-soft);font-weight:400;font-size:.92em}
.tip{margin-top:12px;background:#f3e7e3;border-left:3px solid var(--wine);border-radius:0 10px 10px 0;padding:11px 14px;font-size:.91rem}
.lookcheck{margin-top:10px;background:#edefe6;border-left:3px solid #7d8a5e;border-radius:0 10px 10px 0;padding:11px 14px;font-size:.91rem}
.lookcheck .lc{display:block;font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:#5e6b42;font-weight:700;margin-bottom:3px}
.lookcheck .ref{color:var(--wine);text-decoration:underline;white-space:nowrap;font-weight:600}
.lookcheck .ref:hover{color:var(--wine-bright)}
.stepfig{margin-top:12px;border:1px solid var(--line);border-radius:12px;background:#f6efe0;padding:10px}
.stepfig svg{display:block;width:100%;height:auto;max-height:160px}
.stepfig figcaption{font-size:.74rem;color:var(--ink-soft);text-align:center;margin-top:6px;font-style:italic}
.stepphoto{display:block;width:100%;height:auto;max-height:240px;object-fit:cover;border-radius:8px}
.tip b{color:var(--wine);text-transform:uppercase;font-size:.72rem;letter-spacing:.1em;display:block;margin-bottom:3px}
.step.done{background:#efe6df;border-color:#e2d6c4}
.step.done .title,.step.done .num{color:var(--ink-soft);text-decoration:line-through;text-decoration-thickness:1px}
.step.done .step-body{opacity:.62}
/* injected traditional bits */
li.extra-block{list-style:none;background:#f6efe0;border-left:3px solid var(--brass);border-radius:0 8px 8px 0;padding:7px 11px;margin:7px 0}
li.extra-block::before{display:none}
li.extra-block .xt{display:block;font-size:.66rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);font-weight:700;margin-bottom:2px}

/* extras chooser */
.exwrap{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.exitem{display:flex;gap:12px;padding:13px 16px;border-bottom:1px solid var(--line);cursor:pointer;align-items:flex-start}
.exitem:last-child{border-bottom:none}
.exitem input{appearance:none;-webkit-appearance:none;flex:none;width:24px;height:24px;border:2px solid var(--brass);border-radius:6px;cursor:pointer;position:relative;margin-top:2px;background:#fff}
.exitem input:focus-visible{outline:3px solid var(--wine);outline-offset:2px}
.exitem input:checked{background:var(--brass)}
.exitem input:checked::after{content:"";position:absolute;left:7px;top:2.5px;width:6px;height:12px;border:solid #fff;border-width:0 2.5px 2.5px 0;transform:rotate(45deg)}
.exitem .et{font-weight:600}
.exitem .et .q{font-family:var(--serif);color:var(--wine);font-weight:700}
.exitem .ed{color:var(--ink-soft);font-size:.9rem;margin-top:2px}

/* side recipe cards */
.recipe{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;margin-bottom:14px}
.recipe h3{font-family:var(--serif);font-size:1.3rem;margin:0 0 2px}
.recipe .fr{font-style:italic;color:var(--ink-soft);font-size:.9rem;margin-bottom:8px}
.recipe .meta{font-size:.78rem;letter-spacing:.06em;text-transform:uppercase;color:var(--brass);font-weight:700;margin-bottom:10px}
.recipe .blab{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--wine);font-weight:700;margin:12px 0 4px}
.recipe ul{margin:4px 0;padding-left:18px}
.recipe ul li{margin:3px 0}
.recipe ol{margin:4px 0;padding-left:20px}
.recipe ol li{margin:5px 0}
.recipe .star{display:inline-block;background:var(--wine);color:#fff;font-family:var(--sans);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;border-radius:20px;padding:2px 9px;margin-left:8px;vertical-align:middle}

footer{margin-top:46px;text-align:center;color:var(--ink-soft);font-size:.84rem;border-top:1px solid var(--line);padding-top:20px}
footer .ff{font-family:var(--serif);font-style:italic;color:var(--wine);font-size:1.05rem;margin-bottom:6px}

@media (max-width:440px){
  .glasspanel{flex-direction:column;text-align:center;gap:12px}
  .step-body{padding-left:18px}
  .servings{margin-left:0;width:100%}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}

/* ============================================================
   PANTRY HOME  (index.html) — two-pane Supercook-style layout.
   Reuses the palette + component styles above; only the layout
   shell and the result/picker affordances are new.
   ============================================================ */
.app{max-width:1180px;margin:0 auto;padding:0 18px 80px}

/* top banner of the home page */
.home-top{position:sticky;top:0;z-index:40;display:flex;align-items:center;gap:16px;flex-wrap:wrap;
  background:rgba(237,228,211,.93);backdrop-filter:blur(6px);margin:0 -18px;padding:12px 18px;border-bottom:1px solid var(--line)}
.home-top .brand{font-family:var(--serif);font-weight:700;color:var(--wine);font-size:1.15rem;letter-spacing:-.01em;white-space:nowrap}
.home-top .brand .sub{font-family:var(--sans);font-weight:600;font-size:.66rem;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);display:block;margin-top:1px}
.home-top .counts{margin-left:auto;font-size:.82rem;color:var(--ink-soft);font-family:var(--serif)}
.home-top .counts b{color:var(--wine);font-weight:700}

/* two-pane grid */
.panes{display:grid;grid-template-columns:minmax(300px,38%) 1fr;gap:22px;margin-top:22px;align-items:start}
.pane-pantry{position:sticky;top:74px;max-height:calc(100vh - 96px);overflow:auto;
  background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px}
.pane-results{min-width:0}

/* search box */
.searchwrap{position:relative;margin-bottom:12px}
.searchwrap input{width:100%;font-size:1rem;font-family:var(--sans);padding:11px 14px 11px 38px;border:1px solid var(--line);border-radius:24px;background:#fff;color:var(--ink)}
.searchwrap input:focus{outline:2px solid var(--brass);outline-offset:1px;border-color:var(--brass)}
.searchwrap .si{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:var(--brass);font-size:1rem;pointer-events:none}
.typeahead{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:20;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 8px 24px rgba(36,28,23,.14);overflow:hidden;display:none}
.typeahead.show{display:block}
.ta-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 13px;cursor:pointer;font-size:.92rem}
.ta-item .cat{font-size:.7rem;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-soft)}
.ta-item.active,.ta-item:hover{background:#f1ead9}
.ta-empty{padding:11px 13px;color:var(--ink-soft);font-size:.88rem;font-style:italic}

/* "your kitchen" chips */
.kitchen{margin-bottom:6px}
.kitchen .khead{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.kitchen .khead .kt{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);font-weight:700}
.kitchen .khead .kn{font-family:var(--serif);color:var(--wine);font-weight:700;font-size:.85rem}
.chiprow{display:flex;flex-wrap:wrap;gap:7px;min-height:10px}
.chip{display:inline-flex;align-items:center;gap:7px;background:var(--wine);color:#fff;border:none;border-radius:20px;padding:5px 8px 5px 12px;font-size:.84rem;font-family:var(--sans);cursor:default}
.chip .x{appearance:none;border:none;background:rgba(255,255,255,.22);color:#fff;width:17px;height:17px;border-radius:50%;cursor:pointer;font-size:.8rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;padding:0}
.chip .x:hover{background:rgba(255,255,255,.4)}
.kitchen .empty{color:var(--ink-soft);font-style:italic;font-size:.88rem}

/* staples strip */
.staples{margin:14px 0;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--paper)}
.staples .sthead{display:flex;align-items:center;gap:10px;padding:10px 13px;cursor:pointer;user-select:none}
.staples .sthead .stt{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--brass);font-weight:700;flex:1}
.switch{position:relative;width:38px;height:22px;flex:none}
.switch input{appearance:none;-webkit-appearance:none;width:38px;height:22px;border-radius:22px;background:#d8cbb2;cursor:pointer;margin:0;transition:background .2s}
.switch input:checked{background:var(--wine)}
.switch input::after{content:"";position:absolute;left:3px;top:3px;width:16px;height:16px;border-radius:50%;background:#fff;transition:left .2s}
.switch input:checked::after{left:19px}
.staples .stbody{padding:4px 13px 12px;display:none;flex-wrap:wrap;gap:6px}
.staples.open .stbody{display:flex}
.staples.off .stbody{opacity:.45}
.staple{display:inline-flex;align-items:center;gap:6px;font-size:.83rem;color:var(--ink);cursor:pointer;background:#fff;border:1px solid var(--line);border-radius:18px;padding:4px 10px}
.staple input{appearance:none;-webkit-appearance:none;width:15px;height:15px;border:2px solid var(--brass);border-radius:4px;cursor:pointer;position:relative;margin:0}
.staple input:checked{background:var(--brass)}
.staple input:checked::after{content:"";position:absolute;left:3.5px;top:1px;width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg)}

/* categorized picker */
.cat-block{margin-top:14px}
.cat-block .ch{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);font-weight:700;border-bottom:1px solid var(--line);padding-bottom:5px;margin-bottom:9px}
.pillrow{display:flex;flex-wrap:wrap;gap:7px}
.pill{font-size:.84rem;font-family:var(--sans);background:var(--paper);border:1px solid var(--line);color:var(--ink);border-radius:18px;padding:5px 12px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.pill:hover{border-color:var(--brass)}
.pill.on{background:var(--wine);border-color:var(--wine);color:#fff}

/* results pane */
.results-bar{display:flex;flex-wrap:wrap;align-items:center;gap:10px 14px;margin-bottom:16px}
.results-bar .seg{display:inline-flex;border:1px solid var(--line);border-radius:24px;overflow:hidden;background:var(--paper)}
.results-bar .seg button{font-size:.82rem;border:none;background:none;padding:7px 13px;cursor:pointer;color:var(--ink-soft)}
.results-bar .seg button.on{background:var(--ink);color:var(--paper)}
.results-bar .seg.meal button.on{background:var(--brass);color:#fff}
.results-bar .rlab{font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}

.cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:14px}
.rcard{display:block;text-decoration:none;color:inherit;background:var(--card);border:1px solid var(--line);border-radius:14px;padding:16px 18px;transition:transform .12s ease,box-shadow .12s ease,border-color .12s}
.rcard:hover{transform:translateY(-2px);box-shadow:0 10px 22px rgba(36,28,23,.10);border-color:var(--brass)}
.rcard h3{font-family:var(--serif);font-size:1.25rem;margin:0 0 3px;color:var(--ink)}
.rcard .rmeta{font-size:.74rem;letter-spacing:.05em;text-transform:uppercase;color:var(--brass);font-weight:700;margin-bottom:12px}
.rcard .rstatus{display:inline-flex;align-items:center;gap:8px;font-size:.86rem;font-weight:600}
.rcard .rstatus .dot{width:9px;height:9px;border-radius:50%;flex:none}
.rcard.ready .rstatus{color:#5e6b42}
.rcard.ready .rstatus .dot{background:#7d8a5e}
.rcard.almost .rstatus{color:var(--wine)}
.rcard.almost .rstatus .dot{background:var(--brass)}
.rcard .rmiss{display:block;color:var(--ink-soft);font-weight:400;font-size:.84rem;margin-top:3px}
.rcard .badge{display:inline-block;background:var(--wine);color:#fff;font-size:.62rem;letter-spacing:.08em;text-transform:uppercase;border-radius:20px;padding:2px 9px;margin-left:8px;vertical-align:middle;font-weight:700}

.empty-results{background:var(--card);border:1px dashed var(--line);border-radius:14px;padding:40px 22px;text-align:center;color:var(--ink-soft)}
.empty-results .er-em{font-family:var(--serif);font-style:italic;color:var(--wine);font-size:1.1rem;margin-bottom:6px}

/* mobile: collapse to one column, pantry becomes a drawer */
.kitchen-toggle{display:none}
@media (max-width:900px){
  .panes{grid-template-columns:1fr}
  .pane-pantry{position:fixed;inset:0;z-index:60;max-height:none;border-radius:0;margin:0;
    transform:translateX(-100%);transition:transform .25s ease;overflow:auto}
  .pane-pantry.open{transform:none}
  .kitchen-toggle{display:inline-flex;align-items:center;gap:8px;font-size:.82rem;letter-spacing:.06em;text-transform:uppercase;
    background:var(--wine);color:#fff;border:none;border-radius:22px;padding:9px 16px;cursor:pointer;font-weight:600}
  .pane-pantry .closebar{display:flex;justify-content:flex-end;margin-bottom:6px}
  .pane-pantry .closebar button{font-size:.9rem;background:none;border:1px solid var(--line);border-radius:20px;padding:6px 12px;cursor:pointer;color:var(--ink-soft)}
}
@media (min-width:901px){
  .pane-pantry .closebar{display:none}
}

/* ============================================================
   IMAGE-GENERATION PROMPT placeholders (recipe pages).
   A copyable box shown where a photo/illustration should go.
   ============================================================ */
.imgprompt{margin-top:10px;border:1px dashed var(--brass);border-radius:10px;background:#f7f0e1;padding:10px 12px}
.imgprompt .ip-head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.imgprompt .ip-tag{font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);font-weight:700}
.imgprompt .ip-copy{margin-left:auto;font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--line);background:var(--paper);color:var(--ink-soft);border-radius:16px;padding:4px 11px;cursor:pointer;font-weight:600}
.imgprompt .ip-copy:hover{border-color:var(--brass);color:var(--wine)}
.imgprompt .ip-text{font-size:.82rem;color:var(--ink);line-height:1.5;font-family:var(--sans)}
/* hero prompt (no figure around it) sits a little prouder */
.glasspanel + .imgprompt, .callout + .imgprompt{margin-top:14px}

/* scaling-trap note reuses the callout look but flagged green like a check */
.callout.scale-note{background:#edefe6;border-left-color:#7d8a5e}
.callout.scale-note b{color:#4f5b39}

/* ============================================================
   SIDE DISHES as full scalable mini-recipes.
   Builds on .recipe card styles already defined above.
   ============================================================ */
.recipe.sidefull .meta .sideserves{color:var(--brass)}
.recipe .sideshop{list-style:none;margin:6px 0 2px;padding:0}
.recipe .sideshop li{display:flex;justify-content:space-between;gap:14px;align-items:baseline;padding:6px 0;border-bottom:1px dotted var(--line)}
.recipe .sideshop li:last-child{border-bottom:none}
.recipe .sideshop .sname small{color:var(--ink-soft)}
.recipe .sideshop .samt{font-family:var(--serif);color:var(--wine);white-space:nowrap;text-align:right}
.recipe .blab .sideprog{font-family:var(--serif);color:var(--ink-soft);font-weight:700;margin-left:8px;font-size:.92em;text-transform:none;letter-spacing:0}
.recipe .sidesteps{margin-top:6px}
.recipe .sidesteps .step{margin-bottom:10px;border-radius:12px}
.recipe .sidesteps .step-head{padding:13px 14px;gap:12px}
.recipe .sidesteps .tick{width:23px;height:23px}
.recipe .sidesteps .tick:checked::after{left:7px;top:3px;height:11px}
.recipe .sidesteps .num{font-size:1.35rem;width:1em}
.recipe .sidesteps .title{font-size:1.04rem}
.recipe .sidesteps .step-body{padding:0 14px 14px 46px}
.recipe .sidescalenote{margin-top:8px;background:#edefe6;border-left:3px solid #7d8a5e;border-radius:0 10px 10px 0;padding:9px 12px;font-size:.84rem;color:#4f5b39}
@media (max-width:440px){
  .recipe .sidesteps .step-body{padding-left:16px}
}

/* hero + side-dish photos */
.herofig{margin:18px 0 4px}
.herofig figcaption{font-size:.74rem;color:var(--ink-soft);text-align:center;margin-top:6px;font-style:italic}
.heroimg{display:block;width:100%;height:auto;max-height:440px;object-fit:cover;border-radius:16px;border:1px solid var(--line)}
.recipe .sideimg{display:block;width:100%;height:auto;max-height:240px;object-fit:cover;border-radius:12px;border:1px solid var(--line);margin:10px 0 2px}

/* shopping list + AI shopping prompt */
.shoplist{background:var(--card);border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:14px}
.shoplist .grp{background:#f1ead9;padding:8px 16px;font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);font-weight:700}
.shopul{list-style:none;margin:0;padding:0}
.shopul li{display:flex;justify-content:space-between;gap:14px;align-items:baseline;padding:9px 16px;border-bottom:1px solid var(--line)}
.shopul li:last-child{border-bottom:none}
.shopul .sname{font-weight:600}
.shopul .samt{font-family:var(--serif);color:var(--wine);white-space:nowrap;text-align:right}
.shopbtns{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px}
.aiprompt .ai-text{white-space:pre-wrap;font-family:var(--sans);font-size:.82rem;line-height:1.5}

/* the Print / PDF button in the recipe topbar (screen) */
.reset.print-btn{background:var(--wine);border-color:var(--wine);color:#fff;white-space:nowrap}
.reset.print-btn:hover{background:var(--wine-bright);border-color:var(--wine-bright);color:#fff}
.reset{white-space:nowrap}

/* ============================================================
   PRINT / EXPORT TO PDF
   Click "Print / PDF" on a recipe page, then choose "Save as PDF"
   in the browser dialog. The sheet reflects the current batch size,
   units and switched-on add-ins. Designed for clean page breaks,
   selectable vector text, and minimal ink.
   ============================================================ */
@media print {
  @page { margin: 14mm 14mm 16mm; }
  html, body { background: #fff !important; }
  body { background-image: none !important; color: #1c1612; font-size: 10.8pt; line-height: 1.45; }
  .wrap { max-width: none; margin: 0; padding: 0; }

  /* hide interactive-only chrome (keep the tick boxes — handy on paper) */
  .topbar, .glasspanel, .howto-note, .scalebtns, .units-row,
  .scalebar .hint, .scalebar .slab, .imgprompt, .shopbtns,
  .lookcheck .ref, .print-btn, #resetBtn, .kitchen-toggle { display: none !important; }

  /* scalebar collapses to a plain "serves ~N" line */
  .scalebar { background: none !important; border: none; padding: 0; margin: 0 0 12px; }
  .scalebar .srow { gap: 0; }
  .servings { margin: 0; font-size: 1.05rem; }

  /* editable amount fields print as plain text, not input boxes */
  .qin { -webkit-appearance: none; appearance: none; border: none !important; background: none !important;
         padding: 0; width: auto; min-width: 2em; font-weight: 700; color: var(--wine); }

  /* white cards + their borders; drop heavy fills to save ink */
  .ing, .step, .tl, .recipe, .callout, .exwrap, .scalebar, .equip span,
  .tip, .lookcheck, .stepfig, .step.done, .shoplist { background: #fff !important; }
  .ing .grp, .shoplist .grp { background: #fff !important; border-bottom: 1px solid var(--line); }
  .shopul li { break-inside: avoid; page-break-inside: avoid; }
  .step.done { opacity: 1; }
  .step.done .step-body { opacity: 1; }

  /* keep checkbox fills/marks and accent colours when printing */
  .tick, .exitem input, .num, h1, .sechead h2, .recipe h3, .dayhdr,
  .step.done .title, .step.done .num {
    -webkit-print-color-adjust: exact; print-color-adjust: exact;
  }

  /* page-break control — no orphaned headings, no split steps/figures */
  h1, h2, h3, .sechead, .dayhdr, .blab { break-after: avoid-page; page-break-after: avoid; }
  .step, .tl, .recipe, .callout, .exitem, .ing .row, .stepfig, figure,
  .lookcheck, .tip, .glassread, .recipe .sidesteps .step {
    break-inside: avoid; page-break-inside: avoid;
  }
  .stepphoto, .stepfig svg { max-height: 66mm; }
  .heroimg { max-height: 80mm; }
  .recipe .sideimg { max-height: 52mm; }
  img, svg { max-width: 100% !important; }

  /* paper spacing */
  section { margin-top: 16px; }
  header { padding: 0 0 6px; }
  .step { margin-bottom: 9px; }
  .recipe { margin-bottom: 10px; }
  a { color: inherit; text-decoration: none; }
}
