/* ============================================================
   L1 MOTORSPORTS — design system
   Dark cinematic garage · racing-red accent · Saira Condensed + Inter
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  --bg:#0d0d0f;
  --bg-2:#141519;
  --bg-3:#191b20;
  --card:#16181d;
  --line:rgba(255,255,255,.09);
  --line-2:rgba(255,255,255,.16);
  --text:#f5f5f6;
  --muted:#a4a5ad;
  --muted-2:#8b8c95;
  --accent:#e4222b;
  --accent-h:#ff3b41;
  --accent-ink:#fff;
  --maxw:1240px;
  --pad:clamp(20px,5vw,64px);
  --r:4px;
  --r-lg:6px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 24px 60px -24px rgba(0,0,0,.7);
}

/* ---------- Reset ---------- */
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg);color:var(--text);
  line-height:1.6;font-size:16px;letter-spacing:.01em;
  overflow-x:clip;-webkit-font-smoothing:antialiased;
}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}
::selection{background:var(--accent);color:#fff}

h1,h2,h3,.display{
  font-family:'Saira Condensed',sans-serif;
  font-weight:700;line-height:.95;letter-spacing:.005em;
  text-transform:uppercase;
}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--pad)}
.section{padding-block:clamp(64px,9vw,120px)}
.section-sm{padding-block:clamp(48px,6vw,80px)}
.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-family:'Inter',sans-serif;font-weight:600;font-size:12.5px;
  letter-spacing:.22em;text-transform:uppercase;color:var(--muted);
}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--accent)}
.eyebrow.center::after{content:"";width:26px;height:2px;background:var(--accent)}
.sec-no{
  font-family:'Saira Condensed',sans-serif;font-weight:600;
  color:var(--muted-2);font-size:14px;letter-spacing:.1em;
}
.lead{color:var(--muted);font-size:clamp(16px,1.5vw,18.5px);max-width:60ch;line-height:1.65}
.accent{color:var(--accent)}
.mono{font-variant-numeric:tabular-nums}

/* ---------- Buttons (crisp, no pills) ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-weight:700;font-size:14.5px;letter-spacing:.04em;
  padding:15px 26px;border-radius:var(--r);
  transition:transform .2s var(--ease),background .2s,color .2s,border-color .2s;
  white-space:nowrap;
}
.btn svg{width:17px;height:17px}
.btn-primary{background:var(--accent);color:#fff}
.btn-primary:hover{background:var(--accent-h);transform:translateY(-2px)}
.btn-ghost{border:1.5px solid var(--line-2);color:var(--text)}
.btn-ghost:hover{border-color:#fff;transform:translateY(-2px)}
.btn-light{background:#fff;color:#111}
.btn-light:hover{background:#eee;transform:translateY(-2px)}
.btn-lg{padding:17px 32px;font-size:15px}
.btn-block{width:100%}

/* ---------- Top utility bar ---------- */
.topbar{
  background:#0a0a0b;border-bottom:1px solid var(--line);
  font-size:12.5px;color:var(--muted);
}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;gap:20px;min-height:38px}
.topbar a{color:var(--muted);transition:color .2s}
.topbar a:hover{color:#fff}
.topbar .ti{display:inline-flex;align-items:center;gap:7px}
.topbar .ti svg{width:13px;height:13px;opacity:.7}
.topbar .tstars{color:var(--accent);letter-spacing:1px}
.topbar-right{display:flex;gap:22px;align-items:center}
@media(max-width:820px){.topbar{display:none}}

/* ---------- Header ---------- */
.hdr{
  position:sticky;top:0;z-index:100;
  background:rgba(13,13,15,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:background .3s,border-color .3s;
}
.hdr.scrolled{background:rgba(10,10,11,.94);border-bottom-color:var(--line)}
.hdr .wrap{display:flex;align-items:center;justify-content:space-between;min-height:74px;gap:24px}
.brand{display:flex;align-items:center;gap:13px}
.brand img{height:38px;width:auto}
.brand .tag{
  font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:11px;
  letter-spacing:.34em;color:var(--muted);padding-left:13px;
  border-left:1px solid var(--line-2);text-transform:uppercase;
}
@media(max-width:520px){.brand .tag{display:none}.brand img{height:34px}}
.nav{display:flex;align-items:center;gap:34px}
.nav a{
  font-size:14.5px;font-weight:500;color:var(--muted);letter-spacing:.02em;
  position:relative;padding:6px 0;transition:color .2s;
}
.nav a:hover{color:#fff}
.nav a.active{color:#fff}
.nav a.active::after{
  content:"";position:absolute;left:0;bottom:-2px;width:100%;height:2px;background:var(--accent)
}
.hdr-cta{display:flex;align-items:center;gap:14px}
.hdr-phone{display:inline-flex;align-items:center;gap:8px;font-weight:600;font-size:14.5px}
.hdr-phone svg{width:16px;height:16px;color:var(--accent)}
@media(max-width:980px){.nav,.hdr-phone,.hdr-cta{display:none}}
.burger{display:none;width:44px;height:44px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.burger span{width:24px;height:2px;background:#fff;transition:.3s var(--ease)}
@media(max-width:980px){.burger{display:flex}}
.burger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Mobile menu — display-based (never opacity-only, so it can't vanish) */
.mnav{
  position:fixed;inset:0;z-index:99;background:#0b0b0d;
  display:none;flex-direction:column;padding:96px var(--pad) 40px;
}
.mnav.open{display:flex}
.mnav>a{
  font-family:'Saira Condensed',sans-serif;text-transform:uppercase;
  font-size:34px;font-weight:600;color:var(--text);padding:16px 0;
  border-bottom:1px solid var(--line);display:flex;justify-content:space-between;align-items:center;
}
.mnav>a .idx{font-size:14px;color:var(--muted-2);font-family:'Inter',sans-serif}
.mnav>a.active{color:var(--accent)}
.mnav .m-actions{margin-top:auto;display:flex;flex-direction:column;gap:12px;padding-top:28px}
.mnav .m-meta{margin-top:22px;color:var(--muted);font-size:13.5px;line-height:1.8}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:clamp(600px,92vh,860px);display:flex;align-items:flex-end;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;object-position:center 40%}
.hero-bg::after{
  content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(13,13,15,.72) 0%,rgba(13,13,15,.35) 34%,rgba(13,13,15,.7) 74%,var(--bg) 100%),
             linear-gradient(90deg,rgba(13,13,15,.85) 0%,rgba(13,13,15,.15) 60%);
}
.hero .wrap{position:relative;z-index:2;width:100%;padding-bottom:clamp(52px,7vw,88px);padding-top:80px}
.hero-chip{
  display:inline-flex;align-items:center;gap:10px;margin-bottom:22px;
  background:rgba(255,255,255,.06);border:1px solid var(--line-2);
  padding:8px 15px;border-radius:var(--r);font-size:13px;font-weight:500;
  backdrop-filter:blur(6px);
}
.hero-chip .stars{color:var(--accent);letter-spacing:1px}
.hero-chip b{color:#fff}
.hero h1{
  font-size:clamp(48px,9vw,116px);max-width:15ch;margin-bottom:22px;
}
.hero h1 .thin{-webkit-text-stroke:1.5px rgba(255,255,255,.85);color:transparent;font-weight:600}
.hero p{max-width:48ch;color:#d3d3d7;font-size:clamp(16px,1.7vw,19px);margin-bottom:32px}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;align-items:center}
/* numbered "steps" list — top-align the leading number with the heading */
.svc-list.steps .svc-item{align-items:flex-start}
.svc-list.steps .price{padding-top:1px;line-height:1.05}

/* ---------- Stat / proof band ---------- */
.stats{background:var(--bg);border-block:1px solid var(--line)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:34px var(--pad);border-left:1px solid var(--line);text-align:center}
.stat:first-child{border-left:none}
.stat .n{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:clamp(38px,5vw,58px);line-height:1;letter-spacing:0}
.stat .n .accent{color:var(--accent)}
.stat .l{color:var(--muted);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;margin-top:9px}
@media(max-width:760px){.stats .grid{grid-template-columns:repeat(2,1fr)}.stat:nth-child(-n+2){border-bottom:1px solid var(--line)}.stat:nth-child(odd){border-left:none}}

/* ---------- Section heading block ---------- */
.head{display:flex;justify-content:space-between;align-items:flex-end;gap:30px;margin-bottom:clamp(38px,5vw,60px)}
.head.stack{flex-direction:column;align-items:flex-start}
.head h2{font-size:clamp(34px,5.4vw,64px);margin-top:16px;max-width:18ch}
.head .lead{margin-top:16px}
.head-side{max-width:34ch;flex-shrink:0}
@media(max-width:860px){.head{flex-direction:column;align-items:flex-start}}

/* ---------- Services (asymmetric feature + list) ---------- */
.svc-layout{display:grid;grid-template-columns:1.05fr 1fr;gap:26px}
@media(max-width:900px){.svc-layout{grid-template-columns:1fr}}
.svc-feature{
  position:relative;border-radius:var(--r-lg);overflow:hidden;min-height:420px;
  display:flex;flex-direction:column;justify-content:flex-end;border:1px solid var(--line);
}
.svc-feature img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.svc-feature::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(13,13,15,.1),rgba(13,13,15,.92));z-index:1}
.svc-feature .fc{position:relative;z-index:2;padding:30px}
.svc-feature h3{font-size:34px;margin-bottom:8px}
.svc-feature p{color:#cfcfd4;font-size:14.5px;max-width:40ch}
.svc-list{display:flex;flex-direction:column;gap:0;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.svc-item{
  display:flex;align-items:center;gap:20px;padding:22px 24px;
  border-bottom:1px solid var(--line);background:var(--card);
  transition:background .25s,padding .25s;
}
.svc-item:last-child{border-bottom:none}
.svc-item:hover{background:var(--bg-3);padding-left:30px}
.svc-item .ico{
  width:44px;height:44px;flex-shrink:0;display:flex;align-items:center;justify-content:center;
  border:1px solid var(--line-2);border-radius:var(--r);color:var(--accent);transition:.25s;
}
.svc-item:hover .ico{background:var(--accent);color:#fff;border-color:var(--accent)}
.svc-item .ico svg{width:22px;height:22px}
.svc-item .tx{flex:1}
.svc-item .tx h4{font-family:'Inter',sans-serif;text-transform:none;font-size:16.5px;font-weight:600;letter-spacing:0}
.svc-item .tx p{color:var(--muted);font-size:13.5px;margin-top:2px}
.svc-item .price{font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:20px;color:#fff;white-space:nowrap}
.svc-item .price small{display:block;font-size:10.5px;color:var(--muted-2);letter-spacing:.1em;text-transform:uppercase;font-family:'Inter',sans-serif;font-weight:500}

/* ---------- Service cards grid (services page) ---------- */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:900px){.cards{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.cards{grid-template-columns:1fr}}
.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  padding:30px 26px;transition:border-color .25s,transform .25s,background .25s;position:relative;overflow:hidden
}
.card::before{content:"";position:absolute;left:0;top:0;width:0;height:3px;background:var(--accent);transition:width .3s var(--ease)}
.card:hover{border-color:var(--line-2);transform:translateY(-4px)}
.card:hover::before{width:100%}
.card .ico{width:50px;height:50px;display:flex;align-items:center;justify-content:center;border:1px solid var(--line-2);border-radius:var(--r);color:var(--accent);margin-bottom:20px}
.card .ico svg{width:26px;height:26px}
.card h3{font-size:24px;margin-bottom:10px}
.card p{color:var(--muted);font-size:14.5px;line-height:1.6}
.card .clist{margin-top:16px;display:flex;flex-direction:column;gap:8px}
.card .clist li{display:flex;gap:10px;font-size:13.5px;color:#c7c7cd}
.card .clist li::before{content:"";width:6px;height:6px;background:var(--accent);flex-shrink:0;margin-top:7px;transform:rotate(45deg)}
.card .cprice{margin-top:20px;padding-top:18px;border-top:1px solid var(--line);display:flex;align-items:baseline;gap:8px}
.card .cprice .amt{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:30px}
.card .cprice .from{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.14em}

/* ---------- Marque rail ---------- */
.marque{border-block:1px solid var(--line);overflow:hidden;background:var(--bg-2)}
.marque .inner{display:flex;align-items:center;gap:56px;padding:26px 0;white-space:nowrap;animation:scrollx 34s linear infinite;width:max-content}
.marque:hover .inner{animation-play-state:paused}
.marque .m{font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:26px;letter-spacing:.06em;color:#54555c;text-transform:uppercase;transition:color .3s}
.marque .m:hover{color:var(--text)}
@keyframes scrollx{to{transform:translateX(-50%)}}

/* ---------- Work rail (horizontal scroll — KILLER real content) ---------- */
.rail-wrap{position:relative}
.rail{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;padding-bottom:18px;-webkit-overflow-scrolling:touch;cursor:grab}
.rail.drag{cursor:grabbing;scroll-snap-type:none}
.rail::-webkit-scrollbar{height:4px}
.rail::-webkit-scrollbar-track{background:var(--line)}
.rail::-webkit-scrollbar-thumb{background:var(--accent)}
.rail-card{flex:0 0 clamp(280px,34vw,420px);scroll-snap-align:start;position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:4/3;background:var(--bg-3)}
.rail-card img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.rail-card:hover img{transform:scale(1.05)}
.rail-card .cap{position:absolute;inset:auto 0 0 0;padding:44px 20px 18px;background:linear-gradient(transparent,rgba(13,13,15,.94));z-index:2}
.rail-card .cap .car{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;font-weight:600;font-size:21px}
.rail-card .cap .job{color:var(--accent);font-size:12.5px;font-weight:600;letter-spacing:.06em;margin-top:3px}
.rail-hint{display:flex;align-items:center;gap:10px;color:var(--muted-2);font-size:12px;letter-spacing:.18em;text-transform:uppercase;margin-top:18px}
.rail-hint svg{width:24px;height:12px}

/* ---------- Why / z-pattern ---------- */
.zrow{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px);align-items:center;margin-bottom:clamp(48px,6vw,88px)}
.zrow:last-child{margin-bottom:0}
.zrow.rev .zimg{order:2}
@media(max-width:860px){.zrow{grid-template-columns:1fr;gap:28px}.zrow.rev .zimg{order:0}}
.zimg{position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);aspect-ratio:5/4}
.zimg img{width:100%;height:100%;object-fit:cover}
.zimg .badge{position:absolute;left:18px;bottom:18px;background:var(--accent);color:#fff;font-family:'Saira Condensed',sans-serif;text-transform:uppercase;font-weight:600;font-size:14px;padding:7px 14px;border-radius:var(--r);letter-spacing:.04em}
.zbody h3{font-size:clamp(28px,4vw,44px);margin-bottom:16px}
.zbody p{color:var(--muted);margin-bottom:14px}
.feat-list{display:flex;flex-direction:column;gap:14px;margin-top:22px}
.feat-list li{display:flex;gap:14px;align-items:flex-start}
.feat-list .fi{width:34px;height:34px;flex-shrink:0;border:1px solid var(--line-2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.feat-list .fi svg{width:18px;height:18px}
.feat-list h4{font-family:'Inter',sans-serif;text-transform:none;font-size:15.5px;font-weight:600}
.feat-list p{font-size:13.5px;color:var(--muted);margin:2px 0 0}

/* ---------- Pricing band ---------- */
.priceband{background:var(--bg-2);border-block:1px solid var(--line)}
.pb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:760px){.pb-grid{grid-template-columns:1fr}}
.pb{border:1px solid var(--line);border-radius:var(--r-lg);padding:28px;background:var(--card);position:relative}
.pb .tag{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.pb .amt{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:52px;line-height:1;margin:12px 0 4px;display:flex;align-items:baseline;gap:6px}
.pb .amt .cur{font-size:24px;color:var(--muted)}
.pb .amt .from{font-size:12px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;align-self:flex-start;margin-left:2px}
.pb p{color:var(--muted);font-size:14px;margin-top:6px}

/* ---------- CTA / location ---------- */
.cta{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--bg-2)}
.cta-grid{display:grid;grid-template-columns:1.1fr .9fr}
@media(max-width:860px){.cta-grid{grid-template-columns:1fr}}
.cta-body{padding:clamp(34px,5vw,58px)}
.cta-body h2{font-size:clamp(32px,4.6vw,56px);margin-bottom:18px}
.cta-body p{color:var(--muted);margin-bottom:28px;max-width:44ch}
.cta-actions{display:flex;flex-wrap:wrap;gap:14px}
.cta-map{position:relative;min-height:300px;border-left:1px solid var(--line)}
@media(max-width:860px){.cta-map{border-left:none;border-top:1px solid var(--line);min-height:260px}}
.cta-map iframe{position:absolute;inset:0;width:100%;height:100%;border:0;filter:grayscale(1) invert(.92) contrast(.92)}
.info-row{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}
.info-row .ii{width:38px;height:38px;flex-shrink:0;border:1px solid var(--line-2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--accent)}
.info-row .ii svg{width:18px;height:18px}
.info-row b{display:block;font-weight:600;font-size:15px}
.info-row span{color:var(--muted);font-size:14px}

/* ---------- Footer ---------- */
.ftr{background:#0a0a0b;border-top:1px solid var(--line);padding-block:clamp(52px,7vw,80px) 30px}
.ftr-top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.1fr;gap:40px;padding-bottom:48px;border-bottom:1px solid var(--line)}
@media(max-width:860px){.ftr-top{grid-template-columns:1fr 1fr;gap:34px}}
@media(max-width:520px){.ftr-top{grid-template-columns:1fr}}
.ftr-brand img{height:42px;margin-bottom:18px}
.ftr-brand .tag{font-family:'Saira Condensed',sans-serif;text-transform:uppercase;letter-spacing:.3em;color:var(--accent);font-size:13px;font-weight:600;margin-bottom:14px}
.ftr-brand p{color:var(--muted);font-size:14px;max-width:34ch}
.ftr h5{font-family:'Inter',sans-serif;text-transform:uppercase;letter-spacing:.14em;font-size:12.5px;color:var(--muted-2);margin-bottom:18px;font-weight:600}
.ftr-links a{display:block;color:var(--muted);font-size:14.5px;padding:9px 0;transition:color .2s}
.ftr-links a:hover{color:#fff}
.ftr-contact li{color:var(--muted);font-size:14px;margin-bottom:12px;display:flex;gap:10px;align-items:flex-start}
.ftr-contact svg{width:16px;height:16px;color:var(--accent);flex-shrink:0;margin-top:3px}
.ftr-social{display:flex;gap:12px;margin-top:18px}
.ftr-social a{width:44px;height:44px;border:1px solid var(--line-2);border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--muted);transition:.2s}
.ftr-social a:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.ftr-social svg{width:18px;height:18px}
.ftr-bot{display:flex;justify-content:space-between;align-items:center;gap:16px;padding-top:26px;flex-wrap:wrap}
.ftr-bot p{color:var(--muted-2);font-size:13px}
.ftr-bot a{color:var(--muted);border-bottom:1px solid var(--accent)}

/* ---------- Page hero (interior pages) ---------- */
.phero{position:relative;padding-block:clamp(120px,16vw,180px) clamp(50px,7vw,80px);overflow:hidden;border-bottom:1px solid var(--line)}
.phero::before{content:"";position:absolute;inset:0;background:radial-gradient(120% 100% at 80% 0%,rgba(228,34,43,.14),transparent 60%);z-index:0}
.phero .wrap{position:relative;z-index:2}
.phero h1{font-size:clamp(46px,8vw,92px);margin:18px 0 18px}
.phero .crumb{color:var(--muted);font-size:13px;letter-spacing:.05em}
.phero .crumb a:hover{color:#fff}
.phero .crumb .accent{color:var(--accent)}
.phero p{max-width:56ch;color:var(--muted);font-size:clamp(16px,1.6vw,18px)}

/* ---------- Forms ---------- */
.form{display:flex;flex-direction:column;gap:16px}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.form .row{grid-template-columns:1fr}}
.field label{display:block;font-size:12.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-weight:600}
.field input,.field select,.field textarea{
  width:100%;background:var(--bg-3);border:1px solid var(--line);border-radius:var(--r);
  padding:14px 15px;color:var(--text);font-family:inherit;font-size:15px;transition:border-color .2s,background .2s;
}
.field textarea{resize:vertical;min-height:130px}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--accent);background:#1c1e24}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%23a4a5ad' stroke-width='1.6' fill='none'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 15px center;padding-right:40px}
.form-note{color:var(--muted-2);font-size:12.5px}
.form-ok{display:none;padding:16px;border:1px solid var(--accent);border-radius:var(--r);background:rgba(228,34,43,.08);color:#fff;font-size:14.5px}
.form-ok.show{display:block}

/* ---------- Contact split ---------- */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,64px);align-items:start}
@media(max-width:900px){.contact-grid{grid-template-columns:1fr}}

/* ---------- FAQ / review strip ---------- */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
@media(max-width:860px){.reviews{grid-template-columns:1fr}}
.rev{background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);padding:26px}
.rev .stars{color:var(--accent);letter-spacing:2px;font-size:15px;margin-bottom:12px}
.rev p{font-size:15px;color:#e3e3e6;line-height:1.65}
.rev .by{margin-top:16px;color:var(--muted);font-size:13px;display:flex;align-items:center;gap:8px}
.rev .by b{color:#fff;font-weight:600}

/* ---------- Reveal (fail-safe: only when html.js) ---------- */
html.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
html.js .reveal.in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){html.js .reveal{opacity:1!important;transform:none!important;transition:none}}

/* ---------- misc ---------- */
.divider{height:1px;background:var(--line)}
.text-center{text-align:center}
.mt-cta{margin-top:clamp(38px,5vw,56px)}
.tick-list{display:grid;grid-template-columns:1fr 1fr;gap:14px 26px;margin-top:8px}
@media(max-width:600px){.tick-list{grid-template-columns:1fr}}
.tick-list li{display:flex;gap:12px;font-size:15px;color:#d3d3d7}
.tick-list li svg{width:20px;height:20px;color:var(--accent);flex-shrink:0;margin-top:2px}

/* Touch devices: don't latch hover-lift transforms on tap */
@media (hover:none){
  .card:hover,.btn:hover,.btn-primary:hover,.btn-ghost:hover,.btn-light:hover{transform:none}
  .rail-card:hover img{transform:none}
}
