/* Queko -- per-prospect design system (pipeline-v6)
 * Direction: v6a Night Ledger (V4 apothecary grammar x V5 botanical cinema).
 * Signed off 2026-06-10. Extends to every page via /website-build.
 */

* { box-sizing: border-box; }
[hidden]{ display:none !important; } /* class display rules must never defeat the hidden attribute */

/* UA default margin reset. <figure>, <blockquote>, <dl>, <fieldset>, <menu>
 * ship with surprising browser-default margins (e.g. <figure> defaults to
 * `margin: 1em 40px`) which silently break grid cells. Reset here so layout
 * is determined by site CSS, not UA defaults. */
figure, blockquote, dl, fieldset, menu { margin: 0; }

/* container rails */
.container{ width:100%; max-width:var(--rails-wide); margin-inline:auto; padding-inline:var(--rails-padding); }
.container--narrow{ max-width:var(--rails-narrow); }

/* base */
body{ margin:0; background:var(--deep); color:var(--paper); font-family:var(--font-serif); font-size:1.0625rem; line-height:1.65; -webkit-font-smoothing:antialiased; }
img{ max-width:100%; display:block; }
a{ color:inherit; }
h1,h2,h3{ font-family:var(--font-display); font-weight:400; line-height:1.05; margin:0; }
.eyebrow{ font-family:var(--font-sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--mid-paper); }

/* buttons + text links */
.btn{ display:inline-flex; align-items:center; justify-content:center; min-height:var(--hit-target); padding:0 1.6rem; border:1px solid var(--paper); border-radius:0; background:var(--paper); color:var(--ink); font-family:var(--font-sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase; text-decoration:none; transition:background .22s ease,color .22s ease; cursor:pointer; }
.btn:hover{ background:transparent; color:var(--paper); }
.btn--ghost{ background:transparent; color:var(--paper); }
.btn--ghost:hover{ background:var(--paper); color:var(--ink); }
.btn--ink{ background:var(--ink); color:var(--paper); border-color:var(--ink); }
.btn--ink:hover{ background:transparent; color:var(--ink); }
.tlink{ font-family:var(--font-sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase; text-decoration:none; position:relative; padding-bottom:3px; min-height:var(--hit-target); display:inline-flex; align-items:flex-end; }
button.tlink{ background:none; border:0; color:inherit; cursor:pointer; padding-inline:0; }
.tlink::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:1px; background:currentColor; transform:scaleX(.35); transform-origin:left; transition:transform .25s ease; }
.tlink:hover::after{ transform:scaleX(1); }

/* nav -- one nav across all pages. Base: sticky on the night ground.
 * .nav--floating (index + our-story only): absolute, transparent over the hero. */
.nav{ position:sticky; top:0; z-index:50; background:var(--deep); border-bottom:1px solid var(--line-paper-soft); color:var(--nav-fg-floating); }
.nav--floating{ position:absolute; top:0; left:0; right:0; background:transparent; border-bottom:0; }
.nav__layout{ display:flex; align-items:center; justify-content:space-between; gap:2rem; height:72px; }
.nav__mark{ font-family:var(--font-sans); font-weight:500; font-size:15px; letter-spacing:.42em; text-transform:uppercase; text-decoration:none; }
.nav__links{ display:flex; gap:2.2rem; }
.nav__links a{ font-family:var(--font-sans); font-size:12px; letter-spacing:.14em; text-transform:uppercase; text-decoration:none; opacity:.9; }
.nav__links a:hover{ opacity:1; }
.nav__icons{ display:flex; align-items:center; gap:.35rem; }
.nav__icon{ position:relative; display:inline-flex; align-items:center; justify-content:center; width:var(--hit-target); height:var(--hit-target); color:var(--nav-fg-floating); background:none; border:0; }
.nav__icon svg{ width:21px; height:21px; }
.nav__cart-count{ position:absolute; top:5px; right:3px; font-family:var(--font-sans); font-size:9px; line-height:14px; min-width:14px; text-align:center; background:var(--paper); color:var(--ink); border-radius:999px; padding:0 3px; }
.nav__icon--cart[data-empty="true"] .nav__cart-count{ display:none; }
.nav__icon--menu{ display:none; cursor:pointer; }
@media (max-width:880px){
  .nav__links{ display:none; }
  .nav__icon--search,.nav__icon--account,.nav__icon--wishlist{ display:none; }
  .nav__icon--menu{ display:inline-flex; }
}

/* hero -- catalogue cover printed on the night photo */
.hero{ position:relative; min-height:94vh; display:flex; flex-direction:column; justify-content:flex-end; isolation:isolate; overflow-x:clip; } /* the rotated hero stamp's transparent bbox corners otherwise extend scrollWidth ~11px past the viewport */
.hero__bg{ position:absolute; inset:0; z-index:-2; overflow:hidden; }
.hero__bg img{ width:100%; height:100%; object-fit:cover; object-position:center 64%; }
.hero::after{ content:""; position:absolute; inset:0; z-index:-1; background:linear-gradient(to top, rgba(16,18,16,.94) 0%, rgba(16,18,16,.45) 48%, rgba(16,18,16,.3) 100%); }
.hero__vol{ display:flex; justify-content:space-between; align-items:baseline; font-family:var(--font-sans); font-size:11px; letter-spacing:.22em; text-transform:uppercase; color:var(--paper); opacity:.85; padding-top:96px; }
.hero__main{ margin-top:auto; padding-block:2rem 1.6rem; position:relative; }
.hero h1{ font-size:clamp(3rem,6.8vw,5.6rem); max-width:16ch; }
.hero__lede{ max-width:44ch; font-size:1.12rem; margin:1.2rem 0 0; opacity:.88; }
.hero__cta{ display:flex; gap:1rem; margin-top:2rem; align-items:center; flex-wrap:wrap; }
.hero__stamp{ position:absolute; right:0; bottom:1.2rem; width:128px; height:128px; transform:rotate(11deg); opacity:.92; }
.hero__stamp svg{ width:100%; height:100%; }
.hero__leaders{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1rem,3vw,3rem); border-top:1px solid var(--line-paper); padding-block:1.1rem 2.4rem; font-family:var(--font-sans); font-size:11px; letter-spacing:.14em; text-transform:uppercase; }
.hero__leaders span{ display:flex; align-items:baseline; gap:.6rem; }
.hero__leaders span::after{ content:""; flex:1; border-bottom:1px dotted var(--mid-paper); }
.hero__leaders b{ font-weight:500; }
@media (max-width:880px){ .hero__leaders{ grid-template-columns:1fr; gap:.5rem; } .hero__stamp{ display:none; } }

/* section scaffolding */
.sec{ padding-block:var(--space-section); }
.sec__head{ display:flex; align-items:baseline; justify-content:space-between; gap:2rem; margin-bottom:calc(var(--space-section)*.36); }
.sec__head h2{ font-size:clamp(1.9rem,3.4vw,2.9rem); }
.sec__head .eyebrow{ display:block; margin-bottom:.6rem; }

/* the night ledger (collection table) */
.ledger{ border:1px solid var(--line-paper); }
.ledger__head{ display:grid; grid-template-columns:5rem minmax(9rem,14rem) 1fr minmax(8rem,12rem) 6rem 8rem; gap:1.2rem; padding:.8rem 1.2rem; background:var(--paper); color:var(--ink); font-family:var(--font-sans); font-size:10px; letter-spacing:.22em; text-transform:uppercase; }
.ledger__price-h{ text-align:right; }
.lrow{ display:grid; grid-template-columns:5rem minmax(9rem,14rem) 1fr minmax(8rem,12rem) 6rem 8rem; gap:1.2rem; align-items:baseline; padding:1.05rem 1.2rem; border-top:1px solid var(--line-paper-soft); text-decoration:none; transition:background .2s ease,color .2s ease; }
.lrow:first-of-type{ border-top:0; }
.lrow:hover{ background:var(--paper); color:var(--ink); }
.lrow__no{ font-family:var(--font-display); font-size:1.4rem; }
.lrow__name{ font-family:var(--font-sans); font-size:12.5px; letter-spacing:.2em; text-transform:uppercase; }
.lrow__name i{ display:block; font-family:var(--font-serif); font-style:italic; text-transform:none; letter-spacing:0; font-size:.85rem; opacity:.6; margin-top:.15rem; }
.lrow__ing{ font-style:italic; font-size:.92rem; opacity:.6; }
.lrow__base{ font-family:var(--font-sans); font-size:11px; letter-spacing:.12em; text-transform:uppercase; }
.lrow__caf{ font-family:var(--font-sans); font-size:11px; letter-spacing:.12em; text-transform:uppercase; opacity:.6; }
.lrow__buy{ display:flex; gap:.9rem; align-items:baseline; justify-content:flex-end; font-family:var(--font-sans); font-size:13px; }
.lrow__buy .add{ font-size:10px; letter-spacing:.16em; text-transform:uppercase; opacity:.6; }
.lrow:hover .lrow__buy .add{ opacity:1; text-decoration:underline; }
.ledger__foot{ display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:1rem 1.2rem; border-top:1px solid var(--line-paper); font-family:var(--font-sans); font-size:11px; letter-spacing:.16em; text-transform:uppercase; flex-wrap:wrap; }
@media (max-width:1024px){
  .ledger__head{ display:none; }
  .lrow{ grid-template-columns:3.4rem 1fr auto; }
  .lrow__ing,.lrow__base,.lrow__caf{ display:none; }
}

/* photo proof strip -- full colour, the only colour on the page */
.proof{ border-block:1px solid var(--line-paper); }
.proof .container{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; padding-inline:0; max-width:none; }
.proof figure{ border-right:1px solid var(--line-paper); position:relative; }
.proof figure:last-child{ border-right:0; }
.proof img{ width:100%; aspect-ratio:1/1; object-fit:cover; }
.proof figcaption{ position:absolute; left:.9rem; bottom:.8rem; background:var(--deep); border:1px solid var(--line-paper); padding:.3rem .7rem; font-family:var(--font-sans); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--paper); }
@media (max-width:880px){ .proof .container{ grid-template-columns:1fr; } .proof figure{ border-right:0; border-bottom:1px solid var(--line-paper); } .proof figure:last-child{ border-bottom:0; } }

/* sample band -- paper order slip interruption */
.sample{ background:var(--paper); color:var(--ink); }
.sample .container--narrow{ padding-block:clamp(3.5rem,7vw,6rem); }
.sample__slip{ border:1px dashed rgba(22,22,24,.55); padding:clamp(1.6rem,4vw,3rem); display:grid; grid-template-columns:1fr auto; gap:2rem; align-items:center; }
.sample__slip h2{ font-size:clamp(1.8rem,3.4vw,2.8rem); margin-bottom:.7rem; }
.sample__slip h2 em{ font-style:italic; }
.sample__slip p{ color:#5A554E; margin:0; max-width:44ch; }
.sample__slip .no{ font-family:var(--font-sans); font-size:10px; letter-spacing:.22em; text-transform:uppercase; color:var(--mid); display:block; margin-bottom:1rem; }
.sample__panel{ display:flex; flex-direction:column; gap:.9rem; align-items:flex-end; }
.sample__price{ font-family:var(--font-display); font-size:clamp(2.6rem,5vw,4rem); line-height:1; }
@media (max-width:880px){ .sample__slip{ grid-template-columns:1fr; } .sample__panel{ align-items:flex-start; } }

/* field guide -- spec entries on night */
.guide__grid{ display:grid; grid-template-columns:repeat(2,1fr); border-top:1px solid var(--line-paper); border-left:1px solid var(--line-paper); }
.spec{ border-right:1px solid var(--line-paper); border-bottom:1px solid var(--line-paper); padding:1.6rem clamp(1.2rem,2.4vw,2.2rem) 1.8rem; display:flex; flex-direction:column; gap:.7rem; }
.spec__row{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem; }
.spec__no{ font-family:var(--font-display); font-size:2rem; }
.spec__caf{ font-family:var(--font-sans); font-size:10px; letter-spacing:.16em; text-transform:uppercase; opacity:.55; }
.spec__name{ font-family:var(--font-sans); font-size:13px; letter-spacing:.26em; text-transform:uppercase; }
.spec__lore{ font-size:.95rem; margin:0; max-width:56ch; opacity:.82; }
.spec__leader{ display:flex; align-items:baseline; gap:.6rem; font-family:var(--font-sans); font-size:11px; letter-spacing:.12em; text-transform:uppercase; opacity:.65; margin-top:auto; padding-top:.6rem; }
.spec__leader::before{ content:""; flex:1; border-bottom:1px dotted var(--mid-paper); order:2; }
.spec__leader span{ order:1; }
.spec__leader a{ order:3; opacity:1; }
@media (max-width:880px){ .guide__grid{ grid-template-columns:1fr; } }

/* lore spotlight -- full-bleed photo quote */
.lore{ position:relative; isolation:isolate; padding-block:clamp(7rem,14vw,12rem); }
.lore__bg{ position:absolute; inset:0; z-index:-2; overflow:hidden; }
.lore__bg img{ width:100%; height:100%; object-fit:cover; filter:grayscale(45%) brightness(.5); }
.lore::after{ content:""; position:absolute; inset:0; z-index:-1; background:rgba(16,18,16,.45); }
.lore blockquote{ font-family:var(--font-display); font-size:clamp(1.9rem,4.2vw,3.4rem); line-height:1.18; max-width:24ch; }
.lore blockquote em{ font-style:italic; }
.lore .eyebrow{ display:block; margin-bottom:1.2rem; }
.lore .tlink{ margin-top:1.8rem; display:inline-flex; }

/* eco -- ruled register, night */
.eco .container--narrow{ border:1px solid var(--line-paper); padding:0; max-width:1080px; }
.eco__row{ display:grid; grid-template-columns:4rem 1fr 2fr; gap:1.4rem; align-items:baseline; padding:1.2rem clamp(1.2rem,3vw,2.4rem); border-top:1px solid var(--line-paper-soft); }
.eco__row:first-child{ border-top:0; }
.eco__row b{ font-family:var(--font-display); font-weight:400; font-size:1.25rem; }
.eco__row .num{ font-family:var(--font-sans); font-size:11px; letter-spacing:.18em; opacity:.55; }
.eco__row p{ margin:0; font-size:.95rem; opacity:.6; }
@media (max-width:880px){ .eco__row{ grid-template-columns:3rem 1fr; } .eco__row p{ grid-column:2; } }

/* prints -- framed plate on night */
.prints .container{ display:grid; grid-template-columns:minmax(0,5fr) minmax(0,7fr); gap:clamp(2rem,4vw,4rem); align-items:center; }
.prints figure{ border:1px solid var(--line-paper); padding:clamp(1rem,2.4vw,2rem); }
.prints figure img{ width:100%; aspect-ratio:1/1; object-fit:cover; }
.prints h2{ font-size:clamp(1.9rem,3.2vw,2.7rem); margin-bottom:1rem; }
.prints p{ max-width:46ch; opacity:.8; }
.prints .eyebrow{ display:block; margin-bottom:.8rem; }
@media (max-width:880px){ .prints .container{ grid-template-columns:1fr; } }

/* stockists -- paper band */
.stock{ background:var(--paper); color:var(--ink); }
.stock .container{ display:flex; align-items:baseline; justify-content:space-between; gap:2rem; padding-block:3.2rem; flex-wrap:wrap; }
.stock h2{ font-size:clamp(1.6rem,2.8vw,2.3rem); }
.stock p{ margin:.5rem 0 0; color:#5A554E; max-width:52ch; }

/* newsletter -- subscription slip, night */
.news .container--narrow{ max-width:760px; }
.news__slip{ border:1px solid var(--line-paper); padding:clamp(1.8rem,4vw,3rem); position:relative; }
.news__slip .eyebrow{ display:block; margin-bottom:.8rem; }
.news h2{ font-size:clamp(1.7rem,3vw,2.4rem); margin-bottom:.6rem; }
.news p{ opacity:.65; max-width:46ch; margin:0; }
.news form{ display:flex; margin-top:1.6rem; border:1px solid var(--paper); }
.news input{ flex:1; min-width:0; border:0; background:transparent; padding:0 1.1rem; font-family:var(--font-serif); font-size:1rem; min-height:var(--hit-target); color:var(--paper); }
.news input::placeholder{ color:rgba(250,250,248,.45); }
.news input:focus{ outline:2px solid var(--paper); outline-offset:-2px; }
.news button{ border:0; }

/* footer -- paper ground; abuts the preceding section (no margin-top) */
.footer{ background:var(--paper); color:var(--ink); }
.footer a{ color:inherit; text-decoration:none; }
.footer a:hover{ text-decoration:underline; }
.footer__grid{ display:grid; grid-template-columns:2fr 1fr 1fr 1.4fr; gap:clamp(2rem,4vw,4rem); padding-block:4rem 3rem; }
.footer__grid > div{ min-width:0; } /* grid items' auto minimum otherwise lets the newsletter form force its column past the viewport at <=880px */
.footer__mark{ font-family:var(--font-sans); font-weight:500; letter-spacing:.42em; text-transform:uppercase; font-size:15px; }
.footer__blurb{ color:var(--mid); font-size:.95rem; max-width:30ch; }
.footer h3{ font-family:var(--font-sans); font-size:11px; letter-spacing:.18em; text-transform:uppercase; margin:0 0 1rem; color:var(--mid); font-weight:500; }
.footer ul{ list-style:none; margin:0; padding:0; display:grid; gap:.55rem; font-size:.95rem; }
.footer__news p{ color:var(--mid); font-size:.95rem; margin:0 0 1rem; }
.footer__news form{ display:flex; border:1px solid var(--ink); }
.footer__news input{ flex:1; min-width:0; background:transparent; border:0; padding:0 1rem; min-height:var(--hit-target); font-family:var(--font-serif); }
.footer__social{ display:flex; gap:1.4rem; margin-top:1.2rem; font-family:var(--font-sans); font-size:11px; letter-spacing:.16em; text-transform:uppercase; }
.footer__bottom{ border-top:1px solid var(--line); padding-block:1.4rem; display:flex; justify-content:space-between; gap:1.5rem; flex-wrap:wrap; font-family:var(--font-sans); font-size:11px; letter-spacing:.08em; color:var(--mid); }
.footer__bottom ul{ list-style:none; display:flex; gap:1.4rem; margin:0; padding:0; }
.footer__disclaimer{ margin:1.1rem 0 0; font-family:var(--font-sans); font-size:10.5px; letter-spacing:.06em; color:var(--mid); opacity:.8; max-width:72ch; }
@media (max-width:880px){ .footer__grid{ grid-template-columns:1fr 1fr; } }

/* ============================================================
 * phase 3 -- inner pages. The PDP is an OPENED CATALOGUE ENTRY:
 * plate left, entry column right, paper brew-slip interruption,
 * specimen-label cards (the card IS the pouch label).
 * ============================================================ */

/* page meta ribbon -- catalogue grammar carried onto inner pages */
.pmeta{ border-bottom:1px solid var(--line-paper-soft); }
.pmeta .container{ display:flex; justify-content:space-between; align-items:baseline; gap:1rem 2rem; padding-block:1.05rem; font-family:var(--font-sans); font-size:10.5px; letter-spacing:.2em; text-transform:uppercase; color:var(--mid-paper); flex-wrap:wrap; }
.crumbs{ display:flex; gap:.65rem; flex-wrap:wrap; }
.crumbs a{ text-decoration:none; }
.crumbs a:hover{ text-decoration:underline; color:var(--paper); }
.crumbs .sep{ opacity:.45; }
.crumbs [aria-current]{ color:var(--paper); }

/* framed specimen plate (PDP gallery, pair callout) */
.plate{ border:1px solid var(--line-paper); padding:clamp(1rem,2.2vw,1.8rem); }
.plate img{ width:100%; aspect-ratio:1/1; object-fit:cover; }
.plate figcaption{ margin-top:1rem; display:flex; justify-content:space-between; align-items:baseline; gap:1rem; font-family:var(--font-sans); font-size:10px; letter-spacing:.18em; text-transform:uppercase; color:var(--mid-paper); }

/* the entry spread */
.pdp{ padding-block:calc(var(--space-section)*.62) var(--space-section); }
.pdp__layout{ display:grid; grid-template-columns:minmax(0,11fr) minmax(0,13fr); gap:clamp(2.5rem,5vw,5.5rem); align-items:start; }
.entry__head{ display:flex; align-items:flex-end; gap:clamp(1.2rem,2.5vw,2.2rem); flex-wrap:wrap; border-bottom:1px solid var(--line-paper); padding-bottom:1.5rem; }
.entry__no{ font-family:var(--font-display); font-size:clamp(4.6rem,8.5vw,7.2rem); line-height:.82; }
.entry__name h1{ font-family:var(--font-sans); font-weight:500; font-size:clamp(1.45rem,2.4vw,2rem); letter-spacing:.3em; text-transform:uppercase; line-height:1; }
.entry__name i{ display:block; font-family:var(--font-display); font-style:italic; font-size:1.15rem; opacity:.7; margin-top:.55rem; }
.entry__tags{ margin-top:1.4rem; font-family:var(--font-sans); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--mid-paper); }
.entry__lore{ font-family:var(--font-display); font-style:italic; font-size:clamp(1.3rem,2.1vw,1.65rem); line-height:1.42; max-width:34ch; margin:1.6rem 0 0; }
.entry__flavour{ margin:1.1rem 0 0; max-width:52ch; font-size:.97rem; opacity:.78; }

/* hairline spec table with dotted leaders */
.ltable{ margin-top:2.1rem; border-top:1px solid var(--line-paper); }
.ltable__row{ display:flex; align-items:baseline; gap:1rem; padding-block:.85rem; border-bottom:1px solid var(--line-paper-soft); }
.ltable__row dt{ font-family:var(--font-sans); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--mid-paper); min-width:6.5rem; }
.ltable__row .dots{ flex:1; border-bottom:1px dotted var(--mid-paper); transform:translateY(-3px); }
.ltable__row dd{ margin:0; font-size:.95rem; text-align:right; }

/* order slip (the buy box) */
.order{ margin-top:2.2rem; border:1px solid var(--line-paper); padding:clamp(1.4rem,2.6vw,2rem); }
.order .eyebrow{ display:block; margin-bottom:1.1rem; }
.order__price{ display:flex; align-items:baseline; gap:.9rem; }
.order__price b{ font-family:var(--font-display); font-weight:400; font-size:clamp(2rem,3.4vw,2.7rem); line-height:1; }
.order__price span{ font-family:var(--font-sans); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--mid-paper); }
.order__controls{ display:flex; gap:1rem; margin-top:1.4rem; flex-wrap:wrap; }
.qty{ display:flex; border:1px solid var(--paper); }
.qty button{ width:var(--hit-target); min-height:var(--hit-target); background:transparent; border:0; color:var(--paper); font-family:var(--font-sans); font-size:16px; cursor:pointer; }
.qty button:hover{ background:var(--paper); color:var(--ink); }
.qty input{ width:3.2rem; min-height:var(--hit-target); text-align:center; background:transparent; border:0; border-inline:1px solid var(--line-paper-soft); color:var(--paper); font-family:var(--font-sans); font-size:13px; }
.order .btn{ flex:1; min-width:12rem; }
.order__sample{ margin-top:1.25rem; font-size:.92rem; opacity:.8; font-style:italic; }
.order__sample .tlink{ font-style:normal; margin-left:.5rem; }

/* brew slip -- the page's paper interruption */
.brew{ background:var(--paper); color:var(--ink); }
.brew .container--narrow{ padding-block:clamp(3.5rem,7vw,6rem); }
.brew__slip{ border:1px dashed rgba(22,22,24,.55); padding:clamp(1.6rem,4vw,3rem); }
.brew__slip .eyebrow{ color:var(--mid); display:block; margin-bottom:.7rem; }
.brew__slip h2{ font-size:clamp(1.7rem,3vw,2.4rem); margin-bottom:1.4rem; }
.brew__row{ display:grid; grid-template-columns:3.4rem minmax(9rem,13rem) 1fr; gap:1.2rem; align-items:baseline; padding-block:1rem; border-top:1px solid var(--line); }
.brew__row .num{ font-family:var(--font-sans); font-size:11px; letter-spacing:.18em; color:var(--mid); }
.brew__row b{ font-family:var(--font-display); font-weight:400; font-size:1.2rem; }
.brew__row p{ margin:0; font-size:.95rem; color:#5A554E; }
.brew__note{ display:flex; align-items:baseline; gap:.7rem; margin-top:1.5rem; font-family:var(--font-sans); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; color:var(--mid); }
.brew__note::before{ content:""; flex:0 0 2.2rem; border-bottom:1px dotted var(--mid); transform:translateY(-3px); }
@media (max-width:880px){ .brew__row{ grid-template-columns:3rem 1fr; } .brew__row p{ grid-column:2; } }

/* specimen-label cards -- the card IS the pouch label on the pouch-black ground */
.rel__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,2.5vw,2rem); align-items:stretch; }
.scard{ display:flex; flex-direction:column; text-decoration:none; border:1px solid var(--line-paper); }
.scard__photo{ aspect-ratio:4/5; overflow:hidden; }
.scard__photo img{ width:100%; height:100%; object-fit:cover; transition:transform .45s ease; }
.scard:hover .scard__photo img{ transform:scale(1.03); }
.scard__label{ background:var(--label); color:var(--ink); padding:1.5rem 1.5rem 1.4rem; flex:1; display:flex; flex-direction:column; transition:background .3s ease,color .3s ease; }
.scard:hover .scard__label{ background:var(--deep); color:var(--paper); }
.scard__brand{ font-family:var(--font-sans); font-size:9.5px; letter-spacing:.34em; text-transform:uppercase; opacity:.55; }
.scard__no{ font-family:var(--font-display); font-size:2.4rem; line-height:1; margin-top:1.1rem; }
.scard__name{ font-family:var(--font-sans); font-size:12.5px; letter-spacing:.26em; text-transform:uppercase; margin-top:.55rem; }
.scard__name i{ display:block; font-family:var(--font-serif); font-style:italic; text-transform:none; letter-spacing:0; font-size:.85rem; opacity:.6; margin-top:.25rem; }
.scard__ing{ font-style:italic; font-size:.88rem; opacity:.62; margin-top:.75rem; max-width:30ch; }
.scard__foot{ display:flex; align-items:baseline; gap:.7rem; margin-top:auto; padding-top:1.7rem; font-family:var(--font-sans); font-size:11px; letter-spacing:.14em; text-transform:uppercase; }
.scard__foot::after{ content:""; flex:1; border-bottom:1px dotted currentColor; opacity:.45; order:2; transform:translateY(-3px); }
.scard__foot .ent{ order:3; }
/* label-only card (no surviving photo): the numeral + an abstract ink study carry the panel */
.scard--panel .scard__label{ padding-top:2rem; }
.scard--panel .scard__no{ font-size:clamp(3.2rem,4.5vw,4.4rem); margin-top:1.8rem; }
.scard__art{ display:flex; justify-content:center; align-items:center; margin-block:auto; padding-block:1.6rem; opacity:.85; }
.scard__art svg{ width:clamp(76px,42%,116px); height:auto; }
@media (min-width:1025px){ .pdp__media{ position:sticky; top:88px; } }
@media (max-width:1024px){ .pdp__layout{ grid-template-columns:1fr; } }
@media (max-width:880px){ .rel__grid{ grid-template-columns:1fr; } }

/* ============================================================
 * phase 3 -- mass-build components
 * ============================================================ */

/* nav fill toggle (floating pages; class added by site.js past 50px) */
.nav--floating.nav--filled{ position:fixed; background:var(--deep); border-bottom:1px solid var(--line-paper-soft); }

/* inner page head -- dictionary-entry grammar */
.phead{ padding-block:calc(var(--space-section)*.6) calc(var(--space-section)*.42); }
.phead .eyebrow{ display:block; margin-bottom:1rem; }
.phead h1{ font-size:clamp(2.3rem,4.6vw,3.8rem); max-width:20ch; }
.phead__lede{ max-width:54ch; opacity:.78; margin:1.2rem 0 0; }
.phead--ruled{ border-bottom:1px solid var(--line-paper-soft); }

/* typographic gallery panel (image-less PDPs) */
.plate--panel .panel{ aspect-ratio:1/1; background:var(--label); color:var(--ink); display:flex; flex-direction:column; padding:clamp(1.6rem,3.2vw,2.6rem); }
.panel__brand{ font-family:var(--font-sans); font-size:10px; letter-spacing:.34em; text-transform:uppercase; opacity:.55; }
.panel__no{ font-family:var(--font-display); font-size:clamp(2.6rem,4.6vw,4rem); line-height:1; margin-top:1.2rem; }
.panel__name{ font-family:var(--font-sans); font-size:14px; letter-spacing:.28em; text-transform:uppercase; margin-top:.6rem; }
.panel__name i{ display:block; font-family:var(--font-serif); font-style:italic; text-transform:none; letter-spacing:0; font-size:.9rem; opacity:.6; margin-top:.3rem; }
.panel__art{ display:flex; justify-content:center; align-items:center; margin-block:auto; padding-block:1.4rem; opacity:.85; }
.panel__art svg{ width:clamp(96px,38%,150px); height:auto; }
.panel__foot{ display:flex; align-items:baseline; gap:.7rem; font-family:var(--font-sans); font-size:10.5px; letter-spacing:.16em; text-transform:uppercase; }
.panel__foot::after{ content:""; flex:1; border-bottom:1px dotted currentColor; opacity:.45; order:2; transform:translateY(-3px); }
.panel__foot .r{ order:3; }

/* filter rail (shop) -- static by design: a sticky bar trips the
 * sticky-overlay-non-ancestor audit rule (CocoFlamingo bug class) */
.filters{ background:var(--deep); border-block:1px solid var(--line-paper-soft); }
.filters .container{ display:flex; gap:.4rem 2.6rem; flex-wrap:wrap; padding-block:.4rem; align-items:center; }
.fgroup{ display:flex; gap:1rem; align-items:center; flex-wrap:wrap; }
.fgroup__name{ font-family:var(--font-sans); font-size:10px; letter-spacing:.2em; text-transform:uppercase; color:var(--mid-paper); }
.fbtn{ background:none; border:0; color:var(--paper); opacity:.55; font-family:var(--font-sans); font-size:11px; letter-spacing:.14em; text-transform:uppercase; min-height:var(--hit-target); min-width:var(--hit-target); cursor:pointer; padding:0 .15rem; position:relative; }
.fbtn::after{ content:""; position:absolute; left:0; bottom:10px; width:100%; height:1px; background:currentColor; transform:scaleX(0); transform-origin:left; transition:transform .25s ease; }
.fbtn:hover{ opacity:.9; }
.fbtn[aria-pressed="true"]{ opacity:1; }
.fbtn[aria-pressed="true"]::after{ transform:scaleX(1); }

/* product grid (shop, collections, search, wishlist) */
.pgrid{ display:grid; grid-template-columns:repeat(4,1fr); gap:clamp(1.1rem,2vw,1.8rem); align-items:stretch; }
@media (max-width:1180px){ .pgrid{ grid-template-columns:repeat(3,1fr); } }
@media (max-width:1024px){ .pgrid{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){
  .pgrid{ gap:.8rem; }
  .pgrid .scard__label{ padding:1rem 1rem .95rem; }
  .pgrid .scard__no{ font-size:1.8rem; margin-top:.7rem; }
  .pgrid .scard--panel .scard__no{ font-size:2.2rem; margin-top:1rem; }
  .pgrid .scard__ing{ display:none; }
  .pgrid .scard__foot{ padding-top:1rem; }
}

/* brand callout band (shop) */
.callout{ border-block:1px solid var(--line-paper); padding-block:2.6rem; }
.callout .container{ display:flex; justify-content:space-between; align-items:baseline; gap:1.5rem; flex-wrap:wrap; }
.callout p{ margin:0; font-family:var(--font-display); font-style:italic; font-size:clamp(1.45rem,2.6vw,2.1rem); max-width:30ch; }

/* collection head numeral strip */
.chead__nums{ display:flex; gap:clamp(.9rem,2vw,1.6rem); font-family:var(--font-display); font-size:clamp(1.5rem,2.8vw,2.4rem); opacity:.45; margin-bottom:1.4rem; flex-wrap:wrap; }

/* bag (cart page) */
.cart__layout{ display:grid; grid-template-columns:minmax(0,8fr) minmax(0,4fr); gap:clamp(2rem,4vw,4rem); align-items:start; }
.bag{ border:1px solid var(--line-paper); }
.bag__row{ display:grid; grid-template-columns:3.4rem 1fr auto auto auto; gap:1.1rem; align-items:center; padding:1.05rem 1.2rem; border-top:1px solid var(--line-paper-soft); }
.bag__row:first-child{ border-top:0; }
.bag__no{ font-family:var(--font-display); font-size:1.4rem; }
.bag__name{ font-family:var(--font-sans); font-size:12px; letter-spacing:.18em; text-transform:uppercase; }
.bag__name i{ display:block; font-family:var(--font-serif); font-style:italic; text-transform:none; letter-spacing:0; font-size:.85rem; opacity:.6; margin-top:.15rem; }
.bag__qty .qty{ width:max-content; } /* hug the controls; the 1fr cell would stretch the border (mobile bag rows) */
.bag__qty .qty button{ width:34px; min-height:38px; }
.bag__qty .qty input{ width:2.4rem; min-height:38px; }
.bag__line{ font-family:var(--font-sans); font-size:13px; }
.bag__rm{ background:none; border:0; color:inherit; opacity:.55; font-family:var(--font-sans); font-size:10px; letter-spacing:.14em; text-transform:uppercase; cursor:pointer; min-height:var(--hit-target); }
.bag__rm:hover{ opacity:1; text-decoration:underline; }
.bag__empty{ padding:clamp(2rem,5vw,3.5rem); }
.bag__empty p{ font-family:var(--font-display); font-style:italic; font-size:1.3rem; margin:0 0 1.4rem; }
.totals{ border:1px solid var(--line-paper); padding:clamp(1.3rem,2.4vw,1.8rem); }
.totals .eyebrow{ display:block; margin-bottom:1rem; }
.totals__row{ display:flex; align-items:baseline; gap:.8rem; padding-block:.55rem; font-size:.95rem; }
.totals__row .dots{ flex:1; border-bottom:1px dotted var(--mid-paper); transform:translateY(-3px); }
.totals__row b{ font-family:var(--font-sans); font-size:13px; }
.totals__promo{ display:flex; border:1px solid var(--line-paper); margin-block:1rem; }
.totals__promo input{ flex:1; min-width:0; background:transparent; border:0; color:var(--paper); padding:0 .9rem; min-height:var(--hit-target); font-family:var(--font-serif); font-size:.92rem; }
.totals__promo input::placeholder{ color:rgba(250,250,248,.4); }
.totals__promo button{ border:0; background:none; color:var(--paper); font-family:var(--font-sans); font-size:10px; letter-spacing:.16em; text-transform:uppercase; padding:0 1rem; cursor:pointer; min-height:var(--hit-target); }
.totals .btn{ width:100%; margin-top:.4rem; }
.totals__note{ font-size:.85rem; opacity:.6; margin:.9rem 0 0; font-style:italic; }
.nudge{ border:1px dashed var(--line-paper); padding:1rem 1.2rem; display:flex; justify-content:space-between; gap:1rem; align-items:baseline; margin-top:1.4rem; font-size:.92rem; flex-wrap:wrap; }
@media (max-width:1024px){ .cart__layout{ grid-template-columns:1fr; } }
@media (max-width:680px){ .bag__row{ grid-template-columns:2.4rem 1fr auto; } .bag__qty{ grid-column:2; grid-row:2; } .bag__line{ grid-column:3; } .bag__rm{ grid-column:2 / -1; grid-row:3; text-align:left; min-height:34px; } }

/* search bar */
.searchbar{ display:flex; border:1px solid var(--paper); }
.searchbar input{ flex:1; min-width:0; background:transparent; border:0; color:var(--paper); padding:0 1.2rem; min-height:56px; font-family:var(--font-serif); font-size:1.05rem; }
.searchbar input::placeholder{ color:rgba(250,250,248,.4); }
.searchbar input:focus{ outline:2px solid var(--paper); outline-offset:-2px; }
.searchbar button{ border:0; }
.search__meta{ margin-block:1.6rem .4rem; font-family:var(--font-sans); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--mid-paper); }
.empty{ padding-block:2.5rem; }
.empty p{ font-family:var(--font-display); font-style:italic; font-size:1.25rem; margin:0 0 1rem; }

/* paper slip card (forms: account, commissions, wholesale, review) */
.slip{ background:var(--label); color:var(--ink); border:1px solid var(--line-paper); padding:clamp(1.7rem,3.4vw,2.6rem); }
.slip .eyebrow{ color:var(--mid); display:block; margin-bottom:.7rem; }
.slip h2{ font-size:clamp(1.5rem,2.6vw,2.1rem); margin-bottom:.8rem; }
.slip > p{ color:#5A554E; margin:0 0 1.4rem; max-width:52ch; }
.field{ display:grid; gap:.45rem; margin-bottom:1.15rem; }
.field label{ font-family:var(--font-sans); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--mid); }
.field input,.field textarea,.field select{ background:transparent; border:1px solid rgba(22,22,24,.35); border-radius:0; padding:.65rem .9rem; font-family:var(--font-serif); font-size:1rem; color:var(--ink); min-height:var(--hit-target); }
.field textarea{ min-height:8.5rem; resize:vertical; }
.field input:focus,.field textarea:focus,.field select:focus{ outline:2px solid var(--ink); outline-offset:-2px; }
.slip__grid2{ display:grid; grid-template-columns:1fr 1fr; gap:0 1.2rem; }
@media (max-width:680px){ .slip__grid2{ grid-template-columns:1fr; } }

/* account */
.auth__grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(1.5rem,3vw,2.5rem); align-items:start; }
@media (max-width:880px){ .auth__grid{ grid-template-columns:1fr; } }
.dash{ margin-top:var(--space-section); border:1px solid var(--line-paper); }
.dash__row{ display:grid; grid-template-columns:minmax(8rem,12rem) 1fr auto; gap:1.2rem; align-items:baseline; padding:1.2rem clamp(1.2rem,3vw,2rem); border-top:1px solid var(--line-paper-soft); }
.dash__row:first-child{ border-top:0; }
.dash__row b{ font-family:var(--font-sans); font-size:12px; letter-spacing:.18em; text-transform:uppercase; font-weight:500; }
.dash__row p{ margin:0; font-size:.92rem; opacity:.6; font-style:italic; }
@media (max-width:680px){ .dash__row{ grid-template-columns:1fr; gap:.3rem; } }

/* journal */
.jgrid{ display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(1.2rem,2.5vw,2rem); }
@media (max-width:1024px){ .jgrid{ grid-template-columns:1fr; } }
.jtile{ border:1px solid var(--line-paper); padding:clamp(1.5rem,2.6vw,2.1rem); display:flex; flex-direction:column; gap:.8rem; text-decoration:none; transition:background .25s ease,color .25s ease; }
.jtile:hover{ background:var(--paper); color:var(--ink); }
.jtile h3{ font-size:clamp(1.4rem,2.2vw,1.8rem); }
.jtile p{ margin:0; font-size:.93rem; opacity:.7; }
.jtile .tlink{ margin-top:auto; padding-top:1rem; }
.jtile--soon{ border-style:dashed; }
.jtile--soon:hover{ background:transparent; color:inherit; }

/* article (journal post, policies) */
.article{ padding-block:calc(var(--space-section)*.7) var(--space-section); }
.article .container--narrow{ max-width:760px; }
.article h2{ font-size:clamp(1.45rem,2.4vw,1.9rem); margin:2.4rem 0 .9rem; }
.article p{ margin:0 0 1.15rem; }
.article ul{ margin:0 0 1.15rem; padding-left:1.2rem; }
.article li{ margin-bottom:.4rem; }
.article hr{ border:0; border-top:1px solid var(--line-paper-soft); margin-block:2.2rem; }
.dropcap::first-letter{ font-family:var(--font-display); font-size:3.4em; float:left; line-height:.82; padding:.04em .12em 0 0; }
.article__meta{ font-family:var(--font-sans); font-size:10.5px; letter-spacing:.18em; text-transform:uppercase; color:var(--mid-paper); display:block; margin-bottom:1.1rem; }

/* contact + FAQ */
.contact__layout{ display:grid; grid-template-columns:minmax(0,7fr) minmax(0,5fr); gap:clamp(2rem,4.5vw,4.5rem); align-items:start; }
@media (max-width:1024px){ .contact__layout{ grid-template-columns:1fr; } }
.coords{ border:1px solid var(--line-paper); padding:clamp(1.4rem,2.6vw,2rem); }
.coords .ltable{ margin-top:1rem; border-top:0; }
.faq details{ border-top:1px solid var(--line-paper-soft); }
.faq details:last-child{ border-bottom:1px solid var(--line-paper-soft); }
.faq summary{ cursor:pointer; list-style:none; display:flex; justify-content:space-between; align-items:baseline; gap:1rem; padding-block:1.1rem; font-family:var(--font-display); font-size:1.15rem; min-height:var(--hit-target); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary::after{ content:"+"; font-family:var(--font-sans); opacity:.6; }
.faq details[open] summary::after{ content:"\2212"; }
.faq details p{ margin:0 0 1.2rem; font-size:.95rem; opacity:.75; max-width:60ch; }

/* review funnel -- centred paper card */
.review{ padding-block:var(--space-section); }
.review__card{ max-width:640px; margin-inline:auto; background:var(--label); color:var(--ink); border:1px solid var(--line-paper); padding:clamp(2rem,5vw,3.2rem); text-align:center; }
.review__card .eyebrow{ color:var(--mid); display:block; margin-bottom:.8rem; }
.review__card h1{ font-size:clamp(1.7rem,3.2vw,2.4rem); margin-bottom:.7rem; }
.review__card > p{ color:#5A554E; margin:0 auto; max-width:42ch; }
.stars{ display:flex; justify-content:center; gap:.3rem; margin-top:1.7rem; }
.star{ background:none; border:0; cursor:pointer; width:var(--hit-target); height:var(--hit-target); color:var(--ink); opacity:.3; display:inline-flex; align-items:center; justify-content:center; transition:opacity .15s ease, transform .15s ease; }
.star svg{ width:26px; height:26px; }
.star.is-lit{ opacity:1; }
.star:hover{ transform:scale(1.08); }
.review__form{ display:none; text-align:left; margin-top:1.8rem; border-top:1px solid var(--line); padding-top:1.6rem; }
.review__form.is-open{ display:block; }
.review__optout{ font-size:.85rem; color:#5A554E; margin:1rem 0 0; }
.review__optout a{ text-decoration:underline; }
.review__confirm{ display:none; margin-top:1.8rem; }
.review__confirm.is-open{ display:block; }
.review__fallback{ font-size:.88rem; color:#5A554E; margin-top:.9rem; }
.review__fallback a{ text-decoration:underline; }

/* sample blend picker (fieldset) */
.picker{ border:1px solid var(--line-paper); margin:1.6rem 0 0; padding:0; min-width:0; }
.picker legend{ float:left; width:100%; padding:.8rem 1.1rem .55rem; }
.prow{ clear:both; display:grid; grid-template-columns:auto 3rem 1fr auto; gap:1rem; padding:.8rem 1.1rem; border-top:1px solid var(--line-paper-soft); align-items:baseline; cursor:pointer; transition:background .2s ease,color .2s ease; }
.prow input{ accent-color:var(--paper); width:16px; height:16px; align-self:center; }
.prow__no{ font-family:var(--font-display); font-size:1.25rem; }
.prow__name{ font-family:var(--font-sans); font-size:11.5px; letter-spacing:.18em; text-transform:uppercase; }
.prow__name i{ font-family:var(--font-serif); font-style:italic; text-transform:none; letter-spacing:0; opacity:.6; margin-left:.5rem; }
.prow__caf{ font-family:var(--font-sans); font-size:10px; letter-spacing:.14em; text-transform:uppercase; opacity:.55; }
.prow:has(input:checked){ background:var(--paper); color:var(--ink); }
.prow:has(input:checked) input{ accent-color:var(--ink); }

/* stockists */
.stockgroup{ border:1px solid var(--line-paper); margin-bottom:2rem; }
.stockgroup__head{ padding:.85rem 1.2rem; background:var(--paper); color:var(--ink); font-family:var(--font-sans); font-size:10.5px; letter-spacing:.22em; text-transform:uppercase; }
.stockrow{ display:flex; align-items:baseline; gap:.9rem; padding:1rem 1.2rem; border-top:1px solid var(--line-paper-soft); }
.stockrow:first-of-type{ border-top:0; }
.stockrow .dots{ flex:1; border-bottom:1px dotted var(--mid-paper); transform:translateY(-3px); }
.stockrow b{ font-family:var(--font-sans); font-size:12px; letter-spacing:.16em; text-transform:uppercase; font-weight:500; }
.stockrow span:last-child{ font-size:.92rem; opacity:.7; }
.flagnote{ font-style:italic; opacity:.65; font-size:.9rem; }

/* 404 */
.notfound{ padding-block:calc(var(--space-section)*1.1); }
.notfound h1{ font-size:clamp(6rem,17vw,12.5rem); line-height:.85; }
.notfound__track{ display:flex; gap:1.1rem; margin-block:1.8rem 1.2rem; opacity:.6; }
.notfound__track svg{ width:26px; height:26px; }
.notfound p{ font-family:var(--font-display); font-style:italic; font-size:clamp(1.3rem,2.4vw,1.7rem); max-width:26ch; margin:0 0 1.8rem; }
.notfound .searchbar{ max-width:430px; margin-top:2rem; }

/* drawers, backdrop, lightbox (site.js-injected) */
.backdrop{ position:fixed; inset:0; background:rgba(16,18,16,.62); z-index:90; opacity:0; pointer-events:none; transition:opacity .25s ease; }
.backdrop.is-open{ opacity:1; pointer-events:auto; }
.drawer{ position:fixed; top:0; right:0; bottom:0; width:min(420px,92vw); background:var(--deep); color:var(--paper); border-left:1px solid var(--line-paper); z-index:95; transform:translateX(102%); transition:transform .32s ease; display:flex; flex-direction:column; }
.drawer.is-open{ transform:none; }
.drawer__head{ display:flex; justify-content:space-between; align-items:center; padding:.9rem 1.4rem; border-bottom:1px solid var(--line-paper-soft); font-family:var(--font-sans); font-size:11px; letter-spacing:.22em; text-transform:uppercase; }
.drawer__close{ background:none; border:0; color:inherit; width:var(--hit-target); height:var(--hit-target); cursor:pointer; font-size:18px; font-family:var(--font-sans); }
.drawer__body{ flex:1; overflow:auto; padding:1.2rem 1.4rem; }
.drawer__foot{ border-top:1px solid var(--line-paper); padding:1.2rem 1.4rem; }
.drawer__foot .btn{ width:100%; }
.drow{ display:grid; grid-template-columns:2.6rem 1fr auto; gap:.9rem; padding-block:.9rem; border-bottom:1px solid var(--line-paper-soft); align-items:center; font-size:.92rem; }
.drow__no{ font-family:var(--font-display); font-size:1.2rem; }
.drow__name{ font-family:var(--font-sans); font-size:11px; letter-spacing:.16em; text-transform:uppercase; }
.drow__name small{ display:block; font-family:var(--font-serif); font-style:italic; text-transform:none; letter-spacing:0; opacity:.6; font-size:.82rem; margin-top:.15rem; }
.drow__price{ font-family:var(--font-sans); font-size:12px; }
.drow__rm{ background:none; border:0; color:inherit; opacity:.5; font-size:10px; font-family:var(--font-sans); letter-spacing:.12em; text-transform:uppercase; cursor:pointer; padding:0; margin-top:.2rem; }
.drow__rm:hover{ opacity:1; text-decoration:underline; }
.mnav{ display:grid; }
.mnav a{ padding:.85rem 0; border-bottom:1px solid var(--line-paper-soft); font-family:var(--font-sans); font-size:13px; letter-spacing:.18em; text-transform:uppercase; text-decoration:none; min-height:var(--hit-target); display:flex; align-items:center; }
.drawer .searchbar{ margin-bottom:1.2rem; }
.drawer .searchbar input{ min-height:var(--hit-target); }
.lightbox{ position:fixed; inset:0; z-index:99; background:rgba(16,18,16,.93); display:flex; align-items:center; justify-content:center; padding:clamp(1rem,4vw,3rem); opacity:0; pointer-events:none; transition:opacity .25s ease; }
.lightbox.is-open{ opacity:1; pointer-events:auto; }
.lightbox img{ max-width:min(92vw,920px); max-height:86vh; width:auto; height:auto; }
.lightbox__close{ position:absolute; top:1rem; right:1rem; background:none; border:1px solid var(--line-paper); color:var(--paper); width:var(--hit-target); height:var(--hit-target); cursor:pointer; font-size:18px; font-family:var(--font-sans); }
[data-lightbox]{ cursor:zoom-in; }

/* page-rhythm utilities + story hero + soon-cards */
.sec--tight{ padding-top:0; }
.stockgroup--spaced{ margin-top:2.5rem; }
.review__cta{ margin-top:1.8rem; }
.coords .flagnote{ margin:1rem 0 0; }
.flagnote{ display:block; margin:.9rem 0 0; }
.hero--story{ min-height:70vh; }
.hero--story .hero__bg img{ filter:grayscale(45%) brightness(.55); }
.scard--soon{ border-style:dashed; }
.scard--soon .scard__label{ background:transparent; color:inherit; }
.scard--soon .scard__ing{ max-width:none; }
.faq .sec__head{ margin-bottom:calc(var(--space-section)*.2); }

/* commerce states (Seller-Owned Checkout, ADR 0035) -- dashed border is the
   ledger's annotation motif (.nudge, .brew__slip, .scard--soon): an inactive
   entry reads as a pencilled margin note, never a third colour. */
.btn:disabled{ background:transparent; color:var(--mid-paper); border:1px dashed var(--line-paper); cursor:not-allowed; }
.btn:disabled:hover{ background:transparent; color:var(--mid-paper); }
.btn.is-pending{ opacity:.55; cursor:progress; }
.order__fulfil{ margin-top:1.1rem; font-size:.9rem; font-style:italic; opacity:.75; max-width:46ch; }
.order--ooak .qty{ display:none; }
.order--closed .qty{ opacity:.4; pointer-events:none; }
.totals__error{ border:1px dashed var(--line-paper); padding:.85rem 1rem; margin:1rem 0 0; font-size:.9rem; font-style:italic; }

/* order-received receipt slip (cart.html?checkout=success) */
.receipt{ grid-column:1 / -1; border:1px solid var(--line-paper); padding:clamp(1.8rem,4vw,3rem); position:relative; }
.receipt .eyebrow{ display:block; margin-bottom:.8rem; }
.receipt h2{ font-size:clamp(1.7rem,3vw,2.4rem); margin:0 0 1rem; }
.receipt p{ max-width:52ch; margin:0 0 1.4rem; }
.receipt__art{ position:absolute; right:clamp(1.2rem,3vw,2.4rem); top:clamp(1.2rem,3vw,2.4rem); width:72px; opacity:.65; }
.receipt__art svg{ width:100%; height:auto; display:block; }
.receipt__rows{ max-width:26rem; margin:1.6rem 0 1.4rem; border-top:1px solid var(--line-paper-soft); padding-top:.5rem; }
.receipt__total{ border-top:1px solid var(--line-paper-soft); margin-top:.3rem; padding-top:.85rem; }
.receipt__total b{ font-size:14px; }
.receipt__email{ font-style:italic; opacity:.75; margin:0 0 1.4rem; }
/* thank-you mode: a just-paid visitor sees only the receipt slip */
.cart__layout--received .cart__goods{ display:none; }
.cart__layout--received > .totals{ display:none; }
@media (max-width:880px){ .receipt__art{ width:50px; } .receipt .eyebrow{ padding-right:64px; } }

/* the Order Trail (order.html + the lookup on account.html) -- ADR 0039.
   Stripe is the status DB; the session id in the URL is the capability
   token. The trail draws as ledger entries down a dashed margin rule --
   the same pencilled-annotation motif as .nudge and .scard--soon. */
.trail__layout{ display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.15fr); gap:clamp(1.6rem,3.4vw,3rem); align-items:start; }
.slip .totals__row .dots{ border-bottom-color:rgba(22,22,24,.4); }
.slip .receipt__total{ border-top-color:rgba(22,22,24,.25); }
.slip__rows{ margin:1.4rem 0 .4rem; border-top:1px solid rgba(22,22,24,.25); padding-top:.5rem; }
.slip__links{ display:flex; gap:1.8rem; margin-top:1.4rem; flex-wrap:wrap; }
.slip__note{ font-style:italic; color:#5A554E; font-size:.9rem; margin:1rem 0 0; max-width:46ch; }
.trail__col > .eyebrow{ display:block; margin-bottom:1.6rem; }
.trail{ list-style:none; margin:0; padding:.2rem 0 0; position:relative; }
.trail::before{ content:""; position:absolute; left:10px; top:16px; bottom:16px; border-left:1px dashed var(--line-paper); }
.trail__stage{ position:relative; padding:0 0 2.4rem 2.7rem; }
.trail__stage:last-child{ padding-bottom:0; }
.trail__dot{ position:absolute; left:0; top:.1rem; width:21px; height:21px; border:1px dashed var(--line-paper); border-radius:999px; background:var(--deep); }
.trail__stage b{ font-family:var(--font-sans); font-size:12px; letter-spacing:.18em; text-transform:uppercase; font-weight:500; display:block; margin-bottom:.35rem; opacity:.45; }
.trail__stage p{ margin:0; font-size:.95rem; opacity:.42; max-width:46ch; }
.trail__stage.is-done b,.trail__stage.is-now b{ opacity:1; }
.trail__stage.is-done p,.trail__stage.is-now p{ opacity:.78; }
.trail__stage.is-done .trail__dot{ border-style:solid; border-color:var(--paper); background:var(--paper); }
.trail__stage.is-now .trail__dot{ border-style:solid; border-color:var(--paper); box-shadow:0 0 0 5px rgba(250,250,248,.08); }
.trail__stage.is-now .trail__dot::after{ content:""; position:absolute; inset:5px; border-radius:999px; background:var(--paper); }
.trail__track{ margin-top:1.1rem; }
.trail__refund{ border:1px dashed var(--line-paper); padding:1rem 1.3rem; margin:0 0 1.9rem; font-style:italic; font-size:.95rem; max-width:52ch; }
.trail--refunded .trail__stage b,.trail--refunded .trail__stage p{ opacity:.35; }
.trail--refunded .trail__stage .trail__dot{ border-style:dashed; border-color:var(--line-paper); background:var(--deep); box-shadow:none; }
.trail--refunded .trail__stage .trail__dot::after{ content:none; }
.trail__note{ font-style:italic; opacity:.7; margin:0 0 1.6rem; max-width:52ch; }
.lookup{ max-width:38rem; }
.lookup__form{ display:flex; gap:.9rem; align-items:flex-end; }
.lookup__form .field{ flex:1; margin-bottom:0; }
.lookup__error{ font-style:italic; color:#5A554E; font-size:.9rem; margin:.9rem 0 0; }

/* Device Memory -- the remembered-orders slip under the lookup (ADR 0039
 * amendment pending). Ledger rows like .totals__row; snapshot data only. */
.devmem{ max-width:38rem; margin-top:1.6rem; }
.devmem__list{ list-style:none; margin:1.2rem 0 0; padding:.3rem 0 0; border-top:1px solid rgba(22,22,24,.25); }
.devmem__row{ display:flex; align-items:baseline; gap:.8rem; padding-block:.65rem; text-decoration:none; color:inherit; min-height:var(--hit-target); }
.devmem__row .dots{ flex:1; border-bottom:1px dotted rgba(22,22,24,.4); transform:translateY(-3px); }
.devmem__row b{ font-family:var(--font-sans); font-size:13px; white-space:nowrap; }
.devmem__what{ display:grid; gap:.15rem; min-width:0; }
.devmem__when{ font-size:.8rem; font-style:italic; color:#5A554E; }
.devmem__row:hover .devmem__title,.devmem__row:focus-visible .devmem__title{ text-decoration:underline; }
.devmem__forget{ margin-top:1.2rem; color:#5A554E; }
@media (max-width:880px){
  .trail__layout{ grid-template-columns:1fr; }
  .lookup__form{ flex-direction:column; align-items:stretch; }
}

/* scroll reveal -- JS adds .fade-in only to below-fold elements; no-JS sees everything */
html.js .fade-in{ opacity:0; transform:translateY(14px); transition:opacity .6s cubic-bezier(.22,.61,.36,1), transform .6s cubic-bezier(.22,.61,.36,1); }
html.js .fade-in.is-visible{ opacity:1; transform:none; }
@media (prefers-reduced-motion:reduce){ html.js .fade-in{ opacity:1; transform:none; transition:none; } }
