/* Menu & Recipe Builder (R2) — shared module styles for the
   Dishes / Components / Ingredients pages. Uses the portal's --color-*
   tokens (defined in shared/styles.css), so per-site theming applies. */

/* ---- sub-nav ---- */
.rb-nav { display:flex; gap:0.4rem; flex-wrap:wrap; margin:0.4rem 0 1.2rem; }
.rb-nav a {
  padding:0.4rem 0.9rem; border-radius:var(--radius-pill); text-decoration:none;
  font-size:0.85rem; font-weight:600; color:var(--color-text-muted);
  border:1px solid var(--color-border); background:var(--color-surface);
}
.rb-nav a.on { background:var(--color-primary); color:#fff; border-color:var(--color-primary); }
.rb-nav a:hover:not(.on) { border-color:var(--color-accent); }

/* two-row workspace nav: primary tabs + a lighter secondary strip below a
   divider. Rendered by GRAND.renderModuleNav into the .rb-nav host. */
.rb-nav-wrap { display:flex; flex-direction:column; gap:0.5rem; margin:0.5rem 0 1.2rem; }
.rb-nav-wrap .rb-nav { margin:0; }
.rb-nav.rb-primary a { font-size:0.9rem; padding:0.42rem 0.95rem; }
.rb-nav.rb-secondary { gap:0.3rem; padding-top:0.5rem; border-top:1px solid var(--color-border); }
.rb-nav.rb-secondary a { padding:0.26rem 0.7rem; font-size:0.76rem; }
.rb-nav.rb-secondary a.on { background:var(--color-accent); color:#fff; border-color:var(--color-accent); }
/* catalogue type switch (Ingredients / Drink products / Non-food) */
.rb-nav.rb-cattype { align-items:center; gap:0.35rem; padding:0.45rem 0.6rem; margin-top:0.1rem; background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-md); }
.rb-nav.rb-cattype .rb-cat-label { font-size:0.6rem; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:var(--color-text-muted); margin-right:0.2rem; }
.rb-nav.rb-cattype a { padding:0.3rem 0.85rem; font-size:0.82rem; background:var(--color-bg); }
.rb-nav.rb-cattype a.on { background:var(--color-primary); color:#fff; border-color:var(--color-primary); }

/* ---- filters ---- */
.rb-filters { display:flex; gap:0.5rem; flex-wrap:wrap; align-items:center; margin-bottom:1rem; }
.rb-input {
  padding:0.45rem 0.6rem; border:1px solid var(--color-border); border-radius:var(--radius-md);
  font:inherit; font-size:0.85rem; background:var(--color-surface); color:var(--color-text);
}
.rb-input:focus { outline:none; border-color:var(--color-accent); }
/* In the filter bar, controls size to content and sit on one tidy row
   (the global input/select width:100% would otherwise stack them full-width). */
.rb-filters .rb-input { width:auto; flex:0 0 auto; }
.rb-filters select.rb-input { min-width:0; max-width:200px; }
.rb-filters #rb-search { flex:1 1 200px; min-width:160px; }
.rb-count { font-size:0.8rem; color:var(--color-text-muted); align-self:center; margin-left:auto; }

/* ---- card grid ---- */
.rb-grid { display:grid; grid-template-columns:repeat(auto-fill, minmax(210px,1fr)); gap:0.55rem; }
.dish-card {
  text-align:left; cursor:pointer; background:var(--color-surface);
  border:1px solid var(--color-border); border-radius:var(--radius-md);
  padding:0.6rem 0.7rem; display:flex; flex-direction:column; gap:0.28rem; transition:.12s; font:inherit; color:inherit;
}
.dish-card:hover { border-color:var(--color-accent); box-shadow:0 6px 18px rgba(47,93,116,.08); }

/* multi-select merge mode (Ingredients list) */
.dish-card { position:relative; }
.dish-card.sel-on { border-color:var(--color-primary); box-shadow:0 0 0 2px var(--color-primary) inset; }
.sel-tick { position:absolute; top:8px; right:8px; width:22px; height:22px; border-radius:50%; border:2px solid var(--color-border); background:var(--color-surface); display:none; align-items:center; justify-content:center; font-size:0.78rem; font-weight:800; color:#fff; line-height:1; }
.rb-grid.selecting .sel-tick { display:flex; }
.dish-card.sel-on .sel-tick { background:var(--color-primary); border-color:var(--color-primary); }
.merge-bar { position:fixed; left:50%; transform:translateX(-50%); bottom:1rem; z-index:50; background:var(--color-surface); border:1px solid var(--color-border); box-shadow:0 10px 30px rgba(0,0,0,.18); border-radius:var(--radius-lg); padding:0.7rem 0.9rem; display:flex; gap:0.6rem; align-items:center; flex-wrap:wrap; max-width:calc(100vw - 2rem); }
.merge-bar select { max-width:240px; }
.merge-bar .mb-count { font-weight:700; color:var(--color-primary); white-space:nowrap; }

/* supplier dashboard (shared: standalone page + insights slide-in) */
.sv-head { display:flex; gap:0.6rem; align-items:baseline; flex-wrap:wrap; }
.sv-type { font-size:0.66rem; font-weight:700; text-transform:uppercase; letter-spacing:.04em; padding:0.12rem 0.55rem; border-radius:var(--radius-pill); background:rgba(47,93,116,.12); color:var(--color-primary); }
.sv-contact { color:var(--color-text-muted); font-size:0.84rem; margin:0.3rem 0 0; }
.sv-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:0.6rem; margin:0.9rem 0 1rem; }
.sv-stat { background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:0.7rem 0.8rem; }
.sv-stat .n { font-size:1.3rem; font-weight:800; color:var(--color-primary); font-variant-numeric:tabular-nums; line-height:1.1; }
.sv-stat .l { font-size:0.66rem; color:var(--color-text-muted); text-transform:uppercase; letter-spacing:.03em; margin-top:0.15rem; }
.sv-grid { display:grid; grid-template-columns:1fr 1fr; gap:0.8rem; }
.sv-panel { background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:0.8rem 0.9rem; }
.sv-panel h4 { margin:0 0 0.1rem; font-size:0.98rem; }
.sv-sub { color:var(--color-text-muted); font-size:0.78rem; margin:0 0 0.6rem; }
.sv-bar-row { display:grid; grid-template-columns:minmax(80px,1.3fr) 2.4fr auto; gap:0.5rem; align-items:center; margin-bottom:0.35rem; }
.sv-bar-label { font-size:0.84rem; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.sv-bar { background:var(--color-bg); border-radius:999px; height:12px; overflow:hidden; }
.sv-bar-fill { display:block; height:100%; background:var(--color-primary); border-radius:999px; }
.sv-bar-val { font-variant-numeric:tabular-nums; font-weight:700; font-size:0.82rem; white-space:nowrap; }
.sv-list-row { display:flex; justify-content:space-between; gap:0.6rem; align-items:baseline; padding:0.35rem 0; border-bottom:1px solid var(--color-border); font-size:0.86rem; flex-wrap:wrap; }
/* interactive price sparkline (insights / supplier quick-view) */
.spk-wrap { position:relative; background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:0.5rem 0.6rem; }
.spk-wrap svg { display:block; overflow:visible; }
.spk-dot { transition:r .1s; }
.spk-dot:hover { r:6; }
.spk-tip { position:absolute; transform:translate(-50%,-100%); background:var(--color-text); color:#fff; font-size:0.72rem; line-height:1.35; padding:0.35rem 0.5rem; border-radius:6px; pointer-events:none; opacity:0; transition:opacity .1s; white-space:nowrap; z-index:6; box-shadow:0 4px 14px rgba(0,0,0,.22); }
.spk-tip.on { opacity:1; }
.spk-tip-link { color:var(--color-accent-light, #e2be9f); }
/* colour-coded recent-price list */
.pr-list { margin-top:0.2rem; }
.pr-row { display:grid; grid-template-columns:1fr auto auto; gap:0.7rem; align-items:center; padding:0.45rem 0.6rem; border-bottom:1px solid var(--color-border); border-radius:var(--radius-sm); }
.pr-row:hover { background:var(--color-bg); }
.pr-main { display:flex; gap:0.45rem; align-items:baseline; flex-wrap:wrap; font-size:0.84rem; min-width:0; }
.pr-date { font-weight:700; }
.pr-sup { color:var(--color-text-muted); }
.pr-price { font-weight:800; font-variant-numeric:tabular-nums; white-space:nowrap; font-size:0.92rem; }
.pr-delta { font-size:0.72rem; font-weight:800; font-variant-numeric:tabular-nums; white-space:nowrap; }
.pr-delta.up { color:var(--color-danger); } .pr-delta.down { color:var(--color-success); }
.pr-tag { font-size:0.56rem; font-weight:800; text-transform:uppercase; letter-spacing:.03em; padding:0.06rem 0.4rem; border-radius:var(--radius-pill); }
.pr-tag.cheap { background:rgba(90,139,90,.16); color:#2f6e48; }
.pr-tag.dear { background:rgba(181,58,43,.14); color:var(--color-danger); }
.pr-note { font-size:0.76rem; color:var(--color-warning); margin:0.35rem 0 0; }
.sv-list-row:last-child { border-bottom:0; }
.sv-flux { color:var(--color-warning); font-weight:700; font-variant-numeric:tabular-nums; }
.sv-cheap { color:var(--color-success); font-weight:800; font-size:0.72rem; text-transform:uppercase; }
.sv-inv-list { display:flex; flex-direction:column; }
.sv-inv { display:grid; grid-template-columns:auto 1fr auto auto; gap:0.6rem; align-items:baseline; padding:0.4rem 0; border-bottom:1px solid var(--color-border); font-size:0.86rem; }
.sv-inv:last-child { border-bottom:0; }
.sv-inv-no { font-weight:700; } .sv-inv-total { font-variant-numeric:tabular-nums; font-weight:700; } .sv-inv-acts { white-space:nowrap; }
.linklike { background:none; border:0; padding:0; color:var(--color-primary); font:inherit; cursor:pointer; text-decoration:underline; }
@media (max-width:780px){ .sv-stats{grid-template-columns:repeat(2,1fr);} .sv-grid{grid-template-columns:1fr;} .sv-inv{grid-template-columns:auto 1fr auto;} .sv-inv .sv-inv-acts{grid-column:1/-1;} }
/* compact ingredient quick-view (insights slide-in) */
.qv-cost { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--color-border); border:1px solid var(--color-border); border-radius:var(--radius-md); overflow:hidden; margin:0.5rem 0; }
.qv-cell { background:var(--color-surface); padding:0.6rem; } .qv-cell.off { background:rgba(199,123,46,.08); box-shadow:inset 0 0 0 2px var(--color-warning); }
.qv-cell .v { font-size:1.1rem; font-weight:800; color:var(--color-primary); } .qv-cell .s { font-size:0.66rem; color:var(--color-text-muted); text-transform:uppercase; }

/* purchase-intelligence chip (card) + panel (detail) */
.buy-stat { font-size:0.72rem; font-weight:600; color:var(--color-text-muted); font-variant-numeric:tabular-nums; }
.buy-stat.split { color:var(--color-warning); }
.buy-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:0.5rem; }
.buy-cell { background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:0.5rem; text-align:center; }
.bc-n { display:block; font-size:1.15rem; font-weight:800; color:var(--color-primary); font-variant-numeric:tabular-nums; line-height:1.1; }
.bc-l { display:block; font-size:0.66rem; color:var(--color-text-muted); text-transform:uppercase; letter-spacing:.03em; margin-top:0.15rem; }
@media (max-width:480px) { .buy-grid { grid-template-columns:repeat(2, 1fr); } }
.dish-card h3 { margin:0; font-size:0.95rem; line-height:1.2; }
.dish-card .dc-meta { display:flex; gap:0.35rem; flex-wrap:wrap; align-items:center; }
.dc-gp { margin-left:auto; font-variant-numeric:tabular-nums; font-weight:700; }
.dc-gp.good { color:var(--color-success); } .dc-gp.bad { color:var(--color-danger); }
.dc-cost { font-variant-numeric:tabular-nums; color:var(--color-text-muted); font-size:0.85rem; }

/* A11: per-dish cost-ceiling chips (cost vs ceiling, per site) */
.mcc-strip { display:inline-flex; gap:0.3rem; flex-wrap:wrap; align-items:center; }
.mcc-chip { display:inline-flex; align-items:center; gap:0.3rem; font-size:0.72rem; font-weight:700; font-variant-numeric:tabular-nums; padding:0.1rem 0.45rem; border-radius:var(--radius-pill); border:1px solid transparent; white-space:nowrap; }
.mcc-chip .mcc-site { font-size:0.6rem; font-weight:800; text-transform:uppercase; letter-spacing:.03em; opacity:.8; }
.mcc-green { background:rgba(90,139,90,.16); color:var(--color-success); border-color:rgba(90,139,90,.35); }
.mcc-amber { background:rgba(199,123,46,.16); color:var(--color-warning); border-color:rgba(199,123,46,.4); }
.mcc-red { background:rgba(181,58,43,.14); color:var(--color-danger); border-color:rgba(181,58,43,.4); }
.mcc-ceil-l { font-size:0.78rem; display:inline-flex; align-items:center; gap:0.25rem; color:var(--color-text-muted); }
.mcc-summary { font-size:0.76rem; color:var(--color-text-muted); margin:0.15rem 0 0; display:flex; gap:0.45rem; flex-wrap:wrap; align-items:center; }
.mcc-sum { font-variant-numeric:tabular-nums; }
.mcc-sum.good { color:var(--color-success); } .mcc-sum.bad { color:var(--color-danger); font-weight:700; }
.mcc-signal { font-size:0.82rem; font-weight:600; padding:0.4rem 0.6rem; border-radius:var(--radius-sm); margin-bottom:0.6rem; }
.mcc-signal.good { background:rgba(90,139,90,.12); color:var(--color-success); }
.mcc-signal.bad { background:rgba(181,58,43,.1); color:var(--color-danger); }

.pill {
  display:inline-flex; align-items:center; font-size:0.68rem; font-weight:700; letter-spacing:.04em;
  padding:0.12rem 0.5rem; border-radius:var(--radius-pill); text-transform:uppercase;
}
.pill.course { background:rgba(47,93,116,.1); color:var(--color-primary); }
.pill.status-draft { background:rgba(199,123,46,.16); color:var(--color-warning); }
.pill.status-in_review { background:rgba(47,93,116,.12); color:var(--color-primary); }
.pill.status-ready_to_publish { background:rgba(90,139,90,.16); color:var(--color-success); }
.pill.status-published { background:var(--color-primary); color:#fff; }
.tagchip { font-size:0.7rem; padding:0.12rem 0.5rem; border-radius:var(--radius-pill); background:var(--color-bg); border:1px solid var(--color-border); color:var(--color-text); }
.algchip { font-size:0.7rem; padding:0.12rem 0.5rem; border-radius:var(--radius-pill); background:rgba(209,152,116,.16); color:var(--color-accent-dark); }

/* ---- slide-over ---- */
.scrim { position:fixed; inset:0; background:var(--color-overlay); opacity:0; pointer-events:none; transition:.18s; z-index:60; }
.scrim.on { opacity:1; pointer-events:auto; }
.sheet {
  position:fixed; top:0; right:0; height:100vh; height:100dvh; width:min(680px,100vw); background:var(--color-bg);
  box-shadow:-8px 0 30px rgba(0,0,0,.18); transform:translateX(100%); transition:transform .22s, width .22s; z-index:61;
  overflow-y:auto; overscroll-behavior:contain; -webkit-overflow-scrolling:touch;
}
/* the read-first Cook view takes more of the screen so ingredients + method sit side by side on tablet/desktop */
.sheet.cook-wide { width:min(1120px,100vw); }
/* lock the page behind while a slide-over is open so touch scroll stays in the sheet */
body.sheet-open { overflow:hidden; }
.sheet.on { transform:none; }
/* stacked sub-panels: a recipe/ingredient editor opened on top of a dish, breadcrumb back */
.sheet.sub { width:min(640px,96vw); box-shadow:-22px 0 55px rgba(0,0,0,.30); }
.ln-name.ln-open { cursor:pointer; }
.ln-name.ln-open:hover { text-decoration:underline; }
.sheet-h { position:sticky; top:0; background:var(--color-primary); color:#fff; padding:1rem 1.2rem; display:flex; justify-content:space-between; align-items:center; gap:0.8rem; z-index:2; }
.sheet-h h2 { margin:0; font-size:1.15rem; }
.sheet-x { background:none; border:0; color:#fff; font-size:1.5rem; line-height:1; cursor:pointer; opacity:.85; }
.sheet-x:hover { opacity:1; }
.sheet-back { background:none; border:0; color:#fff; font-size:0.95rem; font-weight:600; cursor:pointer; opacity:.9; white-space:nowrap; }
.sheet-back:hover { opacity:1; }
.sheet-b { padding:1.2rem; }
.sec { background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg); padding:0.8rem 0.95rem; margin-bottom:0.7rem; }
.sec h4 { margin:0 0 0.5rem; font-size:0.74rem; text-transform:uppercase; letter-spacing:.06em; color:var(--color-text-muted); }
.fld { margin-bottom:0.6rem; }
.fld:last-child { margin-bottom:0; }
.fld label { display:block; font-size:0.72rem; font-weight:700; color:var(--color-text-muted); margin-bottom:0.2rem; text-transform:uppercase; letter-spacing:.03em; }
.fld.compact { margin-bottom:0; }
.fld.compact textarea { min-height:36px; }
.fld input, .fld select, .fld textarea {
  width:100%; padding:0.55rem 0.65rem; border:1px solid var(--color-border); border-radius:var(--radius-md);
  font:inherit; font-size:0.9rem; background:var(--color-surface); color:var(--color-text);
}
.fld textarea { min-height:80px; resize:vertical; }
.two { display:grid; grid-template-columns:1fr 1fr; gap:0.7rem; }
.three { display:grid; grid-template-columns:1.4fr 0.8fr 1.1fr; gap:0.6rem; align-items:end; }
@media (max-width:440px) { .three { grid-template-columns:1fr 1fr; } }
.toggle { display:inline-block; font-size:0.78rem; font-weight:600; padding:0.35rem 0.7rem; border-radius:var(--radius-pill); background:var(--color-surface); border:1.5px solid var(--color-border); color:var(--color-text-muted); cursor:pointer; margin:0 0.35rem 0.35rem 0; }
.toggle.on { background:var(--color-primary); border-color:var(--color-primary); color:#fff; }

/* A9 — HACCP process target params */
.haccp-row { display:flex; align-items:center; gap:0.6rem; flex-wrap:wrap; padding:0.5rem 0.6rem; background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-md); margin-bottom:0.45rem; }
.haccp-row-label { font-weight:700; font-size:0.82rem; min-width:6.5rem; }
.haccp-param { display:flex; flex-direction:column; gap:0.15rem; }
.haccp-param span { font-size:0.66rem; text-transform:uppercase; letter-spacing:.03em; color:var(--color-text-muted); }
.haccp-param .haccp-input { width:5.5rem; font-variant-numeric:tabular-nums; }

.line { display:flex; align-items:center; gap:0.5rem; padding:0.28rem 0; border-top:1px solid var(--color-border); }
.line.pending { opacity:0.55; animation:line-pending 0.9s ease-in-out infinite alternate; }
@keyframes line-pending { from { opacity:0.4; } to { opacity:0.7; } }
.line .ln-qty, .line .ln-unit-select { padding-top:0.3rem; padding-bottom:0.3rem; }
.line:first-of-type { border-top:0; }
.line .ln-name { flex:1; font-weight:600; font-size:0.9rem; }
.line .ln-name .ln-sub { display:block; font-weight:400; font-size:0.72rem; color:var(--color-text-muted); }
.line .ln-qty { width:74px; }
.line .ln-unit { width:58px; color:var(--color-text-muted); font-size:0.82rem; }
.line .ln-unit-input { width:64px; font-size:0.82rem; padding:0.35rem 0.4rem; }
.line .ln-unit-select { width:72px; font-size:0.82rem; padding:0.34rem 0.3rem; }

/* ---- "Used in" panel (ingredient detail) ---- */
.use-h { font-size:0.66rem; text-transform:uppercase; letter-spacing:.05em; color:var(--color-text-muted); font-weight:800; margin:0.6rem 0 0.3rem; }
.use-h:first-child { margin-top:0; }
.use-row { display:flex; align-items:center; gap:0.5rem; flex-wrap:wrap; padding:0.32rem 0; border-bottom:1px solid var(--color-border); }
.use-row:last-child { border-bottom:0; }
.use-row a { font-weight:600; font-size:0.88rem; }
.use-sub { font-size:0.76rem; color:var(--color-text-muted); }
.use-status { font-size:0.64rem; text-transform:uppercase; letter-spacing:.03em; color:var(--color-text-muted); }
.use-tag { font-size:0.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.03em; padding:0.1rem 0.45rem; border-radius:var(--radius-pill); margin-left:auto; }
.use-tag.live { background:rgba(90,139,90,.16); color:var(--color-success); }
.use-tag.onmenu { background:rgba(47,93,116,.12); color:var(--color-primary); }
.use-tag.unused { background:var(--color-bg); color:var(--color-text-muted); }
.line .ln-cost { width:70px; text-align:right; font-variant-numeric:tabular-nums; color:var(--color-text-muted); font-size:0.85rem; }
.line .ln-del { background:none; border:0; color:var(--color-danger); cursor:pointer; font-size:1.05rem; opacity:.6; }
.line .ln-del:hover { opacity:1; }
.line .ln-change { background:none; border:0; color:var(--color-text-muted); cursor:pointer; font-size:1rem; opacity:.6; }
.line .ln-change:hover { opacity:1; color:var(--color-primary); }
.relinking { outline:2px solid var(--color-accent); outline-offset:2px; border-radius:var(--radius-md); }
.line.dragging { opacity:0.45; }
.line .ln-drag { font-size:1rem; line-height:1; }
.line .ln-drag:active { cursor:grabbing; }
.line .ln-note { flex:1 1 160px; min-width:130px; border-style:dashed; color:var(--color-text-muted); font-size:0.8rem; padding:0.3rem 0.5rem; }
.line .ln-note.hide { display:none; }
.line .ln-notebtn { background:none; border:0; color:var(--color-text-muted); cursor:pointer; font-size:0.92rem; opacity:.5; padding:0; }
.line .ln-notebtn:hover { opacity:1; color:var(--color-primary); }
.line .ln-notebtn.on { opacity:1; color:var(--color-primary); }
.reuse-badge { font-size:0.62rem; font-weight:700; padding:0.05rem 0.4rem; border-radius:var(--radius-pill); background:rgba(47,93,116,.12); color:var(--color-primary); margin-left:0.35rem; }

.sugg { position:relative; }
.sugg-list { position:absolute; left:0; right:0; top:calc(100% + 4px); background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-md); box-shadow:0 12px 30px rgba(0,0,0,.12); z-index:9; max-height:260px; overflow-y:auto; }
.sugg-item { padding:0.6rem 0.7rem; cursor:pointer; border-top:1px solid var(--color-border); display:flex; justify-content:space-between; gap:0.6rem; align-items:center; font-size:0.88rem; }
.sugg-item:first-child { border-top:0; }
.sugg-item:hover, .sugg-item.active { background:var(--color-bg); }
.sugg-item.new { color:var(--color-primary); font-weight:600; }
/* type distinction in the build search: recipes (navy) vs ingredients (green) */
.sugg-item.t-ingredient { border-left:3px solid #5a8b5a; }
.sugg-item.t-recipe { border-left:3px solid var(--color-primary); }
.sugg-nm { font-weight:600; }
.sugg-badge { font-size:0.58rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; padding:0.07rem 0.42rem; border-radius:var(--radius-pill); margin-right:0.4rem; white-space:nowrap; }
.sugg-badge.ingredient { background:rgba(90,139,90,.18); color:#2f6e48; }
.sugg-badge.recipe { background:rgba(47,93,116,.16); color:var(--color-primary); }
.sugg-item.new.t-ingredient { color:#2f6e48; }
.sugg-item.new.t-recipe { color:var(--color-primary); }
/* estimated (draft) price marker */
.est-badge { font-size:0.6rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; padding:0.07rem 0.45rem; border-radius:var(--radius-pill); background:rgba(199,123,46,.16); color:#8a5524; margin-left:0.35rem; }

/* ---- per-site cost/GP box ---- */
.gp-sites { display:grid; grid-template-columns:repeat(3,1fr); gap:1px; background:var(--color-border); border:1px solid var(--color-border); border-radius:var(--radius-md); overflow:hidden; }
.gp-site { background:var(--color-surface); padding:0.7rem 0.6rem; }
.gp-site .gs-name { font-size:0.66rem; text-transform:uppercase; letter-spacing:.05em; color:var(--color-text-muted); }
.gp-site .gs-gp { font-size:1.15rem; font-weight:800; margin-top:0.15rem; font-variant-numeric:tabular-nums; }
.gp-site .gs-gp.good { color:var(--color-success); } .gp-site .gs-gp.bad { color:var(--color-danger); }
.gp-site .gs-cost { font-size:0.76rem; color:var(--color-text-muted); font-variant-numeric:tabular-nums; }
.gp-site .gs-prov { font-size:0.66rem; color:var(--color-warning); }
.gp-site.price-off { background:rgba(199,123,46,.08); box-shadow:inset 0 0 0 2px var(--color-warning); }
.gp-site .off-flag { color:var(--color-warning); font-weight:700; }
.gp-site .gs-inv { display:inline-block; font-size:0.72rem; font-weight:600; color:var(--color-primary); margin-top:0.3rem; }
.auto-note { font-size:0.74rem; color:var(--color-text-muted); margin-top:0.5rem; }
.save-state { font-size:0.74rem; color:var(--color-text-muted); }

/* ---- live price <-> GP recommendation ---- */
.price-reco { margin-top:0.5rem; padding:0.55rem 0.7rem; background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-md); font-size:0.82rem; }
.price-reco .reco-line { display:flex; align-items:baseline; gap:0.35rem 0.5rem; flex-wrap:wrap; }
.price-reco .reco-line + .reco-line { margin-top:0.4rem; }
.price-reco .reco-muted { color:var(--color-text-muted); }
.price-reco .reco-rec { font-weight:800; font-size:1.05rem; color:var(--color-primary); font-variant-numeric:tabular-nums; }
/* compact inline affordance, right-aligned; override .btn's tall touch-target min-height so it doesn't wrap to a big block and shove the next line down */
.price-reco .reco-use { padding:0.25rem 0.7rem; font-size:0.74rem; min-height:0; line-height:1.3; margin-left:auto; align-self:center; }
.price-reco .reco-gp { font-weight:800; font-variant-numeric:tabular-nums; }
.price-reco .reco-gp.good { color:var(--color-success); } .price-reco .reco-gp.bad { color:var(--color-danger); }
.price-reco .reco-flag { font-size:0.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; color:var(--color-danger); }
.price-reco .reco-ok { font-size:0.66rem; font-weight:800; text-transform:uppercase; letter-spacing:.04em; color:var(--color-success); }

/* ---- ingredient price graph ---- */
.pg-wrap { background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-md); padding:0.8rem; }
.pg-legend { display:flex; gap:0.9rem; flex-wrap:wrap; margin-top:0.5rem; font-size:0.76rem; }
.pg-legend span { display:inline-flex; align-items:center; gap:0.3rem; color:var(--color-text-muted); }
.pg-swatch { width:12px; height:3px; border-radius:2px; display:inline-block; }
.saving-flag { display:inline-block; font-size:0.74rem; font-weight:600; padding:0.2rem 0.55rem; border-radius:var(--radius-pill); background:rgba(90,139,90,.16); color:var(--color-success); }

/* ---- year planner timeline ---- */
.cal { border:1px solid var(--color-border); border-radius:var(--radius-lg); background:var(--color-surface); overflow:hidden; }
.cal-months { display:grid; grid-template-columns:150px repeat(12,1fr); }
.cal-months > div { padding:8px 2px; font-size:0.64rem; font-weight:700; color:var(--color-text-muted); text-align:center; border-left:1px solid var(--color-border); border-bottom:1px solid var(--color-border); }
.cal-months > div:first-child { border-left:0; }
.cal-site { padding:6px 14px; background:var(--color-bg); font-weight:800; font-size:0.7rem; letter-spacing:.05em; color:var(--color-primary); text-transform:uppercase; }
.cal-row { display:grid; grid-template-columns:150px 1fr; border-top:1px solid var(--color-border); }
.cal-row .lbl { padding:6px 12px; font-size:0.8rem; display:flex; align-items:center; color:var(--color-text); }
.cal-track { position:relative; margin:5px 8px; min-height:28px; background:repeating-linear-gradient(90deg, transparent, transparent calc(100%/12 - 1px), var(--color-border) calc(100%/12 - 1px), var(--color-border) calc(100%/12)); }
.bar { position:absolute; top:3px; bottom:3px; border-radius:6px; color:#fff; font-size:0.68rem; font-weight:700; display:flex; align-items:center; padding:0 8px; overflow:hidden; white-space:nowrap; cursor:pointer; box-shadow:0 1px 3px rgba(0,0,0,.16); }
.bar:hover { filter:brightness(1.08); }
.cal-legend { display:flex; gap:0.8rem; flex-wrap:wrap; margin-top:0.6rem; font-size:0.76rem; }
.cal-legend span { display:inline-flex; align-items:center; gap:0.3rem; color:var(--color-text-muted); }
.cal-swatch { width:14px; height:10px; border-radius:3px; display:inline-block; }
.undated { margin-top:0.9rem; }
.undated .tagchip { cursor:pointer; }

/* small on/off site toggles */
.site-toggles { display:flex; gap:0.35rem; flex-wrap:wrap; }
.site-toggle { font-size:0.74rem; font-weight:600; padding:0.25rem 0.7rem; border-radius:var(--radius-pill); border:1.5px solid var(--color-border); background:var(--color-surface); color:var(--color-text-muted); cursor:pointer; }
.site-toggle.on { background:var(--color-primary); border-color:var(--color-primary); color:#fff; }

/* menu card archive state + inline actions */
.dish-card.archived { opacity:.62; }
.dish-card.archived:hover { opacity:1; }
.pill.archived { background:var(--color-border); color:var(--color-text-muted); }
.dc-actions { display:flex; gap:0.4rem; margin-top:0.1rem; }
.dc-act { font-size:0.72rem; font-weight:600; padding:0.2rem 0.55rem; border-radius:var(--radius-pill); border:1px solid var(--color-border); background:var(--color-surface); color:var(--color-text-muted); cursor:pointer; }
.dc-act:hover { border-color:var(--color-accent); color:var(--color-text); }
.dc-act.danger:hover { border-color:var(--color-danger); color:var(--color-danger); }
/* destructive action buttons in the detail sheet */
.sheet-danger-row { display:flex; gap:0.5rem; flex-wrap:wrap; margin-top:0.8rem; padding-top:0.8rem; border-top:1px solid var(--color-border); }

/* incomplete-dish badge (A1) */
.incompl-badge { display:inline-block; font-size:0.66rem; font-weight:700; padding:0.12rem 0.5rem; border-radius:var(--radius-pill); background:rgba(199,123,46,.14); color:var(--color-warning); border:1px solid rgba(199,123,46,.4); }
.incompl-dot { color:var(--color-warning); font-weight:700; }

/* estimated-yield strip in the recipe editor */
.yield-est:empty { display:none; }
.yield-est { margin-top:0.7rem; padding:0.55rem 0.75rem; background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-md); font-size:0.86rem; }
.yield-est-row { display:flex; justify-content:space-between; align-items:center; gap:0.6rem; flex-wrap:wrap; }

/* AI recipe refinement (A6) */
.ai-box { margin:0 0 0.6rem; padding:0.55rem 0.75rem; background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-md); font-size:0.85rem; }
.ai-box.review { border-left:3px solid var(--color-warning); }
.ai-review-chip { display:inline-block; font-size:0.64rem; font-weight:800; text-transform:uppercase; letter-spacing:.03em; padding:0.1rem 0.45rem; border-radius:var(--radius-pill); background:rgba(199,123,46,.16); color:var(--color-warning); border:1px solid rgba(199,123,46,.4); }
.ai-done-chip { display:inline-block; font-size:0.64rem; font-weight:700; padding:0.1rem 0.45rem; border-radius:var(--radius-pill); background:var(--color-bg); color:var(--color-text-muted); border:1px solid var(--color-border); }
.ai-corr { margin:0.2rem 0 0; padding-left:0; list-style:none; display:flex; flex-direction:column; gap:0.25rem; }
.ai-corr li { font-size:0.82rem; line-height:1.35; padding-left:0.7rem; border-left:2px solid var(--color-border); }
.ai-corr li.ai-corr-high { border-left-color:var(--color-warning); }
.ai-corr-t { font-weight:700; }
.ai-add-chip { display:inline-block; font-size:0.62rem; font-weight:800; text-transform:uppercase; letter-spacing:.03em; padding:0.08rem 0.4rem; border-radius:var(--radius-pill); background:var(--color-bg); color:var(--color-text-muted); border:1px solid var(--color-border); white-space:nowrap; }
.ai-add-chip.ai-add-new { background:rgba(199,123,46,.16); color:var(--color-warning); border-color:rgba(199,123,46,.4); }
.ai-diff { display:grid; grid-template-columns:1fr 1fr; gap:0.7rem; }
@media (max-width:640px) { .ai-diff { grid-template-columns:1fr; } }
.ai-pre { white-space:pre-wrap; word-break:break-word; font-family:inherit; font-size:0.82rem; line-height:1.4; margin:0; padding:0.55rem 0.65rem; background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-md); max-height:46vh; overflow:auto; }

/* AI bulk-refine progress panel (A6 Phase 2) */
.abk-panel { position:fixed; right:1rem; bottom:1rem; z-index:90; width:min(320px,92vw); background:var(--color-surface); border:1px solid var(--color-border); border-radius:var(--radius-lg); box-shadow:0 10px 30px rgba(0,0,0,.18); padding:0.8rem 0.9rem; font-size:0.85rem; }
.abk-h { margin-bottom:0.45rem; }
.abk-bar { height:8px; background:var(--color-bg); border-radius:999px; overflow:hidden; margin-bottom:0.4rem; }
.abk-bar span { display:block; height:100%; background:var(--color-primary); border-radius:999px; transition:width .25s; }
.abk-meta { color:var(--color-text-muted); font-size:0.8rem; line-height:1.4; }
.abk-actions { margin-top:0.55rem; display:flex; justify-content:flex-end; }

/* ============================================================
   Cook view — chef-facing, read-first, scalable batch (Recipes)
   ============================================================ */
.seg { display:inline-flex; border:1px solid var(--color-border); border-radius:9px; overflow:hidden; background:var(--color-surface); }
.seg-b { border:0; background:transparent; padding:0.4rem 1rem; font:inherit; font-size:0.9rem; font-weight:600; color:var(--color-text-muted); cursor:pointer; }
.seg-b + .seg-b { border-left:1px solid var(--color-border); }
.seg-b.on { background:var(--color-primary); color:#fff; }

.cook-view { padding:1.4rem 1.5rem calc(3rem + env(safe-area-inset-bottom, 0px)); container-type:inline-size; }
/* Ingredients + Method: stacked on a phone-width panel, side by side once the panel is wide (iPad/desktop). Driven by panel width via a container query, not the viewport. */
.cook-cols { display:grid; grid-template-columns:1fr; column-gap:2.4rem; }
.cook-col { min-width:0; }
@container (min-width:700px) {
  .cook-cols { grid-template-columns:minmax(260px, 0.82fr) 1fr; }
  .cook-cols .cook-h { margin-top:0.4rem; }
}
.cook-title { margin:0 0 0.15rem; font-size:1.55rem; line-height:1.15; }
.cook-sub { color:var(--color-text-muted); font-size:0.92rem; margin-bottom:0.55rem; }
.cook-alg { display:flex; flex-wrap:wrap; gap:0.3rem; margin-bottom:0.8rem; }
/* A9 — start-a-batch action on the Cook view */
.cook-batch { display:flex; flex-wrap:wrap; gap:0.6rem; align-items:center; margin:0 0 0.9rem; padding:0.7rem 0.8rem; background:var(--color-bg); border:1px solid var(--color-border); border-radius:var(--radius-md); }
.cook-desc { font-size:0.98rem; color:var(--color-text); font-style:italic; margin:0 0 0.7rem; }
/* Info | Edit view toggle (Ingredients, Menus): a pure CSS show/hide, no re-fetch */
.sheet[data-mode="info"] .js-edit { display:none; }
.sheet[data-mode="edit"] .js-info { display:none; }
.kv-row { display:flex; flex-wrap:wrap; gap:0.4rem; }
.kv-chip { background:var(--color-bg); border:1px solid var(--color-border); border-radius:999px; padding:0.2rem 0.7rem; font-size:0.84rem; color:var(--color-text); font-weight:600; }

.cook-scale { background:var(--color-bg); border:1px solid var(--color-border); border-radius:13px; padding:0.75rem 0.9rem; margin-bottom:1.15rem; }
.cs-row { display:flex; flex-wrap:wrap; align-items:center; gap:0.5rem 0.85rem; }
.cs-label { font-weight:700; font-size:0.74rem; text-transform:uppercase; letter-spacing:0.05em; color:var(--color-text-muted); }
.cs-mult { font-weight:800; font-size:1.1rem; color:var(--color-primary); min-width:2.6rem; }
.cs-portions { font-size:0.92rem; color:var(--color-text); display:inline-flex; align-items:center; gap:0.4rem; margin-left:auto; }
.cs-reset { border:1px solid var(--color-border); background:var(--color-surface); border-radius:8px; padding:0.35rem 0.7rem; font:inherit; font-size:0.82rem; font-weight:600; color:var(--color-text-muted); cursor:pointer; }
.cs-reset:hover { border-color:var(--color-accent); color:var(--color-text); }
.cs-slider { -webkit-appearance:none; appearance:none; width:100%; height:6px; border-radius:999px; background:var(--color-border); margin:0.75rem 0 0.3rem; cursor:pointer; }
.cs-slider::-webkit-slider-thumb { -webkit-appearance:none; appearance:none; width:26px; height:26px; border-radius:50%; background:var(--color-accent); border:3px solid var(--color-surface); box-shadow:0 1px 5px rgba(0,0,0,0.28); cursor:grab; }
.cs-slider::-moz-range-thumb { width:26px; height:26px; border-radius:50%; background:var(--color-accent); border:3px solid var(--color-surface); box-shadow:0 1px 5px rgba(0,0,0,0.28); cursor:grab; }
.cs-slider:active::-webkit-slider-thumb { cursor:grabbing; }
.cs-ends { display:flex; justify-content:space-between; font-size:0.72rem; color:var(--color-text-muted); font-weight:700; }
.cs-portions input { width:3.8rem; padding:0.4rem; border:1px solid var(--color-border); border-radius:9px; font:inherit; font-weight:700; text-align:center; background:var(--color-surface); }
.cs-makes { margin-top:0.6rem; font-size:0.93rem; color:var(--color-text); }

/* slider tick marks + batch cost */
.cs-ticks { display:flex; justify-content:space-between; margin:-0.05rem 1px 0.2rem; }
.cs-ticks i { width:2px; height:7px; background:var(--color-border); border-radius:1px; }
.cs-cost { margin-top:0.4rem; font-size:0.86rem; color:var(--color-text-muted); }
.cs-cost b { color:var(--color-text); }
.cc-warn { color:var(--color-warning); }

/* times & temps strip */
.cook-tt { display:flex; flex-wrap:wrap; gap:0.4rem; margin:0.2rem 0 0.2rem; }
.tt-chip { background:var(--color-bg); border:1px solid var(--color-border); border-radius:999px; padding:0.25rem 0.7rem; font-size:0.9rem; font-weight:600; color:var(--color-text); }

.cook-h { margin:1.15rem 0 0.5rem; font-size:0.76rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--color-text-muted); border-bottom:1px solid var(--color-border); padding-bottom:0.3rem; }
.cook-ings { list-style:none; margin:0; padding:0; }
.cook-ing { display:flex; gap:0.7rem; align-items:center; padding:0.55rem 0; border-bottom:1px solid var(--color-border); }
.cook-ing .ci-check { flex:0 0 auto; width:22px; height:22px; accent-color:var(--color-accent); cursor:pointer; }
.cook-ing .ci-q { flex:0 0 6.4rem; text-align:right; font-variant-numeric:tabular-nums; color:var(--color-text); white-space:nowrap; }
.cook-ing .ci-qn { font-size:1.18rem; font-weight:700; }
.cook-ing .ci-n { flex:1; font-size:1.04rem; }
.cook-ing .ci-note { color:var(--color-text-muted); font-size:0.92rem; font-style:italic; }
.cook-ing .ci-cost { flex:0 0 auto; font-size:0.82rem; color:var(--color-text-muted); font-variant-numeric:tabular-nums; white-space:nowrap; }
.cook-ing.done .ci-q, .cook-ing.done .ci-n { text-decoration:line-through; opacity:0.5; }

.cook-steps { display:flex; flex-direction:column; gap:0.15rem; }
.cook-step { display:flex; gap:0.65rem; align-items:flex-start; padding:0.45rem 0; border-bottom:1px solid var(--color-border); cursor:pointer; font-size:1.03rem; line-height:1.5; color:var(--color-text); }
.cook-step .st-check { flex:0 0 auto; width:22px; height:22px; margin-top:0.05rem; accent-color:var(--color-accent); cursor:pointer; }
.cook-step .st-n { flex:0 0 auto; font-weight:700; color:var(--color-accent); min-width:1.4rem; }
.cook-step .st-t { flex:1; }
.cook-step.done .st-t { text-decoration:line-through; opacity:0.5; }
.cook-method { font-size:1.03rem; line-height:1.55; color:var(--color-text); }
.cook-notes { font-size:0.95rem; color:var(--color-text); }
.cook-usedin { font-size:0.82rem; margin-top:1.1rem; }
@media (max-width:560px) {
  .cook-ing .ci-q { flex-basis:4.6rem; }
  .cs-portions { margin-left:0; }
  .cook-title { font-size:1.35rem; }
}

/* ============================================================
   Menus "Service view" — the menu as it reads in service
   ============================================================ */
.sv-menu { columns:1; margin-top:0.5rem; }
@container (min-width:760px) { .sv-menu { columns:2; column-gap:3rem; } }
.sv-section { break-inside:avoid; margin-bottom:1.7rem; }
.sv-sec-name { text-align:center; text-transform:uppercase; letter-spacing:0.14em; font-size:1rem; font-weight:700; color:var(--color-accent); margin:0 0 0.15rem; }
.sv-brief { text-align:center; font-size:0.8rem; color:var(--color-text-muted); font-style:italic; margin-bottom:0.7rem; }
.sv-dish { margin-bottom:0.95rem; }
.sv-dline { display:flex; align-items:baseline; gap:0.5rem; }
.sv-dname { font-weight:600; font-size:1.02rem; color:var(--color-primary); }
.sv-leader { flex:1 1 auto; border-bottom:1px dotted var(--color-border); align-self:flex-end; transform:translateY(-0.28rem); min-width:1rem; }
.sv-price { font-weight:700; font-variant-numeric:tabular-nums; color:var(--color-text); white-space:nowrap; }
.sv-ddesc { color:var(--color-text); font-size:0.9rem; line-height:1.4; margin-top:0.1rem; }
.sv-dmeta { display:flex; justify-content:space-between; align-items:baseline; gap:0.6rem; margin-top:0.2rem; }
.sv-diet { font-size:0.72rem; text-transform:uppercase; letter-spacing:0.04em; color:var(--color-text-muted); }
.sv-gp { font-size:0.72rem; font-weight:700; white-space:nowrap; }
.sv-gp.good { color:var(--color-success); }
.sv-gp.bad { color:var(--color-danger); }

/* ============================================================
   Embed mode — the dish editor shown inside a slide-over on the
   Menus page (chromeless). Hide the portal shell; the editor fills.
   ============================================================ */
body.embed-mode .page { display:none !important; }
body.embed-mode .app-scrim { display:none !important; }
body.embed-mode #scrim { display:none !important; }
body.embed-mode { background:var(--color-bg); }
body.embed-mode .sheet { width:100vw !important; max-width:100vw; box-shadow:none; }
/* close via the parent "Back to menu" bar, not the inner X (it'd blank the frame) */
body.embed-mode #sheet > .sheet-h .sheet-x { display:none; }

/* the "Build this dish here" stacked panel on the Menus page (holds an iframe) */
.sheet.build-embed { width:min(1120px,100vw); padding:0; overflow:hidden; display:flex; flex-direction:column; }
.sheet.build-embed .sheet-h { flex:0 0 auto; }
.sheet.build-embed .be-note { color:#fff; opacity:0.85; font-size:0.82rem; margin-left:auto; margin-right:0.6rem; white-space:nowrap; }
.build-frame { flex:1 1 auto; width:100%; height:100%; border:0; display:block; background:var(--color-bg); }
@media (max-width:560px) { .sheet.build-embed .be-note { display:none; } }
