/* ===========================================================
   Dash Expedite — shared styles (v3: Apple-clean, brand color)
   =========================================================== */
:root{
  --ink:#1d1d1f;
  --grey:#5f6573;
  --hair:#e6e8ee;
  --bg:#ffffff;
  --tint:#eef3fc;        /* soft blue band */
  --navy-1:#0a1a47;      /* deep brand navy */
  --navy-2:#16307e;
  --blue:#1B3AA8;        /* Dash blue */
  --blue-bright:#7aa0ff;
  --red:#E0202B;         /* Dash red */
  --red-deep:#c11820;
  --max:1060px;
  --font:-apple-system,BlinkMacSystemFont,"SF Pro Display","SF Pro Text","Helvetica Neue","Inter","Segoe UI",Roboto,Arial,sans-serif;
}
*{box-sizing:border-box;}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;scroll-behavior:smooth;}
body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font);line-height:1.5;font-size:17px;}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}
.wrap{max-width:var(--max);margin:0 auto;padding:0 28px;}
section{padding:120px 0;}
.eyebrow{font-size:12.5px;font-weight:700;letter-spacing:.14em;color:var(--blue);margin:0 0 14px;text-transform:uppercase;}
.eyebrow::before,.eyebrow::after{content:"";display:inline-block;width:20px;height:2px;border-radius:2px;background:var(--red);vertical-align:3.5px;}
.eyebrow::before{margin-right:11px;}
.eyebrow::after{margin-left:11px;}
.verse-band .eyebrow::before,.verse-band .eyebrow::after{background:currentColor;}
h1,h2{letter-spacing:-.032em;font-weight:700;margin:0;}
h3{letter-spacing:-.022em;font-weight:600;margin:0;}
.center{text-align:center;}
.lede{font-size:21px;line-height:1.5;color:var(--grey);font-weight:400;}
.soft{background:var(--tint);}

/* section head (centered eyebrow + h2 + lede) */
.head{text-align:center;max-width:700px;margin:0 auto;}
.head h2{font-size:clamp(30px,4.6vw,48px);line-height:1.08;}
.head .lede{margin-top:16px;}

/* icon chip */
.chip{width:54px;height:54px;border-radius:16px;display:inline-flex;align-items:center;justify-content:center;margin:0 auto 22px;background:linear-gradient(150deg,var(--blue),#2f56d8);box-shadow:0 8px 22px rgba(27,58,168,.28);}
.chip svg{width:26px;height:26px;fill:none;stroke:#fff;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.chip.red{background:linear-gradient(150deg,var(--red),#ff4d57);box-shadow:0 8px 22px rgba(224,32,43,.28);}

/* ---------- Nav ---------- */
.nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.8);backdrop-filter:saturate(180%) blur(20px);-webkit-backdrop-filter:saturate(180%) blur(20px);border-bottom:1px solid var(--hair);}
.nav__in{max-width:var(--max);margin:0 auto;padding:0 28px;height:58px;display:flex;align-items:center;gap:34px;}
.nav__logo{display:inline-flex;align-items:center;transition:opacity .2s,transform .2s;}
.nav__logo:hover{opacity:.72;transform:translateY(-1px);}
.nav__logo .wm{display:flex;flex-direction:column;line-height:1;}
.nav__logo .wm-1{color:var(--blue);font-weight:800;font-size:23px;letter-spacing:.02em;}
.nav__logo .wm-2{color:var(--red);font-weight:700;font-size:8.5px;letter-spacing:.2em;margin-top:3px;}
.nav__menu{display:flex;align-items:center;gap:30px;margin-left:auto;}
.nav__menu a{font-size:14px;color:#333;opacity:.85;transition:opacity .2s,color .2s;}
.nav__menu a:hover{opacity:1;color:var(--blue);}
.nav__menu a.active{opacity:1;color:var(--blue);font-weight:600;}
.nav__cta{font-size:14px;font-weight:600;background:var(--red);padding:8px 17px;border-radius:980px;transition:background .2s;}
.nav__menu .nav__cta{color:#fff;opacity:1;}
.nav__menu .nav__cta:hover{background:var(--red-deep);color:#fff;}
.nav__toggle{display:none;margin-left:auto;width:42px;height:42px;border:0;background:transparent;cursor:pointer;flex-direction:column;justify-content:center;align-items:center;gap:5px;border-radius:10px;}
.nav__toggle:hover{background:rgba(0,0,0,.04);}
.nav__toggle span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;transition:transform .25s,opacity .25s;}
.nav.open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav.open .nav__toggle span:nth-child(2){opacity:0;}
.nav.open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

/* a11y: skip link + visible keyboard focus */
.skip-link{position:absolute;left:-9999px;top:0;z-index:200;background:#fff;color:var(--blue);font-weight:600;padding:12px 18px;border-radius:0 0 12px 0;box-shadow:0 10px 28px rgba(10,26,71,.2);}
.skip-link:focus{left:0;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
main:focus{outline:none;}
a:focus-visible,button:focus-visible,.btn:focus-visible,.tlink:focus-visible,.nav__menu a:focus-visible,.nav__toggle:focus-visible,.dock__item:focus-visible,.dock__toggle:focus-visible{outline:2px solid var(--blue);outline-offset:3px;border-radius:6px;}
.hero a:focus-visible,.hero .btn:focus-visible,.page-hero a:focus-visible,.close a:focus-visible,.close .btn:focus-visible,.dock__toggle:focus-visible{outline-color:#fff;}

/* ---------- Buttons / links ---------- */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--red);color:#fff;font-weight:600;font-size:17px;padding:14px 28px;border-radius:980px;transition:background .2s,transform .25s cubic-bezier(.2,.7,.3,1),box-shadow .25s cubic-bezier(.2,.7,.3,1);box-shadow:0 8px 22px rgba(224,32,43,.25);cursor:pointer;border:0;font-family:inherit;}
.btn:hover{background:var(--red-deep);transform:translateY(-2px);box-shadow:0 12px 30px rgba(224,32,43,.35);}
.btn:active{transform:translateY(0) scale(.97);box-shadow:0 4px 12px rgba(224,32,43,.25);transition-duration:.12s;}
.btn.ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.4);box-shadow:none;}
.btn.ghost:hover{background:rgba(255,255,255,.1);}
.tlink{font-size:17px;font-weight:600;display:inline-flex;align-items:center;gap:6px;color:var(--blue);position:relative;padding:6px 4px;margin:-6px -4px;}
.tlink::after{content:"";position:absolute;left:4px;right:4px;bottom:1px;height:2px;background:currentColor;border-radius:2px;transform:scaleX(0);transform-origin:left;transition:transform .3s cubic-bezier(.22,1,.36,1);}
.tlink:hover::after{transform:scaleX(1);}
.tlink .chev{transition:transform .2s;}
.tlink:hover .chev{transform:translateX(3px);}

/* ---------- Home hero (navy) ---------- */
.hero{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--navy-1) 0%,var(--navy-2) 70%);color:#fff;text-align:center;padding:120px 0 124px;}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(900px 420px at 82% -8%,rgba(224,32,43,.22),transparent 60%),radial-gradient(700px 380px at 8% 110%,rgba(122,160,255,.18),transparent 60%);pointer-events:none;}
.hero>.wrap{position:relative;z-index:1;}
.hero .eyebrow{color:var(--blue-bright);}
.hero h1{font-size:clamp(38px,9.6vw,88px);line-height:1.03;}
.hero h1 .accent{color:var(--blue-bright);}
.hero .lede{color:#c3cee8;max-width:670px;margin:26px auto 0;font-size:clamp(19px,2.4vw,23px);}
.cta-row{margin-top:38px;display:flex;gap:24px;justify-content:center;align-items:center;flex-wrap:wrap;}
.hero .tlink,.page-hero .tlink{color:#fff;}
.hero__note{margin-top:30px;font-size:14px;color:#aebbd6;display:inline-flex;align-items:center;gap:8px;}
.dot{width:9px;height:9px;border-radius:50%;background:var(--red);display:inline-block;animation:pulse 2.4s infinite;}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(224,32,43,.55);}70%{box-shadow:0 0 0 8px rgba(224,32,43,0);}100%{box-shadow:0 0 0 0 rgba(224,32,43,0);}}

/* ---------- Inner-page hero (compact navy) ---------- */
.page-hero{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--navy-1),var(--navy-2));color:#fff;text-align:center;padding:116px 0 92px;}
.page-hero::after{content:"";position:absolute;inset:0;background:radial-gradient(800px 360px at 84% -10%,rgba(224,32,43,.2),transparent 60%),radial-gradient(640px 320px at 6% 120%,rgba(122,160,255,.16),transparent 60%);pointer-events:none;}
.page-hero>.wrap{position:relative;z-index:2;}
.page-hero .eyebrow{color:var(--blue-bright);}
.page-hero h1{font-size:clamp(33px,8vw,62px);line-height:1.05;}
.page-hero h1 .accent{color:var(--blue-bright);}
.page-hero .lede{color:#c3cee8;max-width:620px;margin:20px auto 0;}

/* ---------- Stat band (soft blue) ---------- */
.stats{background:var(--tint);padding:84px 0;}
.stats .eyebrow{text-align:center;}
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px;margin-top:30px;}
.stat{text-align:center;position:relative;}
.stat b{display:block;font-size:clamp(40px,5vw,58px);font-weight:700;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums;color:var(--blue);background:linear-gradient(135deg,var(--blue),var(--navy-2));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}
.stat b .plus{color:var(--red);-webkit-text-fill-color:var(--red);}
.stat>span{display:block;margin-top:10px;font-size:15px;color:var(--grey);}
.stat b .n,.stat b .plus{display:inline;}
@media(min-width:821px){.stat+.stat::before{content:"";position:absolute;left:-15px;top:10px;bottom:6px;width:1px;background:var(--hair);}}


/* ---------- Cards (divisions / fleet / equipment) ---------- */
.div-grid{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:52px;}
.cards-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;}
.card{position:relative;background:#fff;border:1px solid var(--hair);border-radius:22px;overflow:hidden;box-shadow:0 1px 2px rgba(10,26,71,.04),0 10px 30px rgba(10,26,71,.05);transition:box-shadow .35s cubic-bezier(.22,1,.36,1),transform .35s cubic-bezier(.22,1,.36,1),border-color .3s;}
.card:hover{border-color:rgba(27,58,168,.3);box-shadow:0 24px 60px rgba(10,26,71,.14);transform:translateY(-5px);}
.card::after{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--blue),var(--red));transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.22,1,.36,1);z-index:2;}
.card:hover::after{transform:scaleX(1);}
.card .chip{margin:0 0 18px;}
.card__media{height:184px;display:flex;align-items:flex-end;padding:18px;position:relative;}
.card__media.tl{background:linear-gradient(140deg,#16307e,#2f56d8);}
.card__media.exp{background:linear-gradient(140deg,#a3121a,#e0202b);}
.card__media.flat{background:linear-gradient(140deg,#0a1a47,#2f56d8);}
.card__media svg{position:absolute;right:18px;top:18px;width:46px;height:46px;fill:none;stroke:rgba(255,255,255,.9);stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;}
.card__media .slot{font-size:12px;color:rgba(255,255,255,.78);font-weight:500;letter-spacing:.03em;}
/* real truck photos in a media panel (studio renders on white) */
.card__media.photo{background:linear-gradient(180deg,#fff,#f3f6fc);padding:0;align-items:stretch;border-bottom:1px solid var(--hair);position:relative;}
.card__media.photo::before{content:"";position:absolute;left:14%;right:14%;bottom:9px;height:16px;background:radial-gradient(50% 100% at 50% 50%,rgba(10,26,71,.16),transparent 70%);}
.card__media.photo img{width:100%;height:100%;object-fit:contain;display:block;padding:12px 18px;position:relative;transition:transform .5s cubic-bezier(.22,1,.36,1);}
.card:hover .card__media.photo img{transform:scale(1.035);}
.split__media.photo{background:linear-gradient(180deg,#fff,#f3f6fc);border:1px solid var(--hair);display:flex;align-items:center;justify-content:center;overflow:hidden;}
.split__media.photo img{width:100%;height:100%;object-fit:contain;display:block;padding:16px 26px;}
.card__body{padding:30px 34px 36px;}
.card .tag{font-size:13px;font-weight:700;letter-spacing:.03em;}
.card .tag.tl{color:var(--blue);}.card .tag.exp{color:var(--red);}.card .tag.flat{color:var(--blue);}.card .tag.ftl{color:var(--navy-2);}
.card h3{font-size:24px;margin:10px 0 10px;}
.card p{color:var(--grey);font-size:16px;margin:0 0 18px;}

/* equipment make pills */
.spec{list-style:none;margin:6px 0 0;padding:0;display:flex;flex-wrap:wrap;gap:8px;}
.spec li{font-size:13px;font-weight:600;color:var(--ink);background:var(--tint);border-radius:8px;padding:6px 12px;}

/* readable per-class list + fine print (drivers requirements) */
.ladder{list-style:none;margin:8px 0 0;padding:0;display:grid;gap:11px;}
.ladder li{position:relative;padding-left:18px;font-size:14.5px;line-height:1.5;color:var(--grey);}
.ladder li::before{content:"";position:absolute;left:0;top:9px;width:7px;height:7px;border-radius:50%;background:var(--blue);}
.ladder li b{color:var(--ink);font-weight:600;}
.fineprint{margin:22px auto 0;max-width:760px;font-size:12.5px;line-height:1.55;color:var(--grey);text-align:center;}

/* simple icon card (fleet overview / why) */
.icard .chip{margin:0 0 18px;}

/* ---------- Lanes ---------- */
.lanes{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:46px;}
.lane{background:#fff;border:1px solid var(--hair);border-radius:14px;padding:20px 22px;}
.lane .route{font-weight:600;font-size:17px;display:flex;align-items:center;gap:9px;}
.lane .route .ar{color:var(--blue);font-weight:700;}
.lane .meta{margin-top:6px;font-size:13px;color:var(--grey);}
.lane .meta.hot{color:var(--red);font-weight:600;}

/* ---------- About: prose + timeline + growth ---------- */
.prose{max-width:720px;margin:0 auto;text-align:center;}
.prose p{font-size:19px;line-height:1.65;color:var(--grey);margin:0 0 18px;}
.prose strong{color:var(--ink);font-weight:600;}
.pull{font-size:clamp(22px,3vw,30px);line-height:1.4;color:var(--ink);font-weight:600;letter-spacing:-.02em;max-width:760px;margin:34px auto 0;}
.pull .q{color:var(--blue);}
.timeline{max-width:720px;margin:48px auto 0;}
.tl-item{display:grid;grid-template-columns:104px 1fr;gap:22px;padding:20px 0 20px 36px;position:relative;}
.tl-item::before{content:"";position:absolute;left:9px;top:0;bottom:0;width:2px;background:var(--hair);}
.tl-item:first-child::before{top:28px;}
.tl-item:last-child::before{bottom:auto;height:28px;}
.tl-item::after{content:"";position:absolute;left:3px;top:24px;width:10px;height:10px;border-radius:50%;background:#fff;border:3px solid var(--blue);box-shadow:0 0 0 4px rgba(27,58,168,.12);}
.tl-item:last-child::after{border-color:var(--red);box-shadow:0 0 0 4px rgba(224,32,43,.12);}
.tl-year{font-weight:700;color:var(--blue);font-size:15px;padding-top:3px;}
.tl-item p{margin:0;color:var(--grey);font-size:16px;}

/* ---------- Contact: form + info + map ---------- */
.form-wrap .btn{width:100%;justify-content:center;margin-top:6px;}
.form-note{margin:14px 0 0;font-size:13px;color:var(--grey);text-align:center;}
.info-row .k{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--grey);min-width:80px;padding-top:2px;}
.info-row .v{font-size:16px;color:var(--ink);}
.info-row .v a{color:var(--blue);font-weight:600;}
.info-row .v small{display:block;color:var(--grey);font-size:13px;font-weight:400;margin-top:2px;}
.map .open{margin-top:14px;font-weight:600;font-size:14px;color:#fff;display:inline-flex;gap:5px;}

/* ---------- Closing CTA (navy) ---------- */
.close{position:relative;overflow:hidden;background:linear-gradient(160deg,var(--navy-1),var(--navy-2));color:#fff;text-align:center;}
.close::after{content:"";position:absolute;inset:0;background:radial-gradient(700px 360px at 50% 120%,rgba(224,32,43,.22),transparent 60%);pointer-events:none;}
.close>.wrap{position:relative;z-index:1;}
.close h2{font-size:clamp(36px,5.5vw,58px);line-height:1.05;color:#fff;}
.close .lede{color:#aebbd6;max-width:600px;margin:20px auto 0;}
.close .tlink{color:#fff;}

/* ---------- Footer ---------- */
footer{background:#f5f5f7;color:var(--grey);font-size:14px;padding:56px 0 28px;border-top:1px solid var(--hair);}
.foot{display:grid;grid-template-columns:1.5fr 1fr 1.2fr;gap:30px;}
.foot h4,.foot h3{font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);margin:0 0 12px;font-weight:700;}
.foot ul{list-style:none;margin:0;padding:0;}
.foot li{margin:8px 0;}
.foot a:hover{color:var(--blue);}
.foot__bottom{margin-top:36px;padding-top:18px;border-top:1px solid var(--hair);display:flex;justify-content:space-between;gap:16px;flex-wrap:wrap;color:var(--grey);font-size:13px;}

/* ---------- Floating contact dock (call / Telegram / email) ---------- */
.dock{position:fixed;right:24px;bottom:24px;z-index:90;display:flex;flex-direction:column;align-items:flex-end;gap:12px;}
.dock__menu{display:flex;flex-direction:column;gap:10px;opacity:0;visibility:hidden;transform:translateY(12px) scale(.98);pointer-events:none;transition:opacity .22s ease,transform .22s ease,visibility .22s;}
.dock.open .dock__menu{opacity:1;visibility:visible;transform:none;pointer-events:auto;}
.dock__item{display:inline-flex;align-items:center;gap:12px;background:#fff;color:var(--ink);border:1px solid var(--hair);padding:11px 18px 11px 12px;border-radius:14px;box-shadow:0 14px 36px rgba(10,26,71,.16);font-size:15px;font-weight:600;line-height:1.2;transition:transform .15s;}
.dock__item:hover{transform:translateX(-3px);}
.dock__item small{display:block;font-weight:400;color:var(--grey);font-size:12px;margin-top:2px;}
.dock__ic{width:34px;height:34px;border-radius:10px;display:grid;place-items:center;flex:none;}
.dock__ic svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.dock__ic.call{background:var(--blue);}
.dock__ic.tg{background:#229ED9;}
.dock__ic.mail{background:#2f56d8;}
.dock__item.primary{background:var(--blue);color:#fff;border-color:var(--blue);}
.dock__item.primary small{color:rgba(255,255,255,.75);}
.dock__item.primary .dock__ic.call{background:rgba(255,255,255,.18);}
.dock__toggle{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;padding:0;background:linear-gradient(160deg,#2AABEE,#229ED9);color:#fff;border:0;cursor:pointer;border-radius:50%;box-shadow:0 14px 34px rgba(34,158,217,.45);transition:filter .2s,transform .2s;}
.dock__toggle:hover{filter:brightness(1.06);transform:translateY(-2px) scale(1.03);}
.dock__toggle .lbl{display:none;}
.dock__toggle .msg svg{width:30px;height:30px;fill:#fff;stroke:none;margin-left:-2px;}
.dock__toggle .x{display:none;}
.dock__toggle .x svg{width:24px;height:24px;fill:none;stroke:#fff;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;}
.dock.open .dock__toggle{background:#5f6573;box-shadow:0 14px 30px rgba(0,0,0,.22);}
.dock.open .dock__toggle .msg{display:none;}
.dock.open .dock__toggle .x{display:inline-flex;}

/* ---------- Responsive ---------- */
@media(max-width:820px){
  section{padding:84px 0;}
  .stat-grid{grid-template-columns:1fr 1fr;gap:34px 20px;}
  .div-grid{grid-template-columns:1fr;}
  /* card rows become edge-to-edge swipe rails with a peek of the next card */
  .cards-3{display:grid;grid-template-columns:none;grid-auto-flow:column;grid-auto-columns:min(82%,340px);overflow-x:auto;scroll-snap-type:x mandatory;scroll-padding-left:28px;margin:44px -28px 0;padding:6px 28px 22px;scrollbar-width:none;-webkit-overflow-scrolling:touch;}
  .cards-3::-webkit-scrollbar{display:none;}
  .cards-3 .card{scroll-snap-align:start;}
  .card__media.photo::before{display:none;}
  .lanes{grid-template-columns:1fr 1fr;}
  .foot{grid-template-columns:1fr 1fr;}
}
@media(max-width:560px){
  .lanes{grid-template-columns:1fr;}
  .tl-item{grid-template-columns:78px 1fr;gap:14px;}
  .foot{grid-template-columns:1fr;}
  .dock{right:14px;bottom:calc(14px + env(safe-area-inset-bottom,0px));}
  .dock__toggle{width:58px;height:58px;}
  /* phone-tuned heroes: compact bands, natural line breaks, full-width CTAs */
  .hero{padding:84px 0 96px;}
  .page-hero{padding:78px 0 68px;}
  .hero h1 br,.page-hero h1 br{display:none;}
  .hero .lede{font-size:17px;margin-top:18px;}
  .cta-row{flex-direction:column;gap:16px;}
  .cta-row .btn{width:100%;max-width:340px;justify-content:center;padding:16px 24px;}
  /* the freight map becomes a deliberate glow band under the headline */
  .hero-routes{-webkit-mask-image:linear-gradient(180deg,transparent 0 30%,#000 58%);mask-image:linear-gradient(180deg,transparent 0 30%,#000 58%);}
  .hero-routes .lane{stroke:rgba(122,160,255,.72);}
  .hero-routes .lane.soft,.hero-routes .node.dim{display:none;}
}

/* ===========================================================
   Animated aurora — slow living background motion on navy
   surfaces (pure CSS, GPU-composited, respects reduced-motion)
   =========================================================== */
.hero::before,.page-hero::before,.close::before{
  content:"";position:absolute;inset:-14%;z-index:0;pointer-events:none;
  background:
    radial-gradient(34% 40% at 18% 24%, rgba(45,91,215,.65), transparent 62%),
    radial-gradient(30% 34% at 86% 26%, rgba(224,32,43,.34), transparent 60%),
    radial-gradient(42% 46% at 64% 104%, rgba(122,160,255,.46), transparent 62%);
  filter:blur(38px);opacity:.55;
  animation:auroraA 24s ease-in-out infinite alternate;
}
.hero::after,.page-hero::after,.close::after{
  animation:auroraB 31s ease-in-out infinite alternate;
}
@keyframes auroraA{
  0%  {transform:translate3d(0,0,0);   opacity:.5;}
  50% {transform:translate3d(4%,3%,0); opacity:.66;}
  100%{transform:translate3d(-3%,-2%,0); opacity:.52;}
}
@keyframes auroraB{
  0%  {transform:translate3d(0,0,0) scale(1);}
  100%{transform:translate3d(-4%,3%,0) scale(1.1);}
}
@media (prefers-reduced-motion: reduce){
  .hero::before,.page-hero::before,.close::before,
  .hero::after,.page-hero::after,.close::after{animation:none;}
}

/* animated US map of Dash's freight network (homepage hero) */
.hero-routes{position:absolute;inset:0;width:100%;height:100%;z-index:1;pointer-events:none;}
.hero-routes .usmap path{fill:none;stroke:rgba(122,160,255,.18);stroke-width:1;vector-effect:non-scaling-stroke;}
.hero-routes .lane{fill:none;stroke:rgba(122,160,255,.6);stroke-width:1.6;stroke-linecap:round;stroke-dasharray:2 15;vector-effect:non-scaling-stroke;animation:routeFlow 6s linear infinite;animation-delay:var(--d,0s);}
.hero-routes .lane.soft{stroke:rgba(122,160,255,.30);stroke-width:1.1;animation-duration:8.5s;}
.hero-routes .node{fill:#7aa0ff;animation:nodePulse 3s ease-in-out infinite;animation-delay:var(--p,0s);}
.hero-routes .node.hub{fill:#9ab8ff;}
.hero-routes .node.home{fill:#ff5b62;}
.hero-routes .node.dim{fill:#6f8fd6;animation-name:nodePulseDim;}
.hero-routes .ping{fill:none;stroke:#ff5b62;stroke-width:1.4;transform-box:fill-box;transform-origin:center;animation:ping 3s ease-out infinite;}
.hero>.wrap{z-index:2;}
@keyframes routeFlow{to{stroke-dashoffset:-170;}}
@keyframes nodePulse{0%,100%{opacity:.5;}50%{opacity:1;}}
@keyframes nodePulseDim{0%,100%{opacity:.22;}50%{opacity:.5;}}
@keyframes ping{0%{transform:scale(.5);opacity:.7;}80%,100%{transform:scale(2.6);opacity:0;}}
@media (prefers-reduced-motion: reduce){
  .hero-routes .lane,.hero-routes .node,.hero-routes .ping,.dot{animation:none;}
}

/* ===========================================================
   v4 — dual-audience: fork hero, testimonials, compliance,
   contact paths, fat footer, legal + track pages
   =========================================================== */

.nav__menu{gap:24px;}

/* Compliance ledger (Safety) */
.compliance{max-width:780px;margin:46px auto 0;border:1px solid var(--hair);border-radius:20px;overflow:hidden;background:#fff;}
.compliance .row{display:grid;grid-template-columns:1fr auto;gap:18px;align-items:center;padding:17px 26px;border-bottom:1px solid var(--hair);}
.compliance .row:last-child{border-bottom:0;}
.compliance .row dt,.compliance .row .k{font-size:15px;color:var(--grey);margin:0;}
.compliance .row dd,.compliance .row .v{margin:0;font-size:16px;font-weight:600;color:var(--ink);text-align:right;min-width:0;overflow-wrap:anywhere;}
.compliance .row .v.pending{font-weight:600;color:#8a6d00;background:#fff7e0;border:1px dashed #e3c24d;border-radius:8px;padding:4px 11px;font-size:12.5px;}


/* compact credential stat */
.stat.stat--id b{font-size:clamp(22px,3vw,30px);}

/* Fat footer */
.foot__id{margin-top:38px;padding-top:22px;border-top:1px solid var(--hair);display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:baseline;}
.foot__id .brand{font-weight:700;color:var(--ink);letter-spacing:-.02em;}
.foot__id .brand .r{color:var(--red-deep);}
.foot__id .meta{color:var(--grey);font-size:13px;}
.foot__legal a{font-weight:600;}
.foot__legal a:hover{color:var(--blue);}

/* Legal / prose pages */
.legal-prose{max-width:760px;margin:0 auto;}
.legal-prose h2{font-size:25px;margin:38px 0 12px;letter-spacing:-.02em;}
.legal-prose h3{font-size:18px;margin:24px 0 8px;}
.legal-prose p,.legal-prose li{color:var(--grey);font-size:16px;line-height:1.65;}
.legal-prose ul{padding-left:20px;margin:8px 0;}
.legal-prose a{color:var(--blue);font-weight:600;}
.legal-prose .updated{color:var(--grey);font-size:14px;margin-top:6px;}

/* Track action cards */
.track-actions .card__body{text-align:center;padding:34px 28px 32px;}
.track-actions .chip{margin:0 auto 18px;}

/* split feature (copy + media side by side) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:center;}
.split h2{font-size:clamp(30px,4.2vw,44px);line-height:1.1;letter-spacing:-.025em;}
.split .lede{margin-top:16px;}
.split .ladder{margin-top:22px;}
.split .cta-row{margin-top:28px;justify-content:flex-start;}
.split__media{order:0;border-radius:22px;height:320px;}
.split.media-left .split__media{order:-1;}

@media(max-width:820px){
  .split{grid-template-columns:1fr;gap:26px;}
  .split.media-left .split__media{order:0;}
  .split__media{height:240px;}
}
@media(max-width:960px){
  /* mobile: hamburger + full-height menu sheet; the Apply CTA stays visible in the bar */
  .nav__in{position:relative;z-index:2;}
  .nav__toggle{display:flex;margin-left:10px;}
  .nav__in .nav__cta--bar{display:inline-flex;margin-left:auto;font-size:13px;padding:7px 15px;}
  .nav__menu{position:absolute;top:100%;left:0;right:0;z-index:1;height:calc(100vh - 58px);height:calc(100dvh - 58px);margin:0;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:0;background:rgba(255,255,255,.98);padding:26px 28px calc(28px + env(safe-area-inset-bottom,0px));overflow:auto;opacity:0;visibility:hidden;pointer-events:none;transition:opacity .25s ease,visibility .25s;}
  .nav.open .nav__menu{opacity:1;visibility:visible;pointer-events:auto;}
  .nav__menu a{font-size:25px;font-weight:600;letter-spacing:-.02em;padding:18px 2px;border-bottom:1px solid var(--hair);opacity:1;}
  .nav__menu .nav__cta{margin-top:26px;justify-content:center;text-align:center;padding:16px;font-size:17px;color:#fff;border-bottom:0;letter-spacing:0;}
  @media (prefers-reduced-motion: no-preference){
    .nav.open .nav__menu a{animation:menuIn .35s cubic-bezier(.22,1,.36,1) both;}
    .nav.open .nav__menu a:nth-child(2){animation-delay:.05s;}
    .nav.open .nav__menu a:nth-child(3){animation-delay:.1s;}
    .nav.open .nav__menu a:nth-child(4){animation-delay:.15s;}
  }
}
@media(max-width:560px){
  .compliance .row{grid-template-columns:1fr;gap:4px;}
  .compliance .row dd,.compliance .row .v{text-align:left;}
}

/* ===========================================================
   America 250 — "Proudly American" theme (1776–2026 launch)
   =========================================================== */
.usa250{position:relative;background:#fbfcff;color:var(--ink);text-align:center;font-size:12.5px;font-weight:500;letter-spacing:.015em;line-height:1.3;padding:9px 16px 8px;display:flex;align-items:center;justify-content:center;gap:9px;flex-wrap:wrap;}
.usa250::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--red) 0 33.34%,#fff 33.34% 66.67%,var(--blue) 66.67% 100%);}
.usa250 .stars{letter-spacing:2px;font-size:11px;color:var(--red);}
.usa250 .stars .b{color:var(--blue);}
.usa250 strong{font-weight:700;color:var(--blue);}
@media(max-width:560px){.usa250{font-size:11px;padding:8px 12px 7px;gap:6px;}}

/* footer "Proudly American" badge */
.usa250-foot{display:flex;align-items:center;gap:13px;margin-top:24px;padding-top:20px;border-top:1px solid var(--hair);}
.usa250-foot svg{width:42px;height:42px;flex:none;}
.usa250-foot .t{font-size:13px;color:var(--grey);line-height:1.45;}
.usa250-foot .t strong{color:var(--ink);font-weight:700;}

/* patriotic line on navy close band */
.usa250-line{margin:26px auto 0;font-size:12.5px;letter-spacing:.06em;text-transform:uppercase;color:#c3cee8;display:inline-flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:center;}
.usa250-line .s{color:#ff5b62;letter-spacing:3px;}
.usa250-line .s.b{color:var(--blue-bright);}

/* ===== seasonal holiday themes (Thanksgiving / Christmas / New Year) ===== */
.verse-band{text-align:center;padding:104px 0;}
.verse-band .eyebrow{margin-bottom:16px;}
.verse-band blockquote{margin:0 auto;max-width:880px;font-size:clamp(23px,3.4vw,36px);line-height:1.4;font-weight:500;letter-spacing:-.012em;}
.verse-band cite{display:block;margin-top:24px;font-size:13px;font-style:normal;letter-spacing:.08em;text-transform:uppercase;}
@media(max-width:820px){.verse-band{padding:80px 0;}}
.theme-thanksgiving .usa250{background:#FBF4E6;color:#5A2A2A;}
.theme-thanksgiving .usa250::before{background:linear-gradient(90deg,#7A2E2E 0%,#B8842B 50%,#D8A93D 100%);}
.theme-thanksgiving .usa250 strong{color:#7A2E2E;}
.theme-thanksgiving .usa250 .stars{color:#B8842B;}
.theme-thanksgiving .usa250 .stars .b{color:#7A2E2E;}
.theme-christmas .usa250{background:#0B3D2E;color:#F7F3E8;}
.theme-christmas .usa250::before{background:linear-gradient(90deg,#0B3D2E 0%,#C8A24B 50%,#9E1B1B 100%);}
.theme-christmas .usa250 strong{color:#E6C766;}
.theme-christmas .usa250 .stars{color:#C8A24B;}
.theme-christmas .usa250 .stars .b{color:#fff;}
.theme-newyear .usa250{background:#0B1A3A;color:#F7F3E8;}
.theme-newyear .usa250::before{background:linear-gradient(90deg,#BF9B30 0%,#E6C766 50%,#BF9B30 100%);}
.theme-newyear .usa250 strong{color:#E6C766;}
.theme-newyear .usa250 .stars{color:#E6C766;}
.theme-newyear .usa250 .stars .b{color:#E6C766;}

/* ===========================================================
   Festive holiday layers — change the whole feel per season
   (particles come from festive.js; below = decor + atmosphere)
   =========================================================== */

/* --- Christmas twinkling light string (sits under the nav) --- */
.xmas-lights{display:flex;justify-content:center;flex-wrap:wrap;align-items:flex-start;gap:30px;height:24px;padding:0 16px;background:var(--navy-1);position:relative;overflow:hidden;}
.xmas-lights::before{content:"";position:absolute;top:5px;left:0;right:0;height:2px;background:rgba(255,255,255,.14);}
.xmas-lights i{margin-top:6px;width:10px;height:13px;border-radius:50% 50% 46% 46%;position:relative;animation:twinkle 2.6s ease-in-out infinite;}
.xmas-lights i:nth-child(4n+1){background:#ff4d57;box-shadow:0 0 9px #ff4d57;animation-delay:0s;}
.xmas-lights i:nth-child(4n+2){background:#E6C766;box-shadow:0 0 9px #E6C766;animation-delay:.5s;}
.xmas-lights i:nth-child(4n+3){background:#3fd07a;box-shadow:0 0 9px #3fd07a;animation-delay:1s;}
.xmas-lights i:nth-child(4n+4){background:#9ab8ff;box-shadow:0 0 9px #9ab8ff;animation-delay:1.5s;}
@keyframes twinkle{0%,100%{opacity:1;filter:brightness(1.2);}50%{opacity:.4;filter:brightness(.65);}}
@media (prefers-reduced-motion: reduce){.xmas-lights i{animation:none;}}

/* --- Thanksgiving: warm harvest-sunset --- */
.theme-thanksgiving .hero,.theme-thanksgiving .page-hero{background:linear-gradient(160deg,#3a1410 0%,#7a3a14 78%);}
.theme-thanksgiving .hero::before,.theme-thanksgiving .page-hero::before{background:radial-gradient(34% 40% at 18% 24%,rgba(216,169,61,.55),transparent 62%),radial-gradient(30% 34% at 86% 26%,rgba(192,83,31,.42),transparent 60%),radial-gradient(42% 46% at 64% 104%,rgba(227,184,90,.42),transparent 62%);}
.theme-thanksgiving .hero::after,.theme-thanksgiving .page-hero::after{background:radial-gradient(900px 420px at 82% -8%,rgba(192,83,31,.30),transparent 60%),radial-gradient(700px 380px at 8% 110%,rgba(216,169,61,.22),transparent 60%);}
.theme-thanksgiving .hero .eyebrow,.theme-thanksgiving .page-hero .eyebrow{color:#E3B85A;}
.theme-thanksgiving .hero h1 .accent,.theme-thanksgiving .page-hero h1 .accent{color:#E3B85A;}
.theme-thanksgiving .hero .lede,.theme-thanksgiving .page-hero .lede{color:#f0e2c8;}
.theme-thanksgiving .hero-routes .usmap path{stroke:rgba(216,169,61,.20);}
.theme-thanksgiving .hero-routes .lane{stroke:rgba(227,184,90,.62);}
.theme-thanksgiving .hero-routes .lane.soft{stroke:rgba(227,184,90,.30);}
.theme-thanksgiving .hero-routes .node{fill:#E3B85A;}
.theme-thanksgiving .hero-routes .node.hub{fill:#f0cd7a;}
.theme-thanksgiving .hero-routes .node.home{fill:#C0531F;}
.theme-thanksgiving .hero-routes .ping{stroke:#C0531F;}
.theme-thanksgiving .soft{background:#FBF4E6;}
.theme-thanksgiving .close{background:linear-gradient(160deg,#3a1410,#7a3a14);}

/* --- Christmas: wintry navy night --- */
.theme-christmas .hero::before,.theme-christmas .page-hero::before{background:radial-gradient(34% 40% at 18% 24%,rgba(120,180,255,.5),transparent 62%),radial-gradient(30% 34% at 86% 26%,rgba(224,32,43,.3),transparent 60%),radial-gradient(42% 46% at 64% 104%,rgba(70,200,140,.32),transparent 62%);}
.theme-christmas .hero .eyebrow,.theme-christmas .page-hero .eyebrow{color:#E6C766;}
.theme-christmas .hero-routes .node{fill:#dbeaff;}
.theme-christmas .hero-routes .node.home{fill:#ff5b62;}
.theme-christmas .soft{background:#F1F6F1;}

/* --- New Year: midnight gold --- */
.theme-newyear .hero,.theme-newyear .page-hero{background:linear-gradient(160deg,#070d20 0%,#0e1a3a 80%);}
.theme-newyear .hero::before,.theme-newyear .page-hero::before{background:radial-gradient(34% 40% at 18% 24%,rgba(230,199,102,.42),transparent 62%),radial-gradient(30% 34% at 86% 26%,rgba(230,199,102,.3),transparent 60%),radial-gradient(42% 46% at 64% 104%,rgba(154,184,255,.32),transparent 62%);}
.theme-newyear .hero .eyebrow,.theme-newyear .page-hero .eyebrow{color:#E6C766;}
.theme-newyear .hero h1 .accent,.theme-newyear .page-hero h1 .accent{color:#E6C766;}
.theme-newyear .hero-routes .lane{stroke:rgba(230,199,102,.6);}
.theme-newyear .hero-routes .node{fill:#E6C766;}
.theme-newyear .hero-routes .node.home{fill:#ffffff;}
.theme-newyear .soft{background:#F4F1E8;}

/* Footer social (coming soon) */
.foot__social{margin-top:18px;}
.foot__social-t{display:block;font-size:13px;color:var(--grey);margin-bottom:9px;}
.foot__social-t em{font-style:normal;color:#9aa1af;}
.foot__social-ic{display:inline-flex;gap:10px;}
.foot__social-ic .soc{width:34px;height:34px;border-radius:9px;border:1px solid var(--hair);display:inline-flex;align-items:center;justify-content:center;color:var(--grey);opacity:.7;}
.foot__social-ic .soc svg{width:18px;height:18px;}

/* Contact — office map image */
.card__media.map-img{padding:0;height:210px;overflow:hidden;}
.card__media.map-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s;}
.card__media.map-img:hover img{transform:scale(1.04);}

/* ===========================================================
   POLISH KIT (2026-07) — motion system, navy stat band,
   hero choreography, conversion band, mobile ergonomics
   =========================================================== */

/* anchors never hide under the sticky nav */
[id]{scroll-margin-top:84px;}
.card:target{box-shadow:0 0 0 3px var(--blue),0 22px 55px rgba(10,26,71,.12);border-color:var(--blue);}

/* --- nav: scroll elevation + brand progress hairline --- */
.nav::after{content:"";position:absolute;left:0;right:0;bottom:-1px;height:2px;background:linear-gradient(90deg,var(--blue),var(--red));transform:scaleX(var(--sp,0));transform-origin:left;}
.nav.scrolled{box-shadow:0 6px 24px rgba(10,26,71,.08);}
.nav__cta{color:#fff;}
.nav__cta--bar{display:none;}

/* --- hero entrance choreography (CSS-only, reduced-motion safe) --- */
@media (prefers-reduced-motion: no-preference){
  .hero .wrap>*,.page-hero .wrap>*{opacity:0;animation:heroUp .7s cubic-bezier(.22,1,.36,1) forwards;}
  .hero .wrap>*:nth-child(1),.page-hero .wrap>*:nth-child(1){animation-delay:.05s;}
  .hero .wrap>*:nth-child(2),.page-hero .wrap>*:nth-child(2){animation-delay:.13s;}
  .hero .wrap>*:nth-child(3),.page-hero .wrap>*:nth-child(3){animation-delay:.21s;}
  .hero .wrap>*:nth-child(4),.page-hero .wrap>*:nth-child(4){animation-delay:.29s;}
  .hero .wrap>*:nth-child(5),.page-hero .wrap>*:nth-child(5){animation-delay:.37s;}
  .hero .wrap>*:nth-child(6),.page-hero .wrap>*:nth-child(6){animation-delay:.45s;}
  .hero-routes{opacity:0;animation:mapIn 1.1s ease-out .5s forwards;}
  .dock__toggle{opacity:0;animation:dockIn .5s cubic-bezier(.34,1.56,.64,1) .9s forwards;}
}
@keyframes heroUp{from{opacity:0;transform:translateY(16px);}to{opacity:1;transform:none;}}
@keyframes mapIn{to{opacity:1;}}
@keyframes dockIn{from{opacity:0;transform:scale(.6) translateY(10px);}to{opacity:1;transform:none;}}
@keyframes menuIn{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

/* --- scroll-reveal system (JS adds html.motion + .rv/.in; no-JS = fully visible) --- */
html.motion .rv{opacity:0;transform:translateY(18px);transition:opacity .65s cubic-bezier(.22,1,.36,1),transform .65s cubic-bezier(.22,1,.36,1);transition-delay:calc(var(--i,0)*75ms);}
html.motion .rv.in{opacity:1;transform:none;}

/* --- pause off-screen infinite animations (battery / jank) --- */
.parked::before,.parked::after{animation-play-state:paused;}
.parked .hero-routes .lane,.parked .hero-routes .node,.parked .hero-routes .ping,.parked .dot{animation-play-state:paused;}

/* --- navy statement band for the proof numbers (reuses .close theming) --- */
.close .eyebrow{color:var(--blue-bright);}
.stats-band .head .lede{color:#aebbd6;}
.stats-band .stat b{color:#fff;background:linear-gradient(135deg,#fff,#b9ccff);-webkit-background-clip:text;background-clip:text;}
.stats-band .stat b .plus{color:#ff5b62;-webkit-text-fill-color:#ff5b62;}
.stats-band .stat>span{color:#aebbd6;}
.stats-band .fineprint{color:#8fa0c4;}
@media(min-width:821px){.stats-band .stat+.stat::before{background:rgba(255,255,255,.16);}}
.stats-band .compliance{margin-top:48px;border:0;box-shadow:0 30px 70px rgba(0,0,0,.28);text-align:left;}
.hero__note a{color:#fff;font-weight:600;text-decoration:underline;text-decoration-color:rgba(255,255,255,.35);text-underline-offset:3px;}
.soft .hero__note{color:var(--grey);}

/* --- glass trust chips under hero CTAs --- */
.hero-chips{list-style:none;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:28px 0 0;padding:0;}
.hero-chips li{font-size:13px;font-weight:600;color:#dbe4f7;padding:7px 14px;border-radius:980px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);}

/* --- numbered steps strip (apply funnel) --- */
.steps{list-style:none;counter-reset:step;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;max-width:860px;margin:44px auto 0;padding:0;text-align:left;}
.steps li{position:relative;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.14);border-radius:18px;padding:22px 24px 20px 24px;color:#c3cee8;font-size:15px;line-height:1.5;}
.steps li b{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:50%;background:var(--red);color:#fff;font-size:15px;font-weight:700;margin-bottom:14px;}
.steps li strong{color:#fff;font-weight:600;}
.steps li a{color:#fff;font-weight:600;text-decoration:underline;text-decoration-color:rgba(255,255,255,.35);text-underline-offset:3px;}
@media(max-width:820px){.steps{grid-template-columns:1fr;gap:12px;}.steps li{display:grid;grid-template-columns:34px 1fr;gap:16px;align-items:start;}.steps li b{margin-bottom:0;}}

/* --- copyable application-password keycap --- */
.pass-chip{display:inline-flex;align-items:center;gap:9px;margin-top:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.3);color:#dbe4f7;font-family:inherit;font-size:14px;font-weight:500;padding:10px 18px;border-radius:12px;cursor:pointer;transition:background .2s,border-color .2s;}
.pass-chip:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.5);}
.pass-chip b{color:#fff;font-weight:700;letter-spacing:.04em;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:7px;padding:2px 10px;font-variant-numeric:tabular-nums;}
.pass-chip .cp{font-size:15px;opacity:.8;}
.pass-chip.ok{border-color:#3fd07a;color:#c9f3dc;}
.close .form-note{color:#aebbd6;}

/* --- wide banner card (company-driver path) --- */
.card--wide{grid-column:1/-1;}
.card--wide .card__body{display:flex;align-items:center;gap:12px 34px;flex-wrap:wrap;padding:26px 34px;}
.card--wide .card__body h3{margin:0;}
.card--wide .card__body p{margin:0;flex:1;min-width:240px;}
.card--wide .card__body .tag{width:100%;}

/* --- footer signature watermark --- */
.foot__wm{display:block;font-weight:800;font-size:clamp(44px,9vw,104px);letter-spacing:-.035em;line-height:.95;color:var(--blue);opacity:.07;user-select:none;pointer-events:none;margin:0 0 26px;white-space:nowrap;}
.foot__wm em{font-style:normal;color:var(--red);}
footer .foot a{display:inline-block;padding:5px 0;margin:-5px 0;}

/* --- dock: open cascade + touch ergonomics --- */
.dock__menu .dock__item{opacity:0;transform:translateY(8px);}
.dock.open .dock__menu .dock__item{opacity:1;transform:none;transition:opacity .25s ease,transform .3s cubic-bezier(.22,1,.36,1);}
.dock.open .dock__menu .dock__item:nth-last-child(1){transition-delay:.03s;}
.dock.open .dock__menu .dock__item:nth-last-child(2){transition-delay:.09s;}
.dock.open .dock__menu .dock__item:nth-last-child(3){transition-delay:.15s;}
.dock__toggle:active{transform:scale(.94);}

/* --- touch: no dead hovers, real press feedback --- */
@media(hover:none){
  .card:hover{transform:none;border-color:var(--hair);box-shadow:0 1px 2px rgba(10,26,71,.04),0 10px 30px rgba(10,26,71,.05);}
  .card:hover::after{transform:scaleX(0);}
  .card:hover .card__media.photo img{transform:none;}
  .dock__item:hover{transform:none;}
  .btn:hover{transform:none;box-shadow:0 8px 22px rgba(224,32,43,.25);}
}
@media (prefers-reduced-motion: reduce){
  .btn:active,.dock__toggle:active{transform:none;}
  .dock__menu .dock__item{opacity:1;transform:none;transition:none;}
  .nav.open .nav__menu a{animation:none;}
}
