/* =========================================================
   ARIZONA CUSTOM CYCLES — design system
   Pitch black + bone + raw steel + copper signature
   ========================================================= */

:root{
  /* Pulled from Arizona Custom Cycles' real logo: safety orange + steel + black */
  --ink:        #0A0A0A;
  --ink-2:      #131210;
  --ink-3:      #1C1A17;
  --steel:      #A5A5A4;   /* real logo steel gray */
  --steel-dk:   #4A4744;
  --steel-2:    #6B6663;
  --bone:       #F4EFE7;
  --bone-dim:   #CFC9BD;   /* lifted for readability */
  --bone-mute:  #9A958C;   /* lifted from 8B8780 for contrast */
  /* keep --copper variable NAME to avoid breaking refs — values are now brand orange */
  --copper:     #ED7524;   /* exact brand orange from logo */
  --copper-hot: #FF8A3D;
  --copper-deep:#B4561A;
  --orange:     #ED7524;
  --rule:       rgba(244,239,231,0.12);
  --rule-strong:rgba(244,239,231,0.24);
  --shadow:     0 30px 80px -20px rgba(0,0,0,.9);
  /* checkered shop-floor motif (their real floor is red/white diamond) */
  --check-a:    #1C1A17;
  --check-b:    #131210;

  --f-display:  'Anton', 'Bebas Neue', Impact, sans-serif;
  --f-mega:     'Bebas Neue', 'Anton', Impact, sans-serif;
  --f-body:     'Inter', system-ui, sans-serif;
  --f-mono:     'JetBrains Mono', ui-monospace, monospace;
}

*,*::before,*::after{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
html,body{ margin:0; padding:0; }
body{
  background:var(--ink);
  color:var(--bone);
  font-family:var(--f-body);
  font-size:16px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* utility */
.wrap{ width:100%; max-width:1440px; margin:0 auto; padding:0 40px; }
.wrap--narrow{ max-width:1080px; }
.eyebrow{
  font-family:var(--f-mono);
  font-size:11px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--copper);
  margin:0;
}
.rule{ height:1px; background:var(--rule); border:0; margin:0; }
.rule--copper{ height:1px; background:var(--copper); width:80px; border:0; margin:24px 0; }

/* =========================================================
   NAV
   ========================================================= */
.nav{
  position:fixed; top:0; left:0; right:0;
  z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 40px;
  background:linear-gradient(180deg, rgba(10,9,8,.92) 0%, rgba(10,9,8,.55) 70%, rgba(10,9,8,0) 100%);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
}
.nav__brand{
  display:flex; align-items:center; gap:12px;
  font-family:var(--f-display);
  text-transform:uppercase;
  letter-spacing:.04em;
  font-size:18px;
  line-height:1;
}
.nav__brand .mark{
  width:34px; height:34px;
  display:inline-flex; align-items:center; justify-content:center;
  border:1.5px solid var(--copper);
  color:var(--copper);
  font-family:var(--f-mega);
  font-size:18px;
  transform:rotate(-2deg);
}
.nav__brand b{ color:var(--bone); font-weight:400; }
.nav__brand span{ color:var(--copper); font-weight:400; }
.nav__links{
  display:flex; align-items:center; gap:30px;
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone-dim);
}
.nav__links a:hover{ color:var(--copper); }
.nav__cta{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 18px;
  border:1px solid var(--copper);
  color:var(--copper);
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  transition:all .25s ease;
}
.nav__cta:hover{ background:var(--copper); color:var(--ink); }
.nav__burger{ display:none; background:none; border:0; color:var(--bone); font-size:24px; }

@media (max-width:900px){
  .nav{ padding:14px 20px; }
  .nav__links{ display:none; }
  .nav__cta{ padding:8px 12px; font-size:10px; }
}

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; align-items:flex-end;
  overflow:hidden;
  background:var(--ink);
}
.hero__bg{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 90% at 80% 10%, rgba(237,117,36,.10) 0%, rgba(10,10,10,0) 55%),
    linear-gradient(180deg, rgba(10,10,10,.55) 0%, rgba(10,10,10,.78) 60%, rgba(10,10,10,.98) 100%),
    var(--ink);
}
.hero__grain{
  position:absolute; inset:0;
  background-image:url("data:image/svg+xml;utf8,<svg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/><feColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 .12 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
  mix-blend-mode:overlay;
  opacity:.55;
  pointer-events:none;
}
.hero__inner{
  position:relative;
  width:100%;
  padding:140px 40px 60px;
}
.hero__meta{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:40px;
  margin-bottom:32px;
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone-dim);
}
.hero__meta span b{ color:var(--copper); font-weight:500; }
.hero__title{
  font-family:var(--f-mega);
  font-weight:400;
  font-size:clamp(64px, 13vw, 220px);
  line-height:.86;
  letter-spacing:-.005em;
  text-transform:uppercase;
  margin:0;
  color:var(--bone);
}
.hero__title em{
  font-style:normal;
  color:var(--copper);
  display:inline-block;
}
.hero__row{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:60px; margin-top:36px;
  flex-wrap:wrap;
}
.hero__tag{
  max-width:540px;
  font-size:17px; line-height:1.55;
  color:var(--bone);
}
.hero__tag b{ color:var(--copper); font-weight:600; }
.hero__cta-group{
  display:flex; gap:14px; flex-wrap:wrap;
}
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:18px 28px;
  font-family:var(--f-mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  border:1px solid var(--copper);
  background:var(--copper);
  color:var(--ink);
  transition:all .25s ease;
}
.btn:hover{ background:var(--copper-hot); border-color:var(--copper-hot); transform:translateY(-2px); }
.btn--ghost{ background:transparent; color:var(--bone); }
.btn--ghost:hover{ background:var(--bone); color:var(--ink); border-color:var(--bone); }
.btn__arrow{ font-size:14px; }

.hero__scroll{
  position:absolute; bottom:24px; right:40px;
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.3em; text-transform:uppercase;
  color:var(--bone-mute);
  writing-mode:vertical-rl;
  transform:rotate(180deg);
}

@media (max-width:768px){
  .hero__inner{ padding:120px 20px 40px; }
  .hero__meta{ font-size:10px; letter-spacing:.18em; }
  .hero__scroll{ display:none; }
  .hero__row{ flex-direction:column; align-items:flex-start; }
  .btn{ padding:14px 20px; font-size:10px; }
}

/* =========================================================
   STATS BAR
   ========================================================= */
.stats{
  background:var(--ink);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.stats__grid{
  display:grid; grid-template-columns:repeat(4, 1fr);
  padding:48px 40px;
  max-width:1440px; margin:0 auto;
  gap:0;
}
.stat{ padding:0 24px; border-left:1px solid var(--rule); }
.stat:first-child{ border-left:0; padding-left:0; }
.stat__num{
  font-family:var(--f-mega);
  font-size:clamp(48px,6vw,84px);
  line-height:1;
  color:var(--bone);
  margin:0 0 10px;
}
.stat__num em{ font-style:normal; color:var(--copper); font-size:.5em; vertical-align:.4em; margin-left:4px; }
.stat__lbl{
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--bone-mute);
  margin:0;
}
@media (max-width:768px){
  .stats__grid{ grid-template-columns:repeat(2,1fr); gap:30px 0; padding:32px 20px; }
  .stat{ padding:0 16px; }
  .stat:nth-child(3){ border-left:0; padding-left:0; }
}

/* =========================================================
   SECTION CHROME
   ========================================================= */
section{ position:relative; }
.sec-head{
  padding:120px 40px 40px;
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1.6fr; gap:60px;
  align-items:end;
}
.sec-head__title{
  font-family:var(--f-display);
  font-weight:400;
  font-size:clamp(40px, 5.2vw, 84px);
  line-height:.92;
  letter-spacing:-.01em;
  text-transform:uppercase;
  margin:14px 0 0;
  color:var(--bone);
}
.sec-head__title em{ font-style:normal; color:var(--copper); }
.sec-head__lede{
  font-size:17px; line-height:1.55;
  color:var(--bone-dim);
  max-width:560px;
}
@media (max-width:900px){
  .sec-head{ grid-template-columns:1fr; gap:24px; padding:80px 20px 30px; }
}

/* =========================================================
   BUILD GALLERY
   ========================================================= */
.builds{
  padding:0 40px 100px;
  max-width:1440px; margin:0 auto;
}
.build-grid{
  display:grid; grid-template-columns:repeat(12, 1fr);
  gap:30px;
}
.build-card{
  position:relative;
  background:var(--ink-2);
  overflow:hidden;
  border:1px solid var(--rule);
  display:block;
  transition:border-color .3s ease;
}
.build-card:hover{ border-color:var(--copper); }
.build-card:hover .build-card__img{ transform:scale(1.04); }
.build-card:hover .build-card__cta{ color:var(--copper); }
.build-card__media{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
  background:linear-gradient(135deg,#1E1A16 0%, #0A0908 100%);
}
.build-card__img{
  width:100%; height:100%;
  object-fit:cover;
  transition:transform .8s ease;
}
.build-card__tag{
  position:absolute; top:18px; left:18px;
  font-family:var(--f-mono);
  font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper);
  background:rgba(10,9,8,.78);
  padding:6px 10px;
  border:1px solid var(--copper);
}
.build-card__num{
  position:absolute; bottom:18px; right:18px;
  font-family:var(--f-mega);
  font-size:60px;
  line-height:1;
  color:rgba(242,237,227,.15);
}
.build-card__body{
  padding:26px 24px 28px;
  display:flex; flex-direction:column;
  border-top:1px solid var(--rule);
}
.build-card__title{
  font-family:var(--f-display);
  font-weight:400;
  font-size:28px; line-height:1;
  letter-spacing:.01em;
  text-transform:uppercase;
  margin:0 0 8px;
  color:var(--bone);
}
.build-card__meta{
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone-mute);
  margin:0 0 16px;
}
.build-card__meta b{ color:var(--copper); font-weight:500; }
.build-card__cta{
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone-dim);
  display:inline-flex; align-items:center; gap:8px;
  margin-top:auto;
  padding-top:14px;
  border-top:1px dashed var(--rule);
  transition:color .25s ease;
}

/* card sizes */
.build-card--lg{ grid-column:span 8; }
.build-card--lg .build-card__media{ aspect-ratio:16/10; }
.build-card--md{ grid-column:span 4; }
.build-card--sm{ grid-column:span 4; }
.build-card--sm .build-card__media{ aspect-ratio:1/1; }
.build-card--feature{ grid-column:span 12; }
.build-card--feature .build-card__media{ aspect-ratio:21/9; }
.build-card--feature .build-card__title{ font-size:44px; }

@media (max-width:1024px){
  .build-card--lg, .build-card--md{ grid-column:span 6; }
  .build-card--sm{ grid-column:span 6; }
}
@media (max-width:640px){
  .builds{ padding:0 20px 60px; }
  .build-grid{ gap:18px; }
  .build-card--lg, .build-card--md, .build-card--sm, .build-card--feature{ grid-column:span 12; }
  .build-card--feature .build-card__title{ font-size:32px; }
}

/* =========================================================
   PROCESS — 6 steps
   ========================================================= */
.process{
  background:var(--ink-2);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.process__grid{
  max-width:1440px; margin:0 auto;
  padding:0 40px 110px;
  display:grid; grid-template-columns:repeat(6,1fr);
  gap:0;
}
.step{
  padding:40px 22px 32px;
  border-left:1px solid var(--rule);
  position:relative;
}
.step:first-child{ border-left:0; }
.step__num{
  font-family:var(--f-mega);
  font-size:54px; line-height:1;
  color:var(--copper);
  margin:0 0 18px;
}
.step__title{
  font-family:var(--f-display);
  font-weight:400;
  font-size:22px; line-height:1.05;
  letter-spacing:.02em;
  text-transform:uppercase;
  margin:0 0 12px;
  color:var(--bone);
}
.step__body{ font-size:14px; line-height:1.55; color:var(--bone-dim); margin:0; }
.step__week{
  display:block; margin-top:18px;
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone-mute);
}
@media (max-width:1024px){
  .process__grid{ grid-template-columns:repeat(3,1fr); }
  .step:nth-child(4){ border-left:0; }
  .step:nth-child(n+4){ border-top:1px solid var(--rule); }
}
@media (max-width:640px){
  .process__grid{ grid-template-columns:repeat(2,1fr); padding:0 20px 60px; }
  .step{ border-left:1px solid var(--rule) !important; border-top:none !important; padding:30px 16px 24px; }
  .step:nth-child(odd){ border-left:0 !important; }
  .step:nth-child(n+3){ border-top:1px solid var(--rule) !important; }
}

/* =========================================================
   SERVICES
   ========================================================= */
.services{ padding-bottom:100px; }
.services__grid{
  max-width:1440px; margin:0 auto;
  padding:0 40px;
  display:grid; grid-template-columns:repeat(5,1fr);
  gap:0;
  border-top:1px solid var(--rule);
}
.svc{
  padding:50px 24px;
  border-right:1px solid var(--rule);
  position:relative;
  transition:background .3s ease;
}
.svc:last-child{ border-right:0; }
.svc:hover{ background:var(--ink-2); }
.svc__icon{
  font-family:var(--f-mono);
  font-size:11px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper);
  margin-bottom:24px;
  display:block;
}
.svc__title{
  font-family:var(--f-display); font-weight:400;
  font-size:26px; line-height:1.05;
  text-transform:uppercase; letter-spacing:.01em;
  margin:0 0 12px;
  color:var(--bone);
}
.svc__body{ font-size:14px; line-height:1.55; color:var(--bone-dim); margin:0 0 18px; }
.svc__bullets{
  list-style:none; padding:0; margin:0;
  font-family:var(--f-mono);
  font-size:10px; letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone-mute);
}
.svc__bullets li{ padding:6px 0; border-top:1px dashed var(--rule); }
.svc__bullets li:first-child{ border-top:0; }
@media (max-width:1024px){
  .services__grid{ grid-template-columns:repeat(2,1fr); }
  .svc{ border-right:1px solid var(--rule) !important; border-bottom:1px solid var(--rule); }
  .svc:nth-child(even){ border-right:0 !important; }
}
@media (max-width:640px){
  .services__grid{ grid-template-columns:1fr; padding:0 20px; }
  .svc{ border-right:0 !important; padding:36px 0; }
}

/* =========================================================
   MEET JOHNNY
   ========================================================= */
.johnny{
  background:var(--ink-2);
  border-top:1px solid var(--rule);
  padding:120px 40px;
}
.johnny__grid{
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1.2fr;
  gap:80px; align-items:start;
}
.johnny__media{
  position:relative;
  aspect-ratio:4/5;
  background:linear-gradient(135deg,#1E1A16 0%, #0A0908 100%);
  overflow:hidden;
  border:1px solid var(--rule);
}
.johnny__media img{ width:100%; height:100%; object-fit:cover; filter:grayscale(.2) contrast(1.08); }
.johnny__media::after{
  content:'JOHNNY GOODSON / PHOENIX';
  position:absolute; bottom:18px; left:18px;
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.25em; text-transform:uppercase;
  color:var(--copper);
  background:rgba(10,9,8,.78);
  padding:6px 10px;
  border:1px solid var(--copper);
}
.johnny__title{
  font-family:var(--f-display); font-weight:400;
  font-size:clamp(40px,5vw,76px); line-height:.94;
  letter-spacing:-.01em; text-transform:uppercase;
  margin:18px 0 28px;
  color:var(--bone);
}
.johnny__title em{ font-style:normal; color:var(--copper); }
.johnny p{ font-size:16px; line-height:1.7; color:var(--bone-dim); margin:0 0 18px; max-width:580px; }
.johnny p b{ color:var(--bone); font-weight:600; }
.johnny__credits{
  margin-top:36px;
  display:grid; grid-template-columns:repeat(2,1fr);
  gap:18px 30px;
  border-top:1px solid var(--rule);
  padding-top:30px;
  max-width:560px;
}
.cred__lbl{
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone-mute);
  margin:0 0 6px;
}
.cred__val{
  font-family:var(--f-display); font-weight:400;
  font-size:20px; line-height:1.05;
  text-transform:uppercase; letter-spacing:.01em;
  color:var(--bone);
  margin:0;
}
.cred__val em{ font-style:normal; color:var(--copper); }
@media (max-width:900px){
  .johnny{ padding:80px 20px; }
  .johnny__grid{ grid-template-columns:1fr; gap:40px; }
}

/* =========================================================
   PRESS
   ========================================================= */
.press{ padding:120px 40px; }
.press__grid{
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:30px;
}
.press-tile{
  border:1px solid var(--rule);
  padding:36px 24px;
  background:var(--ink);
  transition:all .3s ease;
}
.press-tile:hover{ border-color:var(--copper); transform:translateY(-3px); }
.press-tile__year{
  font-family:var(--f-mega); font-size:44px; line-height:1;
  color:var(--copper); margin:0 0 16px;
}
.press-tile__pub{
  font-family:var(--f-display); font-weight:400;
  font-size:22px; line-height:1.05;
  text-transform:uppercase; letter-spacing:.01em;
  margin:0 0 8px; color:var(--bone);
}
.press-tile__body{
  font-size:13px; line-height:1.55; color:var(--bone-dim);
  margin:0 0 18px;
}
.press-tile__tag{
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone-mute);
  padding-top:14px;
  border-top:1px dashed var(--rule);
  display:block;
}
@media (max-width:900px){
  .press{ padding:80px 20px; }
  .press__grid{ grid-template-columns:repeat(2,1fr); gap:16px; }
}
@media (max-width:520px){ .press__grid{ grid-template-columns:1fr; } }

/* =========================================================
   START A BUILD — form
   ========================================================= */
.startbuild{
  position:relative;
  background:var(--ink);
  border-top:1px solid var(--rule);
  padding:120px 40px;
  overflow:hidden;
}
.startbuild::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(80% 60% at 15% 100%, rgba(237,117,36,.12) 0%, rgba(10,10,10,0) 60%);
  pointer-events:none;
}
.startbuild > *{ position:relative; }
.startbuild__grid{
  max-width:1280px; margin:0 auto;
  display:grid; grid-template-columns:1fr 1.4fr;
  gap:80px; align-items:start;
}
.startbuild__title{
  font-family:var(--f-display); font-weight:400;
  font-size:clamp(40px,5vw,76px); line-height:.94;
  letter-spacing:-.005em; text-transform:uppercase;
  margin:16px 0 22px; color:var(--bone);
}
.startbuild__title em{ font-style:normal; color:var(--copper); }
.startbuild__lede{ font-size:16px; line-height:1.65; color:var(--bone-dim); max-width:420px; }
.startbuild__lede b{ color:var(--bone); font-weight:600; }
.form{
  display:grid; grid-template-columns:1fr 1fr;
  gap:18px;
  background:rgba(10,9,8,.55);
  border:1px solid var(--rule-strong);
  padding:36px;
  backdrop-filter:blur(4px);
}
.field{ display:flex; flex-direction:column; gap:6px; }
.field--full{ grid-column:1/-1; }
.field label{
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone-mute);
}
.field input, .field select, .field textarea{
  background:transparent;
  border:0; border-bottom:1px solid var(--rule-strong);
  color:var(--bone); font-family:var(--f-body);
  font-size:15px; padding:10px 0;
  transition:border-color .25s ease;
}
.field input:focus, .field select:focus, .field textarea:focus{
  outline:0; border-color:var(--copper);
}
.field textarea{ resize:vertical; min-height:90px; }
.field select{ appearance:none; background-image:linear-gradient(45deg,transparent 50%,var(--copper) 50%),linear-gradient(135deg,var(--copper) 50%,transparent 50%); background-position:calc(100% - 14px) 22px,calc(100% - 8px) 22px; background-size:6px 6px; background-repeat:no-repeat; padding-right:24px; }
.field select option{ background:var(--ink-2); color:var(--bone); }
.form__submit{ grid-column:1/-1; margin-top:8px; }
.form__submit button{
  width:100%;
  padding:20px 24px;
  background:var(--copper); color:var(--ink);
  border:0;
  font-family:var(--f-mono);
  font-size:12px; letter-spacing:.28em; text-transform:uppercase;
  font-weight:600;
  transition:background .25s ease;
}
.form__submit button:hover{ background:var(--copper-hot); }
.form__note{
  grid-column:1/-1;
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.18em; text-transform:uppercase;
  color:var(--bone-mute);
  margin:6px 0 0;
}
@media (max-width:900px){
  .startbuild{ padding:80px 20px; }
  .startbuild__grid{ grid-template-columns:1fr; gap:36px; }
  .form{ grid-template-columns:1fr; padding:24px; }
}

/* =========================================================
   VISIT
   ========================================================= */
.visit{ padding:120px 40px; border-top:1px solid var(--rule); }
.visit__grid{
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:1.1fr 1fr;
  gap:80px;
}
.visit__title{
  font-family:var(--f-display); font-weight:400;
  font-size:clamp(40px,5vw,76px); line-height:.94;
  letter-spacing:-.005em; text-transform:uppercase;
  margin:16px 0 30px; color:var(--bone);
}
.visit__title em{ font-style:normal; color:var(--copper); }
.visit-list{
  display:grid; gap:0;
  border-top:1px solid var(--rule);
}
.vrow{
  display:grid; grid-template-columns:160px 1fr;
  gap:24px;
  padding:22px 0;
  border-bottom:1px solid var(--rule);
  align-items:start;
}
.vrow__lbl{
  font-family:var(--f-mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper);
}
.vrow__val{
  font-size:16px; color:var(--bone);
  font-family:var(--f-body);
}
.vrow__val a:hover{ color:var(--copper); }
.vrow__val b{ display:block; font-family:var(--f-display); font-size:22px; text-transform:uppercase; letter-spacing:.02em; font-weight:400; margin-bottom:4px; }

.map{
  width:100%; height:480px;
  background:linear-gradient(135deg,#1E1A16 0%, #0A0908 100%);
  border:1px solid var(--rule);
}
.map iframe{ width:100%; height:100%; border:0; filter:grayscale(.8) invert(.92) contrast(.92); }

.ig-strip{
  margin-top:60px;
  max-width:1440px;
  margin-left:auto; margin-right:auto;
  padding:0 40px;
}
.ig-head{
  display:flex; justify-content:space-between; align-items:end;
  margin-bottom:20px;
  padding-bottom:20px;
  border-bottom:1px solid var(--rule);
}
.ig-head h3{
  font-family:var(--f-display); font-weight:400;
  font-size:28px; text-transform:uppercase; letter-spacing:.02em;
  margin:0; color:var(--bone);
}
.ig-head a{
  font-family:var(--f-mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper);
}
.ig-grid{
  display:grid; grid-template-columns:repeat(9,1fr);
  gap:8px;
}
.ig-grid a{
  aspect-ratio:1/1;
  background:linear-gradient(135deg,#1E1A16,#0A0908);
  overflow:hidden;
  position:relative;
}
.ig-grid img{ width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.ig-grid a:hover img{ transform:scale(1.06); }
@media (max-width:900px){
  .visit{ padding:80px 20px; }
  .visit__grid{ grid-template-columns:1fr; gap:40px; }
  .map{ height:320px; }
  .ig-grid{ grid-template-columns:repeat(3,1fr); }
  .ig-strip{ padding:0 20px; }
}

/* =========================================================
   FOOTER
   ========================================================= */
.foot{
  background:var(--ink);
  border-top:1px solid var(--rule);
  padding:80px 40px 30px;
}
.foot__grid{
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:2fr 1fr 1fr 1fr;
  gap:60px;
  padding-bottom:60px;
  border-bottom:1px solid var(--rule);
}
.foot__brand{
  font-family:var(--f-mega);
  font-size:48px; line-height:.9;
  text-transform:uppercase; letter-spacing:.005em;
  color:var(--bone); margin:0 0 14px;
}
.foot__brand em{ font-style:normal; color:var(--copper); }
.foot__tag{ font-size:14px; color:var(--bone-dim); margin:0 0 20px; max-width:340px; }
.foot__col h4{
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.25em; text-transform:uppercase;
  color:var(--copper); margin:0 0 16px;
}
.foot__col ul{ list-style:none; padding:0; margin:0; font-size:14px; line-height:2; }
.foot__col ul a{ color:var(--bone-dim); }
.foot__col ul a:hover{ color:var(--copper); }
.foot__bottom{
  max-width:1440px; margin:0 auto;
  padding-top:24px;
  display:flex; justify-content:space-between; align-items:center;
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone-mute);
  flex-wrap:wrap; gap:12px;
}
.foot__bottom a{ color:var(--bone-dim); }
.foot__bottom a:hover{ color:var(--copper); }
@media (max-width:900px){
  .foot{ padding:60px 20px 24px; }
  .foot__grid{ grid-template-columns:1fr 1fr; gap:30px; }
  .foot__brand{ font-size:36px; }
  .foot__col:first-child{ grid-column:1/-1; }
}

/* =========================================================
   REVEAL — fallback safe
   Items only get hidden once JS has confirmed it'll reveal them.
   If JS fails, content stays visible.
   ========================================================= */
.reveal{ /* default: visible */ }
.reveal--armed{ opacity:0; transform:translateY(28px); }
.reveal--in{
  opacity:1 !important; transform:none !important;
  transition:opacity .9s ease, transform .9s cubic-bezier(.2,.7,.1,1);
}

/* marquee */
.marquee{
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  background:var(--ink);
  overflow:hidden;
  white-space:nowrap;
  padding:22px 0;
}
.marquee__track{
  display:inline-block;
  animation:scroll 38s linear infinite;
}
.marquee__track span{
  font-family:var(--f-display);
  font-size:38px; line-height:1;
  text-transform:uppercase; letter-spacing:.04em;
  color:var(--bone);
  margin:0 28px;
}
.marquee__track .dot{ color:var(--copper); }
.marquee__track em{ font-style:normal; color:var(--copper); }
@keyframes scroll{ from{transform:translateX(0);} to{transform:translateX(-50%);} }
@media (max-width:640px){ .marquee__track span{ font-size:26px; margin:0 18px; } }

/* =========================================================
   PREMIUM PASS v2 — real-brand additions
   ========================================================= */

/* nav: real logo image */
.nav__logo{ height:40px; width:auto; display:block; filter:drop-shadow(0 2px 8px rgba(0,0,0,.5)); }
@media (max-width:900px){ .nav__logo{ height:32px; } }

/* checkered shop-floor motif (nod to their real red/white diamond floor) */
.checker{
  background-image:
    linear-gradient(45deg, var(--check-a) 25%, transparent 25%),
    linear-gradient(-45deg, var(--check-a) 25%, transparent 25%),
    linear-gradient(45deg, transparent 75%, var(--check-a) 75%),
    linear-gradient(-45deg, transparent 75%, var(--check-a) 75%);
  background-size:28px 28px;
  background-position:0 0,0 14px,14px -14px,-14px 0;
  background-color:var(--check-b);
}

/* ---------- SPLIT HERO with real photo ---------- */
.hero__grid{
  position:relative;
  width:100%;
  display:grid; grid-template-columns:1.25fr .9fr;
  gap:48px; align-items:end;
  padding:150px 40px 64px;
}
.hero__left{ min-width:0; }
.hero__right{ position:relative; align-self:stretch; display:flex; align-items:flex-end; }
.hero__frame{
  position:relative; width:100%;
  aspect-ratio:363/484;
  max-height:74vh;
  border:1px solid var(--rule-strong);
  overflow:hidden;
  background:var(--ink-2);
  box-shadow:var(--shadow);
}
.hero__frame img{ width:100%; height:100%; object-fit:cover; }
.hero__frame::after{
  content:""; position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(10,10,10,0) 55%, rgba(10,10,10,.55) 100%);
}
.hero__frame-tag{
  position:absolute; left:0; bottom:0; z-index:2;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.22em; text-transform:uppercase;
  color:var(--ink); background:var(--orange);
  padding:8px 14px;
}
.hero__est{
  position:absolute; top:-1px; right:-1px; z-index:2;
  font-family:var(--f-mono); font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--bone); background:rgba(10,10,10,.7); border:1px solid var(--rule-strong);
  padding:8px 12px;
}
@media (max-width:980px){
  .hero__grid{ grid-template-columns:1fr; gap:32px; padding:120px 20px 44px; }
  .hero__right{ order:-1; }
  .hero__frame{ aspect-ratio:16/11; max-height:42vh; }
}

/* ---------- PUBLICATIONS bar ---------- */
.pubs{
  background:var(--ink); border-bottom:1px solid var(--rule);
  padding:30px 40px;
}
.pubs__inner{
  max-width:1440px; margin:0 auto;
  display:flex; align-items:center; gap:40px; flex-wrap:wrap;
  justify-content:space-between;
}
.pubs__label{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--bone-mute); white-space:nowrap;
}
.pubs__logos{ display:flex; align-items:center; gap:38px; flex-wrap:wrap; }
.pubs__logos img{
  height:26px; width:auto;
  filter:brightness(0) invert(1) opacity(.62);
  transition:filter .3s ease;
}
.pubs__logos img:hover{ filter:brightness(0) invert(1) opacity(1); }
@media (max-width:640px){
  .pubs{ padding:24px 20px; }
  .pubs__logos{ gap:24px; }
  .pubs__logos img{ height:20px; }
}

/* ---------- count-up tabular ---------- */
.stat__num[data-count]{ font-variant-numeric:tabular-nums; }

/* ---------- magnetic CTA wrapper ---------- */
.mag{ display:inline-block; will-change:transform; }

/* ---------- image mask reveal ---------- */
.mask{ position:relative; overflow:hidden; }
.mask::after{
  content:""; position:absolute; inset:0; background:var(--orange);
  transform:scaleX(1); transform-origin:right;
  transition:transform .9s cubic-bezier(.7,0,.2,1);
  z-index:3;
}
.mask--in::after{ transform:scaleX(0); }
.mask img{ transform:scale(1.12); transition:transform 1.2s cubic-bezier(.2,.7,.1,1); }
.mask--in img{ transform:scale(1); }

/* ---------- build card: real photo aspect (portrait native) ---------- */
.build-card__media{ aspect-ratio:363/484; }
.build-card--lg .build-card__media{ aspect-ratio:363/420; }
.build-card--feature .build-card__media{ aspect-ratio:16/8; }
.build-card--feature .build-card__media img{ object-position:center 38%; }
@media (max-width:640px){
  .build-card__media,
  .build-card--lg .build-card__media,
  .build-card--feature .build-card__media{ aspect-ratio:363/430; }
}

/* ---------- Meet Johnny real photo tweak ---------- */
.johnny__media{ aspect-ratio:363/484; }
.johnny__media img{ object-position:center 30%; }

/* ---------- section divider: orange tick rule ---------- */
.tickrule{
  max-width:1440px; margin:0 auto; padding:0 40px;
  display:flex; align-items:center; gap:14px;
}
.tickrule span{ height:1px; flex:1; background:var(--rule); }
.tickrule b{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.24em; text-transform:uppercase;
  color:var(--orange); font-weight:500;
}
@media (max-width:640px){ .tickrule{ padding:0 20px; } }

/* ---------- readability hardening ---------- */
.hero__tag, .sec-head__lede, .johnny p, .step__body, .svc__body,
.press-tile__body, .startbuild__lede, .vrow__val, .build-card__meta{
  color:var(--bone-dim);
}
.hero__tag{ color:var(--bone); }

/* selection */
::selection{ background:var(--orange); color:var(--ink); }

/* focus-visible for a11y */
a:focus-visible, button:focus-visible, input:focus-visible,
select:focus-visible, textarea:focus-visible{
  outline:2px solid var(--orange); outline-offset:3px;
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important;
     transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal--armed{ opacity:1 !important; transform:none !important; }
  .mask::after{ transform:scaleX(0) !important; }
  .mask img{ transform:scale(1) !important; }
}
