/* =====================================================================
   DMP AWNINGS — site stylesheet  (standalone static build)
   Design system carried over 1:1 from the original dark "motorsports"
   theme, with the WordPress/Avada wrapper hacks removed and a set of
   new components added for the expanded SEO pages.
   Built by SHIFT Design — https://www.shiftdesignmn.com
   ===================================================================== */

:root{
  --bg:#0b0c0e;
  --bg-2:#101216;
  --surface:#15181e;
  --surface-2:#1b1f27;
  --line:#262b34;
  --line-soft:#1e222a;
  --ink:#eef1f5;
  --ink-2:#aab0bb;
  --ink-3:#7c838f;       /* faint labels — bumped to clear WCAG AA on light panels */
  --steel:#cfd5dd;
  --accent:#4fb7ec;      /* light blue — accents, icons, eyebrows, hairlines on dark */
  --accent-2:#9bd9f5;
  --accent-d:#2f9ad4;
  --btn:#1577b8;         /* button fill — darkened so white label text passes WCAG AA (4.8:1) */
  --btn-d:#156fa9;
  --cta:#0e6aa6;         /* deep blue CTA band */
  --maxw:1240px;
  --ease:cubic-bezier(.16,1,.3,1);
  --hero:url("assets/img/race-trailer-awning-trackside.jpg");
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
/* visible keyboard focus (WCAG 2.4.7) — pointer users unaffected via :focus-visible */
a:focus-visible,button:focus-visible,summary:focus-visible,input:focus-visible,
select:focus-visible,textarea:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--accent);outline-offset:3px;border-radius:2px}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:'Saira',system-ui,sans-serif;
  font-size:17px;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
body::before{
  content:"";position:fixed;inset:0;z-index:0;pointer-events:none;
  background:
    radial-gradient(900px 500px at 80% -10%, rgba(79,183,236,.13), transparent 70%),
    radial-gradient(700px 600px at -5% 10%, rgba(80,120,180,.05), transparent 60%);
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 28px;position:relative;z-index:1}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}

/* ---------- type ---------- */
h1,h2,h3,.cond{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;letter-spacing:.01em;line-height:.98}
.eyebrow{
  font-family:'Space Mono',monospace;font-size:12.5px;letter-spacing:.28em;
  text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:12px;
}
.eyebrow::before{content:"";width:30px;height:2px;background:var(--accent)}
.eyebrow.center::before{display:none}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;cursor:pointer;border:none;
  font-family:'Saira',sans-serif;font-weight:700;font-size:14px;letter-spacing:.06em;
  text-transform:uppercase;padding:15px 26px;color:#fff;background:var(--btn);
  clip-path:polygon(0 0,100% 0,100% 100%,12px 100%);transition:.3s var(--ease);position:relative;
}
.btn:hover{background:var(--btn-d);transform:translateY(-2px)}
.btn .ar{transition:.3s var(--ease)}
.btn:hover .ar{transform:translateX(4px)}
.btn.ghost{background:transparent;color:var(--ink);border:1px solid var(--line);clip-path:none}
.btn.ghost:hover{background:var(--surface-2);border-color:var(--steel)}
.btn.lg{padding:18px 32px;font-size:15px}

/* ---------- header ---------- */
header{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(11,12,14,.72);backdrop-filter:blur(14px);
  border-bottom:1px solid transparent;transition:.4s var(--ease);
}
header.scrolled{background:rgba(11,12,14,.94);border-bottom-color:var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:84px;transition:.4s var(--ease)}
header.scrolled .nav{height:68px}
.logo{display:flex;align-items:center}
.logo img{height:42px;width:auto;transition:.4s var(--ease)}
.logo-txt{display:none;align-items:baseline;gap:6px;font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:800;font-size:1.7rem;text-transform:uppercase;color:#fff;letter-spacing:.02em;line-height:1}
.logo-txt i{font-style:normal;font-weight:600;color:var(--accent);font-size:1.1rem;letter-spacing:.14em}
header.scrolled .logo img{height:36px}
.nav-links{display:flex;align-items:center;gap:28px;list-style:none}
.nav-links a{
  font-size:13.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-2);
  position:relative;padding:4px 0;transition:.25s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--accent);transition:.3s var(--ease)}
.nav-links a:hover{color:var(--ink)}
.nav-links a:hover::after,.nav-links a.active::after{width:100%}
.nav-links a.active{color:var(--ink)}
.nav-cta{display:flex;align-items:center;gap:20px}
.nav-phone{font-family:'Space Mono',monospace;font-size:14px;color:var(--steel);white-space:nowrap}
.nav-phone span{color:var(--ink-3);font-size:11px;display:block;letter-spacing:.18em}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* ---------- hero ---------- */
.hero{position:relative;min-height:82vh;display:flex;align-items:center;padding:150px 0 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;background:var(--hero) center/cover no-repeat;z-index:0}
.hero-bg::after{content:"";position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(11,12,14,.55) 0%,rgba(11,12,14,.35) 38%,rgba(11,12,14,.86) 82%,var(--bg) 100%),
  linear-gradient(90deg,rgba(11,12,14,.7),transparent 55%);}
.hero-grid{position:absolute;inset:0;z-index:1;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.035) 1px,transparent 1px);
  background-size:64px 64px;mask-image:linear-gradient(180deg,transparent,#000 40%,#000 70%,transparent)}
.hero .wrap{width:100%}
.hero-inner{max-width:880px}
.hero h1{
  font-size:clamp(3.4rem,9.2vw,8.2rem);font-weight:800;text-transform:uppercase;
  margin:22px 0 0;color:#fff;text-shadow:0 4px 40px rgba(0,0,0,.5)
}
.hero h1 em{font-style:normal;color:var(--accent)}
.hero h1 .ln{display:block;overflow:hidden}
.hero h1 .ln>span{display:block;transform:translateY(105%);animation:rise .9s var(--ease) forwards}
.hero h1 .ln:nth-child(2)>span{animation-delay:.12s}
@keyframes rise{to{transform:translateY(0)}}
.hero-sub{max-width:640px;color:var(--ink-2);font-size:18.5px;margin:26px 0 34px;
  opacity:0;animation:fade .8s .5s var(--ease) forwards}
@keyframes fade{to{opacity:1}}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;opacity:0;animation:fade .8s .7s var(--ease) forwards}
.hero-stats{display:flex;flex-wrap:wrap;gap:0;margin-top:54px;border-top:1px solid var(--line);
  opacity:0;animation:fade .8s .9s var(--ease) forwards}
.hero-stats div{padding:20px 34px 4px 0;margin-right:34px;border-right:1px solid var(--line)}
.hero-stats div:last-child{border-right:none}
.hero-stats .k{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.16em;color:var(--accent);text-transform:uppercase}
.hero-stats .v{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.15rem;text-transform:uppercase;color:var(--steel);letter-spacing:.02em}

/* ---------- section frame ---------- */
section{position:relative;padding:108px 0;background:var(--bg)}
.sec-head{max-width:760px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head.center .eyebrow{justify-content:center}
.sec-head h2{font-size:clamp(2.3rem,5vw,4rem);font-weight:800;text-transform:uppercase;margin:16px 0 0;color:#fff}
.sec-head h2 em{font-style:normal;color:var(--accent)}
.sec-head p{color:var(--ink-2);margin-top:18px;font-size:18px}
.divider{height:1px;background:var(--line);max-width:var(--maxw);margin:0 auto}

/* ---------- trust strip ---------- */
.trust{background:var(--bg);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:14px 34px;padding:20px 28px}
.trust span{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--ink-2);display:inline-flex;align-items:center;gap:12px}
.trust span b{color:var(--accent);font-weight:700}
.trust span::before{content:"";width:6px;height:6px;background:var(--accent);transform:rotate(45deg)}

/* ---------- about ---------- */
.about{background:var(--bg-2)}
.about-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:64px;align-items:center}
.about-copy p{color:var(--ink-2);margin-top:18px;font-size:18px}
.about-copy strong{color:var(--ink)}
.about-card{background:var(--surface);border:1px solid var(--line);padding:38px;position:relative;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 26px),calc(100% - 26px) 100%,0 100%)}
.about-card .tag{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.2em;color:var(--accent);text-transform:uppercase}
.about-card h3{font-size:2rem;font-weight:700;text-transform:uppercase;margin:14px 0 10px;color:#fff}
.about-card p{color:var(--ink-2);font-size:16px}
.about-card .who{display:flex;align-items:center;gap:14px;margin-top:26px;padding-top:22px;border-top:1px solid var(--line)}
.about-card .who .badge{width:46px;height:46px;flex:none;display:grid;place-items:center;background:var(--btn);
  font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:800;font-size:1.3rem;color:#fff}
.about-card .who b{display:block;color:var(--ink);font-size:15px}
.about-card .who span{font-size:13px;color:var(--ink-3)}

/* ---------- features / specs ---------- */
.spec-banner{display:inline-flex;align-items:center;gap:10px;background:rgba(79,183,236,.12);
  border:1px solid rgba(79,183,236,.4);color:#8fd3f5;padding:8px 16px;font-family:'Space Mono',monospace;
  font-size:12px;letter-spacing:.14em;text-transform:uppercase;margin-bottom:22px}
.spec-banner .dot{width:8px;height:8px;background:var(--accent);border-radius:50%}
.spec-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.spec{background:var(--surface);padding:30px 28px;transition:.3s var(--ease);position:relative}
.spec:hover{background:var(--surface-2)}
.spec .no{font-family:'Space Mono',monospace;font-size:12px;color:var(--ink-3);letter-spacing:.1em}
.spec h4{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.4rem;text-transform:uppercase;margin:10px 0 8px;color:#fff;line-height:1.02}
.spec p{font-size:14.5px;color:var(--ink-2);line-height:1.55}
.spec .std{display:inline-block;margin-top:14px;font-family:'Space Mono',monospace;font-size:10.5px;
  letter-spacing:.12em;text-transform:uppercase;color:var(--accent);border:1px solid rgba(79,183,236,.4);padding:3px 9px}
.spec::before{content:"";position:absolute;left:0;top:0;width:3px;height:0;background:var(--accent);transition:.35s var(--ease)}
.spec:hover::before{height:100%}

/* ---------- options strip ---------- */
.options{background:var(--bg-2)}
.opt-row{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.opt{border:1px solid var(--line);padding:34px 30px;background:var(--surface);
  clip-path:polygon(0 0,calc(100% - 22px) 0,100% 22px,100% 100%,0 100%)}
.opt .ico{width:52px;height:52px;display:grid;place-items:center;border:1px solid var(--accent);color:var(--accent);margin-bottom:20px}
.opt .ico svg{width:26px;height:26px}
.opt h4{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.6rem;text-transform:uppercase;color:#fff;margin-bottom:8px}
.opt p{color:var(--ink-2);font-size:15px}

/* ---------- capabilities ---------- */
.caps-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.cap{background:var(--surface);padding:40px 38px;display:flex;gap:24px;align-items:flex-start;transition:.3s var(--ease)}
.cap:hover{background:var(--surface-2)}
.cap .n{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:800;font-size:2.4rem;color:var(--line);line-height:.8;transition:.3s}
.cap:hover .n{color:var(--accent)}
.cap h4{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.55rem;text-transform:uppercase;color:#fff;margin-bottom:8px}
.cap p{color:var(--ink-2);font-size:15.5px}

/* ---------- applications band ---------- */
.apps{background:var(--bg-2);text-align:center}
.apps .wrap{max-width:980px}
.apps h2{font-size:clamp(1.8rem,4vw,3rem);font-weight:700;text-transform:uppercase;color:#fff;margin:18px 0 30px}
.app-tags{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.app-tags span{border:1px solid var(--line);padding:12px 22px;font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:600;
  font-size:1.2rem;text-transform:uppercase;letter-spacing:.03em;color:var(--steel);transition:.3s var(--ease)}
.app-tags span:hover{border-color:var(--accent);color:#fff;background:rgba(79,183,236,.07)}

/* ---------- gallery ---------- */
.gal-grid{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:220px;gap:14px}
.gal-item{position:relative;overflow:hidden;cursor:pointer;background:var(--surface);border:1px solid var(--line)}
.gal-item img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease);filter:grayscale(.15)}
.gal-item:hover img{transform:scale(1.08);filter:grayscale(0)}
.gal-item::after{content:"";position:absolute;inset:0;background:linear-gradient(transparent 55%,rgba(11,12,14,.55));opacity:0;transition:.3s}
.gal-item:hover::after{opacity:1}
.gal-item.tall{grid-row:span 2}
.gal-item.wide{grid-column:span 2}
.gal-plus{position:absolute;right:14px;bottom:14px;width:34px;height:34px;display:grid;place-items:center;
  background:var(--btn);color:#fff;font-size:20px;opacity:0;transform:translateY(8px);transition:.3s var(--ease);z-index:2}
.gal-item:hover .gal-plus{opacity:1;transform:translateY(0)}

/* ---------- race team ---------- */
.team{background:linear-gradient(180deg,var(--bg-2),var(--bg));position:relative;overflow:hidden}
.team::before{content:"DMP";position:absolute;right:-3%;top:50%;transform:translateY(-50%);
  font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:800;font-size:34vw;color:#fff;opacity:.025;line-height:1;pointer-events:none}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.team-copy h2{font-size:clamp(2.2rem,5vw,3.8rem);font-weight:800;text-transform:uppercase;color:#fff;margin:16px 0 0}
.team-copy h2 em{font-style:normal;color:var(--accent)}
.team-copy p{color:var(--ink-2);font-size:18px;margin-top:20px}
.team-stats{display:flex;gap:40px;margin-top:32px}
.team-stats .v{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:800;font-size:2.6rem;color:var(--accent);line-height:1}
.team-stats .k{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-top:6px}
.video-frame{position:relative;border:1px solid var(--line);background:#000;aspect-ratio:16/9;
  clip-path:polygon(0 0,100% 0,100% calc(100% - 26px),calc(100% - 26px) 100%,0 100%)}
.video-frame iframe{width:100%;height:100%;border:0}
.video-cap{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-top:14px}

/* ---------- documents / video utility ---------- */
.docs{background:var(--bg-2)}
.docs-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:center}
.docs-list{list-style:none}
.docs-list li{display:flex;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--line)}
.docs-list li:first-child{border-top:1px solid var(--line)}
.docs-list .ic{width:40px;height:40px;flex:none;border:1px solid var(--accent);color:var(--accent);display:grid;place-items:center}
.docs-list b{display:block;color:var(--ink);font-size:16px;font-weight:600}
.docs-list span{font-size:13.5px;color:var(--ink-3)}
.docs-list a{margin-left:auto;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);white-space:nowrap}

/* ---------- quote cta ---------- */
.cta{background:var(--cta);position:relative;overflow:hidden}
.cta::before{content:"";position:absolute;inset:0;opacity:.16;
  background-image:repeating-linear-gradient(45deg,#000 0 2px,transparent 2px 22px)}
.cta .wrap{position:relative;text-align:center;padding:20px 0}
.cta h2{font-size:clamp(2.4rem,6vw,5rem);font-weight:800;text-transform:uppercase;color:#fff}
.cta p{color:rgba(255,255,255,.92);font-size:19px;margin:16px auto 32px;max-width:560px}
.cta .btn{background:#0b0c0e;color:#fff}
.cta .btn:hover{background:#000}

/* ---------- contact / footer ---------- */
.contact{background:var(--bg)}
.contact-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px}
.contact h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;text-transform:uppercase;color:#fff;margin:14px 0 22px}
.cinfo{display:grid;gap:2px;margin-top:10px}
.cinfo a,.cinfo div{display:flex;gap:16px;align-items:flex-start;padding:18px 0;border-bottom:1px solid var(--line);transition:.25s}
.cinfo a:hover{color:var(--accent)}
.cinfo .ic{width:22px;color:var(--accent);flex:none;margin-top:3px}
.cinfo .lab{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3)}
.cinfo .val{font-size:17px;color:var(--ink)}
.qform{background:var(--surface);border:1px solid var(--line);padding:34px}
.qform h3{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.7rem;text-transform:uppercase;color:#fff;margin-bottom:6px}
.qform p{color:var(--ink-3);font-size:14px;margin-bottom:22px}
.qform label{display:block;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin:14px 0 6px}
.qform input,.qform select,.qform textarea{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--ink);
  font-family:'Saira',sans-serif;font-size:15px;padding:13px 14px;transition:.25s}
.qform input:focus,.qform select:focus,.qform textarea:focus{outline:none;border-color:var(--accent)}
.qform .btn{width:100%;justify-content:center;margin-top:22px;clip-path:none}
.qform button[disabled],.btn[disabled]{opacity:.6;cursor:default;transform:none}
/* honeypot (hidden from people, catches bots) */
.hp{position:absolute!important;left:-9999px!important;top:auto;width:1px;height:1px;overflow:hidden;opacity:0;pointer-events:none}
/* async form status line */
.form-status{font-family:'Space Mono',monospace;font-size:13px;letter-spacing:.02em;line-height:1.5;margin-top:14px;min-height:1.2em}
.form-status.sending{color:var(--ink-3)}
.form-status.ok{color:var(--accent)}
.form-status.err{color:#ff6b6b}
.form-status a{color:inherit;text-decoration:underline}

footer{background:var(--bg-2);border-top:1px solid var(--line);padding:56px 0 30px}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--line)}
.foot-brand img{height:46px;margin-bottom:18px}
.foot-brand p{color:var(--ink-3);font-size:14.5px;max-width:320px}
.foot-col h5{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.foot-col a,.foot-col div{display:block;color:var(--ink-2);font-size:14.5px;padding:5px 0;transition:.2s}
.foot-col a:hover{color:var(--ink)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;padding-top:26px}
.foot-bottom p{color:var(--ink-3);font-size:13px}
.foot-bottom a{color:var(--ink-2)}
.foot-bottom a:hover{color:var(--accent)}
.fb{width:36px;height:36px;border:1px solid var(--line);display:grid;place-items:center;color:var(--ink-2);transition:.25s}
.fb:hover{border-color:var(--accent);color:var(--accent)}

/* ---------- reveal ---------- */
.rv{opacity:1;transform:none;transition:opacity .8s var(--ease),transform .8s var(--ease)}
.js .rv{opacity:0;transform:translateY(28px)}
.js .rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.08s}.rv.d2{transition-delay:.16s}.rv.d3{transition-delay:.24s}
@media (prefers-reduced-motion:reduce){.js .rv{opacity:1;transform:none;transition:none}}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;z-index:200;background:rgba(7,8,9,.94);display:none;align-items:center;justify-content:center;padding:40px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:88vh;border:1px solid var(--line)}
.lb-close{position:absolute;top:24px;right:30px;color:#fff;font-size:34px;cursor:pointer;font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif}

/* ============ INNER PAGE COMPONENTS ============ */
/* sub-page hero */
.subhero{position:relative;padding:150px 0 64px;border-bottom:1px solid var(--line);overflow:hidden;background:var(--bg-2)}
.subhero.has-img .subhero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;opacity:.22}
.subhero::before{content:"";position:absolute;inset:0;z-index:0;opacity:.5;pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px);
  background-size:60px 60px;mask-image:radial-gradient(120% 100% at 50% 0,#000,transparent 75%)}
.subhero::after{content:"";position:absolute;right:-6%;top:-40%;width:560px;height:560px;border-radius:50%;
  background:radial-gradient(circle,rgba(79,183,236,.14),transparent 65%);pointer-events:none}
.subhero .wrap{position:relative;z-index:1}
.crumb{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);margin-bottom:18px}
.crumb a{color:var(--ink-3)}.crumb a:hover{color:var(--accent)}
.crumb span{color:var(--accent)}
.subhero h1{font-size:clamp(2.6rem,6.5vw,5.2rem);font-weight:800;text-transform:uppercase;color:#fff;margin:14px 0 0;line-height:.96}
.subhero h1 em{font-style:normal;color:var(--accent)}
.subhero p{max-width:640px;color:var(--ink-2);font-size:18.5px;margin-top:20px}

.lead{max-width:820px;color:var(--ink-2);font-size:19px}
.lead strong{color:var(--ink)}

/* generic two-col */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.wide-left{grid-template-columns:1.15fr .85fr}
.split.wide-right{grid-template-columns:.85fr 1.15fr}
.split img,.split .ph{width:100%;border:1px solid var(--line);background:var(--surface);object-fit:cover;aspect-ratio:4/3}
.split.tall img{aspect-ratio:3/4}
.block-num{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:800;font-size:3rem;color:var(--line);line-height:.8}

/* process steps */
.process{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.process.cols4{grid-template-columns:repeat(4,1fr)}
.process.cols3{grid-template-columns:repeat(3,1fr)}
.step{background:var(--surface);padding:30px 24px;position:relative;transition:.3s var(--ease)}
.step:hover{background:var(--surface-2)}
.step .sn{font-family:'Space Mono',monospace;font-size:12px;color:var(--accent);letter-spacing:.1em}
.step h4{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.35rem;text-transform:uppercase;color:#fff;margin:12px 0 8px;line-height:1.02}
.step p{font-size:14px;color:var(--ink-2)}

/* faq accordion */
.faq{border-top:1px solid var(--line);max-width:880px}
.faq.full{max-width:none}
.faq details{border-bottom:1px solid var(--line)}
.faq summary{list-style:none;cursor:pointer;padding:24px 0;display:flex;justify-content:space-between;align-items:center;gap:20px;
  font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.5rem;text-transform:uppercase;color:#fff;transition:.25s}
.faq summary::-webkit-details-marker{display:none}
.faq summary:hover{color:var(--accent)}
.faq summary .pm{flex:none;width:30px;height:30px;border:1px solid var(--line);display:grid;place-items:center;color:var(--accent);font-size:20px;transition:.3s var(--ease)}
.faq details[open] summary .pm{transform:rotate(45deg);border-color:var(--accent)}
.faq .ans{padding:0 0 26px;color:var(--ink-2);font-size:16.5px;max-width:820px}
.faq .ans a{color:var(--accent)}

/* color chips */
.chips{display:flex;flex-wrap:wrap;gap:14px}
.chip{display:flex;flex-direction:column;align-items:center;gap:8px}
.chip .sw{width:64px;height:64px;border:1px solid var(--line)}
.chip span{font-family:'Space Mono',monospace;font-size:10.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}

/* map */
.map-embed{border:1px solid var(--line);aspect-ratio:16/10;width:100%;filter:grayscale(.3) contrast(1.05);background:var(--surface)}
.map-embed iframe{width:100%;height:100%;border:0;display:block}

/* big quote */
.bigquote{max-width:900px;margin:0 auto;text-align:center}
.bigquote q{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:clamp(1.8rem,4.2vw,3rem);color:#fff;line-height:1.1;text-transform:uppercase;quotes:none}
.bigquote .src{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-top:22px}

/* ============ NEW SEO-PAGE COMPONENTS ============ */
/* pillar / service cards (3-up) */
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.pillars.cols2{grid-template-columns:repeat(2,1fr)}
.pillar{background:var(--surface);border:1px solid var(--line);display:flex;flex-direction:column;
  clip-path:polygon(0 0,calc(100% - 22px) 0,100% 22px,100% 100%,0 100%);transition:.3s var(--ease)}
.pillar:hover{background:var(--surface-2);transform:translateY(-3px)}
.pillar .pillar-img{aspect-ratio:16/10;width:100%;overflow:hidden;background:var(--bg)}
.pillar .pillar-img img{width:100%;height:100%;object-fit:cover;transition:.6s var(--ease);filter:grayscale(.12)}
.pillar:hover .pillar-img img{transform:scale(1.06);filter:grayscale(0)}
.pillar .pillar-body{padding:28px 28px 30px;display:flex;flex-direction:column;flex:1}
.pillar .tagk{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent)}
.pillar h3{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.7rem;text-transform:uppercase;color:#fff;margin:10px 0 8px;line-height:1.04}
.pillar p{color:var(--ink-2);font-size:15px;flex:1}
.pillar .more{margin-top:18px;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:8px}
.pillar .more .ar{transition:.3s var(--ease)}
.pillar:hover .more .ar{transform:translateX(4px)}

/* checklist / bullet feature list */
.checklist{list-style:none;display:grid;gap:14px;max-width:820px}
.checklist.two{grid-template-columns:1fr 1fr;gap:14px 40px}
.checklist li{display:flex;gap:14px;align-items:flex-start;color:var(--ink-2);font-size:16px}
.checklist li::before{content:"";flex:none;width:20px;height:20px;margin-top:3px;border:1px solid var(--accent);
  background:rgba(79,183,236,.1);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 12l5 5L20 6' fill='none' stroke='%234fb7ec' stroke-width='2.5'/%3E%3C/svg%3E") center/14px no-repeat;}
.checklist li::before{content:"\2713";display:grid;place-items:center;color:var(--accent);font-size:12px;font-weight:700;-webkit-mask:none}
.checklist li strong{color:var(--ink)}

/* comparison table */
.table-wrap{max-width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
.compare{width:100%;border-collapse:collapse;border:1px solid var(--line);background:var(--surface);font-size:15.5px}
.table-wrap .compare{min-width:480px}
.compare caption{caption-side:top;text-align:left;color:var(--ink-3);font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.12em;text-transform:uppercase;margin-bottom:14px}
.compare th,.compare td{padding:16px 20px;border-bottom:1px solid var(--line);text-align:left;vertical-align:top}
.compare thead th{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.15rem;text-transform:uppercase;color:#fff;background:var(--bg-2)}
.compare tbody th{font-weight:600;color:var(--ink);font-family:'Saira',sans-serif;font-size:15.5px}
.compare td{color:var(--ink-2)}
.compare .yes{color:var(--accent);font-weight:700}
.compare .no{color:var(--ink-3)}
.compare tr:last-child th,.compare tr:last-child td{border-bottom:none}

/* callout / note */
.callout{background:rgba(79,183,236,.07);border:1px solid rgba(79,183,236,.32);border-left-width:3px;
  padding:24px 28px;color:var(--ink-2);font-size:16.5px;max-width:880px}
.callout b{color:var(--ink)}
.callout .k{display:block;font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:10px}

/* prose (article body) */
.prose{max-width:760px;color:var(--ink-2);font-size:18px;line-height:1.75}
.prose h2{font-size:clamp(1.7rem,3.6vw,2.4rem);font-weight:800;text-transform:uppercase;color:#fff;margin:48px 0 16px}
.prose h3{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.5rem;text-transform:uppercase;color:#fff;margin:34px 0 12px}
.prose p{margin:0 0 20px}
.prose strong{color:var(--ink)}
.prose a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.prose ul,.prose ol{margin:0 0 22px;padding-left:22px}
.prose li{margin:0 0 10px}
.prose img{border:1px solid var(--line);margin:30px 0}
.prose figure{margin:30px 0}
.prose figcaption{font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-top:10px}
.prose blockquote{border-left:3px solid var(--accent);padding:6px 0 6px 24px;margin:28px 0;color:var(--ink);font-size:20px}

/* article meta + author */
.amasthead{max-width:820px}
.ameta{display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin-top:22px}
.ameta .tag{color:var(--accent)}

/* article cards / related grid */
.cardgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.acard{background:var(--surface);border:1px solid var(--line);display:flex;flex-direction:column;transition:.3s var(--ease)}
.acard:hover{background:var(--surface-2);transform:translateY(-3px)}
.acard .acard-img{aspect-ratio:16/10;overflow:hidden;background:var(--bg)}
.acard .acard-img img{width:100%;height:100%;object-fit:cover;filter:grayscale(.12);transition:.6s var(--ease)}
.acard:hover .acard-img img{transform:scale(1.06);filter:grayscale(0)}
.acard .acard-body{padding:24px 26px 26px;display:flex;flex-direction:column;flex:1}
.acard .k{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.acard h3{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.5rem;text-transform:uppercase;color:#fff;margin:10px 0 8px;line-height:1.06}
.acard p{color:var(--ink-2);font-size:14.5px;flex:1}
.acard .more{margin-top:16px;font-family:'Space Mono',monospace;font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent)}

/* internal-link / "explore more" row */
.linkrow{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.linkrow a{background:var(--surface);padding:28px 26px;transition:.3s var(--ease);display:block}
.linkrow a:hover{background:var(--surface-2)}
.linkrow .k{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent)}
.linkrow h4{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:700;font-size:1.4rem;text-transform:uppercase;color:#fff;margin:10px 0 6px}
.linkrow p{color:var(--ink-2);font-size:14px}

/* full-width media band */
.mediaband{position:relative;min-height:420px;display:flex;align-items:flex-end;overflow:hidden;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.mediaband .mb-bg{position:absolute;inset:0;background-size:cover;background-position:center;z-index:0}
.mediaband .mb-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(11,12,14,.92),rgba(11,12,14,.45))}
.mediaband .wrap{position:relative;z-index:1;padding:54px 28px}
.mediaband h2{font-size:clamp(2rem,5vw,3.6rem);font-weight:800;text-transform:uppercase;color:#fff;max-width:760px}
.mediaband p{color:var(--ink-2);max-width:620px;margin-top:14px;font-size:18px}

/* stat row */
.statrow{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
.statrow.cols3{grid-template-columns:repeat(3,1fr)}
.statrow .st{background:var(--surface);padding:34px 26px}
.statrow .v{font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:800;font-size:2.8rem;color:var(--accent);line-height:.9}
.statrow .k{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin-top:10px}

/* TOC for long pages */
.toc{background:var(--surface);border:1px solid var(--line);padding:24px 26px;max-width:760px}
.toc .k{font-family:'Space Mono',monospace;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);margin-bottom:12px;display:block}
.toc ol{list-style:none;counter-reset:t;display:grid;gap:8px}
.toc li{counter-increment:t}
.toc a{color:var(--ink-2);font-size:15px}
.toc a:hover{color:var(--accent)}
.toc li::before{content:counter(t,decimal-leading-zero);font-family:'Space Mono',monospace;font-size:12px;color:var(--ink-3);margin-right:12px}

/* utility */
.center{text-align:center}
.mt-s{margin-top:22px}.mt-m{margin-top:34px}.mt-l{margin-top:48px}
.maxw-md{max-width:880px}
.sponsor-strip{display:flex;flex-wrap:wrap;gap:14px 18px;align-items:center}
.sponsor-strip a{border:1px solid var(--line);padding:12px 20px;font-family:'Saira Condensed','Arial Narrow',Oswald,sans-serif;font-weight:600;font-size:1.05rem;text-transform:uppercase;letter-spacing:.03em;color:var(--steel);transition:.3s var(--ease)}
.sponsor-strip a:hover{border-color:var(--accent);color:#fff;background:rgba(79,183,236,.07)}

/* ---------- responsive ---------- */
@media(max-width:1000px){
  .about-grid,.team-grid,.docs-grid,.contact-grid{grid-template-columns:1fr;gap:40px}
  .foot-top{grid-template-columns:1fr 1fr;gap:34px}
  .spec-grid,.caps-grid{grid-template-columns:repeat(2,1fr)}
  .gal-grid{grid-template-columns:repeat(3,1fr)}
  .split,.split.wide-left,.split.wide-right{grid-template-columns:1fr;gap:36px}
  .process{grid-template-columns:repeat(2,1fr)}
  .pillars,.pillars.cols2,.cardgrid,.linkrow{grid-template-columns:1fr 1fr}
  .statrow,.statrow.cols3{grid-template-columns:repeat(2,1fr)}
  .checklist.two{grid-template-columns:1fr}
}
@media(max-width:760px){
  body{font-size:16px}
  .nav-links,.nav-phone{display:none}
  .nav-links{position:fixed;top:68px;left:0;right:0;background:var(--bg-2);flex-direction:column;
    align-items:flex-start;gap:0;padding:10px 28px 24px;border-bottom:1px solid var(--line);transform:translateY(-130%);transition:.4s var(--ease)}
  .nav-links.open{display:flex;transform:translateY(0)}
  .nav-links a{padding:14px 0;width:100%;border-bottom:1px solid var(--line-soft);font-size:16px}
  .burger{display:flex}
  section{padding:72px 0}
  .subhero{padding:120px 0 48px}
  .opt-row,.spec-grid,.caps-grid{grid-template-columns:1fr}
  .gal-grid{grid-template-columns:repeat(2,1fr);grid-auto-rows:160px}
  .gal-item.wide{grid-column:span 2}
  .gal-item.tall{grid-row:span 1}
  .hero-stats div{padding-right:18px;margin-right:18px}
  .team-stats{gap:28px}
  .process,.process.cols4,.process.cols3{grid-template-columns:1fr}
  .pillars,.pillars.cols2,.cardgrid,.linkrow{grid-template-columns:1fr}
  .statrow,.statrow.cols3{grid-template-columns:1fr 1fr}
  .faq summary{font-size:1.25rem}
  .compare{font-size:14px}
  .compare th,.compare td{padding:12px 12px}
}
