/* ============================================
   THE PIT STOP by PIT SPEED — Investor Demo
   Bright build + bold motion
============================================ */

:root {
  --black: #0d0d0d;
  --dark: #141414;
  --panel: #1a1a1a;
  --red: #E10600;
  --red-bright: #FF1A1A;
  --red-dark: #B00000;
  --white: #FFFFFF;
  --off: #F4F5F7;
  --silver: #C8C8C8;
  --ink: #16181D;
  --slate: #4A4F5A;
  --gold: #D4AF37;
  --gray: #8A8F99;
  --font-display: 'Barlow Condensed', sans-serif;
  --font-head: 'Oswald', sans-serif;
  --font-body: 'Barlow', sans-serif;
}

* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--font-body); background: var(--off); color: var(--ink); overflow-x: hidden; line-height: 1.6; }
a { text-decoration: none; color: inherit; }
.container { max-width: 1200px; margin: 0 auto; padding: 0 24px; }
.red { color: var(--red); }
.section { padding: 100px 0; position: relative; }

/* REVEAL */
.reveal { opacity: 0; transform: translateY(46px); transition: opacity .7s cubic-bezier(.2,.7,.2,1), transform .7s cubic-bezier(.2,.7,.2,1); transition-delay: var(--d, 0s); }
.reveal.visible { opacity: 1; transform: translateY(0); }

/* DEMO BANNER */
.demo-banner { background: var(--red); color: #fff; text-align: center; padding: 8px 20px; font-weight: 600; font-size: 13px; letter-spacing: 1px; position: relative; z-index: 100; }

/* NAVBAR */
.navbar { position: sticky; top: 0; z-index: 999; background: rgba(13,13,13,.97); border-bottom: 2px solid var(--red); backdrop-filter: blur(12px); transition: box-shadow .3s; }
.nav-inner { max-width: 1200px; margin: 0 auto; padding: 0 24px; display: flex; align-items: center; justify-content: space-between; height: 72px; }
.nav-brand { display: flex; flex-direction: column; line-height: 1; }
.brand-pit { font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: 24px; color: #fff; letter-spacing: 1px; }
.brand-by { font-family: var(--font-head); font-weight: 500; font-size: 11px; color: var(--red); letter-spacing: 3px; text-transform: uppercase; }
.nav-links { display: flex; list-style: none; align-items: center; gap: 30px; }
.nav-links a { font-family: var(--font-head); font-weight: 500; font-size: 14px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--silver); transition: color .2s; }
.nav-links a:hover { color: var(--red); }
.nav-cta { background: var(--red) !important; color: #fff !important; padding: 9px 20px !important; border-radius: 3px; font-weight: 600 !important; }
.nav-cta:hover { background: var(--red-dark) !important; }
.hamburger { display: none; background: none; border: 1px solid var(--red); color: #fff; font-size: 20px; padding: 6px 12px; cursor: pointer; border-radius: 3px; }
.mobile-menu { display: none; flex-direction: column; background: var(--black); border-top: 1px solid var(--red); }
.mobile-menu a { padding: 15px 24px; font-family: var(--font-head); font-weight: 500; font-size: 15px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--silver); border-bottom: 1px solid #222; }
.mobile-menu a:hover { color: var(--red); background: #161616; }
.mob-cta { background: var(--red) !important; color: #fff !important; }
.mobile-menu.open { display: flex; }

/* ===== HERO (bright) ===== */
.hero { position: relative; min-height: 100vh; display: flex; align-items: center; overflow: hidden; background: #bcd; }
.hero-bg { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.hero-img { width: 100%; height: 100%; object-fit: cover; object-position: center; transform: scale(1.05); animation: heroZoom 12s ease-out forwards; }
@keyframes heroZoom { to { transform: scale(1); } }
/* Light scrim — keeps it BRIGHT, just enough for text legibility bottom-left */
.hero-scrim { position: absolute; inset: 0; background:
   linear-gradient(180deg, rgba(0,0,0,.28) 0%, rgba(0,0,0,0) 26%),
   linear-gradient(75deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.18) 42%, rgba(0,0,0,0) 70%); }

/* Animated speed lines */
.speed-lines { position: absolute; inset: 0; z-index: 1; pointer-events: none; overflow: hidden; }
.speed-lines span { position: absolute; left: -40%; height: 3px; width: 40%; background: linear-gradient(90deg, transparent, var(--red), transparent); opacity: 0; animation: streak 4.5s linear infinite; }
.speed-lines span:nth-child(1){ top: 22%; animation-delay: .2s; }
.speed-lines span:nth-child(2){ top: 44%; width: 55%; animation-delay: 1.4s; }
.speed-lines span:nth-child(3){ top: 67%; width: 30%; animation-delay: 2.6s; }
.speed-lines span:nth-child(4){ top: 82%; width: 48%; animation-delay: 3.4s; }
@keyframes streak { 0%{ left:-40%; opacity:0;} 10%{opacity:.9;} 60%{opacity:.6;} 100%{ left:120%; opacity:0;} }

.hero-content { position: relative; z-index: 2; max-width: 720px; padding: 60px 40px; }
.hero-badge { display: inline-block; background: var(--red); color: #fff; font-family: var(--font-head); font-weight: 500; font-size: 12px; letter-spacing: 2px; text-transform: uppercase; padding: 7px 16px; margin-bottom: 22px; clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 100%, 8px 100%); box-shadow: 0 6px 20px rgba(225,6,0,.4); }
.hero-title { position: relative; display: inline-block; }
.hero-title .line { display: block; font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: clamp(60px, 10vw, 122px); line-height: .9; color: #fff; text-transform: uppercase; letter-spacing: -2px; text-shadow: 4px 5px 0 rgba(0,0,0,.45); }
.hero-byline { font-family: var(--font-head); font-weight: 600; font-size: clamp(20px,3vw,32px); color: var(--red); letter-spacing: 6px; text-transform: uppercase; margin: 2px 0 18px; text-shadow: 2px 2px 0 rgba(0,0,0,.4); }
.hero-tagline { font-size: clamp(16px,2vw,21px); color: #fff; max-width: 560px; margin-bottom: 34px; font-weight: 500; text-shadow: 1px 1px 6px rgba(0,0,0,.6); }
.hero-btns { display: flex; gap: 16px; flex-wrap: wrap; }

/* entrance anims */
.anim-pop { opacity: 0; transform: scale(.85); animation: pop .6s cubic-bezier(.2,1.3,.4,1) .1s forwards; }
@keyframes pop { to { opacity:1; transform: scale(1);} }
.anim-slide { opacity: 0; transform: translateY(28px); animation: slideUp .7s cubic-bezier(.2,.7,.2,1) forwards; animation-delay: var(--d, 0s); }
@keyframes slideUp { to { opacity:1; transform: translateY(0);} }

/* chrome shine sweep over title */
.shine { position: absolute; top: 0; left: -30%; width: 30%; height: 100%; background: linear-gradient(105deg, transparent, rgba(255,255,255,.55), transparent); transform: skewX(-18deg); animation: sweep 4.2s ease-in-out 1.2s infinite; pointer-events: none; }
@keyframes sweep { 0%{ left:-40%; } 45%{ left:130%; } 100%{ left:130%; } }

/* BUTTONS */
.btn-primary { background: var(--red); color: #fff; font-family: var(--font-head); font-weight: 600; font-size: 15px; letter-spacing: 2px; text-transform: uppercase; padding: 15px 34px; clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 100%, 10px 100%); transition: background .2s, transform .2s, box-shadow .2s; display: inline-block; box-shadow: 0 8px 24px rgba(225,6,0,.35); }
.btn-primary:hover { background: var(--red-dark); transform: translateY(-3px); box-shadow: 0 12px 30px rgba(225,6,0,.5); }
.btn-primary.large { font-size: 17px; padding: 18px 44px; }
.btn-outline { border: 2px solid #fff; color: #fff; font-family: var(--font-head); font-weight: 600; font-size: 15px; letter-spacing: 2px; text-transform: uppercase; padding: 13px 32px; transition: all .2s; display: inline-block; }
.btn-outline:hover { background: #fff; color: var(--ink); transform: translateY(-3px); }

.checkered-strip { position: absolute; bottom: 0; left: 0; right: 0; height: 14px; background-image: repeating-conic-gradient(#000 0 25%, #fff 0 50%); background-size: 28px 14px; z-index: 3; }

/* MARQUEE */
.marquee { background: var(--red); overflow: hidden; padding: 12px 0; white-space: nowrap; }
.marquee-track { display: inline-flex; align-items: center; gap: 22px; animation: scroll 26s linear infinite; }
.marquee-track span { font-family: var(--font-head); font-weight: 600; font-size: 15px; letter-spacing: 3px; text-transform: uppercase; color: #fff; }
.marquee-track .dot { color: rgba(255,255,255,.6); font-size: 10px; }
@keyframes scroll { from { transform: translateX(0);} to { transform: translateX(-50%);} }

/* SECTION HEADERS */
.section-header { text-align: center; margin-bottom: 56px; }
.eyebrow { display: inline-block; font-family: var(--font-head); font-weight: 600; font-size: 13px; letter-spacing: 4px; text-transform: uppercase; color: var(--red); margin-bottom: 12px; }
.eyebrow.center { display: block; }
.section-header h2 { font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: clamp(34px,5vw,58px); text-transform: uppercase; letter-spacing: 1px; line-height: 1; color: var(--ink); }
.section-header.light h2 { color: #fff; }
.section-header .sub { font-size: 18px; color: var(--slate); max-width: 660px; margin: 18px auto 0; }
.section-header.light .sub, .section-header .sub.dark { color: var(--gray); }
.checkered-accent { width: 64px; height: 8px; margin: 0 auto 18px; background-image: repeating-conic-gradient(var(--red) 0 25%, var(--ink) 0 50%); background-size: 16px 8px; }
.section-header.light .checkered-accent { background-image: repeating-conic-gradient(var(--red) 0 25%, #fff 0 50%); }

/* VISION (light) */
.vision { background: var(--off); }
.vision-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 60px; align-items: center; }
.vision-text .lead { font-size: 21px; color: var(--ink); font-weight: 600; margin-bottom: 18px; line-height: 1.5; }
.vision-text p { color: var(--slate); margin-bottom: 16px; font-size: 16px; }
.vision-text .signoff { color: var(--red); font-weight: 600; font-size: 18px; font-style: italic; border-left: 3px solid var(--red); padding-left: 18px; }
.vision-pillars { display: flex; flex-direction: column; gap: 18px; }
.pillar { display: flex; gap: 16px; align-items: flex-start; background: #fff; border: 1px solid #e6e8ec; border-left: 3px solid var(--red); padding: 20px; border-radius: 4px; transition: transform .25s, box-shadow .25s; }
.pillar:hover { transform: translateX(6px); box-shadow: 0 10px 30px rgba(0,0,0,.08); }
.pillar-icon { font-size: 28px; }
.pillar h4 { font-family: var(--font-head); font-weight: 600; font-size: 17px; text-transform: uppercase; letter-spacing: 1px; color: var(--ink); margin-bottom: 3px; }
.pillar p { font-size: 14px; color: var(--slate); }

/* LOCATION (dark) */
.location { background: var(--black); }
.loc-hero-img { width: 100%; height: 440px; object-fit: cover; border-radius: 8px; display: block; }
.loc-hero-cap { background: var(--panel); color: var(--silver); font-size: 14px; padding: 14px 18px; border-left: 3px solid var(--red); margin-top: -4px; border-radius: 0 0 6px 6px; }
.location-feature { margin-bottom: 28px; }
.location-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-bottom: 44px; }
.loc-card { background: var(--panel); border-radius: 8px; overflow: hidden; }
.loc-card img { width: 100%; height: 200px; object-fit: cover; display: block; transition: transform .5s; }
.loc-card:hover img { transform: scale(1.06); }
.loc-cap { display: block; font-size: 13px; color: var(--gray); padding: 12px 16px; }
.location-advantages { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; }
.adv { background: var(--panel); border-top: 3px solid var(--red); padding: 28px 18px; text-align: center; border-radius: 0 0 6px 6px; }
.adv-num { display: block; font-family: var(--font-display); font-weight: 900; font-size: 48px; color: var(--red); line-height: 1; margin-bottom: 6px; }
.adv-num.icon { font-size: 38px; }
.adv-suffix { display: block; font-family: var(--font-head); font-size: 13px; letter-spacing: 1px; color: var(--silver); text-transform: uppercase; margin-bottom: 8px; }
.adv-label { font-family: var(--font-head); font-weight: 500; font-size: 13px; letter-spacing: 1px; color: var(--silver); text-transform: uppercase; }

/* CONVERSION / BUILD (light) */
.conversion { background: var(--off); }
.ba-wrap { display: grid; grid-template-columns: 1fr auto 1fr; gap: 24px; align-items: center; margin-bottom: 40px; }
.ba-col { text-align: center; }
.ba-label { display: inline-block; font-family: var(--font-head); font-weight: 600; font-size: 14px; letter-spacing: 3px; text-transform: uppercase; padding: 6px 18px; margin-bottom: 14px; border-radius: 3px; }
.ba-label.before { background: #e6e8ec; color: var(--slate); }
.ba-label.after { background: var(--red); color: #fff; }
.ba-img { border-radius: 8px; overflow: hidden; box-shadow: 0 14px 40px rgba(0,0,0,.15); }
.ba-img img { width: 100%; height: 300px; object-fit: cover; display: block; transition: transform .5s; }
.ba-img:hover img { transform: scale(1.05); }
.ba-cap { font-size: 14px; color: var(--slate); margin-top: 14px; max-width: 420px; margin-left: auto; margin-right: auto; }
.ba-arrow { font-size: 44px; color: var(--red); font-weight: 900; animation: nudge 1.6s ease-in-out infinite; }
@keyframes nudge { 0%,100%{ transform: translateX(0);} 50%{ transform: translateX(8px);} }
.conversion-points { display: grid; grid-template-columns: repeat(4,1fr); gap: 16px; }
.cp { background: #fff; border: 1px solid #e6e8ec; border-radius: 6px; padding: 18px; font-size: 14px; font-weight: 600; color: var(--ink); display: flex; align-items: center; gap: 10px; }
.cp span { color: #fff; background: var(--red); width: 24px; height: 24px; border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 13px; flex-shrink: 0; }

/* FACILITY (dark) */
.facility { background: var(--black); }
.facility-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 22px; }
.fac-card { background: var(--panel); border-top: 3px solid var(--red); padding: 34px 26px; border-radius: 0 0 8px 8px; transition: transform .25s, box-shadow .25s; }
.fac-card:hover { transform: translateY(-8px); box-shadow: 0 18px 44px rgba(225,6,0,.22); }
.fac-icon { font-size: 40px; display: block; margin-bottom: 14px; }
.fac-card h3 { font-family: var(--font-head); font-weight: 600; font-size: 20px; text-transform: uppercase; color: #fff; margin-bottom: 10px; }
.fac-card p { font-size: 15px; color: var(--gray); }

/* REVENUE (light) */
.revenue { background: var(--off); }
.revenue-grid { display: grid; grid-template-columns: repeat(4,1fr); gap: 20px; margin-bottom: 32px; }
.rev-card { background: #fff; border: 1px solid #e6e8ec; padding: 32px 22px; text-align: center; border-radius: 8px; transition: transform .25s, box-shadow .25s; }
.rev-card:hover { transform: translateY(-8px); box-shadow: 0 16px 40px rgba(0,0,0,.12); }
.rev-card.featured { border: 2px solid var(--gold); }
.rev-tag { display: inline-block; background: var(--red); color: #fff; font-family: var(--font-head); font-weight: 600; font-size: 10px; letter-spacing: 1.5px; padding: 4px 12px; text-transform: uppercase; margin-bottom: 16px; }
.rev-tag.gold { background: var(--gold); color: var(--ink); }
.rev-icon { font-size: 38px; display: block; margin-bottom: 14px; }
.rev-card h3 { font-family: var(--font-head); font-weight: 600; font-size: 18px; text-transform: uppercase; color: var(--ink); margin-bottom: 10px; }
.rev-card p { font-size: 14px; color: var(--slate); }
.revenue-note { text-align: center; font-size: 18px; color: var(--slate); font-style: italic; max-width: 700px; margin: 0 auto; }

/* MARKET (dark) */
.market { background: var(--black); }
.market-grid { display: grid; grid-template-columns: repeat(2,1fr); gap: 22px; }
.market-card { background: var(--panel); border-left: 3px solid var(--red); padding: 32px; border-radius: 0 6px 6px 0; transition: transform .25s; }
.market-card:hover { transform: translateX(6px); }
.market-icon { font-size: 36px; display: block; margin-bottom: 14px; }
.market-card h3 { font-family: var(--font-head); font-weight: 600; font-size: 20px; text-transform: uppercase; color: #fff; margin-bottom: 10px; }
.market-card p { font-size: 15px; color: var(--gray); }

/* OPERATOR (light) */
.operator { background: var(--off); }
.operator-inner { display: grid; grid-template-columns: 1fr 1.6fr; gap: 60px; align-items: center; }
.operator-img-col { text-align: center; }
.operator-logo { width: 100%; max-width: 320px; border-radius: 8px; margin-bottom: 18px; box-shadow: 0 14px 40px rgba(0,0,0,.18); }
.vet-badge { display: inline-block; background: linear-gradient(135deg, var(--gold), #9c7a1e); color: var(--ink); font-family: var(--font-head); font-weight: 600; font-size: 14px; letter-spacing: 2px; padding: 11px 22px; text-transform: uppercase; border-radius: 3px; }
.operator-text-col h2 { font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: clamp(32px,4vw,50px); text-transform: uppercase; color: var(--ink); line-height: 1; margin-bottom: 18px; }
.operator-text-col p { color: var(--slate); font-size: 16px; margin-bottom: 16px; }
.operator-proof { margin-top: 22px; display: flex; flex-direction: column; gap: 12px; }
.proof-item { display: flex; align-items: center; gap: 14px; font-size: 16px; color: var(--ink); }
.proof-num { background: var(--red); color: #fff; width: 28px; height: 28px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-weight: 700; flex-shrink: 0; }

/* ASK (dark, punchy) */
.ask { background: var(--black); }
.ask-box { background: linear-gradient(135deg, #1c1c1c, #111); border-top: 4px solid var(--red); padding: 64px 50px; text-align: center; border-radius: 10px; box-shadow: 0 20px 60px rgba(0,0,0,.4); }
.ask-box h2 { font-family: var(--font-display); font-weight: 900; font-style: italic; font-size: clamp(36px,5vw,58px); text-transform: uppercase; color: #fff; margin-bottom: 22px; }
.ask-lead { font-size: 20px; color: #fff; max-width: 770px; margin: 0 auto 16px; font-weight: 500; }
.ask-box > p { color: var(--gray); max-width: 720px; margin: 0 auto 34px; font-size: 16px; }
.ask-points { display: grid; grid-template-columns: repeat(4,1fr); gap: 18px; max-width: 760px; margin: 0 auto 40px; }
.ask-point { background: rgba(255,255,255,.04); border: 1px solid #2a2a2a; padding: 24px 12px; border-radius: 6px; transition: transform .25s, border-color .25s; }
.ask-point:hover { transform: translateY(-5px); border-color: var(--red); }
.ask-point span { font-size: 32px; display: block; margin-bottom: 10px; }
.ask-point h4 { font-family: var(--font-head); font-weight: 600; font-size: 14px; letter-spacing: 1px; text-transform: uppercase; color: var(--silver); }

/* CONTACT (light) */
.contact { background: var(--off); }
.contact-box { display: flex; justify-content: center; gap: 40px; flex-wrap: wrap; background: #fff; border-top: 3px solid var(--red); padding: 40px; border-radius: 8px; box-shadow: 0 12px 40px rgba(0,0,0,.08); }
.contact-item { font-size: 17px; color: var(--ink); font-weight: 600; }
.contact-item a { color: var(--red); }

/* FOOTER */
.footer { background: var(--black); }
.footer-checkered { height: 10px; background-image: repeating-conic-gradient(var(--red) 0 25%, #1a1a1a 0 50%); background-size: 20px 10px; }
.footer-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 24px; padding: 50px 24px 30px; }
.footer-brand .brand-pit { font-size: 26px; display: block; }
.footer-brand .brand-by { font-size: 12px; display: block; margin-bottom: 10px; }
.footer-brand p { color: var(--gray); font-size: 14px; max-width: 360px; }
.footer-note { text-align: right; }
.footer-note p { color: var(--silver); font-size: 14px; margin-bottom: 4px; }
.footer-bottom { border-top: 1px solid #1f1f1f; padding: 20px 24px; display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 10px; max-width: 1200px; margin: 0 auto; }
.footer-bottom p { font-size: 13px; color: #555; }
.credit a { color: var(--red); }

/* RESPONSIVE */
@media (max-width: 1024px) {
  .vision-grid, .operator-inner { grid-template-columns: 1fr; gap: 40px; }
  .facility-grid, .revenue-grid { grid-template-columns: repeat(2,1fr); }
  .location-advantages { grid-template-columns: repeat(2,1fr); }
  .conversion-points { grid-template-columns: repeat(2,1fr); }
  .ask-points { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 768px) {
  .nav-links { display: none; }
  .hamburger { display: block; }
  .section { padding: 70px 0; }
  .location-grid, .market-grid { grid-template-columns: 1fr; }
  .facility-grid, .revenue-grid { grid-template-columns: 1fr; }
  .ba-wrap { grid-template-columns: 1fr; }
  .ba-arrow { transform: rotate(90deg); margin: 0 auto; animation: nudgeV 1.6s ease-in-out infinite; }
  @keyframes nudgeV { 0%,100%{ transform: rotate(90deg) translateX(0);} 50%{ transform: rotate(90deg) translateX(8px);} }
  .footer-inner, .footer-note { text-align: center; }
  .footer-inner { flex-direction: column; }
  .footer-bottom { flex-direction: column; text-align: center; }
  .loc-hero-img { height: 280px; }
}
@media (max-width: 480px) {
  .hero-content { padding: 40px 22px; }
  .location-advantages, .conversion-points, .ask-points { grid-template-columns: 1fr; }
  .contact-box { flex-direction: column; gap: 18px; text-align: center; }
}
