/* Hallmark · macrostructure: Alternating Showcase · tone: established-tattoo-institution · anchor hue: oxblood-red 30
 * studied: yes · DNA-source: image (inspiration/ref.png) · theme: custom "Union Square Ink"
 * pre-emit critique: P5 H5 E5 S5 R5 V5
 */

/* ============================================================
   TOKENS
   ============================================================ */
:root{
  --bg:        oklch(15.5% 0.012 60);
  --bg-2:      oklch(20%   0.014 58);
  --bg-3:      oklch(24%   0.014 58);
  --ink:       oklch(92%   0.018 82);
  --ink-2:     oklch(82%   0.02  78);
  --muted:     oklch(73%   0.02  76);
  --accent:    oklch(57%   0.19  30);
  --accent-2:  oklch(64%   0.20  32);
  --link:      oklch(72%   0.155 34);   /* brighter oxblood for AA body links on dark */
  --gold:      oklch(78%   0.10  82);
  --line:      oklch(30%   0.012 60);
  --line-2:    oklch(38%   0.012 60);

  --font-display: "Anton", "Arial Narrow", system-ui, sans-serif;
  --font-serif:   "Libre Caslon Display", Georgia, "Times New Roman", serif;
  --font-body:    "Hanken Grotesk", system-ui, -apple-system, sans-serif;

  --h1: clamp(46px, 8.4vw, 108px);
  --h2: clamp(30px, 4.6vw, 58px);
  --h3: clamp(20px, 2.4vw, 28px);
  --eyebrow: clamp(12px, 1.1vw, 14px);

  --maxw: 1240px;
  --gut: clamp(20px, 5vw, 64px);
  --r: 4px;
  --r-lg: 8px;

  --space-xs: 8px;
  --space-sm: 16px;
  --space-md: 28px;
  --space-lg: 56px;
  --space-xl: clamp(72px, 11vw, 148px);

  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in:  cubic-bezier(0.7, 0, 0.84, 0);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --dur: 0.5s;

  --shadow: 0 24px 60px -32px rgba(0,0,0,.7);
}

/* ============================================================
   RESET / BASE
   ============================================================ */
*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html,body{ overflow-x:clip; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--ink);
  font-size:17px;
  line-height:1.6;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{ display:block; max-width:100%; height:auto; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; cursor:pointer; background:none; border:none; }
::selection{ background:var(--accent); color:#fff; }

.wrap{ max-width:var(--maxw); margin:0 auto; padding-inline:var(--gut); }
.eyebrow{
  font-family:var(--font-body);
  font-size:var(--eyebrow);
  font-weight:700;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--accent);
  display:inline-flex; align-items:center; gap:10px;
}
.eyebrow::before{ content:""; width:28px; height:2px; background:var(--accent); display:inline-block; }
.eyebrow.gold{ color:var(--gold); }
.eyebrow.gold::before{ background:var(--gold); }

h1,h2{ font-family:var(--font-display); font-weight:400; line-height:.95; letter-spacing:.005em; text-transform:uppercase; overflow-wrap:anywhere; text-wrap:balance; }
h2{ font-size:var(--h2); }
/* h3 = refined serif sub-level (item names): big Anton caps stay for hero + section statements only */
h3{ font-family:var(--font-serif); font-weight:400; font-size:var(--h3); line-height:1.05; letter-spacing:0; text-transform:none; overflow-wrap:anywhere; text-wrap:balance; }
.serif{ font-family:var(--font-serif); text-transform:none; font-weight:400; letter-spacing:0; line-height:1.2; }
.lead{ font-family:var(--font-serif); font-size:clamp(19px,2vw,24px); line-height:1.5; color:var(--ink-2); }

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  font-family:var(--font-body); font-weight:700; font-size:15px;
  letter-spacing:.04em; text-transform:uppercase;
  padding:15px 28px; border-radius:var(--r);
  transition:transform .25s var(--ease-out), background .25s var(--ease-out), border-color .25s var(--ease-out), color .25s var(--ease-out);
  border:2px solid transparent; white-space:nowrap;
}
.btn-primary{ background:var(--accent); color:#fff; }
.btn-primary:hover{ background:var(--accent-2); transform:translateY(-2px); }
.btn-primary:active{ transform:translateY(0); }
.btn-ghost{ border-color:var(--line-2); color:var(--ink); }
.btn-ghost:hover{ border-color:var(--ink); transform:translateY(-2px); }
.btn:focus-visible{ outline:3px solid var(--gold); outline-offset:3px; }

/* ============================================================
   NAV (N9 edge-aligned)
   ============================================================ */
.nav{
  position:fixed; inset:0 0 auto 0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px var(--gut);
  transition:background .4s var(--ease-out), border-color .4s var(--ease-out), padding .4s var(--ease-out);
  border-bottom:1px solid transparent;
}
.nav.scrolled{ background:color-mix(in oklab, var(--bg) 88%, transparent); backdrop-filter:blur(12px); border-bottom-color:var(--line); padding-block:12px; }
/* backdrop-filter traps fixed children: drop it while the mobile menu overlay is open so it covers the viewport */
.nav.menu-open{ background:transparent; backdrop-filter:none; -webkit-backdrop-filter:none; border-bottom-color:transparent; }
.nav__brand{ display:flex; align-items:center; gap:12px; font-family:var(--font-display); text-transform:uppercase; font-size:20px; letter-spacing:.04em; position:relative; z-index:60; }
.nav__brand img{ height:132px; width:auto; transition:height .4s var(--ease-out); }
.nav.scrolled .nav__brand img{ height:96px; }
@media (max-width:880px){ .nav__brand img{ height:96px; } .nav.scrolled .nav__brand img{ height:78px; } }
.nav__links{ display:flex; align-items:center; gap:30px; }
.nav__links a{
  font-size:15px; font-weight:600; letter-spacing:.04em; text-transform:uppercase; color:var(--ink-2);
  position:relative; padding-block:4px;
}
.nav__links a::after{ content:""; position:absolute; left:0; bottom:0; width:100%; height:2px; background:var(--accent); transform:scaleX(0); transform-origin:right; transition:transform .3s var(--ease-out); }
.nav__links a:hover{ color:var(--ink); }
.nav__links a:hover::after{ transform:scaleX(1); transform-origin:left; }
.nav__right{ display:flex; align-items:center; gap:18px; }
.nav__phone{ font-weight:700; font-size:15px; letter-spacing:.02em; color:var(--ink); display:flex; align-items:center; gap:8px; }
.nav__phone svg{ width:16px; height:16px; fill:var(--accent); }
.nav__toggle{ display:none; width:44px; height:44px; flex-direction:column; gap:5px; align-items:center; justify-content:center; position:relative; z-index:60; }
.nav__toggle span{ width:24px; height:2px; background:var(--ink); transition:transform .3s var(--ease-out), opacity .2s var(--ease-out); }
.nav__toggle[aria-expanded="true"] span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav__toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav__toggle[aria-expanded="true"] span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* mobile menu */
.nav__menu{ display:contents; }
@media (max-width:880px){
  .nav__toggle{ display:flex; }
  .nav__menu{
    position:fixed; inset:0; z-index:49;
    background:color-mix(in oklab, var(--bg) 97%, #000);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:8px;
    padding:100px var(--gut) 40px;
    display:flex; transform:translateY(-100%); transition:transform .45s var(--ease-out), visibility .45s var(--ease-out);
    pointer-events:none; visibility:hidden; overflow-y:auto;
  }
  .nav__menu:not([hidden]){ transform:translateY(0); pointer-events:auto; visibility:visible; }
  .nav__links{ flex-direction:column; align-items:flex-start; gap:6px; }
  .nav__links a{ font-family:var(--font-display); font-size:clamp(34px,9vw,56px); color:var(--ink); }
  .nav__links a::after{ display:none; }
  .nav__menu .nav__right{ flex-direction:column; align-items:flex-start; gap:18px; margin-top:32px; }
}

/* ============================================================
   HERO (H6 photographic, left-bias)
   ============================================================ */
.hero{ position:relative; min-height:100svh; display:flex; align-items:flex-end; overflow:hidden; }
.hero__media{ position:absolute; inset:0; z-index:0; }
.hero__media img{ width:100%; height:100%; object-fit:cover; object-position:center 30%; transform:scale(1.5); will-change:transform; }
.hero__media::after{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, color-mix(in oklab,var(--bg) 96%, transparent) 0%, color-mix(in oklab,var(--bg) 72%, transparent) 45%, color-mix(in oklab,var(--bg) 32%, transparent) 82%),
    linear-gradient(0deg, var(--bg) 4%, transparent 52%),
    color-mix(in oklab, var(--bg) 22%, transparent);
}
@keyframes kenburns{ from{ transform:scale(1.06) translateY(0); } to{ transform:scale(1.14) translateY(-2%); } }
.hero__inner{ position:relative; z-index:1; padding-bottom:var(--space-xl); padding-top:140px; max-width:760px; }
.hero h1{ font-size:var(--h1); margin:0; }
.hero h1 .red{ color:var(--accent); }
.hero__sub{ margin-top:22px; max-width:48ch; }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-top:34px; }
.hero__chips{ display:flex; flex-wrap:wrap; gap:10px 26px; margin-top:34px; align-items:center; }
.chip{ display:inline-flex; align-items:center; gap:9px; font-size:15px; font-weight:600; color:var(--ink-2); letter-spacing:.01em; }
.chip svg{ width:16px; height:16px; }
.chip .stars{ color:var(--gold); letter-spacing:2px; font-size:15px; }
.hero__scroll{ position:absolute; bottom:24px; left:50%; transform:translateX(-50%); z-index:2; color:var(--muted); font-size:12px; letter-spacing:.2em; text-transform:uppercase; display:flex; flex-direction:column; align-items:center; gap:8px; }
.hero__scroll span{ width:1px; height:40px; background:linear-gradient(var(--muted),transparent); animation:scrollpulse 2s ease-in-out infinite; }
@keyframes scrollpulse{ 0%,100%{ opacity:.3; transform:scaleY(.6);} 50%{ opacity:1; transform:scaleY(1);} }

/* ============================================================
   SECTION HEAD
   ============================================================ */
.sec{ padding-block:var(--space-xl); }
.sec__head{ display:flex; flex-direction:column; gap:14px; margin-bottom:var(--space-lg); max-width:680px; }
.sec__head.center{ margin-inline:auto; align-items:center; text-align:center; }
.sec__head p{ color:var(--muted); }

/* ============================================================
   STYLE RAIL (horizontal cards)
   ============================================================ */
.rail{ display:flex; gap:18px; overflow-x:auto; scroll-snap-type:x mandatory; padding-bottom:14px; margin-inline:calc(var(--gut)*-1); padding-inline:var(--gut); scrollbar-width:thin; scrollbar-color:var(--line-2) transparent; }
.rail::-webkit-scrollbar{ height:6px; }
.rail::-webkit-scrollbar-thumb{ background:var(--line-2); border-radius:99px; }
.style-card{ scroll-snap-align:start; position:relative; flex:0 0 clamp(220px,72vw,300px); aspect-ratio:3/4; border-radius:var(--r-lg); overflow:hidden; border:1px solid var(--line); background:var(--bg-2); }
.style-card img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-out); filter:saturate(1.02); }
.style-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(0deg, color-mix(in oklab,var(--bg) 94%,transparent) 8%, transparent 60%); }
.style-card__label{ position:absolute; left:0; right:0; bottom:0; z-index:2; padding:20px; }
.style-card__label h3{ font-size:clamp(22px,2.4vw,28px); }
.style-card__label span{ font-size:14px; color:var(--ink-2); font-weight:600; }
.style-card:hover img{ transform:scale(1.07); }
.style-card:focus-within{ outline:3px solid var(--gold); outline-offset:3px; }

/* ============================================================
   THE WORK — MOSAIC GALLERY
   ============================================================ */
/* Even grid (no masonry holes): every figure fills its cell via aspect-ratio + cover. */
.mosaic{ display:grid; grid-template-columns:repeat(4, minmax(0,1fr)); gap:14px; }
.mosaic figure{ position:relative; overflow:hidden; border-radius:var(--r-lg); border:1px solid var(--line); background:var(--bg-2); aspect-ratio:3/4; }
.mosaic figure img{ width:100%; height:100%; object-fit:cover; object-position:center 35%; transition:transform .8s var(--ease-out); }
.mosaic figure:hover img{ transform:scale(1.06); }
.mosaic figure::after{ content:""; position:absolute; inset:0; box-shadow:inset 0 0 0 1px rgba(255,255,255,.03); pointer-events:none; }
.mosaic__more{ display:flex; justify-content:center; margin-top:var(--space-lg); }

/* ============================================================
   FULL-BLEED BANDS
   ============================================================ */
.band{ position:relative; min-height:64svh; display:flex; align-items:center; overflow:hidden; }
.band__media{ position:absolute; inset:0; z-index:0; }
.band__media img{ width:100%; height:100%; object-fit:cover; transform:scale(1.5); will-change:transform; }
/* darken both edges (visit text sits left, heritage text sits right) + an even scrim so copy reads */
.band__media::after{ content:""; position:absolute; inset:0; background:
  linear-gradient(90deg, color-mix(in oklab,var(--bg) 86%,transparent) 0%, color-mix(in oklab,var(--bg) 34%,transparent) 50%, color-mix(in oklab,var(--bg) 86%,transparent) 100%),
  color-mix(in oklab, var(--bg) 32%, transparent); }
.band__inner{ position:relative; z-index:1; padding-block:var(--space-xl); max-width:620px; }
.band h2{ margin:16px 0 18px; }
.band .lead{ margin-bottom:28px; }
.band__split{ max-width:1180px; display:grid; grid-template-columns:auto minmax(0,1fr); align-items:center; gap:clamp(32px,5vw,72px); }
.band__split .band__text{ max-width:560px; }
.band__split h2{ margin-top:0; }
.band__logo{ width:clamp(300px,42vw,520px); height:auto; filter:drop-shadow(0 16px 46px rgba(0,0,0,.6)); }
@media (max-width:760px){
  .band__split{ grid-template-columns:1fr; gap:22px; }
  .band__logo{ width:clamp(220px,60vw,320px); }
}

/* ============================================================
   ARTISTS RAIL
   ============================================================ */
.artists{ display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:22px; }
.artist{ background:var(--bg-2); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden; transition:border-color .3s var(--ease-out), transform .3s var(--ease-out); }
.artist:hover{ border-color:var(--line-2); transform:translateY(-4px); }
.artist__img{ aspect-ratio:4/5; overflow:hidden; }
.artist__img img{ width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease-out); }
.artist:hover .artist__img img{ transform:scale(1.05); }
.artist__body{ padding:22px; }
.artist__body h3{ font-size:26px; }
.artist__body .role{ color:var(--accent-2); font-weight:700; font-size:14px; letter-spacing:.08em; text-transform:uppercase; margin-top:4px; }
.artist__body p{ color:var(--ink-2); font-size:16px; margin-top:12px; }
.artist__link{ display:inline-flex; align-items:center; gap:8px; margin-top:16px; font-weight:700; font-size:14px; text-transform:uppercase; letter-spacing:.04em; color:var(--ink); }
.artist__link svg{ width:15px; transition:transform .3s var(--ease-out); }
.artist:hover .artist__link svg{ transform:translateX(4px); }

/* ============================================================
   PROOF STAT LANDMARK
   ============================================================ */
.proof{ text-align:center; }
.proof__big{ font-family:var(--font-display); text-transform:uppercase; line-height:.86; }
.proof__big .num{ font-size:clamp(96px,20vw,260px); color:var(--ink); display:block; }
.proof__big .num .star{ color:var(--gold); }
.proof__row{ display:flex; flex-wrap:wrap; justify-content:center; gap:18px 56px; margin-top:30px; }
.proof__stat{ display:flex; flex-direction:column; gap:2px; }
.proof__stat b{ font-family:var(--font-display); font-size:clamp(34px,5vw,52px); color:var(--accent); line-height:1; }
.proof__stat span{ font-size:14px; font-weight:500; letter-spacing:.08em; text-transform:uppercase; color:var(--muted); }
.proof__quote{ max-width:760px; margin:var(--space-lg) auto 0; }
.proof__quote blockquote{ font-family:var(--font-serif); font-size:clamp(22px,3vw,34px); line-height:1.35; color:var(--ink); }
.proof__quote cite{ display:block; margin-top:20px; font-family:var(--font-body); font-style:normal; font-size:14px; letter-spacing:.06em; text-transform:uppercase; color:var(--muted); }

/* ============================================================
   FAQ ACCORDION
   ============================================================ */
.faq{ max-width:820px; margin-inline:auto; }
.faq details{ border-bottom:1px solid var(--line); }
.faq details:first-of-type{ border-top:1px solid var(--line); }
.faq summary{ display:flex; align-items:center; justify-content:space-between; gap:20px; padding:26px 4px; list-style:none; cursor:pointer; font-family:var(--font-serif); font-size:clamp(18px,2.2vw,23px); color:var(--ink); transition:color .25s var(--ease-out); }
.faq summary::-webkit-details-marker{ display:none; }
.faq summary:hover{ color:var(--accent); }
.faq summary .ic{ flex:0 0 auto; width:24px; height:24px; position:relative; }
.faq summary .ic::before,.faq summary .ic::after{ content:""; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); background:var(--accent); transition:transform .3s var(--ease-out); }
.faq summary .ic::before{ width:18px; height:2px; }
.faq summary .ic::after{ width:2px; height:18px; }
.faq details[open] summary .ic::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq__a{ overflow:hidden; }
.faq details[open] .faq__a{ animation:faqopen .4s var(--ease-out); }
.faq__a p{ padding:0 4px 28px; color:var(--ink-2); max-width:66ch; }
.faq__a a{ color:var(--link); text-decoration:underline; text-underline-offset:3px; }
@keyframes faqopen{ from{ opacity:0; transform:translateY(-8px);} to{ opacity:1; transform:translateY(0);} }

/* ============================================================
   FOOTER
   ============================================================ */
.foot{ background:var(--bg-2); border-top:1px solid var(--line); padding-top:var(--space-xl); }
.foot__grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:40px; padding-bottom:var(--space-lg); }
.foot__logo{ display:inline-block; }
.foot__logo img{ width:128px; height:auto; }
.foot__brand p{ color:var(--muted); margin-top:18px; max-width:34ch; font-size:15px; }
.foot__col h4{ font-family:var(--font-body); font-size:14px; letter-spacing:.08em; color:var(--muted); margin-bottom:18px; font-weight:700; }
.foot__col a, .foot__col p{ display:block; color:var(--ink-2); font-size:15.5px; margin-bottom:11px; transition:color .25s var(--ease-out); }
.foot__col a:hover{ color:var(--accent); }
.foot__social{ display:flex; gap:12px; margin-top:6px; }
.foot__social a{ width:42px; height:42px; border:1px solid var(--line-2); border-radius:var(--r); display:flex; align-items:center; justify-content:center; transition:.3s var(--ease-out); }
.foot__social a:hover{ background:var(--accent); border-color:var(--accent); transform:translateY(-3px); }
.foot__social svg{ width:18px; height:18px; fill:var(--ink); }
.foot__bar{ border-top:1px solid var(--line); padding-block:24px; display:flex; flex-wrap:wrap; gap:10px 24px; justify-content:space-between; align-items:center; }
.foot__bar small{ color:var(--muted); font-size:14px; }

/* ============================================================
   STICKY MOBILE CALL BAR (CRO)
   ============================================================ */
.callbar{ display:none; }
@media (max-width:760px){
  .callbar{ position:fixed; inset:auto 0 0 0; z-index:48; display:grid; grid-template-columns:1fr 1fr; gap:1px; background:var(--line); border-top:1px solid var(--line); }
  .callbar a{ background:var(--bg-2); padding:15px; text-align:center; font-weight:700; font-size:15px; text-transform:uppercase; letter-spacing:.03em; display:flex; align-items:center; justify-content:center; gap:8px; }
  .callbar a.book{ background:var(--accent); color:#fff; }
  .callbar svg{ width:16px; height:16px; }
  body{ padding-bottom:56px; }
}

/* ============================================================
   SCROLL REVEAL
   ============================================================ */
/* reveals only hide when JS is on (html.js). No-JS / headless => content visible. */
html.js .reveal{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease-out), transform .8s var(--ease-out); }
html.js .reveal.in{ opacity:1; transform:none; }
.reveal[data-d="1"]{ transition-delay:.08s; }
.reveal[data-d="2"]{ transition-delay:.16s; }
.reveal[data-d="3"]{ transition-delay:.24s; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .foot__grid{ grid-template-columns:1fr 1fr; gap:32px; }
  .artists{ grid-template-columns:1fr; }
  .artist{ display:grid; grid-template-columns:140px 1fr; }
  .artist__img{ aspect-ratio:1; }
}
@media (max-width:760px){
  .mosaic{ grid-template-columns:repeat(2,minmax(0,1fr)); gap:10px; }
  .hero__cta .btn{ flex:1 1 auto; }
}
@media (max-width:560px){
  .foot__grid{ grid-template-columns:1fr; }
  .artist{ grid-template-columns:1fr; }
  .artist__img{ aspect-ratio:4/5; }
  .proof__row{ gap:16px 32px; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; }
  .reveal{ opacity:1; transform:none; transition:opacity .15s linear; }
  .hero__media img, .band__media img{ animation:none; transform:scale(1.06); }
  html{ scroll-behavior:auto; }
}
