:root{
  --paper:#f6f2ea;
  --paper-2:#ece4d2;
  --ink:#1B1611;
  --ink-2:#5a4f3f;
  --ink-3:#7a6c5c;
  --accent:#6b5440;
  --accent-soft:#a89578;
  --rule:rgba(27,22,17,.14);
  --rule-soft:rgba(27,22,17,.07);
  --max:1440px;
  --pad-x:clamp(20px, 4vw, 56px);
  --pad-y:clamp(72px, 9vw, 120px);
  --r:0;
  --t-fast:200ms cubic-bezier(.2,.7,.2,1);
  --t:420ms cubic-bezier(.2,.7,.2,1);
  --t-slow:900ms cubic-bezier(.2,.7,.2,1);
  --font:"Playfair Display", ui-serif, Georgia, serif;
}
body.theme-stone{
  --paper:#f4f2ee; --paper-2:#e6e2d9;
  --ink:#23211d; --ink-2:#5e5a52;
  --accent:#6c7860; --accent-soft:#a8b29c;
}
body.theme-paper{
  --paper:#faf8f3; --paper-2:#ece8de;
  --ink:#0f0d0a; --ink-2:#5b554b;
  --accent:#6f2a1f; --accent-soft:#caa78b;
}
body.theme-onyx{
  --paper:#1a1612; --paper-2:#252019;
  --ink:#ece4d2; --ink-2:#b9aa8e;
  --accent:#c9a76a; --accent-soft:#e0c79a;
  --rule:rgba(236,228,210,.18);
  --rule-soft:rgba(236,228,210,.08);
}
body.theme-onyx .nav{background:rgba(26,22,18,.78)!important}
body.theme-onyx .foot-brand .wm img{filter:none}

*,*::before,*::after{box-sizing:border-box}
html,body{margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--font);
  font-weight:400;
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
  transition:background var(--t), color var(--t);
}
img{display:block;max-width:100%;height:auto}
a{color:inherit}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
::selection{background:var(--ink);color:var(--paper)}

.eyebrow{
  font-family:var(--font);
  font-weight:500;
  text-transform:uppercase;
  letter-spacing:.22em;
  font-size:.72rem;
  color:var(--accent);
}
h1,h2,h3,h4,h5{margin:0;font-weight:400}
p{margin:0 0 1em}
p:last-child{margin-bottom:0}

.shell{max-width:var(--max);margin:0 auto;padding-left:var(--pad-x);padding-right:var(--pad-x)}
.section{padding-top:var(--pad-y);padding-bottom:var(--pad-y);position:relative}

/* nav */
.nav{
  position:sticky;top:0;z-index:50;
  background:color-mix(in srgb, var(--paper) 92%, transparent);
  backdrop-filter:saturate(1.1) blur(12px);
  -webkit-backdrop-filter:saturate(1.1) blur(12px);
  border-bottom:1px solid transparent;
  transition:border-color var(--t), background var(--t);
}
.nav.scrolled{border-bottom-color:var(--rule)}
.nav-inner{
  display:flex;align-items:center;gap:28px;
  padding:18px var(--pad-x);max-width:var(--max);margin:0 auto;
}
.wordmark{display:inline-flex;align-items:center;text-decoration:none;margin-right:auto}
.wordmark img{height:36px;width:auto;display:block}
.drawer-wm img{height:28px;width:auto;display:block}
.foot-brand .wm img{height:56px;width:auto;display:block;filter:brightness(0) invert(1)}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{
  text-decoration:none;
  font-family:var(--font);
  font-weight:500;
  font-size:.92rem;
  letter-spacing:.02em;
  position:relative;padding:6px 0;
  color:var(--ink-2);
  transition:color var(--t-fast);
}
.nav-links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:0;height:1px;
  background:var(--accent);transition:right var(--t);
}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after{right:0}
.nav-cta{
  font-family:var(--font);
  font-weight:500;font-size:.88rem;letter-spacing:.04em;
  padding:11px 20px;border:1px solid var(--ink);border-radius:999px;
  text-decoration:none;color:var(--ink);
  transition:background var(--t-fast),color var(--t-fast);
}
.nav-cta:hover{background:var(--ink);color:var(--paper)}
.nav-menu{
  display:none;
  width:44px;height:44px;align-items:center;justify-content:center;
  border:1px solid var(--ink);border-radius:999px;background:transparent;
  cursor:pointer;
}
.hamburger{position:relative;width:18px;height:12px;display:inline-block}
.hamburger::before,.hamburger::after{
  content:"";position:absolute;left:0;right:0;height:1.4px;background:var(--ink);
  transition:transform var(--t), top var(--t), bottom var(--t);
}
.hamburger::before{top:2px}
.hamburger::after{bottom:2px}
.nav-menu[aria-expanded="true"] .hamburger::before{top:5px;transform:rotate(45deg)}
.nav-menu[aria-expanded="true"] .hamburger::after{bottom:5px;transform:rotate(-45deg)}

/* drawer */
.drawer{
  position:fixed;inset:0;z-index:60;
  background:rgba(27,22,17,.45);
  opacity:0;pointer-events:none;
  transition:opacity .28s ease;
}
.drawer.open{opacity:1;pointer-events:auto}
.drawer-panel{
  position:absolute;right:0;top:0;bottom:0;width:min(380px, 88vw);
  background:var(--paper);
  transform:translateX(100%);
  transition:transform .38s cubic-bezier(.2,.7,.2,1);
  display:flex;flex-direction:column;padding:28px 28px 36px;
  box-shadow:-30px 0 60px -30px rgba(0,0,0,.35);
}
.drawer.open .drawer-panel{transform:none}
.drawer-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:36px}
.drawer-close{
  width:40px;height:40px;border-radius:999px;border:1px solid var(--rule);
  background:transparent;cursor:pointer;font-size:24px;line-height:1;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
}
.drawer-close:hover{background:var(--ink);color:var(--paper);border-color:var(--ink)}
.drawer-nav{display:flex;flex-direction:column;gap:0;margin:0 -28px}
.drawer-nav a{
  text-decoration:none;color:var(--ink);
  font-family:var(--font);
  font-weight:400;
  font-size:1.8rem;letter-spacing:-.01em;line-height:1.1;
  padding:18px 28px;border-bottom:1px solid var(--rule-soft);
  display:flex;justify-content:space-between;align-items:center;
}
.drawer-nav a em{font-style:italic;color:var(--accent);font-weight:400}
.drawer-cta{margin-top:28px;justify-content:center}
.drawer-info{
  margin-top:auto;padding-top:32px;display:grid;gap:10px;
  font-family:var(--font);font-size:.95rem;color:var(--ink-2);
}
.drawer-info a{color:inherit;text-decoration:none;display:block;padding:4px 0}
.drawer-info a:hover{color:var(--ink)}
.drawer-info .k{
  display:block;font-size:.65rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--accent);margin-bottom:2px;
}
body.lock{overflow:hidden}

/* hero */
.hero{
  max-width:var(--max);margin:0 auto;
  padding:clamp(48px,7vw,84px) var(--pad-x) clamp(96px,10vw,128px);
  display:grid;grid-template-columns:1.05fr 1fr;
  gap:clamp(40px,7vw,88px);align-items:center;
}
.hero-eyebrow{margin-bottom:24px}
.hero h1{
  font-family:var(--font);font-weight:400;
  font-size:clamp(56px, 7.6vw, 116px);
  line-height:.98;letter-spacing:-.018em;
}
.hero h1 em{font-style:italic;font-weight:400;color:var(--ink)}
.no-lig{font-variant-ligatures:no-common-ligatures}
.hero-sub{
  font-family:var(--font);font-size:clamp(18px,1.4vw,22px);line-height:1.5;
  color:var(--ink-2);margin:30px 0 32px;max-width:38ch;font-weight:400;
}
.hero-actions{display:flex;gap:14px;align-items:center;flex-wrap:wrap}
.btn{
  display:inline-flex;align-items:center;gap:10px;
  padding:15px 26px;border-radius:999px;
  font-family:var(--font);font-size:.95rem;font-weight:500;letter-spacing:.02em;
  transition:transform var(--t-fast), background var(--t-fast), color var(--t-fast), border-color var(--t-fast);
  line-height:1;text-decoration:none;
  border:1px solid transparent;
}
.btn-primary{background:var(--ink);color:var(--paper)}
.btn-primary:hover{background:var(--accent);transform:translateY(-1px)}
.btn-ghost{color:var(--ink);border-color:var(--rule)}
.btn-ghost:hover{border-color:var(--ink)}
.btn .arrow{font-style:italic;transition:transform var(--t-fast)}
.btn:hover .arrow{transform:translateX(4px)}
.hero-contact{
  margin-top:26px;
  font-family:var(--font);font-size:.92rem;color:var(--ink-2);
  display:flex;gap:14px;align-items:center;flex-wrap:wrap;
}
.hero-contact a{
  color:var(--ink);text-decoration:none;
  border-bottom:1px solid var(--rule);padding-bottom:1px;
  transition:border-color var(--t-fast);
}
.hero-contact a:hover{border-bottom-color:var(--accent)}
.hero-contact .or{font-style:italic;color:var(--ink-2)}

.hero-media{
  position:relative;align-self:stretch;
  display:flex;flex-direction:column;
}
.hero-img{
  position:relative;display:block;
  background:var(--paper-2);
  overflow:hidden;
  flex:1;min-height:520px;
  box-shadow:
    -18px 40px 70px -36px rgba(27,22,17,.32),
    -8px 18px 32px -20px rgba(27,22,17,.16);
}
.hero-img picture{display:block;width:100%;height:100%}
.hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.foot-social{display:flex;gap:8px;margin-top:14px}
.foot-social a{
  display:inline-flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  border:1px solid rgba(255,255,255,.35);
  color:rgba(255,255,255,.65);text-decoration:none;
  transition:color var(--t-fast),border-color var(--t-fast),transform var(--t-fast);
}
.foot-social a:hover{color:var(--paper);border-color:var(--paper);transform:translateY(-1px)}
.foot-social svg{width:12px;height:12px;display:block}

/* trio */
.trio{
  display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,64px);
  padding-top:clamp(80px,8vw,120px);padding-bottom:clamp(80px,8vw,120px);
}
.trio-cell .num{
  font-family:var(--font);font-style:italic;
  font-size:1.15rem;color:var(--accent);
  display:block;margin-bottom:18px;
}
.trio-cell h3{
  font-family:var(--font);font-weight:500;
  font-size:clamp(22px,2.2vw,30px);
  line-height:1.1;letter-spacing:-.005em;
  margin:0 0 12px;
}
.trio-cell p{
  font-size:clamp(15px,1.15vw,17px);line-height:1.55;color:var(--ink-2);
  max-width:34ch;
}

/* atelier */
.atelier{background:var(--paper-2);padding:clamp(80px,9vw,120px) 0}
.atelier-inner{
  max-width:var(--max);margin:0 auto;padding:0 var(--pad-x);
  display:grid;grid-template-columns:1fr 1.3fr;gap:clamp(40px,7vw,88px);
  align-items:start;
}
.atelier .eyebrow{margin-bottom:22px}
.atelier h2{
  font-family:var(--font);font-weight:400;
  font-size:clamp(40px,5vw,72px);line-height:1.02;
  letter-spacing:-.018em;margin:0;
}
.atelier h2 em{font-style:italic;color:var(--accent)}
.atelier-body p{
  font-size:clamp(16px,1.2vw,18px);line-height:1.65;color:var(--ink-2);
  margin:0 0 22px;max-width:54ch;
}
.atelier-body p:last-of-type{
  font-style:italic;font-size:clamp(19px,1.5vw,22px);line-height:1.4;color:var(--ink);
}

/* gallery */
.section-head{
  display:flex;justify-content:space-between;align-items:end;
  gap:24px;flex-wrap:wrap;margin-bottom:clamp(36px,4vw,56px);
}
.section-head h2{
  font-family:var(--font);font-weight:400;
  font-size:clamp(44px,5.6vw,84px);line-height:.98;
  letter-spacing:-.018em;
}
.section-head h2 em{font-style:italic;color:var(--accent)}
.section-head .meta{
  font-size:.95rem;color:var(--ink-2);max-width:24ch;
  text-align:right;line-height:1.55;font-style:italic;
}
.gallery-grid{
  display:grid;grid-template-columns:repeat(12,1fr);
  gap:clamp(14px,1.6vw,24px) clamp(12px,1.2vw,18px);
  align-items:start;
}
.g-item{background:var(--paper-2);display:flex;flex-direction:column;margin:0;min-width:0}
.g-item picture{position:relative;display:block;overflow:hidden;background:var(--paper-2)}
.g-item img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.2,.6,.2,1);display:block}
.g-item:hover img{transform:scale(1.03)}
.g-item figcaption{
  font-family:var(--font);font-style:italic;font-weight:400;
  font-size:.92rem;line-height:1.35;color:var(--ink-2);
  padding:14px 4px 0;
}

/* mosaic layout — 12-col grid with matched row heights */
.g-item:nth-child(1){grid-column:span 12}
.g-item:nth-child(1) picture{aspect-ratio:16/7}

.g-item:nth-child(2),
.g-item:nth-child(3){grid-column:span 6}
.g-item:nth-child(2) picture,
.g-item:nth-child(3) picture{aspect-ratio:3/2}

.g-item:nth-child(4),
.g-item:nth-child(5),
.g-item:nth-child(6){grid-column:span 4}
.g-item:nth-child(4) picture,
.g-item:nth-child(5) picture,
.g-item:nth-child(6) picture{aspect-ratio:1/1}

.g-item:nth-child(7){grid-column:span 5}
.g-item:nth-child(7) picture{aspect-ratio:5/4}
.g-item:nth-child(8){grid-column:span 7}
.g-item:nth-child(8) picture{aspect-ratio:7/4}

/* band */
.band{background:var(--ink);color:var(--paper);padding:clamp(64px,8vw,96px) 0}
.band-inner{
  max-width:var(--max);margin:0 auto;padding:0 var(--pad-x);
  display:grid;grid-template-columns:1.4fr 1fr;
  gap:clamp(32px,5vw,72px);align-items:center;
}
.band h3{
  font-family:var(--font);font-weight:400;
  font-size:clamp(28px,3.6vw,52px);line-height:1.08;
  letter-spacing:-.012em;
}
.band h3 em{font-style:italic;color:var(--accent-soft)}
.band p{
  color:rgba(255,255,255,.72);
  font-size:clamp(15px,1.15vw,17px);line-height:1.55;
  margin:0 0 22px;max-width:38ch;
}
.band .btn-primary{background:var(--paper);color:var(--ink)}
.band .btn-primary:hover{background:var(--accent-soft);color:var(--ink)}

/* process */
.process-head{max-width:780px;margin-bottom:clamp(48px,6vw,80px)}
.process-head h2{
  font-family:var(--font);font-weight:400;
  font-size:clamp(40px,5.4vw,76px);line-height:1.0;
  letter-spacing:-.018em;
}
.process-head h2 em{font-style:italic;color:var(--accent)}
.process-head p{
  font-size:clamp(16px,1.2vw,18px);line-height:1.6;color:var(--ink-2);
  margin:22px 0 0;max-width:60ch;
}
.process-list{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  column-gap:clamp(32px,4vw,72px);
  row-gap:0;
}
.process-step{
  display:grid;
  grid-template-columns:clamp(56px,6vw,84px) 1fr;
  column-gap:clamp(18px,2vw,28px);
  align-items:start;
  padding:clamp(20px,2.4vw,32px) 0;
  border-top:1px solid var(--rule-soft);
}
/* hide the very top border on the first row of each column */
.process-step:nth-child(1),
.process-step:nth-child(2){border-top:none}
/* last item spans both columns and centers itself when there's an odd count
   (5 steps → row 1: 2, row 2: 2, row 3: 1 centered). Width is matched to a
   single column so the layout reads as "third row, centered." */
.process-step:last-child:nth-child(odd){
  grid-column:1 / -1;
  max-width:calc((100% - clamp(32px,4vw,72px)) / 2);
  margin-inline:auto;
}
.process-step .pnum{
  font-family:var(--font);font-style:italic;font-weight:400;
  font-size:clamp(36px,4vw,56px);
  line-height:1;letter-spacing:-.02em;
  color:var(--accent);
  align-self:start;justify-self:start;
  transition:transform var(--t),color var(--t);
}
.process-step:hover .pnum{transform:translateX(4px);color:var(--ink)}
.process-step .pcontent{padding-top:4px;max-width:46ch}
.process-step h4{
  font-family:var(--font);font-weight:400;
  font-size:clamp(18px,1.5vw,22px);
  line-height:1.2;letter-spacing:-.005em;
  margin:0 0 8px;
}
.process-step p{
  font-size:clamp(14px,1vw,15px);line-height:1.55;color:var(--ink-2);
  margin:0;
}

/* stories */
.stories{background:var(--paper-2);padding:clamp(80px,9vw,120px) 0}
.stories-inner{max-width:var(--max);margin:0 auto;padding:0 var(--pad-x)}
.stories-grid{
  display:grid;grid-template-columns:1.2fr 1fr;
  gap:clamp(28px,4vw,64px);margin-top:clamp(36px,4vw,56px);
  align-items:start;
}
.story{position:relative;margin:0}
.story blockquote{margin:0;font-family:var(--font);font-weight:400;color:var(--ink)}
.story-quote{
  font-family:var(--font);font-style:italic;color:var(--accent);
  line-height:.85;display:block;pointer-events:none;
}
.story-attr{
  font-family:var(--font);display:flex;align-items:center;gap:14px;
  font-size:.86rem;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-2);
}

/* Featured: boxed treatment with oversized quote mark */
.story-featured{
  background:var(--ink);border:1px solid var(--ink);border-radius:18px;
  padding:clamp(40px,4vw,64px) clamp(28px,3.5vw,52px) clamp(28px,3vw,44px);
  box-shadow:0 24px 50px rgba(0,0,0,.18);
  margin-top:clamp(32px,3vw,52px);
}
.story-featured .story-quote{
  position:absolute;top:-.42em;left:.22em;
  font-size:clamp(120px,14vw,210px);
}
.story-featured blockquote{
  position:relative;z-index:1;color:var(--paper);
  font-size:clamp(20px,1.8vw,27px);line-height:1.4;letter-spacing:-.005em;
  margin-bottom:32px;
}
.story-featured .story-attr{color:var(--paper)}
.story-featured .story-attr-rule{
  display:inline-block;width:32px;height:1px;background:var(--accent);
  flex-shrink:0;
}

/* Simple: editorial, no box, italic prose */
.story-simple{padding:clamp(20px,2vw,32px) 0}
.story-simple .story-quote{
  font-size:clamp(54px,6vw,82px);margin-bottom:-.18em;margin-left:-.05em;
  opacity:.85;
}
.story-simple blockquote{
  font-style:italic;font-size:clamp(17px,1.4vw,21px);line-height:1.55;
  color:var(--ink);margin-bottom:22px;
}
.story-simple .story-attr{
  font-style:normal;color:var(--accent);
}

/* marquee */
.marquee{
  overflow:hidden;padding:18px 0;
  border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);
  background:var(--paper);
}
.marquee-track{
  display:flex;white-space:nowrap;
  animation:marq 38s linear infinite;
}
.marquee span{
  font-family:var(--font);font-style:normal;
  font-size:clamp(16px,1.5vw,22px);letter-spacing:.08em;color:var(--ink-2);
}
.marquee span .sep{color:var(--accent);margin:0 10px;font-style:normal}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* contact */
.contact-inner{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(40px,6vw,88px);align-items:start}
.contact h2{
  font-family:var(--font);font-weight:400;
  font-size:clamp(44px,5.6vw,84px);line-height:.98;
  letter-spacing:-.018em;margin:14px 0 24px;
}
.contact h2 em{font-style:italic;color:var(--accent)}
.contact-intro{
  font-size:clamp(16px,1.2vw,18px);line-height:1.6;color:var(--ink-2);
  margin:0 0 32px;max-width:40ch;
}
.contact-meta{
  border-top:1px solid var(--rule);padding-top:22px;
  display:grid;grid-template-columns:1fr;gap:14px;margin:0;
}
.contact-meta .row{display:grid;grid-template-columns:96px 1fr;gap:16px;align-items:baseline}
.contact-meta dt{
  font-family:var(--font);font-size:.7rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent);font-weight:500;
}
.contact-meta dd{margin:0;color:var(--ink);font-size:1rem}
.contact-meta a{
  color:var(--ink);text-decoration:none;
  border-bottom:1px solid var(--rule);padding-bottom:1px;
  transition:border-color var(--t-fast);
}
.contact-meta a:hover{border-bottom-color:var(--accent)}

.form{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{
  font-family:var(--font);font-size:.7rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--ink-2);font-weight:500;
}
.field label .req{color:var(--accent)}
.field input,.field select,.field textarea{
  width:100%;background:transparent;border:none;
  border-bottom:1px solid var(--ink);padding:10px 0 12px;
  font-family:var(--font);font-size:1rem;color:var(--ink);
  outline:none;border-radius:0;
}
.field input::placeholder,.field textarea::placeholder{color:rgba(0,0,0,.32);font-style:italic}
body.theme-onyx .field input::placeholder,
body.theme-onyx .field textarea::placeholder{color:rgba(255,255,255,.35)}
.field select{
  -webkit-appearance:none;appearance:none;cursor:pointer;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path d='M1 1l4 4 4-4' stroke='currentColor' fill='none' stroke-width='1.2'/></svg>");
  background-repeat:no-repeat;background-position:right 4px center;padding-right:24px;
}
.field textarea{resize:vertical;min-height:120px;line-height:1.5}
.field input:focus,.field select:focus,.field textarea:focus{border-bottom-color:var(--accent)}
.field .err{
  font-family:var(--font);font-style:italic;font-size:.82rem;
  color:#9b3a2c;margin-top:4px;min-height:1em;
}
.field.invalid input,.field.invalid select,.field.invalid textarea{border-bottom-color:#9b3a2c}
.form .terms{
  grid-column:1/-1;font-size:.82rem;color:var(--ink-2);line-height:1.5;
  margin:4px 0 0;font-style:italic;
}
.form .submit-row{grid-column:1/-1;display:flex;justify-content:flex-end}
.form .submit{
  padding:17px 32px;background:var(--ink);color:var(--paper);
  border:none;border-radius:999px;font-family:var(--font);
  font-size:.95rem;font-weight:500;letter-spacing:.02em;cursor:pointer;
  transition:background var(--t-fast),transform var(--t-fast);
  display:inline-flex;align-items:center;gap:10px;
}
.form .submit:hover{background:var(--accent);transform:translateY(-1px)}
.form .submit[disabled]{opacity:.6;cursor:wait}
.form .submit .arrow{font-style:italic}
.success{
  grid-column:1/-1;display:none;
  padding:24px 28px;border:1px solid var(--accent);
  background:var(--paper-2);
  font-family:var(--font);font-style:italic;font-size:1.05rem;color:var(--ink);
}
.success.show{display:block;animation:fadein .6s ease both}
@keyframes fadein{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* legal / info pages */
.legal{padding:clamp(60px,9vw,120px) var(--pad-x) clamp(40px,6vw,80px);background:var(--paper)}
.legal-inner{max-width:760px;margin:0 auto;font-family:var(--font);color:var(--ink)}
.legal .eyebrow{font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:14px}
.legal h1{font-family:var(--font);font-weight:400;font-size:clamp(40px,5vw,68px);line-height:1.05;letter-spacing:-.015em;margin:0 0 12px}
.legal h1 em{font-style:italic;color:var(--accent)}
.legal .updated{font-size:.85rem;color:var(--ink-3);font-style:italic;margin-bottom:36px;padding-bottom:24px;border-bottom:1px solid var(--rule)}
.legal .lede{font-family:var(--font);font-size:clamp(15px,1.1vw,17px);line-height:1.65;color:var(--ink-2);margin:0 0 36px;padding-bottom:24px;border-bottom:1px solid var(--rule);max-width:60ch}
.legal h2{font-family:var(--font);font-weight:400;font-size:clamp(22px,2vw,28px);margin:36px 0 10px;letter-spacing:-.01em}
.legal h3{font-family:var(--font);font-weight:500;font-size:1.05rem;margin:24px 0 6px}
.legal p,.legal li{font-size:1.02rem;line-height:1.7;color:var(--ink-2)}
.legal p{margin:0 0 16px}
.legal ul,.legal ol{margin:0 0 18px 22px;padding:0}
.legal li{margin-bottom:6px}
.legal a{color:var(--accent);border-bottom:1px solid transparent;transition:border-color var(--t-fast)}
.legal a:hover{border-bottom-color:var(--accent)}
.legal .placeholder{
  margin:20px 0;padding:18px 22px;background:var(--paper-2);
  border-left:3px solid var(--accent);border-radius:0 8px 8px 0;
  font-style:italic;color:var(--ink-2);font-size:.95rem;line-height:1.5;
}

/* card form (minimalist, one question at a time) */
.cf{font-family:var(--font);max-width:540px;width:100%;position:relative;margin-top:-56px}
.cf-back-row{min-height:30px;margin-bottom:18px;display:flex}
.cf-back{
  background:none;border:none;color:var(--ink-2);cursor:pointer;
  font-family:var(--font);font-size:.85rem;letter-spacing:.06em;
  padding:4px 12px 4px 0;border-radius:999px;transition:color .2s,background .2s;
}
.cf-back:hover{color:var(--ink);background:rgba(0,0,0,.03)}
.cf-back[disabled]{opacity:0;pointer-events:none}
.cf-progress{display:flex;gap:8px;margin-bottom:32px}
.cf-dot{width:6px;height:6px;border-radius:50%;background:rgba(0,0,0,.12);transition:background .35s,transform .35s}
.cf-dot.done{background:var(--ink-3)}
.cf-dot.cur{background:var(--accent);transform:scale(1.7)}
.cf-body{transition:opacity .25s ease,transform .25s ease;min-height:230px}
.cf-body.fading{opacity:0;transform:translateY(-6px)}
.cf-eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);margin-bottom:12px}
.cf-q{font-size:clamp(24px,2.6vw,34px);line-height:1.18;letter-spacing:-.012em;font-weight:400;color:var(--ink)}
.cf-q em{font-style:italic;color:var(--accent)}
.cf-help{font-size:.92rem;color:var(--ink-2);margin-top:8px;line-height:1.5}
.cf-input{
  width:100%;margin-top:26px;background:transparent;border:none;
  border-bottom:1.5px solid var(--ink);padding:10px 0;
  font-family:var(--font);font-size:1.2rem;color:var(--ink);outline:none;
  transition:border-color .2s;
}
.cf-input::placeholder{color:rgba(0,0,0,.22);font-style:italic;font-size:1rem}
.cf-input:focus{border-color:var(--accent)}
textarea.cf-input{resize:vertical;min-height:110px;line-height:1.5;font-size:1.02rem}
.cf-multi{display:grid;gap:22px;margin-top:26px}
.cf-multi .cf-field{display:flex;flex-direction:column}
.cf-multi .cf-input{margin-top:4px}
.cf-multi .cf-lbl{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.cf-choices{display:grid;gap:4px;margin-top:24px}
.cf-choice{
  background:transparent;border:none;border-bottom:1px solid rgba(0,0,0,.08);
  padding:14px 0;font-family:var(--font);font-size:1.1rem;text-align:left;color:var(--ink);
  cursor:pointer;transition:padding-left .25s,color .25s;position:relative;
}
.cf-choice::before{
  content:'→';position:absolute;left:-22px;top:50%;transform:translateY(-50%);
  color:var(--accent);opacity:0;transition:opacity .2s,left .2s;
}
.cf-choice:hover,.cf-choice.active{padding-left:22px;color:var(--accent)}
.cf-choice:hover::before,.cf-choice.active::before{opacity:1;left:0}
.cf-drop{
  margin-top:26px;border:1.5px dashed var(--rule);border-radius:14px;
  padding:34px 22px;text-align:center;cursor:pointer;
  transition:border-color .2s,background .2s;
}
.cf-drop:hover,.cf-drop.over{border-color:var(--accent);background:rgba(107,84,64,.04)}
.cf-drop p{font-size:.98rem;color:var(--ink-2);margin:0 0 6px}
.cf-drop small{font-size:.78rem;color:var(--ink-3)}
.cf-drop input[type=file]{display:none}
.cf-drop-cta{color:var(--accent);text-decoration:underline;font-style:italic}
.cf-thumbs{display:grid;grid-template-columns:repeat(auto-fill,minmax(78px,1fr));gap:8px;margin-top:14px}
.cf-thumb{position:relative;aspect-ratio:1;background:var(--paper-2);border-radius:8px;overflow:hidden}
.cf-thumb img{width:100%;height:100%;object-fit:cover;display:block}
.cf-thumb-name{
  position:absolute;left:0;right:0;bottom:0;padding:3px 6px;
  font-size:.65rem;color:#fff;background:rgba(0,0,0,.55);
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;
}
.cf-thumb-del{
  position:absolute;top:4px;right:4px;width:22px;height:22px;border-radius:50%;
  border:none;background:rgba(0,0,0,.6);color:#fff;cursor:pointer;
  font-size:13px;line-height:1;padding:0;
}
.cf-thumb-del:hover{background:#a83f2f}
.cf-hint{margin-top:26px;font-size:.78rem;color:var(--ink-3);display:flex;gap:18px;align-items:center;flex-wrap:wrap}
.cf-hint .cf-skip{display:none}
.cf-kbd{display:inline-block;padding:1px 7px;border:1px solid rgba(0,0,0,.18);border-radius:4px;font-size:.7rem;color:var(--ink-2);font-family:monospace;background:#fff}
.cf-submit{
  margin-top:24px;background:var(--ink);color:var(--paper);border:none;border-radius:999px;
  padding:14px 32px;font-family:var(--font);font-size:.95rem;letter-spacing:.04em;cursor:pointer;
  transition:background .2s,transform .2s;display:inline-flex;align-items:center;gap:10px;
}
.cf-submit:hover:not(:disabled){background:var(--accent);transform:translateY(-1px)}
.cf-submit:disabled{opacity:.5;cursor:wait}
.cf-submit .arrow{font-style:italic}
.cf-review{display:grid;gap:0;margin-top:18px}
.cf-row{display:grid;grid-template-columns:130px 1fr auto;gap:14px;align-items:baseline;padding:12px 0;border-bottom:1px solid var(--rule)}
.cf-row dt{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.cf-row dd{margin:0;font-size:1rem;word-break:break-word}
.cf-row dd.empty{color:var(--ink-3);font-style:italic}
.cf-row dd .cf-rev-photos{display:flex;gap:6px;flex-wrap:wrap;margin-top:6px}
.cf-row dd .cf-rev-photos img{width:42px;height:42px;border-radius:6px;object-fit:cover;border:1px solid var(--rule)}
.cf-edit{background:none;border:none;color:var(--accent);cursor:pointer;font:inherit;font-size:.82rem;text-decoration:underline}
.cf-err{margin-top:14px;color:#9c3b2c;font-size:.88rem;font-style:italic}

/* thank-you state */
.cf-thanks{text-align:center;padding:24px 0 8px}
.cf-thanks-logo{display:block;margin:0 auto 28px;height:84px;width:auto;filter:none}
.cf-thanks-title{font-size:clamp(24px,2.4vw,32px);line-height:1.2;font-weight:400;letter-spacing:-.01em;margin-bottom:14px}
.cf-thanks-title em{font-style:italic;color:var(--accent)}
.cf-thanks-msg{font-size:1rem;color:var(--ink-2);line-height:1.6;max-width:48ch;margin:0 auto}

@media (max-width: 760px){
  .cf{max-width:none}
  .cf-progress{margin-bottom:24px}
}

/* footer */
.foot{background:var(--ink);color:var(--paper);padding:clamp(56px,7vw,80px) var(--pad-x) 30px}
.foot-inner{
  max-width:var(--max);margin:0 auto;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:clamp(28px,4vw,56px);
  padding-bottom:42px;border-bottom:1px solid rgba(255,255,255,.12);
  align-items:start;
}
.foot-brand .wm{margin-bottom:14px;line-height:1}
.foot-brand p{
  font-style:italic;font-size:1rem;line-height:1.5;
  color:rgba(255,255,255,.72);max-width:34ch;margin:0 0 18px;
}
.foot-pill{
  display:inline-block;padding:6px 14px;
  border:1px solid rgba(255,255,255,.24);border-radius:999px;
  font-family:var(--font);font-size:.72rem;
  letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent-soft);
}
.foot h4{
  font-family:var(--font);font-size:.7rem;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--accent-soft);font-weight:500;margin:0 0 18px;
}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:10px}
.foot ul a,.foot ul li{
  font-size:.95rem;color:rgba(255,255,255,.78);
  text-decoration:none;transition:color var(--t-fast);
}
.foot ul a:hover{color:var(--paper)}
.foot-bottom{
  max-width:var(--max);margin:24px auto 0;
  display:flex;justify-content:space-between;gap:24px;flex-wrap:wrap;
  font-size:.82rem;color:rgba(255,255,255,.5);
}
.foot-bottom .made{font-style:italic;color:rgba(255,255,255,.72)}

/* reveal */
.reveal{opacity:0;transform:translateY(28px);transition:opacity var(--t-slow), transform var(--t-slow)}
.reveal.in{opacity:1;transform:none}

/* subpage hero */
.sub-hero{
  max-width:var(--max);margin:0 auto;
  padding:clamp(56px,8vw,96px) var(--pad-x) clamp(36px,5vw,56px);
}
.sub-hero .eyebrow{margin-bottom:24px}
.sub-hero h1{
  font-family:var(--font);font-weight:400;
  font-size:clamp(48px,6.4vw,96px);line-height:1.0;
  letter-spacing:-.018em;margin:0 0 24px;
}
.sub-hero h1 em{font-style:italic;color:var(--accent)}
.sub-hero .sub-tag{
  font-size:clamp(17px,1.3vw,21px);line-height:1.55;color:var(--ink-2);
  max-width:54ch;font-weight:400;
}
.sub-feature{
  max-width:var(--max);margin:0 auto;padding:0 var(--pad-x) clamp(72px,8vw,108px);
  display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(40px,6vw,80px);align-items:center;
}
.sub-feature picture{display:block;aspect-ratio:4/5;overflow:hidden;background:var(--paper-2)}
.sub-feature picture img{width:100%;height:100%;object-fit:cover;display:block}
.sub-body{display:grid;gap:22px}
.sub-body p{
  font-size:clamp(16px,1.2vw,18px);line-height:1.7;color:var(--ink-2);
  margin:0;max-width:54ch;
}
.sub-body p:first-of-type::first-letter{
  font-family:var(--font);font-style:italic;font-weight:500;
  color:var(--accent);font-size:3.4em;line-height:.85;
  float:left;padding:6px 12px 0 0;
}
.sub-gallery{
  max-width:var(--max);margin:0 auto;padding:0 var(--pad-x) clamp(80px,9vw,120px);
}
.sub-gallery-grid{
  display:grid;grid-template-columns:repeat(12,1fr);gap:14px;
}
.sg-item{background:var(--paper-2);overflow:hidden;position:relative}
.sg-item picture{position:absolute;inset:0;display:block}
.sg-item img{width:100%;height:100%;object-fit:cover;transition:transform 1.4s cubic-bezier(.2,.6,.2,1);display:block}
.sg-item:hover img{transform:scale(1.03)}
.sg-wide{grid-column:span 8;aspect-ratio:16/9}
.sg-tall{grid-column:span 4;aspect-ratio:3/4}
.sg-half{grid-column:span 6;aspect-ratio:4/3}
.sg-third{grid-column:span 4;aspect-ratio:1/1}

/* mobile */
@media (max-width: 980px){
  .hero{grid-template-columns:1fr;padding-top:clamp(36px,5vw,56px);padding-bottom:clamp(56px,7vw,84px)}
  .hero-media{order:-1;margin-left:calc(var(--pad-x) * -1)}
  .hero-img{min-height:60vh;box-shadow:0 28px 50px -28px rgba(27,22,17,.28)}
  .trio{grid-template-columns:1fr;gap:36px}
  .atelier-inner{grid-template-columns:1fr;gap:28px}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .g-item:nth-child(n){grid-column:span 1}
  .g-item:nth-child(1){grid-column:span 2}
  .g-item:nth-child(1) picture{aspect-ratio:16/9}
  .g-item:nth-child(n+2) picture{aspect-ratio:4/3}
  .band-inner{grid-template-columns:1fr;gap:24px}
  .band .btn-primary{width:100%;justify-content:center}
  .process-list{grid-template-columns:1fr;column-gap:0}
  .process-step{border-top:1px solid var(--rule-soft)}
  .process-step:nth-child(2){border-top:1px solid var(--rule-soft)}
  .process-step:nth-child(1){border-top:none}
  .process-step:last-child:nth-child(odd){grid-column:auto}
  .stories-grid{grid-template-columns:1fr;gap:32px}
  .contact-inner{grid-template-columns:1fr;gap:40px}
  .form{grid-template-columns:1fr;gap:20px}
  .form .submit{width:100%;justify-content:center}
  .foot-inner{grid-template-columns:1fr 1fr;gap:32px}
  .foot-inner > :first-child{grid-column:1/-1}
  .sub-feature{grid-template-columns:1fr;gap:32px}
  .sub-gallery-grid{grid-template-columns:repeat(6,1fr)}
  .sg-wide,.sg-tall,.sg-half,.sg-third{grid-column:span 6;aspect-ratio:4/3}
}
@media (max-width: 760px){
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-menu{display:inline-flex}
  .section-head{flex-direction:column;align-items:flex-start}
  .section-head .meta{text-align:left}
}
@media (max-width: 640px){
  .hero h1{font-size:clamp(48px,12vw,76px)}
  .gallery-grid{grid-template-columns:1fr}
  .g-item:nth-child(n){grid-column:span 1}
  .g-item:nth-child(n) picture{aspect-ratio:4/3}
  .foot-inner{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;align-items:flex-start;gap:6px}
}
@media (prefers-reduced-motion: reduce){
  *{animation-duration:0ms !important;transition-duration:0ms !important}
  .marquee-track{animation:none}
  .reveal{opacity:1;transform:none}
}
