/* ============================================================
   Whiskey Buddy — bottle detail (2026-05-31 redesign).
   Loaded AFTER market.css, which supplies the palette tokens,
   header/footer, .panel, .idx pills, .chip and the Fredoka type.
   This file adds the detail-only layer: header search, the two-column
   public-evidence / private-journal grid, hero band, price + index,
   the price-history chart, retailer evidence rows, and the disabled
   journal stub.
   ============================================================ */

/* extra tokens not in market.css */
:root{
  --red:#b23b27; --red-bg:#f7e0db; --red-line:#eebfb4;
  --ok-bg:#eaf3e4; --ok-line:#cfe0bd;
  /* private journal layer */
  --jrnl-ink:#2a1d14; --jrnl-bg:#f4ece0; --jrnl-card:#fcf8f1;
  --jrnl-line:#d8c4a6; --jrnl-rule:#e7dcc8;
}

/* ---------- header search ---------- */
.wb-search{position:relative;flex:1 1 240px;max-width:430px;margin:0 .4rem}
.wb-search .ico{position:absolute;left:.7rem;top:50%;transform:translateY(-50%);
  color:var(--muted);pointer-events:none}
.wb-search input{width:100%;padding:.55rem .8rem .55rem 2.2rem;border-radius:11px;
  border:1px solid var(--line);background:#fff;font:inherit;color:var(--ink);
  transition:border-color .14s,box-shadow .14s}
.wb-search input::placeholder{color:var(--muted)}
.wb-search input:focus{outline:none;border-color:var(--accent-line);box-shadow:0 0 0 3px rgba(201,135,54,.16)}
.wb-results{position:absolute;top:calc(100% + .45rem);left:0;right:0;background:var(--card);
  border:1px solid var(--line);border-radius:14px;box-shadow:0 16px 38px rgba(51,36,26,.20);
  overflow:hidden auto;max-height:min(66vh,440px);z-index:60;display:none}
.wb-results.open{display:block}
.wb-res-head{font-family:var(--round);font-weight:600;font-size:.72rem;text-transform:uppercase;
  letter-spacing:.06em;color:var(--muted);padding:.55rem .8rem .35rem}
.wb-result{display:flex;align-items:center;gap:.65rem;padding:.5rem .8rem;cursor:pointer;
  border-top:1px solid var(--line-soft);text-decoration:none;color:var(--ink)}
.wb-result:hover{text-decoration:none}
.wb-result.active{background:var(--soft)}
.wb-result img{width:34px;height:44px;object-fit:contain;background:#fff;border:1px solid var(--line-soft);
  border-radius:6px;flex:none;padding:2px}
.wb-result .rtext{min-width:0;display:flex;flex-direction:column;gap:.1rem}
.wb-result .rname{font-family:var(--round);font-weight:600;font-size:.9rem;line-height:1.2;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.wb-result .rmeta{font-size:.77rem;color:var(--muted)}
.wb-result .rright{margin-left:auto;display:flex;flex-direction:column;align-items:flex-end;gap:.2rem;flex:none}
.wb-result .rprice{font-family:var(--round);font-weight:600;color:var(--accent);font-variant-numeric:tabular-nums}
.wb-result .idx{font-size:.72rem;padding:.1rem .4rem}
.wb-res-foot{display:block;padding:.6rem .8rem;border-top:1px solid var(--line);
  font-family:var(--round);font-weight:600;font-size:.85rem;color:var(--accent);background:var(--bg-tint);text-decoration:none}
.wb-res-foot:hover,.wb-res-foot.active{background:var(--accent-bg);text-decoration:none}
@media (max-width:560px){.wb-search{flex:1 1 auto;margin:0}.wb-search input{padding-right:.6rem}}
/* Mobile bottle page: drop the header search — the bottom Buddy/Search bar covers
   it, and the header reclaims vertical space at the top of an already-long page.
   Must out-specify wb-buddy.css `html.bd-rail-on .wb-search{display:revert}` (which
   un-hides it when the rail falls back to the bottom bar), hence the longer selector. */
@media (max-width:860px){ html.bd-rail-on .wb-header .wb-search{ display:none; } }

/* ---------- breadcrumb + grid ---------- */
.crumb{font-size:.9rem;margin:1.2rem 0 .6rem;color:var(--muted)}
.crumb a{font-weight:500}
.detail-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:1.6rem;align-items:start}
@media (max-width:900px){.detail-grid{grid-template-columns:1fr;gap:1.3rem}}

/* ---------- hero ---------- */
.detail-hero{display:grid;grid-template-columns:180px 1fr;gap:1.4rem;align-items:start;
  margin:.2rem 0 1.2rem}
.detail-hero.no-photo{grid-template-columns:1fr}
.hero-photo{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;
  aspect-ratio:4/5;display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(51,36,26,.08)}
.hero-photo img{width:100%;height:100%;object-fit:contain;padding:1rem;display:block;mix-blend-mode:multiply}
/* Branded silhouette shown when a bottle has no harvested photo (or one
   fails to load): fill the slot cleanly — no multiply tint, gentle inset —
   so the page reads as "photo pending", never broken. */
.hero-photo.is-placeholder{background:linear-gradient(180deg,#fdfaf4,#f6efe3)}
.hero-photo.is-placeholder img{mix-blend-mode:normal;padding:1.4rem;opacity:.92}
.hero-body{min-width:0}
.detail-chips{display:flex;flex-wrap:wrap;gap:.35rem;margin:0 0 .5rem}
.chip-rel{background:#efe7da;color:#7a674a}
.detail-title{font-size:clamp(1.5rem,3vw,2.1rem);font-weight:600;line-height:1.12;
  letter-spacing:-.02em;margin:.1rem 0 .55rem;overflow-wrap:anywhere}
.hero-facts{list-style:none;display:flex;flex-wrap:wrap;gap:.4rem;padding:0;margin:.6rem 0 0}
.hero-fact{display:flex;flex-direction:column;gap:.1rem;padding:.4rem .75rem;background:var(--soft);
  border:1px solid var(--line);border-radius:10px}
.hero-fact .fl{font-size:.66rem;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);
  font-weight:700;font-family:var(--round)}
.hero-fact .fv{font-weight:600;font-variant-numeric:tabular-nums;color:var(--ink);font-family:var(--round)}
.hero-distillery{margin:.7rem 0 0;font-size:.92rem;color:var(--ink-soft)}
@media (max-width:620px){.detail-hero{grid-template-columns:1fr;gap:1rem}
  .hero-photo{width:160px;margin:0 auto}}

/* ---------- public panels (extend market.css .panel) ---------- */
.col-public .panel{margin:0 0 1.2rem}
.panel-head{display:flex;align-items:center;gap:.55rem;margin-bottom:.7rem}
.panel-head h2{font-size:1.06rem;font-weight:600;display:flex;align-items:center;gap:.55rem}
.panel-head h2::before{content:"";width:.5rem;height:1rem;border-radius:3px;
  background:linear-gradient(180deg,var(--gold),var(--accent))}

/* price + index */
.market-price{display:flex;align-items:flex-end;gap:.8rem;flex-wrap:wrap;margin-bottom:.25rem}
.market-amount{font-family:var(--round);font-size:2.5rem;font-weight:600;color:var(--accent);
  line-height:.95;letter-spacing:-.02em;font-variant-numeric:tabular-nums}
.detail-price .idx{font-size:.92rem;padding:.25rem .6rem}
.market-meta{font-size:.88rem;color:var(--muted);margin:.15rem 0 0}
.price-lowest{font-size:.9rem;margin-top:.4rem;line-height:1.4;padding-top:.4rem;
  border-top:1px solid var(--line-soft)}
.price-lowest .lv{font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}
.market-empty{font-size:.95rem;line-height:1.45;color:var(--muted);padding:.2rem 0;max-width:48rem}
/* out-of-stock-everywhere banner (>=7d no in-stock signal) */
.market-panel.oos{background:var(--red-bg);border-color:var(--red-line)}
.market-panel.oos .stock-chip.stock-out{background:#fff;font-size:.85rem;padding:.18rem .55rem}
.market-panel.oos .market-empty{color:var(--ink-soft)}
.market-panel.oos .market-empty .note{margin:.5rem 0 0}
.idx-explain{margin:.7rem 0 0;font-size:.86rem;line-height:1.55;color:var(--ink-soft);
  background:var(--bg-tint);border:1px solid var(--line);border-radius:10px;padding:.6rem .8rem}
.idx-explain strong{color:var(--ink)}

/* price history */
.hist-wrap{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.hist-chart{flex:1 1 300px;min-width:240px}
svg.hist{display:block;width:100%;height:auto;border-radius:8px;background:var(--bg-tint);
  border:1px solid var(--line)}
.hist-axis{fill:var(--muted);font-size:9px;font-family:var(--sans)}
.hist-grid{stroke:var(--line);stroke-width:.5;opacity:.7}
.hist-ylabel{fill:var(--muted);font-size:8.5px;font-family:var(--sans);font-variant-numeric:tabular-nums}
.hist-today{fill:var(--green);font-size:10px;font-weight:700;font-family:var(--round);
  font-variant-numeric:tabular-nums;paint-order:stroke;stroke:var(--bg-tint);stroke-width:3px;stroke-linejoin:round}
.hist-stats{display:flex;flex-direction:column;gap:.5rem;font-size:.9rem}
.hist-stat{display:flex;align-items:baseline;gap:.5rem}
.hist-stat .k{color:var(--muted);font-size:.78rem;min-width:5.5rem}
.hist-stat .v{font-family:var(--round);font-weight:600;font-variant-numeric:tabular-nums}
.hist-stat .v.v-low{color:var(--green)}
.hist-low .v{color:var(--green)} .hist-high .v{color:var(--red)}
/* window-low attribution — the retailer + date the low came from (320615945) */
.hist-low-src{color:var(--muted);font-size:.72rem;font-weight:500;margin-left:.1rem}
/* expandable price-change log */
.hist-log{margin-top:.9rem;border-top:1px solid var(--line-soft);padding-top:.7rem}
.hist-log>summary{cursor:pointer;font-family:var(--round);font-weight:600;
  font-size:.9rem;color:var(--ink-soft);list-style:none;display:flex;
  align-items:center;gap:.4rem}
.hist-log>summary::-webkit-details-marker{display:none}
.hist-log>summary::before{content:"▸";color:var(--muted);font-size:.8rem}
.hist-log[open]>summary::before{content:"▾"}
.hist-log .hl-n{background:var(--soft);color:var(--muted);border-radius:999px;
  padding:.02rem .45rem;font-size:.74rem}
.hl-list{list-style:none;margin:.6rem 0 0;padding:0;display:flex;
  flex-direction:column;gap:.05rem}
.hl-row{display:flex;align-items:baseline;gap:.6rem;font-size:.84rem;
  padding:.28rem .2rem;border-bottom:1px solid var(--line-soft)}
.hl-date{color:var(--muted);min-width:6.5rem;font-variant-numeric:tabular-nums}
.hl-price{font-family:var(--round);font-weight:600;
  font-variant-numeric:tabular-nums;min-width:4.5rem}
.hl-ret{color:var(--ink-soft);flex:1;min-width:0;overflow:hidden;
  text-overflow:ellipsis;white-space:nowrap}
.hl-flag{color:var(--green);font-size:.72rem;font-weight:600;flex:none}
.hl-more{color:var(--muted);font-size:.78rem;padding:.4rem .2rem}
.hist-seed{font-size:.95rem;line-height:1.5;color:var(--ink-soft);background:var(--bg-tint);
  border:1px dashed var(--line);border-radius:12px;padding:1rem 1.1rem}

/* retailer evidence (server-rendered via _bottle_evidence_panel) — a <details>
   so the listings collapse on mobile (bottle.js drops `open` ≤900px). */
.evidence-panel>.evidence-sum{cursor:pointer;list-style:none;display:flex;
  align-items:center;gap:.5rem;outline:none}
.evidence-panel>.evidence-sum::-webkit-details-marker{display:none}
.evidence-panel>.evidence-sum h2{margin:0;display:flex;align-items:center;gap:.5rem;flex:1}
.evidence-panel>.evidence-sum::after{content:"";width:.55rem;height:.55rem;flex:none;
  border-right:2px solid var(--muted);border-bottom:2px solid var(--muted);
  transform:rotate(45deg);transition:transform .15s;margin-bottom:.15rem}
.evidence-panel[open]>.evidence-sum::after{transform:rotate(-135deg)}
.evidence-panel .ev-count{font-family:var(--round);font-weight:700;font-size:.8rem;
  color:var(--accent);background:var(--accent-bg);border-radius:999px;padding:.1rem .5rem}
.evidence-panel h3.sub{font-size:.86rem;color:var(--muted);margin:1rem 0 .4rem;
  text-transform:none;font-weight:600;letter-spacing:0}
.evidence-panel h3.sub:first-of-type{margin-top:.2rem}
.listings{list-style:none;padding:0;margin:.35rem 0;display:flex;flex-direction:column;gap:.5rem}
.listing{border:1px solid var(--line);border-radius:11px;padding:.6rem .8rem;background:var(--card)}
.listing-head{display:flex;align-items:center;gap:.45rem;flex-wrap:wrap;margin-bottom:.2rem}
.listing-retailer{font-weight:600;font-family:var(--round)}
.badge{font-size:.66rem;padding:.12rem .5rem;border-radius:999px;font-weight:700;
  text-transform:uppercase;letter-spacing:.04em;font-family:var(--round);border:1px solid transparent}
.badge-elig{background:var(--ok-bg);border-color:var(--ok-line);color:#1e6b1e}
.badge-excl{background:#fef0e7;border-color:#f0c39a;color:#8a3f00}
.listing-title{font-size:.9rem;line-height:1.35;overflow-wrap:anywhere;display:flex;
  align-items:center;gap:.3rem;flex-wrap:wrap}
.listing-thumb-wrap{display:inline-block;width:34px;height:34px;background:#fff;
  border:1px solid var(--line-soft);border-radius:5px;overflow:hidden;flex:none}
.listing-thumb{display:block;width:100%;height:100%;object-fit:contain;padding:2px}
.listing-meta{display:flex;align-items:center;gap:.3rem .5rem;flex-wrap:wrap;font-size:.85rem;
  margin-top:.15rem;color:var(--ink)}
.listing-price{font-family:var(--round);font-weight:700;color:var(--accent);font-variant-numeric:tabular-nums}
.stock-chip{font-size:.72rem;padding:.06rem .45rem;border-radius:6px;border:1px solid transparent;
  font-weight:500;cursor:help}
.stock-in{background:var(--ok-bg);border-color:var(--ok-line);color:#1e6b1e}
.stock-out{background:var(--red-bg);border-color:var(--red-line);color:var(--red)}
.stock-unknown{background:var(--chip-bg);border-color:var(--line);color:var(--muted)}

/* identity record */
.identity-details{margin:0;background:var(--card);border:1px solid var(--line);
  border-radius:14px;padding:.4rem 1rem}
.identity-details>summary{cursor:pointer;font-family:var(--round);font-weight:600;color:var(--ink-soft);
  list-style:none;padding:.55rem 0;display:flex;align-items:center;gap:.4rem}
.identity-details>summary::-webkit-details-marker{display:none}
.identity-details>summary::before{content:"▸";color:var(--accent);transition:transform .15s}
.identity-details[open]>summary::before{transform:rotate(90deg)}
.identity-details[open]{padding-bottom:1rem}
.meta-dl{display:grid;grid-template-columns:max-content 1fr;gap:.25rem 1.2rem;margin:.4rem 0 .2rem}
.meta-dl .dl-row{display:contents}
.meta-dl dt{color:var(--muted);font-size:.85rem;padding:.1rem 0} .meta-dl dd{margin:0;font-size:.9rem;font-weight:500;padding:.1rem 0}

/* ============================================================
   PRIVATE JOURNAL LAYER — disabled Phase-2 stub
   ============================================================ */
.journal{border:2px solid var(--jrnl-ink);border-radius:18px;overflow:hidden;
  background:var(--jrnl-bg);box-shadow:0 10px 30px rgba(42,29,20,.14);position:sticky;top:5rem}
.jrnl-head{background:var(--jrnl-ink);color:#f3e6d2;padding:.85rem 1.1rem;display:flex;align-items:center;gap:.6rem}
.jrnl-head .lock{width:22px;height:22px;flex:none;color:var(--gold-soft)}
.jrnl-head h2{font-size:1.1rem;font-weight:600;color:#fdf4e4;line-height:1.1}
.jrnl-head .priv{margin-left:auto;font-size:.72rem;font-family:var(--round);font-weight:500;color:#cdbba3;text-align:right}
.jrnl-head .priv.soon{background:rgba(224,162,62,.18);color:var(--gold-soft);
  border:1px solid rgba(224,162,62,.3);border-radius:999px;padding:.2rem .6rem}
.jrnl-body{padding:1.1rem}
.stub-intro{font-size:.9rem;line-height:1.55;color:var(--ink-soft);margin:0 0 .4rem}
/* stub reads as a dimmed preview — non-interactive */
.journal-stub .jrnl-sec{opacity:.6;pointer-events:none}
.jrnl-sec{padding:.9rem 0;border-top:1px dashed var(--jrnl-line)}
.jrnl-sec>h3{font-size:.78rem;text-transform:uppercase;letter-spacing:.07em;color:#8a6a44;
  font-weight:700;margin-bottom:.55rem}
.jrnl-sec>h3 .hint{font-weight:500;text-transform:none;letter-spacing:0;color:var(--muted);font-size:.84em}
.rating-row{display:flex;align-items:center;gap:.9rem;flex-wrap:wrap}
.stars{display:inline-flex;gap:.15rem;font-size:1.5rem;line-height:1}
.stars .star{color:#d8c4a6}
.status-grid{display:flex;flex-wrap:wrap;gap:.4rem}
.status-chip{font-family:var(--round);font-weight:500;font-size:.85rem;padding:.4rem .75rem;
  border-radius:999px;border:1px solid var(--jrnl-line);background:var(--jrnl-card);color:var(--ink-soft)}
.target-input{display:inline-flex;align-items:center;gap:.2rem;background:var(--jrnl-card);
  border:1px solid var(--jrnl-line);border-radius:9px;padding:.3rem .55rem;font-family:var(--round);font-weight:600}
.target-input span{color:var(--muted)}
.target-input input{border:none;background:none;width:5.5rem;font:inherit;color:var(--ink);padding:0}
textarea.note-field{width:100%;border:1px solid var(--jrnl-line);border-radius:10px;padding:.6rem .7rem;
  font:inherit;color:var(--ink);resize:vertical;min-height:4rem;background:var(--jrnl-card)}
.btn{font-family:var(--round);font-weight:600;border-radius:10px;border:1px solid transparent;
  font-size:.9rem;padding:.5rem .9rem}
.btn-add{background:var(--jrnl-ink);color:#fdf4e4;display:inline-flex;align-items:center;gap:.4rem}
.empty-note{font-size:.86rem;color:var(--muted);font-style:italic;padding:.3rem 0 0}
/* Mobile makeover (Robert, 2026-06-09): one clean vertical flow. `display:contents`
   dissolves the two desktop columns so every section becomes a direct flex item of
   .detail-grid and `order` can interleave the public + private sections. Surfaces
   Ask Buddy right under the price (was ~4 screens / 3780px down). The journal stays
   full + functional — its journal.js-owned DOM is untouched, only its position
   changes. Desktop two-column layout is unaffected. (Supersedes the 2026-06-05
   journal-above-buddy order; Buddy is now the high shortcut Robert asked for.) */
@media (max-width:900px){
  .detail-grid{display:flex;flex-direction:column;gap:1.1rem}
  .col-public,.col-private{display:contents}
  .col-public .panel{margin-bottom:0}
  .journal{position:static}
  .detail-hero{order:1}
  .detail-price{order:2}
  .buddy-panel{order:3}
  .hist-panel{order:4}
  .evidence-panel{order:5}
  .identity-details{order:6}
  .journal{order:7}
}

/* ============================================================
   PRIVATE JOURNAL LAYER — live (logged-in) editor, wired by journal.js
   ============================================================ */
.jrnl-sec.live{opacity:1}
/* interactive star rating */
.stars.live .star{appearance:none;background:none;border:none;padding:0;cursor:pointer;
  color:#d8c4a6;font-size:1.5rem;line-height:1;transition:color .1s}
.stars.live .star.on{color:var(--accent,#e0a23e)}
.stars.live .star.hover{color:#f0c067}
/* lit "Watching" chip + clear link */
.status-chip.on{background:rgba(224,162,62,.16);border-color:rgba(224,162,62,.45);
  color:#8a5a18;font-weight:600}
.status-chip.soon{opacity:.5}
.soon-grid{margin-bottom:.2rem}
/* interactive shelf chips (live editor) — buttons that toggle a lit .on state */
.status-grid.live .status-chip{appearance:none;cursor:pointer;transition:background .1s,border-color .1s,color .1s}
.status-grid.live .status-chip:hover{border-color:rgba(224,162,62,.55)}
/* reset-rating link sits next to the rating label */
.rating-clear{margin-left:.1rem}
.target-row{display:flex;align-items:center;gap:.6rem;flex-wrap:wrap}
.jrnl-sec.live .target-input input{outline:none}
.jrnl-sec.live .target-input:focus-within{border-color:var(--accent,#e0a23e)}
.lnk{appearance:none;background:none;border:none;padding:0;cursor:pointer;font:inherit;
  color:var(--muted);text-decoration:underline;font-size:.82rem}
.lnk:hover{color:var(--ink-soft)}
/* dated review cards */
.rv-card{border:1px solid var(--jrnl-line);background:var(--jrnl-card);border-radius:10px;
  padding:.55rem .7rem;margin-bottom:.5rem}
.rv-top{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;font-size:.82rem;color:var(--muted)}
.rv-date{font-weight:600;color:var(--ink-soft)}
.rv-score,.rv-val,.rv-paid{background:var(--jrnl-bg);border:1px solid var(--jrnl-line);
  border-radius:999px;padding:.05rem .45rem}
.rv-del{margin-left:auto}
.rv-notes{margin:.35rem 0 0;font-size:.9rem;color:var(--ink);line-height:1.5}
.rv-bits{margin:.3rem 0 0;font-size:.82rem;color:var(--ink-soft);line-height:1.5}
/* add-review form */
.rv-form{margin-top:.6rem;display:flex;flex-direction:column;gap:.45rem}
.rv-row{display:flex;gap:.6rem;flex-wrap:wrap}
.rv-form label{font-size:.78rem;color:#8a6a44;font-weight:600;display:flex;flex-direction:column;gap:.2rem}
.rv-form label.rv-full{width:100%}
.rv-form input,.rv-form textarea{font:inherit;font-weight:400;color:var(--ink);
  border:1px solid var(--jrnl-line);border-radius:8px;padding:.35rem .5rem;background:#fff}
.rv-row input{width:6rem}
.rv-actions{display:flex;align-items:center;gap:.8rem;margin-top:.2rem}
.jrnl-status{display:inline-block;margin-top:.3rem;font-size:.82rem;color:var(--accent,#e0a23e);
  font-family:var(--round);font-weight:600;min-height:1em}

/* --- Ask Buddy panel (Phase 4) -------------------------------------------- */
.buddy-panel{border:2px solid var(--jrnl-ink);border-radius:18px;overflow:hidden;
  margin-bottom:1.1rem;background:linear-gradient(180deg,#2a1d12,#1c130b)}
.buddy-head{display:flex;align-items:baseline;justify-content:space-between;gap:.5rem;
  padding:.8rem 1rem;background:var(--jrnl-ink);color:#fdf4e4}
.buddy-head h2{margin:0;font-size:1.15rem}
.buddy-tag{font-size:.72rem;color:#e0a23e;text-transform:uppercase;letter-spacing:.04em}
.buddy-body{padding:1rem}
.buddy-intro{margin:.1rem 0 .8rem;color:#d8c9b3;font-size:.92rem}
.buddy-ask{background:#e0a23e;color:#241606;font-weight:700;width:100%;
  font-size:.98rem;padding:.65rem;cursor:pointer}
.buddy-ask:disabled{opacity:.6;cursor:default}
.buddy-answer{margin-top:.85rem;color:#f2e8d8;font-size:.95rem;line-height:1.55}
.buddy-answer.buddy-muted{color:#bcae98;font-style:italic}
.buddy-text strong{color:#f2b65a}
.buddy-thinking{color:#bcae98;font-style:italic}
.buddy-foot{margin-top:.5rem;font-size:.78rem;color:#9b8c75;text-transform:uppercase;
  letter-spacing:.04em}
.buddy-cached{color:#7f9b6e}
.buddy-taste{margin-top:1rem;border-top:1px solid rgba(255,235,200,.12);padding-top:.7rem}
.buddy-taste summary{cursor:pointer;color:#d8c9b3;font-size:.9rem}
.buddy-taste label{display:block;font-size:.82rem;color:#bcae98;margin:.55rem 0 0}
.buddy-taste input{display:block;width:100%;margin-top:.2rem;padding:.4rem .5rem;
  border-radius:8px;border:1px solid rgba(255,235,200,.18);background:#150d07;
  color:#f2e8d8;font:inherit;font-size:.88rem}
.taste-status{font-size:.82rem;color:#9b8c75;margin-left:.6rem}

/* "Bottles like this" — flavour-nearest row (ROADMAP #20). */
.similar-panel{margin:1.5rem 0 .5rem}
.similar-h{font-size:1.15rem;margin:0 0 .15rem}
.similar-sub{font-size:.85rem;margin:0 0 .9rem}
.sim-row{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:.8rem}
.sim-card{display:flex;flex-direction:column;align-items:center;text-align:center;
  gap:.5rem;padding:.8rem .6rem;background:#241a11;border:1px solid #3a2a1a;
  border-radius:11px;color:#f4ece0;text-decoration:none;transition:border-color .15s}
.sim-card:hover{border-color:#c9821f}
.sim-img-wrap{height:84px;display:flex;align-items:center;justify-content:center}
.sim-img{max-height:84px;max-width:100%;object-fit:contain}
.sim-name{font-size:.82rem;line-height:1.25;color:#e8ddcb}
