/* CRFT-WEB-009 · Shelfmade Atelier · "Maker's Mark" design system
   Oat + charcoal ink + sage + clay · Bricolage Grotesque + Jost
   v2.1 STRUCTURE: text-only editorial hero + full-bleed lookbook strip · asymmetric
   product-shelf collage · underline-input forms · statement footer (oversized wordmark) */
:root{
  --ink:#26241f; --ink-2:#3a372f; --oat:#ece3d2; --paper:#f8f4ec;
  --sage:#869178; --sage-dk:#67715a; --clay:#bd6a47; --clay-dk:#9c5232;
  --muted:#776f62; --line:#e0d8c6; --white:#fff;
  --disp:'Bricolage Grotesque',system-ui,sans-serif; --body:'Jost',system-ui,sans-serif;
  --r:4px; --r-lg:12px;
  --s3:1.5rem; --s4:2.5rem; --s5:4rem; --s6:6.5rem;
  --sh:0 22px 55px -28px rgba(38,36,31,.4); --sh-sm:0 10px 26px -16px rgba(38,36,31,.28);
  --wrap:1200px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--body);color:var(--ink);background:var(--paper);line-height:1.66;-webkit-font-smoothing:antialiased;font-weight:300}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--disp);font-weight:600;line-height:1.04;letter-spacing:-.02em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 1.7rem}
.wrap.tight{max-width:880px}
section{padding:var(--s6) 0}
.eyebrow{display:inline-block;font-weight:500;font-size:.72rem;letter-spacing:.3em;text-transform:uppercase;color:var(--clay-dk)}
.lead{font-size:1.18rem;color:var(--muted);max-width:60ch;font-weight:300}
.muted{color:var(--muted)}
.center{text-align:center}
.section-head{max-width:60ch}
.section-head.center{margin:0 auto}
.section-head h2{font-size:clamp(2rem,4.4vw,3.1rem);margin:.3rem 0 .5rem;color:var(--ink)}
.section-head p{font-size:1.06rem;color:var(--muted)}
.bg-oat{background:var(--oat)}
.bg-ink{background:var(--ink);color:var(--oat)}
.bg-ink h2,.bg-ink h3{color:#fff}
.bg-ink .muted,.bg-ink .lead{color:#c2bcae}

.btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--body);font-weight:500;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;padding:.9rem 1.8rem;border-radius:999px;cursor:pointer;border:1.5px solid transparent;transition:transform .18s ease,background .18s ease,color .18s ease}
.btn.solid{background:var(--ink);color:var(--oat)}
.btn.solid:hover{background:var(--ink-2)}
.btn.clay{background:var(--clay);color:#fff}
.btn.clay:hover{background:var(--clay-dk)}
.btn.ghost{border-color:var(--ink);color:var(--ink)}
.btn.ghost:hover{background:var(--ink);color:var(--oat)}
.btn.outline-l{border-color:rgba(236,227,210,.5);color:var(--oat)}
.btn.outline-l:hover{background:var(--oat);color:var(--ink)}
.btn.sm{padding:.55rem 1.1rem;font-size:.72rem}

header.site{position:sticky;top:0;z-index:40;background:rgba(248,244,236,.93);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header .nav{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.7rem;max-width:var(--wrap);margin:0 auto}
.brand{font-family:var(--disp);font-weight:600;font-size:1.35rem;letter-spacing:-.02em;color:var(--ink)}
.brand span{color:var(--clay-dk)}
.nav-links{display:flex;align-items:center;gap:1.9rem}
.nav-links a{font-weight:400;font-size:.84rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.nav-links a:not(.btn):hover,.nav-links a.active{color:var(--clay-dk)}
.menu-btn{display:none;background:none;border:0;font-size:1.5rem;cursor:pointer;color:var(--ink)}

/* TEXT-ONLY EDITORIAL HERO (v2.1 distinct) */
.hero{padding:clamp(3.5rem,9vw,7rem) 0 clamp(2.5rem,5vw,4rem);text-align:center}
.hero .eyebrow{color:var(--clay-dk)}
.hero h1{font-size:clamp(3rem,9vw,7rem);color:var(--ink);max-width:14ch;margin:.7rem auto .6rem;letter-spacing:-.03em;line-height:.96}
.hero p{font-size:1.2rem;color:var(--muted);max-width:48ch;margin:0 auto 1.8rem}
.hero .cta{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
/* full-bleed lookbook strip below hero */
.bleed{width:100%;height:clamp(280px,46vw,560px);overflow:hidden;position:relative}
.bleed .ph{position:absolute;inset:0}
.ph{background-size:cover;background-position:center;background-repeat:no-repeat}

/* PRODUCT-SHELF COLLAGE (asymmetric) */
.shelf{display:grid;grid-template-columns:repeat(12,1fr);grid-auto-rows:auto;gap:var(--s3) var(--s4)}
.good{display:flex;flex-direction:column}
.good .img{overflow:hidden;border-radius:var(--r-lg);position:relative;background:var(--oat)}
.good .img .ph{position:absolute;inset:0}
.good .meta{display:flex;justify-content:space-between;align-items:baseline;margin-top:.8rem;gap:1rem}
.good h3{font-family:var(--disp);font-weight:600;font-size:1.15rem;color:var(--ink)}
.good .cat{font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--sage-dk);margin-top:.1rem}
.good .price{font-family:var(--disp);font-weight:600;font-size:1.1rem;color:var(--clay-dk);white-space:nowrap}
/* varied spans + offsets for asymmetry */
.good.w5{grid-column:span 5}
.good.w7{grid-column:span 7}
.good.w4{grid-column:span 4}
.good.w6{grid-column:span 6}
.good.w8{grid-column:span 8}
.good.up{margin-top:-2.5rem}
.good .img.tall{aspect-ratio:3/4}
.good .img.wide{aspect-ratio:4/3}
.good .img.sq{aspect-ratio:1/1}

/* category row */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--s3)}
.catcard{position:relative;border-radius:var(--r-lg);overflow:hidden;aspect-ratio:3/4}
.catcard .ph{position:absolute;inset:0}
.catcard::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(38,36,31,.7))}
.catcard .cap{position:absolute;left:1.2rem;bottom:1.1rem;z-index:2;color:#fff}
.catcard .cap h3{color:#fff;font-size:1.5rem}
.catcard .cap span{font-size:.78rem;color:#e7e0d2}

/* split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:var(--s5);align-items:center}
.split .media{overflow:hidden;border-radius:var(--r-lg);aspect-ratio:4/5;position:relative;box-shadow:var(--sh)}
.split .media.wide{aspect-ratio:4/3}
.split .media .ph{position:absolute;inset:0}
.tick{list-style:none;margin:1.3rem 0 0;display:grid;gap:.9rem}
.tick li{display:flex;gap:.7rem;align-items:flex-start}
.tick .b{flex:none;width:24px;height:24px;border-radius:50%;background:var(--oat);color:var(--clay-dk);display:grid;place-items:center;font-size:.72rem;font-weight:700}

/* process steps (how it's made) */
.making{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--s3);counter-reset:m}
.make{padding-top:1.3rem;border-top:2px solid var(--ink)}
.make::before{counter-increment:m;content:"0" counter(m);font-family:var(--disp);font-weight:600;font-size:1.4rem;color:var(--clay-dk)}
.make h3{font-family:var(--disp);font-size:1.2rem;margin:.3rem 0 .35rem;color:var(--ink)}
.make p{color:var(--muted);font-size:.93rem}

/* stockists list */
.stk{display:grid;gap:0;border-top:1px solid var(--line);max-width:820px;margin:0 auto}
.stk .row{display:grid;grid-template-columns:1fr auto;gap:1rem;padding:1.2rem 0;border-bottom:1px solid var(--line);align-items:baseline}
.stk h3{font-family:var(--disp);font-weight:600;font-size:1.25rem;color:var(--ink)}
.stk .loc{color:var(--muted);font-size:.9rem;margin-top:.1rem}
.stk .tag{font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;color:var(--sage-dk);white-space:nowrap}

/* quote */
.quote-band{text-align:center}
.quote-band blockquote{font-family:var(--disp);font-weight:500;font-size:clamp(1.7rem,3.8vw,2.6rem);line-height:1.25;max-width:22ch;margin:0 auto;color:#fff;letter-spacing:-.02em}
.quote-band .who{margin-top:1.3rem;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--clay)}

/* UNDERLINE-INPUT FORMS (v2.1 distinct) */
.uform{max-width:620px;margin:0 auto}
.uform .field{margin-bottom:1.6rem}
.uform label{display:block;font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.uform input,.uform select,.uform textarea{width:100%;border:0;border-bottom:1.5px solid var(--line);background:transparent;padding:.5rem 0;font-family:inherit;font-size:1.05rem;color:var(--ink)}
.uform input:focus,.uform select:focus,.uform textarea:focus{outline:none;border-color:var(--clay)}
.uform .row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}
.udone{display:none;margin-top:1rem;color:var(--clay-dk);font-weight:500}
/* inline newsletter */
.signup{display:flex;gap:.5rem;max-width:440px;border-bottom:1.5px solid var(--ink);padding-bottom:.4rem}
.signup input{flex:1;border:0;background:transparent;font-family:inherit;font-size:1rem;color:var(--ink);padding:.3rem 0}
.signup input:focus{outline:none}
.signup button{background:none;border:0;font-family:var(--body);font-weight:600;font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;color:var(--clay-dk);cursor:pointer}

/* visit details */
.vstrip{display:flex;gap:var(--s5);flex-wrap:wrap}
.vstrip .k{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--clay-dk)}
.vstrip .v{font-family:var(--disp);font-weight:500;font-size:1.2rem;color:var(--ink);margin-top:.25rem}

/* STATEMENT FOOTER (v2.1 distinct — oversized wordmark) */
footer{background:var(--ink);color:#b3ab9c;padding:var(--s5) 0 2rem}
footer .big{font-family:var(--disp);font-weight:600;font-size:clamp(2.6rem,11vw,8rem);letter-spacing:-.03em;line-height:.92;color:var(--oat)}
footer .big span{color:var(--clay)}
footer .rowf{display:flex;justify-content:space-between;align-items:flex-end;gap:1.5rem;flex-wrap:wrap;margin-top:var(--s4)}
footer .fnav{display:flex;gap:1.4rem;flex-wrap:wrap}
footer .fnav a{color:#b3ab9c;font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}
footer .fnav a:hover{color:var(--clay)}
footer .fine{font-size:.78rem;color:#867e70;max-width:30ch}

@media(max-width:900px){
  .split{grid-template-columns:1fr;gap:var(--s4)}
  .cats,.making{grid-template-columns:1fr 1fr}
  .good.w5,.good.w7,.good.w4,.good.w6,.good.w8{grid-column:span 6}
  .good.up{margin-top:0}
  .uform .row{grid-template-columns:1fr}
  .nav-links{position:absolute;top:100%;left:0;right:0;background:var(--paper);flex-direction:column;align-items:flex-start;padding:1rem 1.7rem;gap:.9rem;border-bottom:1px solid var(--line);display:none}
  .nav-links.open{display:flex}
  .menu-btn{display:block}
}
@media(max-width:560px){
  .cats,.making{grid-template-columns:1fr}
  .good.w5,.good.w7,.good.w4,.good.w6,.good.w8{grid-column:span 12}
  .vstrip{gap:var(--s4)}
  section{padding:var(--s5) 0}
}

/* --- Motion layer (v2) · gated behind reduced-motion --- */
@media (prefers-reduced-motion:no-preference){
  [data-rv]{opacity:0;transform:translateY(24px);transition:opacity .8s cubic-bezier(.2,.7,.2,1),transform .8s cubic-bezier(.2,.7,.2,1);will-change:opacity,transform}
  [data-rv].in{opacity:1;transform:none}
  .bleed .ph{animation:sa-kenburns 26s ease-out both;transform-origin:50% 50%}
  @keyframes sa-kenburns{from{transform:scale(1.1)}to{transform:scale(1)}}
  .btn:hover{transform:translateY(-2px)}
  .good .img .ph,.catcard .ph,.split .media .ph{transition:transform .9s cubic-bezier(.2,.7,.2,1)}
  .good:hover .img .ph,.catcard:hover .ph{transform:scale(1.05)}
  .catcard,.make{transition:transform .3s ease}
  .stk .row{transition:background .2s ease,padding-left .2s ease}
  .stk .row:hover{background:var(--oat);padding-left:.8rem}
}
