/* ============================================================
   DugoutIQ — landing page
   Night-game navy · amber scoreboard accent · clay infield
   Display: Saira Condensed · Data/labels: IBM Plex Mono · Body: Inter
   ============================================================ */

:root{
  --navy:#0E1838;      /* night sky behind the lights */
  --navy-2:#15224C;
  --panel:#16244F;
  --panel-2:#1B2C5E;
  --line:#2B5AA0;
  --royal:#2E6FC4;
  --amber:#F5C518;     /* the one bold accent — scoreboard bulb / CTA */
  --clay:#C46A2E;      /* infield dirt */
  --grass:#16462a;     /* outfield, used dim */
  --chalk:#F4F8FF;
  --powder:#A9C5E8;
  --muted:#7E93C2;
  --maxw:1140px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0; background:var(--navy); color:var(--chalk);
  font-family:"Inter",system-ui,-apple-system,sans-serif;
  line-height:1.5; -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }

/* ---- shared type ---- */
.eyebrow{
  font-family:"IBM Plex Mono",monospace; font-size:12px; font-weight:600;
  letter-spacing:.28em; text-transform:uppercase; color:var(--muted);
  display:inline-block; margin-bottom:14px;
}
.eyebrow.amber{ color:var(--amber); }
h1,h2,h3{ font-family:"Saira Condensed",sans-serif; font-weight:700; line-height:1.02; margin:0; }
h1{ font-size:clamp(40px,8.5vw,76px); letter-spacing:-.01em; }
h1 em{ font-style:normal; color:var(--amber); }
h2{ font-size:clamp(30px,5.4vw,52px); letter-spacing:-.01em; margin-bottom:18px; }
h2.big{ font-size:clamp(44px,9vw,84px); }
h3{ font-size:22px; font-weight:600; letter-spacing:.01em; }
p{ margin:0 0 16px; }

/* ---- buttons ---- */
.btn{
  display:inline-block; font-family:"Saira Condensed",sans-serif; font-weight:700;
  font-size:19px; letter-spacing:.02em; padding:14px 26px; border-radius:12px;
  border:1.5px solid transparent; cursor:pointer; transition:transform .15s ease, box-shadow .2s ease, background .2s ease;
  white-space:nowrap;
}
.btn:active{ transform:translateY(1px) scale(.99); }
.btn-amber{ background:var(--amber); color:#1a1205; box-shadow:0 10px 30px -8px rgba(245,197,24,.5); }
.btn-amber:hover{ box-shadow:0 14px 38px -8px rgba(245,197,24,.65); transform:translateY(-2px); }
.btn-ghost{ border-color:var(--line); color:var(--chalk); background:rgba(255,255,255,.03); }
.btn-ghost:hover{ border-color:var(--royal); background:rgba(255,255,255,.07); }
.btn-sm{ font-size:16px; padding:9px 16px; border-radius:10px; }
.btn.lg{ font-size:23px; padding:17px 40px; }

/* ---- wordmark ---- */
.wordmark{
  font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:26px;
  letter-spacing:.01em; color:var(--chalk); display:flex; align-items:center;
}
.wordmark span{ color:var(--amber); }
.wordmark.sm{ font-size:22px; }
.brand-mark{ padding:2px 0; }
.wm-logo{ height:42px; width:auto; display:block; }

/* ============================================================ NAV */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:50;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px clamp(16px,4vw,40px);
  background:linear-gradient(180deg, rgba(14,24,56,.92), rgba(14,24,56,0));
  backdrop-filter:blur(6px);
  transition:background .3s ease, border-color .3s ease;
  border-bottom:1px solid transparent;
}
.nav.scrolled{ background:rgba(11,20,48,.9); border-bottom-color:var(--line); }
.nav-links{ display:flex; align-items:center; gap:clamp(14px,3vw,28px); }
.nav-links a:not(.btn){ font-size:15px; color:var(--powder); font-weight:500; }
.nav-links a:not(.btn):hover{ color:var(--chalk); }

/* ============================================================ HERO */
.hero{ position:relative; min-height:100svh; padding:120px clamp(16px,4vw,40px) 60px; overflow:hidden; }

/* stadium lights — soft sweeping glows */
.lights{ position:absolute; inset:0; pointer-events:none; z-index:0; transform:translateY(var(--py,0px)); will-change:transform; }
.lights i{ position:absolute; width:60vw; height:60vw; border-radius:50%; filter:blur(80px); opacity:.5; }
.lights i:nth-child(1){ top:-20vw; left:-10vw; background:radial-gradient(circle, rgba(46,111,196,.5), transparent 60%); animation:drift1 14s ease-in-out infinite; }
.lights i:nth-child(2){ top:-25vw; right:-12vw; background:radial-gradient(circle, rgba(245,197,24,.18), transparent 60%); animation:drift2 18s ease-in-out infinite; }
@keyframes drift1{ 50%{ transform:translate(4vw,3vw) scale(1.1); } }
@keyframes drift2{ 50%{ transform:translate(-4vw,4vw) scale(1.08); } }

/* dugout photo background */
.dugout-bg{
  position:absolute; inset:0; z-index:0; pointer-events:none;
  background:url('dugout-hero.jpg') center center / cover no-repeat;
  animation:fieldin 1.4s cubic-bezier(.2,.7,.2,1) both;
}
/* dark gradient so copy stays readable */
.dugout-bg::after{
  content:''; position:absolute; inset:0;
  background:
    linear-gradient(to right, rgba(9,16,42,.82) 0%, rgba(9,16,42,.55) 50%, rgba(9,16,42,.30) 100%),
    linear-gradient(to top, rgba(9,16,42,.7) 0%, transparent 50%);
}
@keyframes fieldin{ from{ opacity:0; } }

/* hero content sits above the field */
.hero-inner{
  position:relative; z-index:3; max-width:var(--maxw); margin:0 auto;
  display:grid; grid-template-columns:1.1fr .9fr; align-items:center; gap:40px;
  min-height:calc(100svh - 180px);
}
.hero-copy{ max-width:560px; }
/* parallax layer wrappers (move at their own speed; never clobber inner transforms) */
.plx{ transform:translateY(var(--py,0px)); will-change:transform; min-width:0; }
.plx.center{ display:flex; justify-content:center; }
.lede{ font-size:clamp(17px,2.4vw,20px); color:var(--powder); max-width:46ch; margin:20px 0 28px; }
.hero-cta{ display:flex; gap:14px; flex-wrap:wrap; margin-bottom:16px; }
.microcopy{ font-family:"IBM Plex Mono",monospace; font-size:12.5px; letter-spacing:.04em; color:var(--muted); margin:0; }

/* phone */
.hero-phone{ position:relative; justify-self:center; }
.device{
  position:relative; width:clamp(240px,30vw,310px); aspect-ratio:1045/1505;
  background:#05080f; border-radius:34px; padding:9px;
  border:1px solid #2a3a64;
  box-shadow:0 40px 80px -20px rgba(0,0,0,.75), 0 0 0 1px rgba(255,255,255,.04) inset;
  transform:rotateY(-6deg) rotateX(2deg);
  transform-style:preserve-3d;
}
.device img, .device video{ width:100%; height:100%; object-fit:cover; border-radius:26px; display:block; }
.device-notch{ display:none; }
[data-float]{ animation:floaty 6s ease-in-out infinite; }
@keyframes floaty{ 50%{ transform:translateY(-14px); } }
.phone-glow{ position:absolute; inset:-10% -10% -20%; z-index:-1; background:radial-gradient(ellipse at 50% 60%, rgba(46,111,196,.45), transparent 65%); filter:blur(30px); }

.scroll-hint{ position:absolute; bottom:18px; left:50%; transform:translateX(-50%); z-index:4; color:var(--muted); font-size:22px; animation:bob 1.8s ease-in-out infinite; }
@keyframes bob{ 50%{ transform:translate(-50%,6px); } }

/* ============================================================ BANDS */
.band{ position:relative; padding:clamp(70px,11vw,120px) clamp(16px,4vw,40px); }
.wrap{ max-width:var(--maxw); margin:0 auto; }
.wrap.center{ text-align:center; }
.problem{ background:linear-gradient(180deg, var(--navy), #0b1430); }
.solution{ background:#0b1430; }
.features{ background:linear-gradient(180deg, #0b1430, var(--navy)); }
.demo{ background:var(--navy); }

/* cards */
.cards{ display:grid; gap:20px; margin-top:36px; }
.cards.three{ grid-template-columns:repeat(3,1fr); }
.card{
  background:var(--panel); border:1px solid var(--line); border-radius:16px; padding:26px 24px;
}
.card-ico{ font-size:30px; display:block; margin-bottom:14px; }
.card h3{ margin-bottom:8px; }
.card p{ color:var(--powder); font-size:15px; margin:0; }

/* solution split */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:50px; align-items:center; }
.split-text p{ color:var(--powder); font-size:17px; max-width:46ch; }
.check-list{ list-style:none; padding:0; margin:22px 0 0; }
.check-list li{ position:relative; padding-left:30px; margin-bottom:12px; color:var(--chalk); font-size:16px; }
.check-list li::before{ content:"✓"; position:absolute; left:0; top:-1px; width:20px; height:20px; background:rgba(245,197,24,.15); color:var(--amber); border-radius:6px; display:grid; place-items:center; font-size:13px; font-weight:700; }
.split-phone{ display:flex; justify-content:center; transform:translateY(var(--py,0px)); will-change:transform; }
.device.sm{ width:clamp(220px,26vw,270px); transform:rotateY(6deg) rotateX(2deg); }

/* features grid */
.feat-grid{ grid-template-columns:repeat(3,1fr); margin-top:40px; }
.feat{
  background:linear-gradient(165deg, var(--panel-2), var(--panel)); border:1px solid var(--line);
  border-radius:16px; padding:26px 24px; transition:transform .2s ease, border-color .2s ease, box-shadow .2s ease;
  transform-style:preserve-3d; will-change:transform;
}
.feat:hover{ border-color:var(--royal); box-shadow:0 24px 50px -24px rgba(46,111,196,.6); }
.feat-tag{
  font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.2em; text-transform:uppercase;
  color:var(--amber); display:inline-block; margin-bottom:14px;
}
.feat h3{ margin-bottom:8px; }
.feat p{ color:var(--powder); font-size:15px; margin:0; }

/* demo */
.demo-frame{ display:flex; justify-content:center; margin-top:40px; transform:translateY(var(--py,0px)); will-change:transform; }
.device.lg{ width:clamp(260px,40vw,340px); transform:none; }
.device.lg video{ background:#05080f; }
.demo-note{ text-align:center; color:var(--muted); font-size:14px; margin-top:22px; font-family:"IBM Plex Mono",monospace; letter-spacing:.03em; }
.app-embed{ display:flex; justify-content:center; margin-top:42px; }
.device.xl{ width:min(366px,92vw); aspect-ratio:360/660; padding:10px; transform:none; }
.device.xl .device-notch{ display:none; }
.device.xl iframe{ width:100%; height:100%; border:0; border-radius:25px; background:var(--navy); display:block; }
.demo-open{ color:var(--amber); border-bottom:1px solid rgba(245,197,24,.4); padding-bottom:2px; }
.demo-open:hover{ border-color:var(--amber); }
.demo-lede{ text-align:center; color:var(--powder); font-size:17px; max-width:48ch; margin:14px auto 0; }

/* ---- interactive mini-scorer — styled to match the DugoutIQ app ---- */
.mini{
  --aNavy:#14204A; --aPanel:#1D2D5C; --aPanel2:#243A72; --aLine:#2B5AA0;
  --aRoyal:#134A8E; --aPowder:#A9C5E8; --aAmber:#F5C518; --aRed:#E8291C; --aChalk:#F4F8FF;
  max-width:374px; margin:38px auto 0;
  background:linear-gradient(180deg, var(--aPanel), var(--aNavy));
  border:1px solid var(--aLine); border-radius:22px; padding:14px 14px 16px;
  box-shadow:0 40px 80px -30px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.05);
}
.mini-brand{ display:flex; align-items:center; justify-content:center; position:relative; margin-bottom:10px; }
.mb-word{ font-family:"Saira Condensed",sans-serif; font-weight:800; font-size:22px; color:var(--aChalk); }
.mb-word b{ color:var(--aAmber); font-weight:800; }
.mb-gear{ position:absolute; right:2px; top:50%; transform:translateY(-50%); font-size:17px; color:var(--aPowder); opacity:.85; }
.mini-board{
  display:flex; align-items:center; justify-content:space-between;
  background:var(--aNavy); border:1px solid var(--aLine); border-radius:12px;
  padding:9px 14px; margin-bottom:11px;
}
.mini-team{ display:flex; align-items:baseline; gap:11px; }
.mt-name{ font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:19px; color:var(--aPowder); }
.mt-score{ font-family:"IBM Plex Mono",monospace; font-weight:700; font-size:34px; color:var(--aChalk); line-height:1; min-width:1ch; }
.mt-score.pop{ animation:scorepop .42s ease; }
@keyframes scorepop{ 40%{ transform:scale(1.32); color:var(--aAmber); } }
.mini-inn{ font-family:"IBM Plex Mono",monospace; font-size:13px; color:var(--aPowder); display:flex; align-items:center; gap:5px; }
.mini-inn .caret{ color:var(--aAmber); }
.mini-inn small{ color:var(--aLine); font-size:10px; letter-spacing:.12em; }
.mini-field{ display:flex; align-items:center; justify-content:space-between; gap:8px; padding:4px 6px 2px; }
.mini-count{ display:flex; flex-direction:column; gap:7px; }
.crow{ display:flex; align-items:center; gap:5px; }
.crow span{ font-family:"IBM Plex Mono",monospace; font-size:12px; color:var(--aPowder); width:12px; }
.crow i{ width:11px; height:11px; border-radius:50%; border:1.5px solid var(--aLine); background:transparent; transition:background .12s, box-shadow .12s; }
.crow i.on{ background:var(--aAmber); border-color:var(--aAmber); box-shadow:0 0 7px rgba(245,197,24,.7); }
.crow:last-child i.on{ background:var(--aRed); border-color:var(--aRed); box-shadow:0 0 7px rgba(232,41,28,.7); }
.mini-diamond{ width:130px; height:130px; flex:0 0 auto; overflow:visible; }
.md-infield{ fill:rgba(43,90,160,.22); stroke:rgba(169,197,232,.30); stroke-width:1; }
.md-lines{ fill:none; stroke:var(--aPowder); stroke-width:2.5; stroke-linejoin:round; }
.mini-diamond .mb{ fill:var(--aNavy); stroke:var(--aPowder); stroke-width:1.8; cursor:grab; touch-action:none; transition:fill .12s; }
.mini-diamond .mb.on{ fill:var(--aAmber); stroke:var(--aAmber); filter:drop-shadow(0 0 5px rgba(245,197,24,.9)); }
.mini-diamond .mb.lift{ cursor:grabbing; filter:drop-shadow(0 0 9px rgba(245,197,24,1)); }
.mini-diamond .mb.target{ stroke:#9be29b; stroke-width:3; }
.md-home{ fill:var(--aChalk); }
.md-home.target{ fill:#9be29b; filter:drop-shadow(0 0 6px rgba(120,230,120,.9)); }
.drag-runner{ position:fixed; width:18px; height:18px; background:var(--aAmber); border-radius:4px; transform:translate(-50%,-50%) rotate(45deg); box-shadow:0 0 14px rgba(245,197,24,.95); pointer-events:none; z-index:300; }
.mini-pc{ font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.12em; color:var(--aPowder); text-align:center; }
.mini-pc b{ display:block; font-size:21px; color:var(--aChalk); font-weight:600; margin-top:2px; }
.mini-play{
  text-align:center; font-family:"IBM Plex Mono",monospace; font-size:13px; color:var(--aPowder);
  background:var(--aNavy); border:1px solid var(--aLine); border-radius:9px;
  padding:9px 10px; margin:6px 0 4px; min-height:19px;
}
.mini-hint{ text-align:center; font-family:"IBM Plex Mono",monospace; font-size:11px; color:var(--aLine); margin:0 0 12px; }
.mini-pad{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.mb-btn{
  padding:13px 6px; border-radius:11px; border:1px solid var(--aLine); background:var(--aRoyal);
  color:var(--aChalk); font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:16px;
  letter-spacing:.02em; cursor:pointer; transition:filter .15s;
}
.mb-btn:hover{ filter:brightness(1.18); }
.mb-btn.hit{ background:var(--aChalk); color:var(--aNavy); border-color:transparent; }
.mb-btn.out{ background:var(--aRed); color:#fff; border-color:transparent; }
.mb-btn.tap{ animation:btap .18s ease; }
@keyframes btap{ 45%{ transform:scale(.9); } }
.mini-foot{ display:flex; align-items:center; justify-content:space-between; gap:8px; margin-top:13px; }
.mini-reset{
  background:transparent; border:1px solid var(--aLine); color:var(--aPowder);
  border-radius:9px; padding:8px 13px; font-family:"IBM Plex Mono",monospace; font-size:12px; cursor:pointer;
}
.mini-reset:hover{ border-color:var(--aPowder); color:var(--aChalk); }
.mini-recap{
  background:rgba(245,197,24,.14); border:1px solid var(--aAmber); color:var(--aAmber);
  border-radius:9px; padding:8px 14px; font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:15px; cursor:pointer;
}
.mini-recap:hover{ background:rgba(245,197,24,.24); }
.mini-get{ color:var(--aAmber); font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:15px; }
/* recap reveal — app palette */
.recap-modal{ position:fixed; inset:0; z-index:120; display:flex; align-items:center; justify-content:center; padding:20px; background:rgba(6,11,26,.74); backdrop-filter:blur(4px); animation:recapfade .22s ease; }
.recap-modal[hidden]{ display:none; }
@keyframes recapfade{ from{ opacity:0; } }
.recap-card{ width:100%; max-width:430px; background:linear-gradient(180deg, #1D2D5C, #14204A); border:1px solid #2B5AA0; border-radius:18px; padding:20px; max-height:88vh; overflow-y:auto; box-shadow:0 40px 90px -20px rgba(0,0,0,.8); animation:recaprise .26s cubic-bezier(.2,.7,.2,1); }
@keyframes recaprise{ from{ transform:translateY(14px); opacity:0; } }
.recap-head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.recap-title{ font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:22px; color:#F4F8FF; }
.recap-x{ background:transparent; border:none; color:#A9C5E8; font-size:20px; cursor:pointer; line-height:1; padding:4px 8px; }
.recap-x:hover{ color:#F4F8FF; }
.recap-score{ display:flex; align-items:center; gap:12px; background:#14204A; border:1px solid #2B5AA0; border-radius:12px; padding:12px 16px; margin-bottom:14px; }
.rs-team{ font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:20px; color:#F4F8FF; }
.recap-score b{ font-family:"IBM Plex Mono",monospace; font-size:30px; color:#F5C518; line-height:1; }
.rs-final{ margin-left:auto; font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.2em; color:#A9C5E8; }
.recap-box{ border:1px solid #2B5AA0; border-radius:12px; overflow:hidden; margin-bottom:16px; }
.recap-box table{ width:100%; border-collapse:collapse; font-variant-numeric:tabular-nums; }
.recap-box th, .recap-box td{ padding:8px 6px; text-align:right; font-family:"IBM Plex Mono",monospace; font-size:13px; }
.recap-box th{ background:#243A72; color:#A9C5E8; font-weight:600; font-size:11px; letter-spacing:.08em; }
.recap-box th.l, .recap-box td.l{ text-align:left; padding-left:14px; }
.recap-box td.l{ color:#F4F8FF; font-family:"Inter",sans-serif; }
.recap-box td.l i{ color:#A9C5E8; font-style:normal; font-size:11px; text-transform:uppercase; letter-spacing:.05em; margin-left:4px; }
.recap-box tbody tr:nth-child(odd) td{ background:rgba(255,255,255,.03); }
.recap-box td{ color:#A9C5E8; }
.recap-opts-label{ font-family:"IBM Plex Mono",monospace; font-size:11px; letter-spacing:.1em; text-transform:uppercase; color:#A9C5E8; margin-bottom:10px; }
.recap-chips{ display:flex; flex-wrap:wrap; gap:8px; margin-bottom:18px; }
.chip{ font-family:"Inter",sans-serif; font-size:13px; font-weight:500; color:#F4F8FF; background:#1D2D5C; border:1px solid #2B5AA0; border-radius:999px; padding:7px 13px; }
.recap-buy{ display:block; text-align:center; }

/* CTA */
.cta{ background:linear-gradient(180deg, var(--navy), #0b1430); overflow:hidden; }
.cta-glow{ position:absolute; left:50%; top:30%; width:80vw; height:60vh; transform:translateX(-50%) translateY(var(--py,0px)); background:radial-gradient(ellipse, rgba(245,197,24,.16), transparent 60%); filter:blur(50px); pointer-events:none; }
.cta .wrap{ position:relative; }
.cta-sub{ color:var(--powder); font-size:clamp(17px,2.4vw,20px); max-width:42ch; margin:6px auto 30px; }
.cta-sub strong{ color:var(--amber); }
.cta .btn{ margin-bottom:16px; }

/* footer */
.foot{
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
  padding:26px clamp(16px,4vw,40px); border-top:1px solid var(--line); background:#0b1430;
}
.foot-tag{ font-family:"IBM Plex Mono",monospace; font-size:12px; letter-spacing:.2em; text-transform:uppercase; color:var(--muted); }
.foot-buy{ color:var(--amber); font-family:"Saira Condensed",sans-serif; font-weight:700; font-size:18px; }

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

/* ============================================================ RESPONSIVE */
@media (max-width:860px){
  .hero-inner{ grid-template-columns:1fr; text-align:center; gap:24px; min-height:auto; }
  .hero-copy{ margin:0 auto; }
  .hero-cta{ justify-content:center; }
  .lede{ margin-left:auto; margin-right:auto; }
  .hero-phone{ margin-top:8px; }
  .device{ transform:none; }

  .cards.three, .feat-grid{ grid-template-columns:1fr; }
  .split{ grid-template-columns:1fr; gap:30px; }
  .split-text{ text-align:center; }
  .split-text .check-list{ display:inline-block; text-align:left; }
  .device.sm{ transform:none; }
  .nav-links a:not(.btn){ display:none; }
}
@media (max-width:420px){
  .hero{ padding-top:100px; }
  .btn{ font-size:18px; }
}

/* ============================================================ A11Y */
.btn:focus-visible, a:focus-visible, video:focus-visible{ outline:3px solid var(--amber); outline-offset:3px; }
@media (prefers-reduced-motion:reduce){
  *{ animation:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; transition:none; }

  [data-float]{ transform:none; }
  [data-parallax]{ --py:0px !important; }
}
