:root{
  /* palette: pulled from the storefront facade + flyers */
  --ink:#141210;          /* warm near-black building */
  --ink-2:#1f1c18;        /* raised black panel */
  --paper:#f3ede1;        /* warm newsprint */
  --paper-2:#e9e0cf;      /* deeper paper */
  --bone:#fbf8f1;         /* light gallery surface */
  --orange:#ef5e1e;       /* safety orange, primary accent */
  --orange-2:#d84d10;     /* hover / deep */
  --amber:#f7931e;        /* flyer amber, secondary spark */
  --line:#33302a;         /* hairline on ink */
  --line-paper:#cdc3b0;   /* hairline on paper */
  --muted:#8d8576;        /* mono captions */
  --muted-dk:#6f6757;

  --display:"Big Shoulders Display", "Arial Narrow", sans-serif;
  --mono:"Space Mono", ui-monospace, monospace;
  --body:"Archivo", system-ui, sans-serif;

  --maxw:1240px;
  --pad:clamp(20px,5vw,72px);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--body);
  background:var(--ink);
  color:var(--paper);
  line-height:1.6;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
/* riso grain overlay */
body::before{
  content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;opacity:.05;mix-blend-mode:multiply;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
::selection{background:var(--orange);color:#fff}

.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}

/* mono placard label */
.label{
  font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--muted);
}
.label--ink{color:var(--muted-dk)}
.num{font-family:var(--mono);font-weight:700}

/* corner-bracket frame, echoes the [V logo */
.bracket{position:relative}
.bracket::before,.bracket::after{
  content:"";position:absolute;width:22px;height:22px;border:2px solid var(--orange);pointer-events:none;
}
.bracket::before{top:-9px;left:-9px;border-right:0;border-bottom:0}
.bracket::after{bottom:-9px;right:-9px;border-left:0;border-top:0}

/* ---------- HEADER ---------- */
header{
  position:sticky;top:0;z-index:100;
  background:rgba(20,18,16,.86);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
  transition:transform .35s ease;
}
.nav{display:flex;align-items:center;justify-content:space-between;height:64px}
.nav__logo{display:flex;align-items:center;gap:0}
.nav__logo img{height:26px;width:auto;filter:invert(1) brightness(1.6)}
.nav__links{display:flex;align-items:center;gap:30px}
.nav__links a{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--paper);
  opacity:.78;transition:opacity .2s, color .2s;position:relative;padding:4px 0;
}
.nav__links a:hover,.nav__links a.is-active{opacity:1;color:var(--orange)}
.nav__visit{
  font-family:var(--mono);font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--ink)!important;background:var(--orange);opacity:1!important;
  padding:9px 16px!important;font-weight:700;
  box-shadow:5px 5px 0 #000;transition:transform .15s, box-shadow .15s, background .2s;
}
.nav__visit:hover{background:var(--amber)!important;transform:translate(-2px,-2px);box-shadow:7px 7px 0 #000}
.nav__burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:8px}
.nav__burger span{width:26px;height:2px;background:var(--paper);transition:.25s}

/* ---------- HERO ---------- */
.hero{position:relative;background:var(--ink);padding-top:clamp(36px,7vw,80px);padding-bottom:clamp(40px,8vw,96px);overflow:hidden}
.hero__diag{position:absolute;top:0;right:-6%;width:46%;height:130%;background:var(--orange);transform:skewX(-12deg);transform-origin:top;opacity:.96;z-index:0}
.hero__diag::after{content:"";position:absolute;inset:0;background:repeating-linear-gradient(135deg,rgba(0,0,0,.06) 0 2px,transparent 2px 7px)}
.hero .wrap{position:relative;z-index:2}
.hero__grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(24px,4vw,56px);align-items:center}
.hero__eyebrow{display:flex;align-items:center;gap:14px;margin-bottom:26px}
.hero__eyebrow .dot{width:9px;height:9px;background:var(--orange);border-radius:50%}
.hero h1{margin:0;line-height:.82}
.hero h1 .visual{
  display:block;font-family:var(--display);font-weight:900;
  font-size:clamp(4.6rem,17vw,15rem);letter-spacing:-.01em;color:var(--paper);
  text-transform:uppercase;
}
.hero h1 .sub{
  display:block;font-family:var(--display);font-weight:600;
  font-size:clamp(1.15rem,3vw,2rem);letter-spacing:.02em;color:var(--orange);
  text-transform:uppercase;margin-top:14px;max-width:18ch;line-height:1.04;
}
.hero__meta{margin-top:30px;display:flex;flex-wrap:wrap;gap:10px 26px;align-items:center}
.hero__tag{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--paper);opacity:.72}
.hero__tag b{color:var(--orange);font-weight:700}
.hero__cta{margin-top:34px;display:flex;flex-wrap:wrap;gap:14px}
.btn{
  font-family:var(--mono);font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;
  padding:14px 22px;display:inline-flex;align-items:center;gap:10px;transition:transform .15s, box-shadow .15s, background .2s, color .2s;cursor:pointer;
}
.btn--solid{background:var(--paper);color:var(--ink);box-shadow:6px 6px 0 var(--orange)}
.btn--solid:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 var(--orange)}
.btn--ghost{background:transparent;color:var(--paper);border:1.5px solid var(--line)}
.btn--ghost:hover{border-color:var(--orange);color:var(--orange)}

/* hero photo as a matted plate */
.plate{position:relative;background:var(--bone);padding:14px;box-shadow:0 30px 70px rgba(0,0,0,.55);transform:rotate(2.2deg)}
.plate img{width:100%;aspect-ratio:4/3;object-fit:cover}
.plate__cap{font-family:var(--mono);font-size:.64rem;letter-spacing:.1em;color:var(--muted-dk);text-transform:uppercase;margin-top:10px;display:flex;justify-content:space-between}
.plate__pin{position:absolute;top:-12px;left:50%;transform:translateX(-50%);width:54px;height:18px;background:var(--orange);box-shadow:3px 3px 0 rgba(0,0,0,.4)}

/* ---------- marquee-free running index strip ---------- */
.strip{background:var(--orange);color:var(--ink);border-block:3px solid var(--ink)}
.strip__inner{display:flex;align-items:center;gap:26px;padding:13px var(--pad);flex-wrap:wrap;justify-content:center}
.strip__inner span{font-family:var(--display);font-weight:700;font-size:clamp(1rem,2.3vw,1.5rem);text-transform:uppercase;letter-spacing:.01em}
.strip__inner .sep{font-family:var(--mono);font-weight:700;opacity:.5}

/* ---------- generic section ---------- */
section{position:relative}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:clamp(30px,5vw,56px);flex-wrap:wrap}
.sec-head h2{
  font-family:var(--display);font-weight:800;text-transform:uppercase;line-height:.92;letter-spacing:-.005em;
  font-size:clamp(2.4rem,6.5vw,5rem);
}
.sec-head .label{margin-bottom:14px;display:block}

/* ---------- TWO DOORS ---------- */
.doors{background:var(--paper);color:var(--ink);padding-block:clamp(64px,9vw,120px)}
.doors .sec-head h2{color:var(--ink)}
.doors__grid{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.door{position:relative;display:flex;flex-direction:column}
.door__media{position:relative;overflow:hidden;border:1px solid var(--line-paper)}
.door__media img{width:100%;aspect-ratio:16/11;object-fit:cover;transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.door:hover .door__media img{transform:scale(1.05)}
.door__no{position:absolute;top:0;left:0;background:var(--ink);color:var(--paper);font-family:var(--mono);font-weight:700;font-size:.8rem;letter-spacing:.1em;padding:8px 14px;z-index:2}
.door__addr{position:absolute;top:0;right:0;background:var(--orange);color:var(--ink);font-family:var(--mono);font-weight:700;font-size:.74rem;letter-spacing:.08em;padding:8px 14px;z-index:2}
.door__body{padding:26px 4px 0}
.door__body h3{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(1.9rem,3.6vw,2.7rem);line-height:.96;margin-bottom:6px}
.door__body h3 em{font-style:normal;color:var(--orange)}
.door__body p{color:#46413a;max-width:42ch;margin-bottom:18px}
.door__tags{display:flex;flex-wrap:wrap;gap:8px}
.pill{font-family:var(--mono);font-size:.68rem;letter-spacing:.08em;text-transform:uppercase;color:#5b5547;border:1px solid var(--line-paper);padding:6px 11px}
.door__body--link{display:inline-flex;align-items:center;gap:8px;margin-top:18px;font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;color:var(--orange)}
.door__body--link:hover{gap:14px}

/* ---------- SUPPLY INDEX ---------- */
.supply{background:var(--ink);padding-block:clamp(64px,9vw,120px)}
.supply__layout{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,5vw,64px);align-items:center}
.supply__copy p{color:#cfc6b4;max-width:46ch;margin-bottom:18px}
.supply__copy .lead{font-family:var(--display);font-weight:600;font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.08;color:var(--paper);text-transform:uppercase;margin-bottom:22px}
.idx{border-top:1px solid var(--line)}
.idx__row{display:flex;align-items:baseline;gap:18px;padding:16px 4px;border-bottom:1px solid var(--line);transition:padding-left .25s, background .25s}
.idx__row:hover{padding-left:16px;background:var(--ink-2)}
.idx__row .n{font-family:var(--mono);font-size:.74rem;color:var(--orange);min-width:34px}
.idx__row .t{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(1.3rem,2.6vw,1.9rem);line-height:1;flex:1}
.idx__row .d{font-family:var(--mono);font-size:.68rem;letter-spacing:.06em;color:var(--muted);text-transform:uppercase;text-align:right;max-width:16ch}
.supply__photo{position:relative}
.supply__photo img{width:100%;aspect-ratio:3/4;object-fit:cover;filter:contrast(1.03)}

/* ---------- SHOWS / FLYER WALL ---------- */
.shows{background:var(--ink-2);padding-block:clamp(64px,9vw,120px);background-image:radial-gradient(var(--line) 1px,transparent 1px);background-size:22px 22px}
.shows__wall{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.flyer{position:relative;background:#000;border:1px solid var(--line);overflow:hidden;transition:transform .3s, box-shadow .3s}
.flyer:nth-child(odd){transform:rotate(-1.4deg)}
.flyer:nth-child(even){transform:rotate(1.2deg)}
.flyer:hover{transform:rotate(0) scale(1.03);box-shadow:0 22px 50px rgba(0,0,0,.6);z-index:3}
.flyer img{width:100%;aspect-ratio:1/1;object-fit:cover}
.flyer__tape{position:absolute;top:-8px;left:50%;transform:translateX(-50%) rotate(-3deg);width:74px;height:20px;background:rgba(247,147,30,.82);box-shadow:0 2px 6px rgba(0,0,0,.3)}
.shows__roster{margin-top:clamp(34px,5vw,56px);padding-top:28px;border-top:1px solid var(--line)}
.shows__roster .label{margin-bottom:14px;display:block}
.roster{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:clamp(1.1rem,2.4vw,1.7rem);line-height:1.25;color:#bcb3a1}
.roster b{color:var(--paper);font-weight:600}
.roster .x{color:var(--orange);padding:0 6px}

/* ---------- JASON / ABOUT ---------- */
.about{background:var(--paper);color:var(--ink);padding-block:clamp(64px,9vw,120px)}
.about__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(30px,5vw,68px);align-items:center}
.about__photo{position:relative;background:var(--bone);padding:14px;box-shadow:0 24px 56px rgba(0,0,0,.22);transform:rotate(-1.6deg)}
.about__photo img{width:100%;aspect-ratio:3/4;object-fit:cover}
.about__photo .plate__cap{color:var(--muted-dk)}
.about__copy .label{color:var(--muted-dk);display:block;margin-bottom:18px}
.about__copy blockquote{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(1.8rem,4vw,3rem);line-height:.98;letter-spacing:-.005em;margin-bottom:26px}
.about__copy blockquote span{color:var(--orange)}
.about__copy p{color:#46413a;max-width:54ch;margin-bottom:16px}
.about__copy .credits{font-family:var(--mono);font-size:.72rem;letter-spacing:.04em;color:var(--muted-dk);text-transform:uppercase;margin-top:22px;line-height:1.9}
.about__copy .credits b{color:var(--ink)}

/* ---------- PROOF ---------- */
.proof{background:var(--ink);padding-block:clamp(56px,8vw,104px)}
.proof__rate{display:flex;align-items:center;gap:18px;justify-content:center;margin-bottom:clamp(34px,5vw,52px);flex-wrap:wrap}
.proof__rate .big{font-family:var(--display);font-weight:900;font-size:clamp(3rem,8vw,5.5rem);color:var(--orange);line-height:1}
.proof__rate .stars{font-size:1.3rem;letter-spacing:.1em;color:var(--amber)}
.proof__rate .meta{font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.quotes{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-bottom:clamp(40px,5vw,60px)}
.quote{border:1px solid var(--line);padding:26px 24px;background:var(--ink-2);position:relative}
.quote .mark{font-family:var(--display);font-weight:900;font-size:3rem;color:var(--orange);line-height:.6;opacity:.85}
.quote p{font-size:1.02rem;color:#ddd4c2;margin:8px 0 16px}
.quote cite{font-family:var(--mono);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-style:normal}
.press{text-align:center;padding-top:28px;border-top:1px solid var(--line)}
.press .label{display:block;margin-bottom:16px}
.press__list{display:flex;flex-wrap:wrap;gap:14px 30px;justify-content:center;align-items:center}
.press__list span{font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:clamp(1rem,2.2vw,1.5rem);color:#9b9384}
.press__list span.nyt{color:var(--paper)}

/* ---------- VISIT ---------- */
.visit{background:var(--orange);color:var(--ink);padding-block:clamp(64px,9vw,120px);position:relative;overflow:hidden}
.visit::before{content:"VISIT";position:absolute;top:-4%;right:-1%;font-family:var(--display);font-weight:900;font-size:28vw;color:rgba(0,0,0,.06);line-height:.7;pointer-events:none}
.visit .wrap{position:relative;z-index:2}
.visit__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:stretch}
.visit h2{font-family:var(--display);font-weight:900;text-transform:uppercase;font-size:clamp(2.6rem,7vw,5.4rem);line-height:.86;margin-bottom:22px}
.visit__info{display:grid;gap:2px;margin-bottom:26px}
.vrow{display:flex;gap:16px;padding:16px 0;border-bottom:2px solid rgba(0,0,0,.18);align-items:baseline}
.vrow .k{font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;min-width:96px;font-weight:700}
.vrow .v{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(1.1rem,2.4vw,1.5rem);line-height:1.05}
.vrow .v a:hover{text-decoration:underline}
.vrow small{display:block;font-family:var(--body);font-weight:400;text-transform:none;font-size:.82rem;letter-spacing:0;opacity:.7}
.visit__cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:6px}
.btn--ink{background:var(--ink);color:var(--paper);box-shadow:6px 6px 0 rgba(0,0,0,.25)}
.btn--ink:hover{transform:translate(-2px,-2px);box-shadow:8px 8px 0 rgba(0,0,0,.25)}
.map{position:relative;min-height:340px;border:3px solid var(--ink);box-shadow:10px 10px 0 var(--ink);overflow:hidden}
.map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(.3) contrast(1.05)}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:var(--paper);padding-top:clamp(56px,8vw,96px);padding-bottom:40px;border-top:1px solid var(--line)}
.foot__top{display:flex;justify-content:space-between;gap:40px;flex-wrap:wrap;align-items:flex-start;margin-bottom:clamp(40px,6vw,72px)}
.foot__brand .word{font-family:var(--display);font-weight:900;text-transform:uppercase;font-size:clamp(3.4rem,11vw,8rem);line-height:.8;letter-spacing:-.01em}
.foot__brand .word b{color:var(--orange)}
.foot__brand p{font-family:var(--mono);font-size:.74rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-top:16px;max-width:34ch;line-height:1.8}
.foot__cols{display:flex;gap:clamp(36px,6vw,72px);flex-wrap:wrap}
.foot__col h4{font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.foot__col a,.foot__col p{display:block;font-family:var(--display);font-weight:600;text-transform:uppercase;font-size:1.15rem;line-height:1.5;color:var(--paper)}
.foot__col a:hover{color:var(--orange)}
.foot__bottom{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;padding-top:24px;border-top:1px solid var(--line);font-family:var(--mono);font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.foot__bottom a{color:var(--muted)}
.foot__bottom a:hover{color:var(--orange)}

.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease, transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* =========================================================
   PAGE TEMPLATES (shop / gallery / about)
   ========================================================= */

/* page hero */
.phero{position:relative;background:var(--ink);overflow:hidden;padding-top:clamp(48px,8vw,96px);padding-bottom:clamp(40px,6vw,72px);border-bottom:1px solid var(--line)}
.phero__bg{position:absolute;inset:0;z-index:0;opacity:.16}
.phero__bg img{width:100%;height:100%;object-fit:cover;filter:grayscale(.2) contrast(1.05)}
.phero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,18,16,.4),var(--ink));z-index:1}
.phero .wrap{position:relative;z-index:2}
.crumb{display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:24px}
.crumb a:hover{color:var(--orange)}
.crumb .sep{color:var(--orange)}
.phero h1{font-family:var(--display);font-weight:900;text-transform:uppercase;line-height:.84;letter-spacing:-.01em;font-size:clamp(3rem,11vw,8rem);color:var(--paper)}
.phero h1 em{font-style:normal;color:var(--orange)}
.phero__lead{font-family:var(--display);font-weight:500;text-transform:uppercase;font-size:clamp(1.2rem,2.6vw,1.8rem);line-height:1.1;color:#cfc6b4;max-width:30ch;margin-top:22px}
.phero__kick{margin-bottom:18px;display:block}

/* prose / content sections */
.block{padding-block:clamp(56px,8vw,104px)}
.block--paper{background:var(--paper);color:var(--ink)}
.block--ink{background:var(--ink)}
.block--ink2{background:var(--ink-2)}
.prose{max-width:62ch}
.prose.center{margin-inline:auto;text-align:center}
.prose p{font-size:1.06rem;margin-bottom:18px}
.block--paper .prose p{color:#46413a}
.block--ink .prose p,.block--ink2 .prose p{color:#cfc6b4}
.prose .big{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:clamp(1.7rem,4vw,2.8rem);line-height:1;letter-spacing:-.005em;margin-bottom:24px}
.block--ink .prose .big,.block--ink2 .prose .big{color:var(--paper)}
.prose .big em{font-style:normal;color:var(--orange)}

/* feature row (image + text), alternating */
.feature{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.feature + .feature{margin-top:clamp(48px,7vw,96px)}
.feature--flip .feature__media{order:2}
.feature__media{position:relative}
.feature__media img{width:100%;aspect-ratio:4/3;object-fit:cover;border:1px solid var(--line)}
.block--paper .feature__media img{border-color:var(--line-paper)}
.feature__body h3{font-family:var(--display);font-weight:800;text-transform:uppercase;font-size:clamp(1.8rem,4vw,3rem);line-height:.96;margin-bottom:16px}
.feature__body h3 em{font-style:normal;color:var(--orange)}
.feature__body p{margin-bottom:16px}
.block--paper .feature__body p{color:#46413a}
.block--ink .feature__body p,.block--ink2 .feature__body p{color:#cfc6b4}

/* services / capability grid (bracketed cards) */
.caps{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.cap{border:1px solid var(--line);padding:28px 24px;background:var(--ink-2);position:relative;transition:transform .25s, border-color .25s}
.block--paper .cap{background:var(--bone);border-color:var(--line-paper)}
.cap:hover{transform:translateY(-4px);border-color:var(--orange)}
.cap .n{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;color:var(--orange);display:block;margin-bottom:14px}
.cap h3{font-family:var(--display);font-weight:700;text-transform:uppercase;font-size:1.5rem;line-height:1;margin-bottom:10px}
.cap p{font-size:.96rem;line-height:1.55}
.block--ink2 .cap p{color:#bcb3a1}
.block--paper .cap p{color:#5b5547}

/* fact band */
.facts{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;text-align:center}
.fact .big{font-family:var(--display);font-weight:900;font-size:clamp(2.4rem,6vw,4rem);color:var(--orange);line-height:1}
.fact .cap{all:unset;display:block;font-family:var(--mono);font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-top:8px}

/* endcap cross-link */
.endcap{background:var(--ink);padding-block:clamp(56px,8vw,96px);border-top:1px solid var(--line);text-align:center}
.endcap h2{font-family:var(--display);font-weight:900;text-transform:uppercase;font-size:clamp(2.2rem,6vw,4.4rem);line-height:.9;margin-bottom:24px}
.endcap h2 em{font-style:normal;color:var(--orange)}
.endcap .hero__cta{justify-content:center}

/* ---------- RESPONSIVE ---------- */
@media(max-width:920px){
  .hero__grid{grid-template-columns:1fr;gap:40px}
  .plate{max-width:440px;margin:0 auto}
  .supply__layout{grid-template-columns:1fr;gap:36px}
  .supply__photo{order:-1;max-width:480px}
  .about__grid{grid-template-columns:1fr}
  .about__photo{max-width:380px}
  .visit__grid{grid-template-columns:1fr}
  .quotes{grid-template-columns:1fr}
  .shows__wall{grid-template-columns:repeat(2,1fr)}
  .doors__grid{grid-template-columns:1fr;gap:40px}
  .feature{grid-template-columns:1fr;gap:28px}
  .feature--flip .feature__media{order:0}
  .feature__media{max-width:520px}
  .caps{grid-template-columns:1fr 1fr}
  .facts{grid-template-columns:1fr 1fr;gap:30px 20px}
  .nav__links{position:fixed;inset:64px 0 auto 0;background:var(--ink);flex-direction:column;align-items:flex-start;gap:0;padding:10px var(--pad) 24px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:transform .35s ease;height:auto}
  .nav__links.open{transform:none}
  .nav__links a{width:100%;padding:16px 0;border-bottom:1px solid var(--line);font-size:.9rem}
  .nav__visit{box-shadow:4px 4px 0 #000;margin-top:14px;width:100%;justify-content:center}
  .nav__burger{display:flex}
}
@media(max-width:560px){
  .hero__diag{width:64%;right:-14%}
  .strip__inner{gap:14px}
  .vrow{flex-direction:column;gap:4px}
  .vrow .k{min-width:0}
  .caps{grid-template-columns:1fr}
}
/* ---------- PHOTO GRID (real-photo galleries) ---------- */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.pgrid--quad{grid-template-columns:repeat(4,1fr)}
.pgrid figure{position:relative;overflow:hidden;border:1px solid var(--line)}
.block--paper .pgrid figure{border-color:var(--line-paper)}
.pgrid img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block;transition:transform .8s cubic-bezier(.2,.7,.2,1)}
.pgrid figure:hover img{transform:scale(1.06)}
.pgrid figcaption{position:absolute;left:0;bottom:0;background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;padding:6px 10px}

@media(max-width:920px){.pgrid,.pgrid--quad{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.pgrid,.pgrid--quad{grid-template-columns:1fr 1fr;gap:10px}}

@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important;scroll-behavior:auto!important}
  .reveal{opacity:1;transform:none}
  .plate,.about__photo,.flyer{transform:none!important}
}
