:root{
  --navy:#071326;
  --navy-2:#0c1a33;
  --ink:#0b1530;
  --graphite:#111822;
  --stone:#e7e0d6;
  --warm:#f4efe7;
  --warm-2:#fbf7f1;
  --white:#ffffff;
  --muted:#677084;
  --purple:#6a35ff;
  --purple-2:#8b5cf6;
  --sand:#bca98f;
  --line:rgba(255,255,255,.14);
  --max:1240px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:var(--warm-2);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
.container{
  width:min(var(--max), calc(100% - 80px));
  margin-inline:auto;
}
::selection{background:rgba(106,53,255,.22)}

.site-header{
  position:fixed;
  z-index:50;
  top:0; left:0; right:0;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:22px 56px;
  color:#fff;
  background:linear-gradient(180deg, rgba(7,19,38,.96), rgba(7,19,38,.72) 65%, rgba(7,19,38,.08));
  backdrop-filter:blur(10px);
}
.brand{
  display:flex;
  align-items:center;
  gap:16px;
  min-width:0;
}
.brand-r3{
  color:#fff;
  font-size:48px;
  line-height:.84;
  font-weight:900;
  letter-spacing:-.105em;
}
.brand-tagline{
  display:flex;
  flex-direction:column;
  gap:3px;
  color:rgba(255,255,255,.92);
  font-size:10px;
  font-weight:800;
  line-height:1.05;
  letter-spacing:.24em;
  text-transform:uppercase;
  white-space:nowrap;
}
.brand-tagline span:last-child{color:#b993ff}
.nav-links{display:flex;gap:32px;flex-wrap:wrap;justify-content:center}
.nav-links a{
  font-size:13px;
  font-weight:700;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:rgba(255,255,255,.82);
  transition:color .25s ease;
}
.nav-links a:hover{color:#fff}
.nav-button{
  padding:14px 26px;
  border:1px solid rgba(139,92,246,.85);
  border-radius:7px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
  transition:background .25s ease, transform .25s ease, box-shadow .25s ease;
}
.nav-button:hover{
  background:rgba(106,53,255,.1);
  transform:translateY(-1px);
  box-shadow:0 0 22px rgba(106,53,255,.22);
}

section{position:relative;overflow:hidden}
.section-dark{
  color:#fff;
  background:
    radial-gradient(circle at 82% 32%, rgba(106,53,255,.12), transparent 34%),
    linear-gradient(135deg,#061225 0%,#071326 44%,#0c1d38 100%);
}
.hero-grid{
  display:grid;
  align-items:start;
  padding-top:112px;
  padding-bottom:96px;
}
.hero-copy{max-width:980px;position:relative;z-index:3}
.eyebrow,.section-kicker{
  margin:0 0 18px;
  color:var(--purple-2);
  font-size:13px;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.hero h1{
  margin:0 0 22px;
  font-size:clamp(76px,9vw,146px);
  line-height:.96;
  letter-spacing:-.058em;
  font-weight:900;
  max-width:980px;
}
.hero h1 .line,
.hero h1 .accent{display:block}
.hero h1 .accent{
  color:var(--purple-2);
  text-shadow:0 0 24px rgba(139,92,246,.12);
}

.lead{
  margin:22px 0 30px;
  max-width:720px;
  color:rgba(255,255,255,.78);
  font-size:clamp(22px,1.95vw,30px);
  line-height:1.32;
  letter-spacing:-.025em;
}
.lead strong{color:#fff;font-weight:800}
.button{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:58px;
  padding:0 30px;
  border-radius:9px;
  font-weight:800;
  letter-spacing:-.01em;
  transition:transform .25s ease, box-shadow .25s ease, background .25s ease;
}
.button.primary{
  color:#fff;
  background:linear-gradient(135deg,#6533f4,#8f5dff);
  box-shadow:0 18px 48px rgba(106,53,255,.25);
}
.button.primary:hover{transform:translateY(-1px);box-shadow:0 22px 58px rgba(106,53,255,.34)}
.button.secondary{
  color:#fff;
  background:var(--ink);
  box-shadow:0 12px 34px rgba(11,21,48,.16);
}
.button.secondary:hover{
  transform:translateY(-2px);
  background:#101b34;
  box-shadow:0 18px 48px rgba(11,21,48,.22), 0 0 24px rgba(106,53,255,.14);
}
.button.ghost{
  color:#fff;
  border:1px solid rgba(255,255,255,.22);
}
.button.ghost:hover{
  transform:translateY(-2px);
  border-color:rgba(139,92,246,.82);
  background:rgba(139,92,246,.10);
  box-shadow:0 16px 42px rgba(106,53,255,.18);
}
.trail{
  position:absolute;
  pointer-events:none;
  filter:blur(.2px);
}
.trail-hero{
  left:-8%;
  right:-8%;
  bottom:-2%;
  height:32%;
  background-image:url("assets/dakar-trail.svg");
  background-repeat:no-repeat;
  background-position:left bottom;
  background-size:115% 100%;
  opacity:.76;
  transform:translateY(0) rotate(-1.2deg);
  mix-blend-mode:screen;
}
.pain-rotator{
  display:flex;
  align-items:flex-start;
  gap:22px;
  margin:14px 0 10px;
  padding-top:18px;
  max-width:980px;
  border-top:1px solid rgba(255,255,255,.16);
}
.quote-mark{
  flex:0 0 58px;
  width:58px;height:58px;
  display:grid;place-items:center;
  border:1px solid rgba(139,92,246,.8);
  border-radius:50%;
  color:#fff;
  font-size:46px;
  line-height:1;
  margin-top:6px;
}
.pain-lines{
  position:relative;
  min-height:118px;
  flex:1;
  overflow:visible;
}
.pain-lines p{
  position:absolute;
  inset:0 auto auto 0;
  margin:0;
  opacity:0;
  transform:translateY(8px);
  filter:blur(4px);
  color:rgba(255,255,255,.94);
  font-size:clamp(30px,3.05vw,44px);
  font-weight:700;
  line-height:1.04;
  letter-spacing:-.04em;
  max-width:760px;
  transition:opacity .34s ease, transform .34s ease, filter .34s ease;
}
.pain-lines p.active{opacity:1;transform:translateY(0);filter:blur(0)}

.section-warm{
  padding:130px 0 120px;
  background:
    radial-gradient(circle at 72% 42%, rgba(106,53,255,.08), transparent 32%),
    linear-gradient(180deg,var(--warm-2),var(--warm));
}
.method-head{
  display:grid;
  grid-template-columns:minmax(320px,.92fr) minmax(320px,.72fr);
  gap:72px;
  align-items:start;
  margin-bottom:18px;
}
.method-intro h2,
.method-word{
  margin:0;
  font-size:clamp(52px,7vw,106px);
  line-height:.94;
  letter-spacing:-.065em;
  font-weight:900;
}
.method-head p{
  margin:8px 0 0;
  max-width:460px;
  color:#4f5869;
  font-size:23px;
  line-height:1.42;
  letter-spacing:-.025em;
}
.method-stage{
  position:relative;
  min-height:230px;
  display:flex;
  align-items:flex-end;
  justify-content:center;
  margin:0 0 42px;
  padding:16px 0 12px;
}
.method-word{
  position:relative;
  width:100%;
  min-height:1.08em;
  color:var(--purple);
  text-align:center;
  z-index:2;
}
.method-word span{
  position:absolute;
  left:50%;
  top:0;
  width:max-content;
  max-width:100%;
  opacity:0;
  transform:translate(calc(-50% - 180px), 0);
  filter:blur(12px);
  transition:opacity .68s cubic-bezier(.22,.61,.36,1), transform .68s cubic-bezier(.22,.61,.36,1), filter .68s ease;
  white-space:nowrap;
}
.method-word span.active{
  opacity:1;
  transform:translate(-50%, 0);
  filter:blur(0);
}
.method-word span.exiting{
  opacity:0;
  transform:translate(calc(-50% + 220px), 0);
  filter:blur(12px);
}
.trail-method{
  left:-8%;
  right:-8%;
  bottom:-14px;
  height:210px;
  background-image:url("assets/dakar-trail-method.svg");
  background-repeat:no-repeat;
  background-position:center 100%;
  background-size:116% 112%;
  opacity:.94;
  transform:none;
  mix-blend-mode:multiply;
  filter:blur(.03px);
}
.trail-method::after{
  content:"";
  position:absolute;
  inset:8% 2% -4%;
  background-image:url("assets/dakar-trail-method.svg");
  background-repeat:no-repeat;
  background-position:center 100%;
  background-size:112% 100%;
  opacity:.42;
  filter:blur(9px);
}
.method-stage::after{
  content:"";
  position:absolute;
  left:50%;
  bottom:38px;
  width:420px;
  height:110px;
  transform:translateX(-50%);
  background:radial-gradient(ellipse at center, rgba(139,92,246,.16), rgba(139,92,246,0) 72%);
  filter:blur(10px);
  pointer-events:none;
}
.method-cards{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.method-card{
  min-height:250px;
  padding:34px;
  border:1px solid rgba(11,21,48,.13);
  border-radius:18px;
  background:rgba(255,255,255,.52);
  color:var(--ink);
  opacity:.62;
  transition:opacity .5s ease, transform .5s ease, border-color .5s ease, box-shadow .5s ease, background .5s ease;
}
.method-card.active{
  opacity:1;
  transform:translateY(-4px);
  border-color:rgba(106,53,255,.55);
  background:rgba(255,255,255,.88);
  box-shadow:0 24px 70px rgba(106,53,255,.12);
}
.method-card span{
  display:grid;place-items:center;
  width:40px;height:40px;
  margin-bottom:52px;
  border-radius:50%;
  background:rgba(106,53,255,.12);
  color:var(--purple);
  font-weight:900;
}
.method-card h3{
  margin:0 0 14px;
  font-size:30px;
  line-height:1;
  letter-spacing:-.04em;
}
.method-card p{
  margin:0;
  color:#50586a;
  font-size:18px;
  line-height:1.45;
}

.section-graphite{
  padding:128px 0 118px;
  color:#fff;
  background:
    radial-gradient(circle at 80% 20%, rgba(106,53,255,.13), transparent 28%),
    linear-gradient(135deg,#0a1426,#101821 50%,#0d1520);
}
.repair-lines{
  position:absolute;
  inset:0;
  opacity:.32;
  background:
    linear-gradient(120deg, transparent 20%, rgba(255,255,255,.07) 20.1%, transparent 20.35%),
    linear-gradient(155deg, transparent 35%, rgba(106,53,255,.22) 35.1%, transparent 35.3%),
    radial-gradient(ellipse at 80% 12%, rgba(255,255,255,.10), transparent 20%);
  pointer-events:none;
}
.section-kicker.purple{color:#a884ff}
.repair-head{
  max-width:780px;
  margin-bottom:52px;
}
.repair h2{
  margin:0 0 22px;
  font-size:clamp(48px,6vw,88px);
  line-height:.98;
  letter-spacing:-.065em;
  font-weight:900;
}
.repair h2 span{color:#9b6cff}
.repair-head p{
  margin:0;
  color:rgba(255,255,255,.72);
  font-size:24px;
  line-height:1.38;
  letter-spacing:-.025em;
}
.repair-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.repair-card{
  min-height:220px;
  padding:28px;
  border:1px solid rgba(255,255,255,.13);
  border-radius:16px;
  background:rgba(255,255,255,.035);
  transition:transform .3s ease, background .3s ease, border-color .3s ease;
}
.repair-card:hover,.repair-card.active{
  transform:translateY(-3px);
  border-color:rgba(139,92,246,.75);
  background:linear-gradient(135deg,rgba(106,53,255,.18),rgba(255,255,255,.04));
}
.repair-card small{
  display:block;
  margin-bottom:42px;
  color:#9b6cff;
  font-weight:900;
}
.repair-card h3{
  margin:0 0 12px;
  font-size:28px;
  letter-spacing:-.04em;
}
.repair-card p{
  margin:0;
  color:rgba(255,255,255,.68);
  font-size:18px;
  line-height:1.45;
}

.section-road{
  padding:140px 0 128px;
  background:
    radial-gradient(circle at 76% 16%, rgba(106,53,255,.08), transparent 28%),
    linear-gradient(180deg,#fffaf3,#f2eadf);
}
.road{
  position:absolute;
  right:-2%;
  top:-6%;
  width:54%;
  height:112%;
  opacity:.82;
  background-image:url("assets/about-path.svg");
  background-repeat:no-repeat;
  background-position:right center;
  background-size:100% 100%;
  pointer-events:none;
}
.about-grid{
  display:grid;
  grid-template-columns:1fr .9fr;
  gap:90px;
  align-items:start;
  position:relative;
  z-index:2;
}
.about h2{
  margin:0 0 18px;
  font-size:clamp(54px,7vw,104px);
  line-height:.94;
  letter-spacing:-.07em;
  font-weight:900;
}
.about h2 span{color:var(--purple)}
.about h3{
  margin:0;
  max-width:760px;
  font-size:clamp(28px,3vw,48px);
  line-height:1.08;
  letter-spacing:-.05em;
  font-weight:800;
}
.about-copy{
  padding-top:68px;
  position:relative;
  z-index:2;
}
.about-copy p{
  margin:0 0 24px;
  color:#323b50;
  font-size:22px;
  line-height:1.45;
  letter-spacing:-.025em;
}
.about-copy .statement{
  color:var(--ink);
  font-size:30px;
  line-height:1.25;
  font-weight:900;
}
.final-cta{
  padding:110px 0;
  color:#fff;
  background:linear-gradient(135deg,#071326,#101821);
}
.final-box{
  padding:74px;
  border:1px solid rgba(255,255,255,.12);
  border-radius:26px;
  background:
    radial-gradient(circle at 80% 0%, rgba(106,53,255,.22), transparent 30%),
    rgba(255,255,255,.04);
  text-align:center;
}
.final-box h2{
  margin:0 auto 18px;
  max-width:880px;
  font-size:clamp(42px,5.5vw,78px);
  line-height:.98;
  letter-spacing:-.06em;
}
.final-box p{
  margin:0 auto 34px;
  max-width:720px;
  color:rgba(255,255,255,.72);
  font-size:21px;
  line-height:1.45;
}
.cta-actions{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
footer{
  padding:34px 0;
  color:rgba(255,255,255,.68);
  background:#050b16;
}
.footer-inner{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:24px;
}
.footer-brand{display:flex;align-items:center;gap:16px}
.footer-r3{
  color:#fff;
  font-size:38px;
  line-height:.9;
  font-weight:900;
  letter-spacing:-.105em;
}
.footer-tagline{
  display:flex;
  flex-direction:column;
  gap:2px;
  color:rgba(255,255,255,.72);
  font-size:10px;
  font-weight:800;
  line-height:1.05;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.footer-tagline span:last-child{color:#9b6cff}

.reveal{
  opacity:0;
  transform:translateY(22px);
  transition:opacity .75s ease, transform .75s ease;
}
.reveal.show{opacity:1;transform:translateY(0)}

@media (max-width:980px){
  .site-header{padding:22px 24px}
  .nav-links{display:none}
  .container{width:min(var(--max), calc(100% - 40px))}
  .method-head,.about-grid{grid-template-columns:1fr;gap:28px}
  .about-copy{padding-top:0}
  .method-stage{min-height:164px;margin-bottom:34px}
  .trail-method{left:0;right:0;background-size:110% 100%;opacity:.38}
  .method-head p{max-width:100%}
  .method-cards,.repair-grid{grid-template-columns:1fr}
  .hero h1{font-size:clamp(56px,14vw,94px);max-width:100%}
  .road{width:88%;right:-30%;top:4%;opacity:.45}
}
@media (max-width:620px){
  .site-header{padding:18px 18px}
  .nav-button{padding:12px 16px;font-size:12px}
  .button{width:100%;text-align:center;padding-inline:20px}
  .hero-grid{padding-top:128px;padding-bottom:78px}
  .lead{font-size:20px}
  .pain-rotator{align-items:flex-start}
  .quote-mark{width:44px;height:44px;flex-basis:44px;font-size:34px}
  .pain-lines{min-height:138px}
  .pain-lines p{font-size:18px}
  .section-warm,.section-graphite,.section-road{padding:86px 0}
  .method-intro h2,.method-word{font-size:48px}
  .method-stage{min-height:138px;padding-top:8px}
  .method-word span{white-space:normal;width:100%;max-width:100%;font-size:inherit;line-height:.96}
  .trail-method{height:118px;bottom:0;opacity:.32}
  .repair h2,.about h2{font-size:48px}
  .road{width:92%;right:-42%;top:8%;opacity:.34}
  .final-box{padding:44px 22px}
  .footer-inner{flex-direction:column;align-items:flex-start}
}

@media (min-width: 1600px){
  .hero-grid{padding-top:108px;padding-bottom:92px;}
  .hero h1{font-size:clamp(86px,8.2vw,148px);}
  .pain-lines{min-height:110px;}
}

@media (max-width: 960px){
  .brand-r3{font-size:42px}
  .brand-tagline{font-size:9px;letter-spacing:.18em}
}
@media (max-width: 640px){
  .brand{gap:10px}
  .brand-r3{font-size:36px}
  .brand-tagline{display:none}
  .footer-tagline{font-size:9px}
  .method-word span{white-space:normal;text-wrap:balance;line-height:.92}
  .trail-method{height:138px;opacity:.72;left:-8%;right:-8%;background-size:128% 100%}
}
