/* One Happy Leaf -- site.css
 * Per-prospect design system extracted from the signed-off V7 homepage direction.
 * Tokens live in tokens.override.css; this file is layout + components.
 */

/* ---- reset baseline ---- */
*{box-sizing:border-box;}
/* UA default margin reset: <figure>, <blockquote>, <dl>, <fieldset>, <menu> ship with
 * surprising browser-default margins that silently break grid / flex cells. */
figure,blockquote,dl,fieldset,menu{margin:0;}

body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--body);font-size:18px;line-height:1.6;-webkit-font-smoothing:antialiased;}
a{color:inherit;}
img{display:block;max-width:100%;}

/* ---- container rails ---- */
.container{width:100%;max-width:var(--rails-wide);margin-inline:auto;padding-inline:var(--rails-pad);}
.container--narrow{max-width:var(--rails-narrow);}

/* ---- shared type primitives ---- */
.eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--bamboo-deep);}
h1,h2,h3{font-family:var(--display);font-weight:500;line-height:1.04;margin:0;letter-spacing:-.01em;}

/* ---- buttons ---- */
.btn{font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;padding:.95rem 1.8rem;border:1px solid var(--ink);background:var(--ink);color:var(--paper);text-decoration:none;transition:background .2s,color .2s;cursor:pointer;display:inline-block;}
.btn:hover{background:transparent;color:var(--ink);}
.btn--ghost{background:transparent;color:var(--ink);}
.btn--ghost:hover{background:var(--ink);color:var(--paper);}

/* ---- nav ---- */
.nav{position:sticky;top:0;z-index:40;background:rgba(251,247,238,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);}
.nav__row{display:flex;align-items:center;justify-content:space-between;padding-block:18px;gap:1.5rem;}
.nav__mark{font-family:var(--display);font-size:1.4rem;font-weight:600;text-decoration:none;letter-spacing:-.02em;display:flex;align-items:center;gap:.5rem;}
.nav__leaf{width:22px;height:22px;color:var(--green);}
.nav__links{display:flex;gap:2rem;font-family:var(--mono);font-size:12px;letter-spacing:.12em;text-transform:uppercase;}
.nav__links a{text-decoration:none;padding-bottom:2px;border-bottom:1px solid transparent;transition:border-color .2s;}
.nav__links a:hover{border-color:var(--ink);}
.nav__icons{display:flex;gap:1.1rem;align-items:center;}
.nav__icons svg{width:21px;height:21px;}
.nav__icon{color:inherit;display:inline-flex;}
@media(max-width:880px){.nav__links{display:none;}}

/* ---- hero (specimen plate) ---- */
.hero{padding-block:clamp(2.5rem,6vw,5rem) clamp(3rem,7vw,6rem);position:relative;overflow:hidden;}
.hero__grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,5rem);align-items:center;}
.hero__plate{border:1px solid var(--line);}
.hero__platehead{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);padding:.7rem 1rem;border-bottom:1px solid var(--line);}
.hero h1{font-size:clamp(2.6rem,6vw,4.6rem);font-weight:400;margin-bottom:1.4rem;}
.hero h1 em{font-style:italic;color:var(--green);}
.hero__sub{font-size:1.12rem;color:var(--ink-soft);max-width:46ch;margin-bottom:2rem;}
.hero__cta{display:flex;gap:1rem;flex-wrap:wrap;align-items:center;}
.hero__stamp{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--bamboo-deep);margin-top:1.6rem;display:flex;align-items:center;gap:.5rem;}
.hero__specimen{aspect-ratio:3/4;background:var(--paper-2);display:grid;place-items:center;position:relative;padding:1.2rem;}
.hero__specimen img{width:100%;height:100%;object-fit:contain;mix-blend-mode:multiply;}
.hero__label{position:absolute;bottom:.8rem;left:1rem;right:1rem;display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);}

/* ---- featured collection (specimen grid) ---- */
.specimens{padding-block:clamp(3rem,6vw,5.5rem);border-top:1px solid var(--line);}
.sec-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:2.4rem;flex-wrap:wrap;gap:1rem;}
.sec-head h2{font-size:clamp(1.8rem,3.4vw,2.6rem);}
.sec-head a{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;border-bottom:1px solid var(--ink);padding-bottom:3px;}
.spec-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.spec{background:var(--paper);padding:1.4rem 1.2rem 1.1rem;text-decoration:none;display:flex;flex-direction:column;gap:.7rem;transition:background .25s;}
.spec:hover{background:var(--paper-2);}
.spec__no{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--bamboo-deep);}
.spec__img{aspect-ratio:1/1;display:grid;place-items:center;}
.spec__img img{width:86%;height:86%;object-fit:contain;mix-blend-mode:multiply;transition:transform .35s ease;}
.spec:hover .spec__img img{transform:scale(1.05) rotate(-1.5deg);}
.spec__name{font-family:var(--display);font-size:1.12rem;line-height:1.15;}
.spec__meta{display:flex;justify-content:space-between;font-family:var(--mono);font-size:11px;color:var(--ink-soft);border-top:1px dotted var(--line);padding-top:.6rem;margin-top:auto;}
@media(max-width:900px){.spec-grid{grid-template-columns:repeat(2,1fr);}}

/* ---- brand-signature: The Forest We're Growing ---- */
.forest{background:var(--green);color:var(--paper);padding-block:clamp(3.5rem,7vw,6rem);position:relative;overflow:hidden;}
.forest::before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle at 20% 80%,rgba(140,174,99,.4),transparent 45%),radial-gradient(circle at 85% 20%,rgba(140,174,99,.32),transparent 40%);}
.forest__in{position:relative;}
.forest__lead{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--green-light);margin-bottom:1.4rem;}
.forest__row{display:grid;grid-template-columns:auto 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:end;}
.forest__count{font-family:var(--display);font-size:clamp(4rem,12vw,9rem);font-weight:400;line-height:.85;letter-spacing:-.03em;}
.forest__count span{display:block;font-size:.16em;font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;color:var(--green-light);margin-top:1rem;}
.forest__note{font-family:var(--display);font-size:clamp(1.3rem,2.4vw,1.9rem);font-style:italic;line-height:1.3;max-width:30ch;}
.forest__trees{display:flex;gap:.4rem;margin-top:2.6rem;flex-wrap:wrap;}
.forest__trees svg{width:26px;height:34px;opacity:.85;color:var(--green-light);}
.forest__link{display:inline-block;margin-top:2rem;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);border-bottom:1px solid var(--green-light);padding-bottom:3px;text-decoration:none;}

/* ---- maker (centered editorial) ---- */
.maker{padding-block:clamp(3.5rem,7vw,6rem);border-top:1px solid var(--line);text-align:center;}
.maker .eyebrow{margin-bottom:1.2rem;}
.maker h2{font-size:clamp(2rem,4.2vw,3.2rem);font-weight:400;margin-bottom:1.6rem;}
.maker h2 em{font-style:italic;color:var(--green);}
.maker p{color:var(--ink-soft);font-size:1.15rem;max-width:60ch;margin:0 auto 1.3rem;}
.maker__sign{font-family:var(--display);font-style:italic;font-size:1.7rem;margin-top:2rem;}
.maker__byline{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--bamboo-deep);margin-top:.5rem;}
.maker__link{margin-top:1.8rem;}

/* ---- why bamboo ---- */
.why{padding-block:clamp(2.5rem,5vw,4.5rem);background:var(--paper-2);}
.why__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.why__item{background:var(--paper-2);padding:clamp(1.6rem,3vw,2.4rem);}
.why__icon{width:34px;height:34px;color:var(--green);margin-bottom:1.1rem;}
.why__item h3{font-family:var(--display);font-size:1.35rem;margin-bottom:.6rem;}
.why__item p{color:var(--ink-soft);font-size:1rem;}
.why__no{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;color:var(--bamboo-deep);float:right;}
@media(max-width:760px){.why__grid{grid-template-columns:1fr;}}

/* ---- reviews ---- */
.reviews{padding-block:clamp(3.5rem,7vw,6rem);}
.reviews__head{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:1rem;margin-bottom:2.2rem;}
.reviews__head h2{font-size:clamp(1.8rem,3.4vw,2.6rem);}
.reviews__agg{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);text-align:right;}
.reviews__agg b{display:block;font-family:var(--display);font-size:1.8rem;color:var(--ink);letter-spacing:0;}
.reviews__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2vw,1.6rem);}
.review{border:1px solid var(--line);padding:1.8rem;display:flex;flex-direction:column;gap:1rem;background:var(--paper);}
.review__stars{color:var(--bamboo-deep);letter-spacing:.2em;font-size:.95rem;}
.review__text{font-family:var(--display);font-size:1.2rem;line-height:1.35;}
.review__who{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-top:auto;}
@media(max-width:880px){.reviews__grid{grid-template-columns:1fr;}}

/* ---- stockists strip ---- */
.stockists{padding-block:clamp(2.5rem,5vw,4rem);border-top:1px solid var(--line);border-bottom:1px solid var(--line);}
.stockists__row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:1.5rem;}
.stockists__lead{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--bamboo-deep);}
.stockists__names{display:flex;gap:clamp(1.5rem,4vw,3rem);flex-wrap:wrap;font-family:var(--display);font-size:clamp(1.1rem,2vw,1.5rem);}
.stockists__link{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;border-bottom:1px solid var(--ink);padding-bottom:3px;}

/* ---- CTA (Field Notes plate) ---- */
.cta{padding-block:clamp(3.5rem,7vw,6rem);}
.cta__plate{border:1px solid var(--ink);background:var(--paper-2);display:grid;grid-template-columns:1.25fr .75fr;}
.cta__head{grid-column:1/-1;display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);padding:.8rem 1.4rem;border-bottom:1px solid var(--line);}
.cta__body{padding:clamp(2rem,4vw,3.4rem);}
.cta__body .eyebrow{margin-bottom:1rem;display:block;}
.cta__body h2{font-size:clamp(1.9rem,3.8vw,3rem);font-weight:400;margin-bottom:1rem;}
.cta__body h2 em{font-style:italic;color:var(--green);}
.cta__body p{color:var(--ink-soft);max-width:46ch;margin-bottom:1.9rem;}
.cta__form{display:flex;gap:.6rem;flex-wrap:wrap;max-width:460px;}
.cta__form input{flex:1;min-width:210px;padding:.95rem 1.1rem;border:1px solid var(--ink);background:var(--paper);font-family:var(--body);font-size:1rem;color:var(--ink);}
.cta__form input::placeholder{color:var(--ink-soft);}
.cta__note{font-family:var(--mono);font-size:10.5px;letter-spacing:.06em;color:var(--ink-soft);margin-top:1.1rem;text-transform:uppercase;display:flex;align-items:center;gap:.5rem;}
.cta__note svg{width:14px;height:14px;color:var(--green);}
.cta__aside{border-left:1px solid var(--line);background:var(--paper-2);overflow:hidden;}
.cta__aside img{width:100%;height:100%;object-fit:cover;display:block;}
@media(max-width:780px){.cta__plate{grid-template-columns:1fr;}.cta__aside{border-left:none;border-top:1px solid var(--line);order:-1;aspect-ratio:16/10;}}

/* ---- footer (abuts preceding section -- no margin-top) ---- */
.footer{background:var(--ink);color:var(--paper);padding-block:clamp(3rem,5vw,4rem) 2rem;}
.footer__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:2rem;padding-bottom:2.5rem;border-bottom:1px solid rgba(251,247,238,.18);}
.footer__mark{font-family:var(--display);font-size:1.5rem;margin-bottom:1rem;}
.footer p{color:rgba(251,247,238,.62);font-size:.95rem;max-width:32ch;}
.footer__h{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:rgba(251,247,238,.5);margin:0 0 1rem;}
.footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.6rem;}
.footer ul a{color:rgba(251,247,238,.82);text-decoration:none;font-size:.95rem;}
.footer__bottom{display:flex;justify-content:space-between;padding-top:1.6rem;font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:rgba(251,247,238,.5);flex-wrap:wrap;gap:1rem;}

/* ---- responsive collapse ---- */
@media(max-width:900px){
  .hero__grid{grid-template-columns:1fr;}
  .forest__row{grid-template-columns:1fr;}
  .footer__top{grid-template-columns:1fr 1fr;}
}

/* ---- scroll-reveal (no-JS-safe: visible by default, hidden only once .js is set) ---- */
.js .fade-in{opacity:0;transform:translateY(14px);transition:opacity .6s ease,transform .6s ease;}
.js .fade-in.is-visible{opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.js .fade-in{opacity:1;transform:none;transition:none;}}

/* ---- breadcrumb ---- */
.crumb{padding-block:1.1rem;border-bottom:1px solid var(--line);font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);}
.crumb a{text-decoration:none;}
.crumb a:hover{color:var(--ink);}
.crumb span{color:var(--ink);}

/* ---- PDP ---- */
.pdp{padding-block:clamp(2.5rem,5vw,4.5rem);}
.pdp__grid{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(2rem,5vw,5rem);align-items:start;}
.pdp__gallery{border:1px solid var(--line);position:sticky;top:90px;}
.pdp__galhead{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft);padding:.7rem 1rem;border-bottom:1px solid var(--line);}
.pdp__main{aspect-ratio:4/5;background:var(--paper-2);display:grid;place-items:center;padding:clamp(2rem,5vw,4rem);cursor:zoom-in;}
.pdp__main img{width:72%;height:72%;object-fit:contain;mix-blend-mode:multiply;}
.pdp__info .eyebrow{display:block;margin-bottom:.9rem;}
.pdp h1{font-size:clamp(2rem,4vw,3rem);font-weight:400;margin-bottom:.7rem;}
.pdp__price{font-family:var(--display);font-size:1.9rem;color:var(--ink);margin-bottom:1.5rem;}
.pdp__desc{color:var(--ink-soft);margin-bottom:1.8rem;max-width:46ch;}
/* spec as pills (V2 canonical) */
.pdp__pills{display:flex;flex-wrap:wrap;gap:.5rem;margin:0 0 1.9rem;}
.pdp__pills span{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);border:1px solid var(--line);border-radius:999px;padding:.5rem .9rem;}
.pdp__spec{border-top:1px solid var(--line);margin:0 0 1.8rem;}
.pdp__spec div{display:flex;justify-content:space-between;align-items:baseline;padding:.7rem 0;border-bottom:1px dotted var(--line);}
.pdp__spec dt{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);}
.pdp__spec dd{margin:0;font-family:var(--display);font-size:1.02rem;}
.pdp__variants{margin-bottom:1.6rem;}
.pdp__vlabel{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:.7rem;display:block;}
.chip-row{display:flex;gap:.5rem;flex-wrap:wrap;}
.vchip{font-family:var(--mono);font-size:11px;letter-spacing:.06em;padding:.6rem 1rem;border:1px solid var(--line);background:var(--paper);cursor:pointer;text-transform:uppercase;color:var(--ink);transition:.2s;}
.vchip[aria-pressed="true"]{border-color:var(--ink);background:var(--ink);color:var(--paper);}
.pdp__buy{display:flex;gap:.8rem;align-items:stretch;margin-bottom:1.3rem;flex-wrap:wrap;}
.qty{display:flex;border:1px solid var(--ink);}
.qty button{width:44px;background:var(--paper);border:none;font-family:var(--mono);font-size:1.1rem;cursor:pointer;color:var(--ink);}
.qty button:hover{background:var(--paper-2);}
.qty input{width:48px;border:none;text-align:center;font-family:var(--mono);background:var(--paper);color:var(--ink);}
.pdp__buy .btn{flex:1;min-width:200px;text-align:center;}
.pdp__tree{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--green);text-transform:uppercase;display:flex;align-items:center;gap:.5rem;}
.pdp__tree svg{width:15px;height:15px;}
@media(max-width:820px){.pdp__grid{grid-template-columns:1fr;}.pdp__gallery{position:static;}}

/* ---- maker callout (PDP + others) ---- */
.makercallout{background:var(--paper-2);padding-block:clamp(2.2rem,4vw,3.2rem);border-block:1px solid var(--line);}
.makercallout__in{display:flex;align-items:center;gap:1.4rem;justify-content:center;text-align:center;flex-wrap:wrap;}
.makercallout svg{width:30px;height:30px;color:var(--green);flex:none;}
.makercallout p{font-family:var(--display);font-style:italic;font-size:clamp(1.15rem,2vw,1.4rem);max-width:52ch;}
.makercallout a{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;text-decoration:none;border-bottom:1px solid var(--ink);padding-bottom:3px;}

/* ---- related row (reuses .spec-grid / .spec) ---- */
.related{padding-block:clamp(3rem,6vw,5rem);}

/* ===================== shared page components ===================== */

/* page header band (non-hero pages) */
.pagehead{padding-block:clamp(2.6rem,5vw,4.5rem) clamp(1.8rem,3vw,2.6rem);border-bottom:1px solid var(--line);}
.pagehead .eyebrow{margin-bottom:1rem;display:block;}
.pagehead h1{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:400;}
.pagehead h1 em{font-style:italic;color:var(--green);}
.pagehead p{color:var(--ink-soft);max-width:60ch;margin:1rem 0 0;font-size:1.1rem;}

/* chips + filter rail (shop / collections) */
.chips{display:flex;gap:.5rem;flex-wrap:wrap;}
.chip{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;padding:.55rem 1rem;border:1px solid var(--line);background:var(--paper);text-decoration:none;color:var(--ink);transition:.2s;cursor:pointer;}
.chip:hover,.chip[aria-pressed="true"],.chip.is-on{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.shoptools{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;padding-block:1.6rem;border-bottom:1px solid var(--line);}
.shoptools .count{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);}
.shopgrid{padding-block:clamp(2.5rem,5vw,4rem);}
.callout-band{background:var(--green);color:var(--paper);padding-block:clamp(2.5rem,5vw,3.5rem);text-align:center;}
.callout-band p{font-family:var(--display);font-style:italic;font-size:clamp(1.3rem,2.6vw,2rem);max-width:30ch;margin:0 auto;}
.pageniation,.pagination{display:flex;gap:.6rem;justify-content:center;padding-top:2.5rem;}
.pagination a,.pagination span{font-family:var(--mono);font-size:12px;letter-spacing:.08em;text-decoration:none;padding:.4rem .7rem;border:1px solid var(--line);}
.pagination span[aria-current]{background:var(--ink);color:var(--paper);border-color:var(--ink);}

/* generic section + prose */
.section{padding-block:clamp(3rem,6vw,5rem);}
.prose{padding-block:clamp(2.5rem,5vw,4rem);}
.prose p,.prose li{color:var(--ink-soft);max-width:68ch;margin:0 0 1.1rem;}
.prose h2{font-family:var(--display);font-size:clamp(1.5rem,3vw,2.1rem);font-weight:500;margin:2.2rem 0 1rem;}
.prose h3{font-family:var(--display);font-size:1.3rem;margin:1.6rem 0 .7rem;}
.prose ul{padding-left:1.2rem;}
.prose a{color:var(--green);}
.prose__updated{font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:2rem;}

/* forms */
.form{display:grid;gap:1.2rem;max-width:560px;}
.form--wide{max-width:760px;grid-template-columns:1fr 1fr;}
.field{display:flex;flex-direction:column;gap:.5rem;}
.field--full{grid-column:1/-1;}
.field label{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-soft);}
.field input,.field textarea,.field select{font-family:var(--body);font-size:1rem;color:var(--ink);background:var(--paper);border:1px solid var(--line);padding:.85rem 1rem;border-radius:0;}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--green);outline-offset:1px;border-color:var(--green);}
.field textarea{min-height:140px;resize:vertical;}

/* editorial split (our-story etc.) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
.split--narrow-img{grid-template-columns:.8fr 1.2fr;}
.split h2{font-size:clamp(1.7rem,3.4vw,2.6rem);font-weight:400;margin-bottom:1.2rem;}
.split h2 em{font-style:italic;color:var(--green);}
.split p{color:var(--ink-soft);margin-bottom:1.1rem;max-width:52ch;}
.placeholder-img{background:linear-gradient(160deg,var(--paper-2),#E7DCC6);border:1px solid var(--line);display:grid;place-items:center;text-align:center;padding:2rem;aspect-ratio:var(--placeholder-aspect,4 / 5);}
.placeholder-img span{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);max-width:30ch;}
@media(max-width:820px){.split,.split--narrow-img{grid-template-columns:1fr;}.form--wide{grid-template-columns:1fr;}}

/* stockist cards */
.stockist-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.stockist{background:var(--paper);padding:1.8rem;}
.stockist h3{font-family:var(--display);font-size:1.3rem;margin-bottom:.4rem;}
.stockist p{color:var(--ink-soft);font-size:.95rem;margin:0 0 .3rem;}
.stockist .region{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--bamboo-deep);}
@media(max-width:680px){.stockist-grid{grid-template-columns:1fr;}}

/* journal */
.journal-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.2rem,2.5vw,2rem);}
.jcard{text-decoration:none;display:flex;flex-direction:column;gap:.9rem;}
.jcard__img{aspect-ratio:3/2;}
.jcard__cat{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--bamboo-deep);}
.jcard h3{font-family:var(--display);font-size:1.3rem;line-height:1.2;}
.jcard p{color:var(--ink-soft);font-size:.95rem;}
@media(max-width:880px){.journal-grid{grid-template-columns:1fr 1fr;}}
@media(max-width:560px){.journal-grid{grid-template-columns:1fr;}}
.article{padding-block:clamp(2.5rem,5vw,4rem);}
.article__hero{aspect-ratio:16/7;margin-bottom:2.2rem;}
.article__body{max-width:68ch;margin:0 auto;}
.article__body p{color:var(--ink-soft);margin:0 0 1.2rem;}
.article__body h2{font-family:var(--display);font-size:1.5rem;margin:2rem 0 .8rem;}

/* cart */
.cartrow{display:grid;grid-template-columns:90px 1fr auto auto;gap:1.2rem;align-items:center;padding:1.2rem 0;border-bottom:1px solid var(--line);}
.cartrow__img{aspect-ratio:1/1;background:var(--paper-2);display:grid;place-items:center;}
.cartrow__img img{width:80%;height:80%;object-fit:contain;mix-blend-mode:multiply;}
.cartrow__name{font-family:var(--display);font-size:1.1rem;}
.cartrow__meta{font-family:var(--mono);font-size:11px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em;}
.cart-layout{display:grid;grid-template-columns:1.6fr .8fr;gap:clamp(2rem,5vw,4rem);align-items:start;}
.cart-summary{border:1px solid var(--line);padding:1.8rem;background:var(--paper-2);}
.cart-summary h2{font-family:var(--display);font-size:1.4rem;margin-bottom:1.2rem;}
.cart-summary .line{display:flex;justify-content:space-between;padding:.5rem 0;color:var(--ink-soft);font-size:.95rem;}
.cart-summary .total{display:flex;justify-content:space-between;border-top:1px solid var(--line);margin-top:.6rem;padding-top:.9rem;font-family:var(--display);font-size:1.25rem;}
.cart-empty{text-align:center;padding-block:clamp(3rem,6vw,5rem);}
@media(max-width:820px){.cart-layout{grid-template-columns:1fr;}}

/* account tabs / wishlist */
.tabs{display:flex;gap:.5rem;margin-bottom:2rem;border-bottom:1px solid var(--line);}
.tabs button{font-family:var(--mono);font-size:12px;letter-spacing:.1em;text-transform:uppercase;background:none;border:none;padding:.8rem 1rem;cursor:pointer;color:var(--ink-soft);border-bottom:2px solid transparent;}
.tabs button[aria-selected="true"]{color:var(--ink);border-color:var(--green);}
.tabs button{min-height:44px;}

/* contact FAQ */
.faq{display:grid;gap:1rem;}
.faq__item{border-bottom:1px solid var(--line);padding-bottom:1rem;}
.faq__item h3{font-family:var(--display);font-size:1.2rem;margin:0 0 .4rem;}
.faq__item p{color:var(--ink-soft);margin:0;}
.contact-note{margin-top:1.5rem;}

/* search */
.searchbox{display:flex;gap:.6rem;max-width:600px;margin-bottom:2rem;}
.searchbox input{flex:1;font-family:var(--body);font-size:1.1rem;padding:.9rem 1.1rem;border:1px solid var(--ink);background:var(--paper);color:var(--ink);}
.search-results{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line);}
.search-empty{color:var(--ink-soft);padding-block:2rem;}
@media(max-width:900px){.search-results{grid-template-columns:repeat(2,1fr);}}

/* Review Funnel -- one centred card holds heading + stars + branches */
.review-page{padding-block:clamp(3rem,8vw,7rem);background:var(--paper-2);}
.review-card{max-width:560px;margin-inline:auto;text-align:center;background:var(--paper);border:1px solid var(--line);padding:clamp(2rem,5vw,3.4rem);box-shadow:0 26px 60px -34px rgba(var(--shadow-rgb),.42);}
.review-card .eyebrow{display:block;margin-bottom:1rem;}
.review-card__title{font-size:clamp(2rem,4.4vw,2.9rem);font-weight:400;margin:0 0 .7rem;}
.review-card__lead{color:var(--ink-soft);max-width:42ch;margin:0 auto;font-size:1.1rem;}
.stars-input{display:flex;justify-content:center;gap:.3rem;font-size:2.2rem;color:var(--line);margin:1.6rem 0 0;}
.stars-input button{background:none;border:none;cursor:pointer;color:inherit;font-size:inherit;line-height:1;padding:0;}
.stars-input button.is-on,.stars-input button:hover,.stars-input button:hover ~ button{color:var(--bamboo-deep);}
.stars-input.pick-low button.is-on{color:var(--bamboo-deep);}
.review-branch{display:none;margin-top:1.7rem;}
.review-branch.is-active{display:block;}
.review-branch p{color:var(--ink-soft);margin:0 0 1rem;}
.review-card__fallback{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--ink-soft);}
.review-card__fallback a{color:var(--ink);border-bottom:1px solid var(--ink);}
.review-route--private{text-align:left;}
.review-route--private .form{margin-top:1rem;}
.optout{font-family:var(--mono);font-size:11px;letter-spacing:.06em;}

/* 404 */
.notfound{text-align:center;padding-block:clamp(4rem,9vw,7rem);}
.notfound h1{font-size:clamp(3rem,9vw,6rem);font-weight:400;}
.notfound p{color:var(--ink-soft);max-width:42ch;margin:1rem auto 2rem;}

/* ---- injected UI (cart drawer / search overlay / mobile menu) ---- */
.scrim{position:fixed;inset:0;background:rgba(54,48,42,.5);opacity:0;visibility:hidden;transition:opacity .3s;z-index:60;}
.scrim.is-open{opacity:1;visibility:visible;}
.drawer{position:fixed;top:0;right:0;height:100%;width:min(420px,90vw);background:var(--paper);z-index:70;transform:translateX(100%);visibility:hidden;transition:transform .35s cubic-bezier(.2,.8,.2,1),visibility 0s linear .35s;display:flex;flex-direction:column;}
.drawer.is-open{transform:none;visibility:visible;transition:transform .35s cubic-bezier(.2,.8,.2,1);}
.drawer--left{right:auto;left:0;transform:translateX(-100%);}
.drawer--left.is-open{transform:none;}
.drawer__head{display:flex;justify-content:space-between;align-items:center;padding:1.3rem 1.5rem;border-bottom:1px solid var(--line);}
.drawer__head h2{font-family:var(--display);font-size:1.2rem;}
.drawer__close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--ink);line-height:1;}
.drawer__body{padding:1.5rem;overflow-y:auto;flex:1;}
.drawer__links{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.2rem;}
.drawer__links a{display:block;font-family:var(--display);font-size:1.3rem;text-decoration:none;padding:.6rem 0;border-bottom:1px solid var(--line);}
.drawer__foot{padding:1.3rem 1.5rem;border-top:1px solid var(--line);}
.drawer__search{display:flex;gap:.5rem;margin-bottom:1.4rem;}
.drawer__search input{flex:1;font-family:var(--body);padding:.7rem .9rem;border:1px solid var(--line);background:var(--paper);color:var(--ink);}
.drawer__line{display:grid;grid-template-columns:64px 1fr auto;gap:.9rem;align-items:center;padding:.9rem 0;border-bottom:1px solid var(--line);}
.drawer__line img{width:100%;aspect-ratio:1/1;object-fit:contain;mix-blend-mode:multiply;background:var(--paper-2);}
.drawer__line .nm{font-family:var(--display);font-size:1rem;}
.drawer__line .pr{font-family:var(--mono);font-size:12px;color:var(--ink-soft);}
.search-overlay{position:fixed;top:0;left:0;right:0;background:var(--paper);z-index:70;transform:translateY(-100%);visibility:hidden;transition:transform .35s cubic-bezier(.2,.8,.2,1),visibility 0s linear .35s;padding:2rem var(--rails-pad);border-bottom:1px solid var(--line);}
.search-overlay.is-open{transform:none;visibility:visible;transition:transform .35s cubic-bezier(.2,.8,.2,1);}
.search-overlay .searchbox{max-width:none;}
.search-overlay__results{max-width:var(--rails-wide);margin:1.5rem auto 0;display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;}
.search-overlay__results a{text-decoration:none;font-family:var(--display);}
@media(max-width:780px){.search-overlay__results{grid-template-columns:repeat(2,1fr);}}

/* lightbox */
.lightbox{position:fixed;inset:0;background:rgba(54,48,42,.92);z-index:90;display:none;place-items:center;padding:3rem;}
.lightbox.is-open{display:grid;}
.lightbox img{max-width:90vw;max-height:85vh;object-fit:contain;}
.lightbox__close{position:absolute;top:1.5rem;right:1.5rem;background:none;border:none;color:var(--paper);font-size:2rem;cursor:pointer;}

/* nav cart-count badge + 44px hit target */
.nav__icon{position:relative;display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;}
.nav__cart-count{position:absolute;top:-6px;right:-8px;background:var(--green);color:var(--paper);font-family:var(--mono);font-size:9px;min-width:15px;height:15px;border-radius:999px;display:grid;place-items:center;padding:0 3px;}
.nav__icon--cart[data-empty="true"] .nav__cart-count{display:none;}

/* touch targets (WCAG 2.5.5: interactive >= 44x44 at mobile) */
.drawer__close,.lightbox__close{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;}
.vchip{min-height:44px;}
.qty button{min-height:44px;}
.qty input{min-height:44px;}
.stars-input button{min-width:44px;min-height:44px;}

/* mobile nav collapse: cart + menu only */
@media(max-width:880px){
  .nav__icon--search,.nav__icon--account,.nav__icon--wishlist{display:none;}
}
@media(min-width:881px){
  .nav__icon--menu{display:none;}
}

/* ADR-0027 unsolicited-concept disclaimer (inherits footer font + colour) */
.footer__disclaimer{ margin:1.2rem 0 0; max-width:72ch; font-size:10.5px; line-height:1.55; letter-spacing:.04em; opacity:.6; }
