:root{
  --bone:#0F0E0C;          /* off-black background */
  --bone-2:#191713;        /* slightly lifted panel */
  --ink:#F2EAD8;           /* cream text */
  --ink-2:#D9D2C0;         /* secondary text */
  --ink-3:rgba(242,234,216,.55);
  --rule:rgba(242,234,216,.16);
  --coral:#FF5722;         /* hot orange accent */
  --cobalt:#3DDC97;        /* sparing secondary (kept for any legacy refs) */
  --serif:'Newsreader','Times New Roman',serif;
  --display:'Instrument Serif','Newsreader',serif;
  --sans:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --pad:32px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bone);color:var(--ink)}
html{cursor:none}
body{font-family:var(--sans);font-size:16px;line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow-x:hidden}
body::before{content:'';position:fixed;inset:0;pointer-events:none;z-index:1;background-image:repeating-linear-gradient(0deg,transparent 0 2px,rgba(255,255,255,0.012) 2px 3px);mix-blend-mode:screen}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
button{font-family:inherit;border:0;background:transparent;color:inherit;padding:0}

/* Custom cursor */
.cur,.cur-dot{position:fixed;top:0;left:0;pointer-events:none;z-index:9999;mix-blend-mode:normal;will-change:transform}
.cur{width:34px;height:34px;border:1px solid var(--ink);border-radius:50%;transform:translate(-50%,-50%);transition:width .2s,height .2s,background .2s,border-color .2s,opacity .2s}
.cur-dot{width:6px;height:6px;background:var(--coral);border-radius:50%;transform:translate(-50%,-50%)}
.cur.hover{width:54px;height:54px;background:var(--coral);border-color:var(--coral);mix-blend-mode:normal}
@media(hover:none),(pointer:coarse){html{cursor:auto}.cur,.cur-dot{display:none}}

/* Layout */
.wrap{max-width:1480px;margin:0 auto;padding:0 var(--pad);position:relative;z-index:2}

/* Type primitives */
.serif{font-family:var(--serif);font-optical-sizing:auto}
.mono{font-family:var(--mono)}
.eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.kicker{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;font-weight:500}
.rule{border:0;border-top:1px solid var(--rule);margin:0}
.thick{border:0;border-top:2px solid var(--ink);margin:0}

/* Reveal animation */
.r{opacity:0;transform:translateY(18px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.r.in{opacity:1;transform:none}
.r-l{display:inline-block;overflow:hidden;vertical-align:top;padding:0.14em 0;margin:-0.14em 0}
.r-l.in{overflow:visible}
.r-l>span{display:inline-block;transform:translateY(110%);transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.r-l.in>span{transform:none}
.lstag-1{transition-delay:.04s} .lstag-2{transition-delay:.10s} .lstag-3{transition-delay:.18s} .lstag-4{transition-delay:.26s} .lstag-5{transition-delay:.34s} .lstag-6{transition-delay:.42s}

/* Blur-in for body copy — overrides .r baseline when both classes present */
.r.r-blur{opacity:0;filter:blur(14px);transform:translateY(24px);transition:opacity 1.1s cubic-bezier(.2,.7,.2,1),filter 1.1s cubic-bezier(.2,.7,.2,1),transform 1.1s cubic-bezier(.2,.7,.2,1)}
.r.r-blur.in{opacity:1;filter:blur(0);transform:none}

/* Mask wipe-in for big headings */
.r.r-mask{opacity:0;clip-path:inset(0 100% 0 0);transform:none;transition:opacity .2s linear,clip-path 1.2s cubic-bezier(.7,0,.2,1)}
.r.r-mask.in{opacity:1;clip-path:inset(0 0 0 0);transform:none}

/* Scale-in for cards */
.r.r-scale{opacity:0;transform:scale(.96) translateY(24px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.r.r-scale.in{opacity:1;transform:scale(1) translateY(0)}

/* Scroll progress bar */
.scroll-bar{position:fixed;left:0;top:0;height:2px;background:var(--coral);z-index:200;transform-origin:left;transform:scaleX(0);transition:transform .12s linear;pointer-events:none}

/* Section meta — pinned in top-right while scrolling through a section */
.now-pin{position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:90;font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);writing-mode:vertical-rl;rotate:180deg;opacity:0;transition:opacity .4s ease}
.now-pin.show{opacity:1}
.now-pin .dot{display:inline-block;width:6px;height:6px;background:var(--coral);border-radius:50%;rotate:180deg;margin-bottom:14px;animation:pulse 2s ease-in-out infinite}
@keyframes pulse{0%,100%{opacity:.4}50%{opacity:1}}

@media(max-width:760px){.now-pin{display:none}}

@media (prefers-reduced-motion: reduce){
  .r,.r-l>span,.r-blur,.r-mask,.r-scale,.scroll-bar{transition:none !important;animation:none !important}
  .r,.r-blur,.r-scale{opacity:1;transform:none;filter:none;clip-path:none}
  .r-mask{opacity:1;clip-path:none}
  .r-l>span{transform:none}
}

/* Underline-draw on inline links */
.ul{position:relative;display:inline-block}
.ul::after{content:'';position:absolute;left:0;right:0;bottom:-2px;height:1.5px;background:var(--coral);transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.2,.7,.2,1)}
.ul:hover::after{transform:scaleX(1)}

/* ─────────── MASTHEAD ─────────── */
.mast{padding:18px 0;position:sticky;top:0;z-index:100;background:transparent;transition:background .35s ease,padding .35s ease,box-shadow .35s ease}
.mast.scrolled{background:color-mix(in oklab, var(--bone) 85%, transparent);backdrop-filter:blur(14px) saturate(120%);-webkit-backdrop-filter:blur(14px) saturate(120%);padding:12px 0;box-shadow:0 1px 0 var(--rule)}
.mast-row{display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase}
.mast-mono{color:var(--ink-3)}
.mast nav{display:flex;gap:28px}
.mast nav a{transition:color .2s}
.mast nav a:hover{color:var(--coral)}
.mast-title{font-family:var(--display);font-style:italic;font-weight:400;font-size:24px;letter-spacing:-.015em;text-transform:none}

/* ─────────── COVER ─────────── */
.cover{padding:64px 0 80px;border-top:2px solid var(--ink);margin-top:18px}

.cover-stack{max-width:1100px;margin:0 auto;text-align:center;display:flex;flex-direction:column;align-items:center;gap:32px}
.cover-h{font-family:var(--serif);font-weight:700;font-size:clamp(72px,11.5vw,168px);line-height:.84;letter-spacing:-.04em;margin:0;text-wrap:balance}
.cover-h .it{font-family:var(--display);font-style:italic;font-weight:400;letter-spacing:-.025em}
.cover-h .co{color:var(--coral)}
.cover-h .stk{font-family:var(--display);-webkit-text-stroke:1.4px var(--ink);color:transparent;font-style:italic;font-weight:400;letter-spacing:-.025em}

.cover-deck{font-family:var(--serif);font-weight:400;font-size:clamp(20px,1.6vw,24px);line-height:1.4;letter-spacing:-.005em;text-wrap:pretty;margin:0;max-width:54ch;color:var(--ink-2)}
.cover-deck em{font-family:var(--display);font-style:italic;font-weight:400;color:var(--coral)}

.cover-cta{display:flex;gap:14px;align-items:center;flex-wrap:wrap;justify-content:center}
.cover-ig{font-size:11px;letter-spacing:.16em;text-transform:uppercase;margin-left:8px;color:var(--ink-3)}
.btn-ghost{background:transparent;color:var(--ink);border:1px solid var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--bone)}

.cover-photo-wrap{margin-top:64px;position:relative;overflow:hidden;max-width:1280px;margin-left:auto;margin-right:auto}
.cover-photo-wrap img{width:100%;aspect-ratio:3/2;object-fit:cover;border:1px solid var(--rule);will-change:transform}

@media(max-width:760px){
  .cover{padding:32px 0 48px}
  .cover-stack{gap:24px}
  .cover-cta{flex-direction:column;width:100%}
  .cover-cta .btn{width:100%;justify-content:center}
  .cover-ig{margin-left:0}
}

/* ─────────── PHILOSOPHY ─────────── */
.phil{padding:140px 0 96px}
.phil-grid{display:grid;grid-template-columns:140px 1fr 1fr;gap:48px;align-items:start}
.phil-num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);padding-top:16px}
.phil-num b{display:block;color:var(--ink);font-family:var(--display);font-style:italic;font-weight:400;font-size:42px;letter-spacing:-.025em;margin-bottom:8px;text-transform:none}
.phil-h{font-family:var(--serif);font-weight:700;font-size:clamp(48px,6.5vw,92px);line-height:.94;letter-spacing:-.03em;margin:0;text-wrap:balance}
.phil-h em{font-family:var(--display);font-style:italic;font-weight:400;color:var(--coral);letter-spacing:-.02em}
.phil-body{font-family:var(--serif);font-weight:400;font-size:21px;line-height:1.4;letter-spacing:-.003em;color:var(--ink-2)}
.phil-body p{margin:0 0 18px}
.phil-body p:first-child::first-letter{font-family:var(--display);font-weight:400;font-size:108px;float:left;line-height:.8;padding:6px 12px 0 0;color:var(--coral)}
.phil-sig{margin-top:24px;display:flex;align-items:center;gap:14px;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.phil-sig .sw{font-family:var(--display);font-style:italic;font-size:28px;color:var(--ink);text-transform:none;letter-spacing:-.015em}

/* ─────────── BIG PHOTO BREAK ─────────── */
.bphoto{position:relative;overflow:hidden}
.bphoto img{width:100%;aspect-ratio:16/7;object-fit:cover;will-change:transform}
.bphoto .cap{position:absolute;left:32px;bottom:24px;color:var(--ink);font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;text-shadow:0 1px 16px rgba(0,0,0,.7);max-width:60ch;line-height:1.6}
.bphoto .cap b{font-family:var(--display);font-style:italic;font-weight:400;font-size:36px;letter-spacing:-.02em;text-transform:none;color:var(--ink);display:block;margin-bottom:8px}

/* ─────────── THE GAP — single instrument ─────────── */
.gap-sec{padding:140px 0;background:var(--bone);position:relative;overflow:hidden}
.gap-head{margin-bottom:56px;padding-bottom:24px;border-bottom:1px solid var(--rule);display:flex;justify-content:space-between;align-items:flex-end;gap:32px}
.gap-head h2{font-family:var(--serif);font-weight:700;font-size:clamp(48px,6vw,88px);line-height:.92;letter-spacing:-.032em;margin:0;text-wrap:balance;max-width:18ch}
.gap-head h2 em{font-family:var(--display);font-style:italic;font-weight:400;color:var(--coral);letter-spacing:-.02em}
.gap-sub{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);max-width:24ch;text-align:right;line-height:1.6}

/* The instrument card */
.gap-inst{background:var(--bone-2);border:1px solid var(--rule);max-width:880px;margin:0 auto;padding:32px;display:flex;flex-direction:column;gap:24px;position:relative}
.gap-inst::before{content:'';position:absolute;top:-1px;left:-1px;width:14px;height:14px;border-top:1px solid var(--coral);border-left:1px solid var(--coral)}
.gap-inst::after{content:'';position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-bottom:1px solid var(--coral);border-right:1px solid var(--coral)}

.gap-inst-head{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--rule)}
.gap-inst-eyebrow{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3)}
.gap-inst-eyebrow .dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--coral);margin-right:8px;vertical-align:middle;animation:pulse 2s ease-in-out infinite}
.gap-inst-foot{font-family:var(--mono);font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}

/* Three axis stack */
.gap-axis{display:flex;flex-direction:column;gap:10px;padding:24px 0;border-bottom:1px solid var(--rule)}
.gap-axis:first-of-type{padding-top:0}
.gap-axis:last-of-type{border-bottom:0;padding-bottom:8px}

.gap-axis-head{display:grid;grid-template-columns:auto 1fr auto;gap:16px;align-items:baseline;margin-bottom:6px}
.gap-axis-name{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);font-weight:500;min-width:64px}
.gap-axis-q{font-family:var(--display);font-style:italic;font-weight:400;font-size:clamp(17px,1.7vw,21px);line-height:1.3;letter-spacing:-.015em;color:var(--ink);margin:0}
.gap-axis-q em{color:var(--coral);font-style:italic}
.gap-axis-pt{font-family:var(--display);font-style:italic;font-size:24px;font-weight:400;color:var(--ink);letter-spacing:-.015em;text-align:right;white-space:nowrap}
.gap-axis-pt::after{content:'';display:none}

.gap-labels{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-top:4px}
.gap-labels .hi{color:var(--ink)}

.gap-track{position:relative;height:36px;display:flex;align-items:center;cursor:pointer;outline:none}
.gap-track:focus-visible{outline:1px dashed var(--coral);outline-offset:6px}
.gap-rail{position:absolute;left:0;right:0;height:1px;background:var(--rule)}
.gap-fill{position:absolute;left:0;width:0;height:4px;background:var(--coral);transform:translateY(-50%);top:50%;transition:left .15s ease,width .15s ease}
.gap-handle{position:absolute;width:22px;height:22px;border-radius:50%;top:50%;transform:translate(-50%,-50%);cursor:none;transition:transform .12s ease,box-shadow .2s ease;display:flex;align-items:center;justify-content:center;z-index:2}
.gap-handle.now{background:var(--ink);border:1.5px solid var(--ink)}
.gap-handle.want{background:transparent;border:1.5px solid var(--coral);box-shadow:inset 0 0 0 3px var(--bone-2)}
.gap-handle:hover,.gap-handle.dragging{transform:translate(-50%,-50%) scale(1.18)}
.gap-handle.dragging{box-shadow:0 0 0 4px color-mix(in oklab,var(--coral) 25%,transparent)}
.gap-handle .hlbl{position:absolute;top:calc(100% + 8px);left:50%;transform:translateX(-50%);font-family:var(--mono);font-size:8.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3);white-space:nowrap;pointer-events:none}
.gap-handle.now .hlbl{color:var(--ink)}
.gap-handle.want .hlbl{color:var(--coral)}

.gap-cta-block{display:flex;flex-direction:column;gap:8px;align-items:flex-start;margin-top:32px;padding-top:24px;border-top:1px solid var(--rule)}
.gap-cta-block .btn{padding:14px 22px;font-size:11px}
.gap-cta-sub{font-family:var(--mono);font-size:9.5px;letter-spacing:.05em;color:var(--ink-3);margin:0;line-height:1.5;max-width:36ch;text-transform:none}

@media (max-width:760px){
  .gap-head{flex-direction:column;align-items:flex-start;gap:14px}
  .gap-sub{text-align:left}
  .gap-inst{padding:24px 20px}
  .gap-axis-head{grid-template-columns:auto auto;gap:8px;row-gap:6px}
  .gap-axis-q{grid-column:1 / -1;font-size:16px}
  .gap-cta-block{align-items:stretch}
  .gap-cta-block .btn{justify-content:center}
}

/* ─────────── TWO DOORS ─────────── */
.doors{padding:140px 0}
.sec-head{display:grid;grid-template-columns:1fr auto;align-items:end;gap:32px;margin-bottom:56px;padding-bottom:18px;border-bottom:2px solid var(--ink)}
.sec-num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);margin-bottom:12px}
.sec-h{font-family:var(--serif);font-weight:700;font-size:clamp(56px,7.5vw,108px);line-height:.92;letter-spacing:-.032em;margin:0;text-wrap:balance}
.sec-h em{font-family:var(--display);font-style:italic;font-weight:400;color:var(--coral);letter-spacing:-.02em}
.sec-aside{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);text-align:right;max-width:240px;line-height:1.7}

.doors-grid{display:grid;grid-template-columns:1.85fr 1fr;gap:0;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.door{padding:48px 40px;display:flex;flex-direction:column;position:relative;min-height:640px}
.door.primary{background:var(--coral);color:#0F0E0C}
.door.primary .eyebrow,.door.primary .meta-lbl,.door.primary .door-foot{color:rgba(15,14,12,.7)}
.door.primary .door-rule{border-color:rgba(15,14,12,.3)}
.door.secondary{background:var(--bone-2);border-left:1px solid var(--rule)}
.door-tag{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;display:flex;justify-content:space-between;margin-bottom:32px}
.door-h{font-family:var(--serif);font-weight:700;font-size:clamp(56px,7vw,104px);line-height:.92;letter-spacing:-.032em;margin:0 0 28px;text-wrap:balance}
.door.secondary .door-h{font-size:clamp(40px,4.6vw,68px);font-weight:600}
.door-h em{font-family:var(--display);font-style:italic;font-weight:400;letter-spacing:-.02em}
.door-deck{font-family:var(--serif);font-weight:400;font-size:22px;line-height:1.3;letter-spacing:-.005em;margin:0 0 36px;max-width:32ch;text-wrap:pretty}
.door.secondary .door-deck{font-size:18px}
.door-list{list-style:none;padding:0;margin:0 0 36px;display:flex;flex-direction:column;gap:14px}
.door-list li{padding-left:28px;position:relative;font-size:15.5px;line-height:1.45}
.door-list li::before{content:'/';position:absolute;left:0;top:0;font-family:var(--mono);font-weight:600;opacity:.7}
.door-meta{margin-top:auto;padding-top:28px;border-top:1px solid var(--rule);display:grid;grid-template-columns:1fr 1fr;gap:24px}
.door.primary .door-meta{border-color:rgba(255,255,255,.35)}
.meta-lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3);margin-bottom:6px}
.meta-val{font-family:var(--serif);font-weight:500;font-size:22px;letter-spacing:-.01em}
.door-cta{margin-top:28px;display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:14px;padding:16px 22px;background:var(--coral);color:#0F0E0C;font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;border:1px solid var(--ink);transition:transform .25s cubic-bezier(.2,.7,.2,1),box-shadow .25s}
.btn:hover{transform:translate(-3px,-3px);box-shadow:5px 5px 0 var(--ink)}
.door.secondary .btn{background:var(--ink);color:var(--bone)}
.door.secondary .btn:hover{box-shadow:5px 5px 0 var(--coral)}
.btn .arr{transition:transform .25s}
.btn:hover .arr{transform:translateX(3px)}
.door.primary .btn{background:#0F0E0C;color:var(--ink);border-color:#0F0E0C}
.door.primary .btn:hover{box-shadow:5px 5px 0 #0F0E0C}
.door-link{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;border-bottom:1px solid currentColor;padding-bottom:3px;transition:opacity .2s}
.door-link:hover{opacity:.7}

/* ─────────── PINNED NOTES ─────────── */
.takes{padding:140px 0;background:var(--bone-2);position:relative}
.takes-intro{max-width:780px;margin:0 0 72px;display:flex;flex-direction:column;gap:18px}
.takes-eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--ink-3)}
.takes-lede{font-family:var(--serif);font-weight:400;font-size:clamp(28px,3.2vw,42px);line-height:1.18;letter-spacing:-.018em;margin:0;text-wrap:balance;color:var(--ink-2)}
.takes-list{display:grid;grid-template-columns:1fr 1fr 1fr;gap:24px;max-width:1180px}
.take{padding:36px 32px;background:#15130F;border:1px solid var(--rule);position:relative;transform:rotate(var(--rot,0deg));transition:transform .3s ease,box-shadow .3s ease}
.take:nth-child(1){--rot:-.4deg}
.take:nth-child(2){--rot:.5deg}
.take:nth-child(3){--rot:-.3deg}
.take:hover{transform:rotate(0deg);box-shadow:0 12px 32px rgba(255,87,34,.08)}
/* Reveal: only animate opacity/blur on the card; rotation lives on .take itself */
.take.r.r-blur,.take.r.r-blur.in{transform:rotate(var(--rot,0deg))}
.take.r.r-blur:hover,.take.r.r-blur.in:hover{transform:rotate(0deg)}
.take::before{content:'';position:absolute;top:-6px;left:50%;transform:translateX(-50%);width:24px;height:8px;background:color-mix(in oklab,var(--coral) 35%,transparent);border-radius:2px}
.take-q{font-family:var(--serif);font-weight:400;font-size:clamp(20px,1.7vw,24px);line-height:1.32;letter-spacing:-.012em;margin:0;text-wrap:pretty;color:var(--ink)}
.take-attr{margin-top:24px;padding-top:16px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:10px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}

@media(max-width:760px){
  .takes-list{grid-template-columns:1fr;gap:18px}
  .take:nth-child(1),.take:nth-child(2),.take:nth-child(3){--rot:0deg}
}

/* ─────────── PRODUCTS ─────────── */
.prods{padding:140px 0;background:var(--bone)}
.prods-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:2px solid var(--ink);border-bottom:2px solid var(--ink)}
.prod{padding:48px 40px;display:grid;grid-template-rows:auto auto 1fr auto;gap:24px;background:var(--bone-2);position:relative}
.prod:nth-child(2){border-left:1px solid var(--rule)}
.prod-shot{aspect-ratio:5/4;overflow:hidden;border:1px solid var(--rule);background:#000;position:relative}
.prod-shot img{width:100%;height:100%;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.prod:hover .prod-shot img{transform:scale(1.04)}
.prod-head{display:flex;justify-content:space-between;align-items:baseline}
.prod-num{font-family:var(--mono);font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3)}
.prod-status{font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:4px 10px;border:1px solid var(--rule);background:var(--bone)}
.prod-status.live{background:var(--coral);color:#0F0E0C;border-color:var(--coral)}
.prod-title{font-family:var(--serif);font-weight:700;font-size:clamp(40px,4.6vw,64px);line-height:.95;letter-spacing:-.028em;margin:0}
.prod-title em{font-family:var(--display);font-style:italic;font-weight:400;letter-spacing:-.02em}
.prod-desc{font-family:var(--serif);font-weight:400;font-size:20px;line-height:1.35;letter-spacing:-.005em;margin:0;color:var(--ink-2);max-width:42ch}
.prod-foot{display:flex;justify-content:space-between;align-items:center;padding-top:20px;border-top:1px solid var(--rule);font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase}
.prod-foot a{color:var(--coral);font-weight:500}

/* ─────────── LETTERS / NEWSLETTER ─────────── */
.letters-sec{padding:120px 0;background:var(--bone)}
.letters-card{max-width:780px;margin:0 auto;background:var(--bone-2);border:1px solid var(--rule);padding:64px;position:relative;display:flex;flex-direction:column;gap:24px;text-align:center;align-items:center}
.letters-card::before{content:'';position:absolute;top:-1px;left:-1px;width:14px;height:14px;border-top:1px solid var(--coral);border-left:1px solid var(--coral)}
.letters-card::after{content:'';position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-bottom:1px solid var(--coral);border-right:1px solid var(--coral)}
.letters-eyebrow{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500}
.letters-h{font-family:var(--display);font-weight:400;font-size:clamp(40px,4vw,56px);line-height:1.05;letter-spacing:-.015em;margin:0;color:var(--ink);text-wrap:balance}
.letters-h em{font-style:italic;color:var(--coral)}
.letters-deck{font-family:var(--serif);font-weight:400;font-size:18px;line-height:1.55;color:var(--ink-2);margin:0;text-wrap:pretty;max-width:54ch}
.letters-form{display:flex;gap:8px;width:100%;max-width:480px;margin-top:8px}
.letters-form input{flex:1;background:var(--bone);border:1px solid var(--rule);color:var(--ink);font-family:var(--mono);font-size:14px;padding:14px 18px;outline:none;transition:border-color .2s ease;letter-spacing:.02em}
.letters-form input:focus{border-color:var(--coral)}
.letters-form input::placeholder{color:var(--ink-3)}
.letters-form .btn{padding:14px 22px;font-size:11px;letter-spacing:.18em;text-transform:uppercase;background:var(--coral);color:var(--bone);font-weight:600;font-family:var(--mono);display:inline-flex;align-items:center;gap:8px;cursor:pointer;transition:background .2s ease,transform .2s ease;white-space:nowrap}
.letters-form .btn:hover{background:#ff7245}
.letters-form .btn .arr{font-family:var(--serif);font-size:14px}
.letters-form.is-submitting input{opacity:.5;pointer-events:none}
.letters-form.is-submitting .btn{opacity:.6;pointer-events:none}
.letters-note{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin:0;text-align:center}
.letters-note.success{color:#4ade80}
.letters-note.error{color:#f87171}
@media(max-width:760px){
  .letters-sec{padding:80px 0}
  .letters-card{padding:32px 24px}
  .letters-form{flex-direction:column;gap:12px}
  .letters-form .btn{width:100%;justify-content:center}
}

/* ─────────── RECEIPTS ─────────── */
.testi-sec{padding:140px 0}
.receipts-card{background:var(--bone-2);border:1px solid var(--rule);max-width:920px;margin:0 auto;padding:56px 56px 48px;position:relative;display:flex;flex-direction:column;gap:24px}
.receipts-card::before{content:'';position:absolute;top:-1px;left:-1px;width:14px;height:14px;border-top:1px solid var(--coral);border-left:1px solid var(--coral)}
.receipts-card::after{content:'';position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-bottom:1px solid var(--coral);border-right:1px solid var(--coral)}
.receipts-lede{font-family:var(--serif);font-weight:400;font-size:28px;line-height:1.3;letter-spacing:-.01em;margin:0;color:var(--ink);text-wrap:pretty}
.receipts-lede em{font-style:italic;color:var(--coral)}
.receipts-body{font-size:16px;line-height:1.65;color:var(--ink-2);margin:0;text-wrap:pretty;max-width:62ch}
.receipts-body em{font-style:italic;color:var(--ink)}
.receipts-vet{list-style:none;padding:0;margin:16px 0 0;display:flex;flex-direction:column;gap:0;border-top:1px solid var(--rule)}
.receipts-vet li{display:grid;grid-template-columns:64px 1fr;gap:24px;padding:24px 0;border-bottom:1px solid var(--rule);align-items:start}
.receipts-vet li:last-child{border-bottom:0}
.receipts-num{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3);font-weight:500;padding-top:4px}
.receipts-vet strong{display:block;font-family:var(--sans);font-weight:600;font-size:15px;color:var(--ink);margin-bottom:6px;letter-spacing:-.005em}
.receipts-vet div{font-size:15px;line-height:1.6;color:var(--ink-2)}
.receipts-vet a{color:var(--ink)}
@media(max-width:760px){
  .receipts-card{padding:32px 24px}
  .receipts-lede{font-size:22px}
  .receipts-vet li{grid-template-columns:1fr;gap:8px}
  .receipts-num{padding-top:0}
}

/* ─────────── APPLY ─────────── */
.apply-sec{padding:140px 0;background:var(--bone);position:relative}
.apply-card{background:var(--bone-2);border:1px solid var(--rule);max-width:920px;margin:0 auto;padding:48px;display:flex;flex-direction:column;gap:32px;position:relative}
.apply-card::before{content:'';position:absolute;top:-1px;left:-1px;width:14px;height:14px;border-top:1px solid var(--coral);border-left:1px solid var(--coral)}
.apply-card::after{content:'';position:absolute;bottom:-1px;right:-1px;width:14px;height:14px;border-bottom:1px solid var(--coral);border-right:1px solid var(--coral)}

.apply-progress{display:flex;flex-direction:column;gap:12px;padding-bottom:24px;border-bottom:1px solid var(--rule)}
.apply-progress-row{display:flex;justify-content:space-between;align-items:baseline;font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3)}
.apply-progress-row .step-of{color:var(--ink-3)}
.apply-progress-row .step-track{color:var(--coral)}
.apply-bar{height:2px;background:var(--rule);position:relative;overflow:hidden}
.apply-bar-fill{position:absolute;left:0;top:0;height:100%;width:0;background:var(--coral);transition:width .45s cubic-bezier(.2,.7,.2,1)}

.apply-step{display:none;flex-direction:column;gap:18px;animation:applyStepIn .55s cubic-bezier(.2,.7,.2,1)}
.apply-step.active{display:flex}
@keyframes applyStepIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}

.apply-q{font-family:var(--serif);font-weight:700;font-size:clamp(32px,4.2vw,52px);line-height:1.02;letter-spacing:-.025em;margin:0;text-wrap:balance;color:var(--ink)}
.apply-q em{font-family:var(--display);font-style:italic;font-weight:400;color:var(--coral);letter-spacing:-.02em}
.apply-help{font-family:var(--serif);font-style:italic;font-size:17px;line-height:1.4;color:var(--ink-3);margin:0;max-width:54ch}

.apply-text{width:100%;background:var(--bone);border:1px solid var(--rule);color:var(--ink);font-family:var(--serif);font-size:18px;line-height:1.45;padding:18px 20px;resize:vertical;min-height:140px;transition:border-color .2s ease,box-shadow .2s ease;cursor:none}
.apply-text:focus{outline:0;border-color:var(--coral);box-shadow:inset 0 0 0 1px var(--coral)}
.apply-text::placeholder{color:var(--ink-3);font-style:italic}
.apply-counter{margin-top:-6px;font-family:var(--mono);font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);text-align:right}
.apply-counter.ok{color:var(--coral)}

.apply-radio-group{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.apply-radio{position:relative;border:1px solid var(--rule);background:var(--bone);padding:20px 22px;display:flex;flex-direction:column;gap:6px;cursor:none;transition:border-color .2s ease,background .2s ease}
.apply-radio:hover{border-color:var(--ink-2);background:rgba(255,87,34,.04)}
.apply-radio input{position:absolute;opacity:0;pointer-events:none}
.apply-radio strong{font-family:var(--serif);font-size:22px;font-weight:600;color:var(--ink);letter-spacing:-.01em;line-height:1.15}
.apply-radio span{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);line-height:1.4}
.apply-radio.checked{border-color:var(--coral);background:rgba(255,87,34,.08)}
.apply-radio.checked strong{color:var(--coral)}
.apply-radio.checked::after{content:'◆';position:absolute;top:14px;right:18px;color:var(--coral);font-size:13px}

.apply-budget{grid-template-columns:1fr 1fr}
@media(max-width:640px){.apply-budget,.apply-radio-group{grid-template-columns:1fr}}

.apply-final{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:8px}
@media(max-width:640px){.apply-final{grid-template-columns:1fr}}
.apply-field{display:flex;flex-direction:column;gap:6px}
.apply-field label{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-3)}
.apply-field input{background:var(--bone);border:1px solid var(--rule);color:var(--ink);font-family:var(--serif);font-size:18px;padding:14px 18px;cursor:none;transition:border-color .2s ease,box-shadow .2s ease}
.apply-field input:focus{outline:0;border-color:var(--coral);box-shadow:inset 0 0 0 1px var(--coral)}

.apply-deposit{padding:20px 24px;border:1px dashed var(--rule);background:rgba(255,87,34,.04);margin-top:8px}
.apply-deposit-lede{font-family:var(--serif);font-size:16px;line-height:1.5;color:var(--ink-2);margin:0}
.apply-deposit-lede strong{color:var(--coral);font-weight:600}

.apply-nav{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-top:12px;flex-wrap:wrap}
.apply-back{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-3);background:transparent;border:0;padding:14px 4px;cursor:none;transition:color .2s ease}
.apply-back:hover{color:var(--ink)}
.apply-back[disabled]{opacity:.3;pointer-events:none}
.apply-nav .btn{margin-left:auto}

.apply-error{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--coral);margin:8px 0 0}

.apply-loading{display:flex;flex-direction:column;align-items:center;gap:24px;padding:32px 0;text-align:center}
.apply-loading .spinner{width:42px;height:42px;border:2px solid var(--rule);border-top-color:var(--coral);border-radius:50%;animation:spin .9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}

@media (max-width:760px){
  .apply-card{padding:28px 22px;gap:24px}
  .apply-q{font-size:clamp(26px,7vw,38px)}
  .apply-radio{padding:16px 18px}
}

/* Post-checkout banner */
.apply-banner{position:fixed;left:50%;bottom:32px;transform:translate(-50%,40px);background:var(--bone-2);border:1px solid var(--coral);color:var(--ink);padding:14px 22px;font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;z-index:300;opacity:0;transition:opacity .4s ease,transform .4s ease;cursor:none;max-width:calc(100% - 32px);text-align:center}
.apply-banner.show{opacity:1;transform:translate(-50%,0)}
.apply-banner strong{color:var(--coral);font-weight:600;margin-right:6px}
.apply-banner.cancel{border-color:var(--ink-3)}
.apply-banner.cancel strong{color:var(--ink)}

/* ─────────── FOOTER ─────────── */
.foot{background:#000;color:var(--ink);padding:120px 0 32px;border-top:1px solid var(--rule)}
.foot-cta{font-family:var(--serif);font-weight:700;font-size:clamp(64px,11vw,168px);line-height:.84;letter-spacing:-.04em;margin:0 0 56px;text-wrap:balance}
.foot-cta em{font-family:var(--display);font-style:italic;font-weight:400;color:var(--coral);letter-spacing:-.025em}
.foot-cta .stk{font-family:var(--display);-webkit-text-stroke:1.4px var(--ink);color:transparent;font-style:italic;font-weight:400;letter-spacing:-.025em}
.foot-rows{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;padding-top:48px;border-top:1px solid var(--rule)}
.foot-col h4{font-family:var(--mono);font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:var(--ink-3);margin:0 0 18px}
.foot-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.foot-col a{font-family:var(--serif);font-size:20px;font-weight:400;letter-spacing:-.01em}
.foot-col a:hover{color:var(--coral)}
.foot-lede{font-family:var(--serif);font-size:22px;line-height:1.35;font-weight:400;color:var(--ink-2);max-width:32ch;margin:0 0 24px}
.foot-bot{margin-top:64px;padding-top:24px;border-top:1px solid var(--rule);display:flex;justify-content:space-between;font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-3)}
.foot-bot .colophon em{color:var(--coral);font-style:italic;font-family:var(--display);font-size:15px;text-transform:none;letter-spacing:-.01em;font-weight:400}

/* ─────────── RESPONSIVE ─────────── */
@media(max-width:1080px){
  .doors-grid{grid-template-columns:1fr}
  .door.secondary{border-left:0;border-top:1px solid var(--rule)}
  .prods-grid{grid-template-columns:1fr}
  .prod:nth-child(2){border-left:0;border-top:1px solid var(--rule)}
  .phil-grid{grid-template-columns:1fr;gap:32px}
  .counts{grid-template-columns:1fr 1fr}
  .count:nth-child(2){border-right:0}
  .count:nth-child(-n+2){border-bottom:1px solid var(--rule)}
  .foot-rows{grid-template-columns:1fr 1fr;gap:32px}
}
@media(max-width:640px){
  :root{--pad:20px}
  .cover-foot{grid-template-columns:1fr 1fr}
  .mast nav{display:none}
  .slider-head,.sec-head{grid-template-columns:1fr;align-items:start}
  .slider-head .meta,.sec-aside{text-align:left;max-width:none}
  .foot-rows{grid-template-columns:1fr}
  .foot-bot{flex-direction:column;gap:12px}
}
