/* =========================================================
   IRON MIKE'S MOTORCYCLE SHOP — design system
   Jet black asphalt + chrome silver + blood-red Gulf Coast accent
   ========================================================= */

:root{
  --ink:        #060606;
  --ink-2:      #0E0E0E;
  --ink-3:      #161616;
  --steel:      #4A4A4A;
  --steel-2:    #6B6B6B;
  --bone:       #E8E6E2;
  --bone-dim:   #B8B5B0;
  --bone-mute:  #7A7773;
  --copper:     #C5121C;
  --copper-hot: #E11C28;
  --copper-deep:#7A0A12;
  --rule:       rgba(232,230,226,0.10);
  --rule-strong:rgba(232,230,226,0.22);
  --shadow:     0 30px 80px -20px rgba(0,0,0,.90);

  --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:
    linear-gradient(180deg, rgba(10,9,8,.30) 0%, rgba(10,9,8,.58) 55%, rgba(10,9,8,.96) 100%),
    url('../img/hero-candy.jpg') center 38%/cover no-repeat,
    var(--ink-2);
  filter:saturate(.95) contrast(1.06);
}
.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:'MIKE PETERSON · BACLIFF TX';
  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{
  background:
    linear-gradient(180deg, rgba(10,9,8,.88) 0%, rgba(10,9,8,.96) 100%),
    url('../img/bike-0127.jpg') center/cover no-repeat fixed,
    var(--ink-2);
  border-top:1px solid var(--rule);
  padding:120px 40px;
}
.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; } }

/* =========================================================
   IRON MIKE'S — chrome + asphalt accents
   ========================================================= */
/* chrome-shine treatment on the IM brand monogram */
.nav__brand .mark{
  background:linear-gradient(180deg, #F4F4F4 0%, #C8C8C8 45%, #6E6E6E 55%, #9E9E9E 100%);
  -webkit-background-clip:text;
          background-clip:text;
  color:transparent;
  border:1.5px solid #C5121C;
  border-radius:0;
  font-weight:700;
  transform:rotate(0deg);
  box-shadow:inset 0 0 0 1px rgba(255,255,255,.04), 0 0 0 1px rgba(0,0,0,.4);
}
/* shop bar — small red ribbon under hero meta */
.hero__meta{ position:relative; }
.hero__meta::before{
  content:''; position:absolute; left:0; bottom:-14px;
  width:60px; height:2px; background:var(--copper);
}
/* riveted edge accent on stat blocks */
.stat{ position:relative; }
.stat::before{
  content:'●'; position:absolute; top:0; left:-2px;
  font-size:9px; color:var(--copper); opacity:.6;
}
.stat:first-child::before{ display:none; }
/* dyno-meter style red line under hero title (signature accent) */
.hero__title::after{
  content:''; display:block; width:120px; height:4px;
  background:linear-gradient(90deg, #C5121C 0%, #C5121C 70%, transparent 100%);
  margin-top:24px;
}
/* services icons – red badge feel */
.svc__icon{
  display:inline-block;
  padding:6px 10px;
  border:1px solid var(--copper);
  background:rgba(197,18,28,.06);
}
/* press tiles — red corner */
.press-tile{ position:relative; }
.press-tile::before{
  content:''; position:absolute; top:0; left:0;
  width:18px; height:18px;
  border-top:2px solid var(--copper);
  border-left:2px solid var(--copper);
}
.press-tile::after{
  content:''; position:absolute; bottom:0; right:0;
  width:18px; height:18px;
  border-bottom:2px solid var(--copper);
  border-right:2px solid var(--copper);
}
/* dyno-pull section — additional component for Iron Mike */
.dyno{
  background:
    linear-gradient(180deg, rgba(6,6,6,.85) 0%, rgba(6,6,6,.98) 100%),
    repeating-linear-gradient(90deg, rgba(197,18,28,.05) 0 1px, transparent 1px 80px),
    var(--ink-2);
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  padding:90px 40px;
}
.dyno__grid{
  max-width:1440px; margin:0 auto;
  display:grid; grid-template-columns:1.1fr 1fr; gap:60px;
  align-items:center;
}
.dyno__title{
  font-family:var(--f-display); font-weight:400;
  font-size:clamp(36px,4.6vw,68px); line-height:.94;
  text-transform:uppercase; letter-spacing:-.005em;
  margin:14px 0 22px;
  color:var(--bone);
}
.dyno__title em{ font-style:normal; color:var(--copper); }
.dyno__body{ font-size:16px; line-height:1.65; color:var(--bone-dim); margin:0 0 18px; max-width:520px; }
.dyno__body b{ color:var(--bone); font-weight:600; }
.dyno__creds{
  display:flex; gap:10px; flex-wrap:wrap;
  margin-top:24px;
}
.dyno__creds span{
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper);
  padding:8px 12px;
  border:1px solid var(--copper);
  background:rgba(197,18,28,.06);
}
.dyno__chart{
  position:relative;
  aspect-ratio:5/4;
  background:radial-gradient(ellipse at center, rgba(197,18,28,.10) 0%, transparent 60%), var(--ink);
  border:1px solid var(--rule-strong);
  overflow:hidden;
}
.dyno__chart svg{ width:100%; height:100%; display:block; }
@media (max-width:900px){
  .dyno{ padding:60px 20px; }
  .dyno__grid{ grid-template-columns:1fr; gap:36px; }
}

/* =========================================================
   REAL LOGO in nav + footer
   ========================================================= */
.nav__logo{ height:30px; width:auto; display:block; }
@media (max-width:900px){ .nav__logo{ height:26px; } }
.foot__logo{ height:54px; width:auto; display:block; margin-bottom:18px; }

/* =========================================================
   STOREFRONT BAND — real shop exterior
   ========================================================= */
.storefront{
  position:relative;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
  background:var(--ink);
}
.storefront__media{
  position:relative;
  width:100%;
  aspect-ratio:24/9;
  overflow:hidden;
  background:linear-gradient(135deg,#1E1A16,#0A0908);
}
.storefront__media img{
  width:100%; height:100%; object-fit:cover;
  filter:contrast(1.05) saturate(1.05);
}
.storefront__media::after{
  content:''; position:absolute; inset:0;
  background:linear-gradient(90deg, rgba(6,6,6,.78) 0%, rgba(6,6,6,.25) 45%, rgba(6,6,6,.05) 100%);
}
.storefront__cap{
  position:absolute; z-index:2; left:40px; bottom:36px; right:40px;
  display:flex; justify-content:space-between; align-items:flex-end; gap:30px;
  flex-wrap:wrap;
}
.storefront__cap h3{
  font-family:var(--f-mega);
  font-size:clamp(30px,5vw,64px); line-height:.92;
  text-transform:uppercase; letter-spacing:.01em;
  color:var(--bone); margin:0; max-width:680px;
}
.storefront__cap h3 em{ font-style:normal; color:var(--copper); }
.storefront__cap p{
  font-family:var(--f-mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone-dim); margin:0;
}
@media (max-width:768px){
  .storefront__media{ aspect-ratio:4/3; }
  .storefront__cap{ left:20px; right:20px; bottom:22px; }
}

/* =========================================================
   THE CREW — real staff roster
   ========================================================= */
.crew{ padding:0 40px 110px; max-width:1440px; margin:0 auto; }
.crew__grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:30px;
}
.crew-card{
  border:1px solid var(--rule);
  background:var(--ink-2);
  overflow:hidden;
  transition:border-color .3s ease, transform .3s ease;
}
.crew-card:hover{ border-color:var(--copper); transform:translateY(-3px); }
.crew-card__media{
  position:relative; aspect-ratio:4/5; overflow:hidden;
  background:linear-gradient(135deg,#1E1A16,#0A0908);
}
.crew-card__media img{
  width:100%; height:100%; object-fit:cover;
  filter:grayscale(.45) contrast(1.06);
  transition:filter .5s ease, transform .8s ease;
}
.crew-card:hover .crew-card__media img{ filter:grayscale(0) contrast(1.05); transform:scale(1.03); }
.crew-card__role{
  position:absolute; top:16px; left:16px;
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--copper); background:rgba(10,9,8,.82);
  padding:6px 10px; border:1px solid var(--copper);
}
.crew-card__body{ padding:24px 22px 28px; border-top:1px solid var(--rule); }
.crew-card__name{
  font-family:var(--f-display); font-weight:400;
  font-size:26px; line-height:1; text-transform:uppercase;
  letter-spacing:.01em; margin:0 0 6px; color:var(--bone);
}
.crew-card__name em{ font-style:normal; color:var(--copper); }
.crew-card__body p{ font-size:14px; line-height:1.6; color:var(--bone-dim); margin:0 0 14px; }
.crew-card__certs{
  list-style:none; padding:14px 0 0; margin:0;
  border-top:1px dashed var(--rule);
  font-family:var(--f-mono); font-size:10px;
  letter-spacing:.16em; text-transform:uppercase; color:var(--bone-mute);
}
.crew-card__certs li{ padding:5px 0; }
.crew-card__certs li::before{ content:'— '; color:var(--copper); }
@media (max-width:900px){ .crew{ padding:0 20px 70px; } .crew__grid{ grid-template-columns:1fr; gap:18px; } }

/* =========================================================
   SERVICE MENU — real prices
   ========================================================= */
.menu{
  background:var(--ink-2);
  border-top:1px solid var(--rule); border-bottom:1px solid var(--rule);
  padding:0 0 100px;
}
.menu__grid{
  max-width:1280px; margin:0 auto; padding:0 40px;
  display:grid; grid-template-columns:1fr 1fr; gap:0 70px;
}
.menu-row{
  display:grid; grid-template-columns:1fr auto;
  gap:20px; align-items:baseline;
  padding:22px 0;
  border-bottom:1px solid var(--rule);
}
.menu-row__name{
  font-family:var(--f-display); font-weight:400;
  font-size:21px; text-transform:uppercase; letter-spacing:.01em;
  color:var(--bone); margin:0;
}
.menu-row__desc{
  display:block; margin-top:6px;
  font-family:var(--f-body); font-size:13px; line-height:1.5;
  letter-spacing:0; text-transform:none;
  color:var(--bone-dim);
}
.menu-row__price{
  font-family:var(--f-mega); font-size:34px; line-height:1;
  color:var(--copper); white-space:nowrap;
}
.menu-row__price small{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.18em;
  color:var(--bone-mute); display:block; text-align:right; margin-top:4px;
}
.menu__note{
  grid-column:1/-1; margin:34px 0 0;
  font-family:var(--f-mono); font-size:11px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--bone-mute);
  display:flex; align-items:center; gap:10px;
}
.menu__note b{ color:var(--copper); font-weight:500; }
@media (max-width:768px){
  .menu__grid{ grid-template-columns:1fr; padding:0 20px; }
}

/* =========================================================
   TESTIMONIALS — real review themes
   ========================================================= */
.reviews{ padding:110px 40px; max-width:1440px; margin:0 auto; }
.reviews__head{
  display:flex; justify-content:space-between; align-items:flex-end;
  gap:30px; flex-wrap:wrap;
  border-bottom:1px solid var(--rule); padding-bottom:30px; margin-bottom:44px;
}
.reviews__score{
  font-family:var(--f-mega); font-size:64px; line-height:.9; color:var(--bone); margin:0;
}
.reviews__score em{ font-style:normal; color:var(--copper); font-size:.42em; vertical-align:.5em; }
.reviews__stars{ color:var(--copper); font-size:20px; letter-spacing:3px; margin:8px 0 0; }
.reviews__src{
  font-family:var(--f-mono); font-size:11px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--bone-mute); text-align:right;
}
.reviews__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:30px; }
.quote{
  border:1px solid var(--rule); background:var(--ink-2);
  padding:34px 28px 28px; position:relative;
  transition:border-color .3s ease;
}
.quote:hover{ border-color:var(--copper); }
.quote::before{
  content:'\201C'; position:absolute; top:6px; left:18px;
  font-family:var(--f-mega); font-size:80px; line-height:1;
  color:var(--copper); opacity:.22;
}
.quote__stars{ color:var(--copper); font-size:13px; letter-spacing:2px; margin:0 0 14px; }
.quote__text{ font-size:15.5px; line-height:1.65; color:var(--bone); margin:0 0 18px; position:relative; }
.quote__by{
  font-family:var(--f-mono); font-size:10px; letter-spacing:.2em;
  text-transform:uppercase; color:var(--bone-mute);
  padding-top:14px; border-top:1px dashed var(--rule);
}
.quote__by b{ color:var(--copper); font-weight:500; }
@media (max-width:900px){
  .reviews{ padding:70px 20px; }
  .reviews__grid{ grid-template-columns:1fr; gap:18px; }
}

/* sticky bottom call-bar for mobile */
.callbar{
  position:fixed; left:0; right:0; bottom:0;
  z-index:60;
  display:none;
  grid-template-columns:1fr 1fr;
  background:rgba(6,6,6,.96);
  border-top:1px solid var(--copper);
  backdrop-filter:blur(6px);
}
.callbar a{
  padding:14px;
  text-align:center;
  font-family:var(--f-mono); font-size:11px;
  letter-spacing:.22em; text-transform:uppercase;
  color:var(--bone);
}
.callbar a + a{ border-left:1px solid var(--rule); color:var(--copper); }
@media (max-width:768px){
  .callbar{ display:grid; }
  body{ padding-bottom:50px; }
}
