/* =========================================================
   AKSELS ŠARAKS — Personīgais treneris Rīgā
   Dark · Muscular · Strong. Black / Graphite / Blood-red.
   Anton + Bebas Neue + Inter.
   ========================================================= */

:root{
  --bg:        #08080a;
  --bg-soft:   #0c0c0e;
  --bg-elev:   #111114;
  --bg-card:   #131317;
  --line:      #1f1f24;
  --line-2:    #2b2b32;
  --text:      #f3f3f5;
  --text-dim:  #9c9ca6;
  --text-mute: #54545c;
  --accent:    #c5121f;
  --accent-2:  #e0212f;
  --accent-deep:#7a0c14;
  --accent-soft: rgba(197,18,31,.14);

  --display: 'Anton', 'Bebas Neue', Impact, sans-serif;
  --display-2:'Bebas Neue', Impact, sans-serif;
  --body:    'Inter', system-ui, -apple-system, Segoe UI, sans-serif;

  --r-sm: 4px;
  --r-md: 10px;
  --r-lg: 18px;

  --maxw: 1400px;
  --pad: clamp(20px, 4vw, 56px);
}

*,*::before,*::after{ box-sizing:border-box; }
html{
  background:var(--bg);
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  scroll-behavior:smooth;
}
html, body{ overflow-x:clip; max-width:100%; }
body{ width:100%; }
body{
  margin:0;
  font-family:var(--body);
  font-size:16px;
  line-height:1.55;
  font-weight:400;
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(197,18,31,.12), transparent 60%),
    radial-gradient(900px 500px at -10% 30%, rgba(255,255,255,.03), transparent 70%),
    var(--bg);
}
img,video{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; border:0; background:0; color:inherit; }

::selection{ background:var(--accent); color:#fff; }

main{ overflow-x:clip; width:100%; max-width:100%; }
section{ max-width:100vw; }

/* Universal grain overlay (subtle film) */
.grain-overlay,
.hero__grain,
.contact__noise{
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='240' height='240'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='.95' numOctaves='2' stitchTiles='stitch'/><feColorMatrix values='0 0 0 0 1  0 0 0 0 1  0 0 0 0 1  0 0 0 .55 0'/></filter><rect width='100%' height='100%' filter='url(%23n)'/></svg>");
}

/* ---------- typography helpers ---------- */
.eyebrow{
  font-family:var(--body);
  font-size:11px;
  font-weight:700;
  letter-spacing:.28em;
  text-transform:uppercase;
  color:var(--text-mute);
  margin:0 0 14px;
  display:inline-flex;
  align-items:center;
  gap:10px;
}
.eyebrow::before{
  content:"";
  width:28px; height:1px; background:var(--accent);
}
.eyebrow--light{ color:rgba(255,255,255,.7); }
.eyebrow--light::before{ background:#fff; }

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:14px 22px;
  border-radius:2px;
  font-family:var(--body);
  font-weight:700;
  font-size:13px;
  letter-spacing:.14em;
  text-transform:uppercase;
  white-space:nowrap;
  transition:transform .35s cubic-bezier(.2,.8,.2,1), background .25s ease, color .25s ease, border-color .25s ease, box-shadow .35s ease;
  will-change:transform;
}
.btn__arrow{
  display:inline-block;
  transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.btn:hover .btn__arrow{ transform:translateX(5px); }
.btn:active{ transform:translateY(1px); }

.btn--primary{
  background:var(--accent);
  color:#fff;
  box-shadow:
    0 10px 28px -10px rgba(197,18,31,.65),
    inset 0 0 0 1px rgba(255,255,255,.08),
    inset 0 1px 0 rgba(255,255,255,.18);
}
.btn--primary:hover{
  background:var(--accent-2);
  box-shadow:
    0 14px 36px -10px rgba(224,33,47,.85),
    inset 0 0 0 1px rgba(255,255,255,.1),
    inset 0 1px 0 rgba(255,255,255,.22);
}
.btn--ghost{
  background:transparent;
  color:var(--text);
  border:1px solid var(--line-2);
}
.btn--ghost:hover{
  border-color:#fff;
  background:rgba(255,255,255,.04);
}
.btn--lg{ padding:18px 28px; font-size:13px; min-height:48px; }
.btn--sm{ padding:11px 18px; font-size:12px; min-height:44px; }
.btn--xl{ padding:24px 38px; font-size:15px; min-height:56px; }
.btn--full{ width:100%; min-height:48px; }

/* ---------- cookie ---------- */
.cookie{
  position:fixed;
  inset:auto 16px max(16px, env(safe-area-inset-bottom)) 16px;
  z-index:80;
  background:#0e0e10;
  border:1px solid var(--line-2);
  border-left:3px solid var(--accent);
  border-radius:var(--r-md);
  padding:14px 16px;
  display:flex; align-items:center; gap:14px;
  font-size:13px; color:var(--text-dim);
  box-shadow:0 20px 40px -10px rgba(0,0,0,.7);
  max-width:760px; margin:0 auto;
}
.cookie p{ margin:0; flex:1; }
.cookie a{ color:#fff; text-decoration:underline; }
.cookie__btn{
  background:#fff; color:#000;
  padding:10px 16px; border-radius:2px;
  font-size:11px; font-weight:700; letter-spacing:.16em;
  text-transform:uppercase;
  min-height:44px;
}
@media (max-width: 600px){
  .cookie{
    flex-direction:column;
    align-items:stretch;
    gap:10px;
    padding:14px;
    font-size:12.5px;
    line-height:1.5;
    text-align:left;
  }
  .cookie__btn{ width:100%; min-height:48px; padding:14px 16px; }
}

/* ---------- nav ---------- */
.nav{
  position:fixed; top:14px; left:0; right:0;
  z-index:50;
  display:grid;
  grid-template-columns:1fr auto 1fr;
  align-items:center;
  gap:14px;
  padding:8px 8px 8px 18px;
  margin:0 auto;
  width:min(96%, 1280px);
  background:rgba(10,10,12,.7);
  backdrop-filter:blur(18px) saturate(140%);
  -webkit-backdrop-filter:blur(18px) saturate(140%);
  border:1px solid rgba(255,255,255,.06);
  border-radius:2px;
  transition:background .3s ease, border-color .3s ease, transform .4s ease;
}
.nav.is-scrolled{
  background:rgba(8,8,10,.92);
  border-color:rgba(255,255,255,.1);
}
.nav__brand{
  display:flex; align-items:center; gap:10px;
  font-family:var(--display);
  letter-spacing:.06em;
  font-size:16px;
  color:#fff;
}
.nav__mark{
  width:34px; height:34px;
  display:grid; place-items:center;
  background:var(--accent);
  color:#fff;
  font-family:var(--display);
  font-size:13px;
  letter-spacing:.04em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.nav__name{ font-size:15px; font-weight:400; }
.nav__links{
  display:flex; gap:2px;
  font-size:12px;
  letter-spacing:.14em;
  text-transform:uppercase;
  font-weight:600;
  color:var(--text-dim);
}
.nav__links a{
  padding:10px 16px;
  border-radius:2px;
  transition:color .2s, background .2s;
  min-height:44px;
  display:inline-flex; align-items:center;
}
.nav__links a:hover{ color:#fff; background:rgba(255,255,255,.05); }
.nav__cta{
  justify-self:end;
  display:inline-flex;
  align-items:center; gap:8px;
  padding:12px 18px;
  background:var(--accent);
  color:#fff;
  font-size:11px;
  letter-spacing:.18em;
  font-weight:700;
  text-transform:uppercase;
  transition:transform .3s, background .3s, box-shadow .3s;
  min-height:44px;
  box-shadow:0 6px 18px -8px rgba(197,18,31,.7), inset 0 1px 0 rgba(255,255,255,.16);
}
.nav__cta:hover{
  background:var(--accent-2);
  transform:translateY(-1px);
  box-shadow:0 10px 22px -8px rgba(224,33,47,.85), inset 0 1px 0 rgba(255,255,255,.22);
}

@media (max-width: 820px){
  .nav__links{ display:none; }
  .nav{ grid-template-columns:1fr auto; padding:6px 6px 6px 14px; }
  .nav__name{ display:none; }
  .nav__cta{ padding:12px 14px; font-size:10.5px; letter-spacing:.16em; min-height:44px; }
}

/* =========================================================
   HERO — magazine masthead. Layered Anton type.
   Outline / solid white / red lines + ghost wordmark.
   ========================================================= */
.hero{
  position:relative;
  min-height:100vh;
  min-height:100svh;
  padding:96px var(--pad) 56px;
  display:flex;
  align-items:flex-end;
  overflow:hidden;
  isolation:isolate;
}
.hero__video-wrap{
  position:absolute; inset:0; z-index:0;
  pointer-events:none;
}
.hero__video{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 30%;
  filter:contrast(1.18) saturate(.4) brightness(.42);
}
/* Stronger duotone — red + black, multiply blend */
.hero__duotone{
  position:absolute; inset:0;
  background:
    radial-gradient(70% 70% at 75% 18%, rgba(224,33,47,.62), transparent 62%),
    linear-gradient(135deg, rgba(122,12,20,.55) 0%, rgba(8,8,10,.82) 55%, rgba(0,0,0,.98) 100%);
  mix-blend-mode:multiply;
}
.hero__vignette{
  position:absolute; inset:0;
  background:
    radial-gradient(120% 80% at 50% 100%, rgba(0,0,0,.96) 0%, transparent 58%),
    radial-gradient(120% 80% at 50% 0%, rgba(0,0,0,.55) 0%, transparent 50%);
}
.hero__grain{
  position:absolute; inset:0; pointer-events:none;
  opacity:.08; mix-blend-mode:overlay;
}

/* Top mono strip — masthead identity bar */
.hero__strip{
  position:absolute;
  top:84px; left:0; right:0;
  z-index:3;
  display:flex; align-items:center; justify-content:center;
  gap:12px;
  padding:10px var(--pad);
  font-family:var(--body);
  font-size:10.5px;
  font-weight:700;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:rgba(255,255,255,.62);
  border-top:1px solid rgba(255,255,255,.08);
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(8,8,10,.32);
  backdrop-filter:blur(6px);
  -webkit-backdrop-filter:blur(6px);
  white-space:nowrap;
  overflow:hidden;
}
.hero__strip-item--accent{ color:var(--accent-2); }
.hero__strip-dot{ color:rgba(255,255,255,.25); }

/* Ghost wordmark — outline-only Anton, masthead scale */
.hero__ghost{
  position:absolute;
  left:50%; top:54%;
  transform:translate(-50%, -50%);
  z-index:1;
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(160px, 28vw, 480px);
  line-height:1;
  letter-spacing:-.02em;
  color:transparent;
  -webkit-text-stroke:1.5px rgba(255,255,255,.06);
  text-stroke:1.5px rgba(255,255,255,.06);
  pointer-events:none;
  white-space:nowrap;
  user-select:none;
  text-transform:uppercase;
  mix-blend-mode:screen;
  opacity:.9;
}

.hero__inner{
  position:relative; z-index:2;
  width:100%; max-width:var(--maxw); margin:0 auto;
  display:grid;
  grid-template-columns:minmax(0, 1fr);
  gap:clamp(18px, 2.4vw, 32px);
}

/* Editorial edition meta */
.hero__edition{
  display:flex; align-items:center; gap:14px;
  font-family:var(--body);
  font-size:10.5px; font-weight:700;
  letter-spacing:.32em;
  color:rgba(255,255,255,.78);
  text-transform:uppercase;
  flex-wrap:wrap;
}
.hero__ed-num{ color:var(--accent-2); font-family:var(--display); font-size:14px; letter-spacing:.16em; }
.hero__ed-num span{ color:#fff; padding-left:2px; }
.hero__ed-sep{ width:42px; height:1px; background:var(--accent); }
.hero__ed-issue{ color:rgba(255,255,255,.6); }

/* MASSIVE display headline — clamp(64px, 13vw, 180px) */
.hero__title{
  margin:0;
  font-family:var(--display);
  font-weight:400;
  font-size:clamp(64px, 13vw, 180px);
  line-height:.82;
  letter-spacing:-.02em;
  color:var(--text);
  text-transform:uppercase;
  display:flex; flex-direction:column;
  word-break:keep-all;
  overflow-wrap:normal;
  hyphens:none;
  margin-block:clamp(8px, 1.4vw, 18px);
}
.hero__line{
  display:block;
  font-stretch:100%;
  transition:letter-spacing .8s cubic-bezier(.2,.8,.2,1), color .4s ease;
  cursor:default;
  position:relative;
  white-space:nowrap;
  max-width:100%;
}
/* Line 1 — outline only */
.hero__line--outline{
  color:transparent;
  -webkit-text-stroke:2px #fff;
  text-stroke:2px #fff;
  padding-left:.04em;
  font-size:.62em;
  align-self:flex-start;
}
/* Line 2 — solid white, full impact */
.hero__line--solid{
  color:#fff;
  text-shadow:0 12px 48px rgba(0,0,0,.7);
  font-size:1em;
  letter-spacing:-.025em;
  align-self:flex-start;
}
/* Line 3 — red, slightly indented for magazine rhythm */
.hero__line--red{
  color:var(--accent-2);
  text-shadow:0 8px 28px rgba(197,18,31,.4);
  font-size:.78em;
  letter-spacing:-.015em;
  align-self:flex-end;
  padding-right:.04em;
}
.hero__line:hover{ letter-spacing:.005em; }
.hero__line--outline:hover{ letter-spacing:.04em; }
.hero__dot{
  color:var(--accent);
  display:inline-block;
  transform:translateY(-.05em);
}

.hero__base{
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  gap:clamp(18px, 3vw, 40px);
  align-items:end;
  max-width:100%;
}
.hero__lede{
  margin:0;
  max-width:48ch;
  font-size:clamp(15px, 1.25vw, 18px);
  line-height:1.55;
  color:rgba(255,255,255,.82);
  font-weight:400;
  border-left:2px solid var(--accent);
  padding-left:16px;
}
.hero__cta-row{
  display:flex; gap:12px; flex-wrap:wrap;
  margin-top:6px;
  flex-shrink:0;
}

@media (max-width: 980px){
  .hero__base{ grid-template-columns:1fr; align-items:start; }
}

.hero__stats{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:0;
  margin-top:28px;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:24px;
  max-width:680px;
}
.stat{
  display:flex; flex-direction:column;
  gap:4px;
  padding:0 18px 0 0;
  border-right:1px solid rgba(255,255,255,.08);
}
.stat:last-child{ border-right:0; padding-right:0; padding-left:18px; }
.stat:nth-child(2){ padding-left:18px; }
.stat__num{
  font-family:var(--display);
  font-size:clamp(2.4rem, 5vw, 4rem);
  line-height:.9;
  color:#fff;
  letter-spacing:-.01em;
}
.stat__lbl{
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:var(--text-dim);
  font-weight:700;
}

.hero__scroll{
  position:absolute; left:var(--pad); bottom:24px;
  display:flex; align-items:center; gap:12px;
  font-size:10px; letter-spacing:.32em;
  color:var(--text-dim);
  text-transform:uppercase;
  z-index:3;
  font-weight:700;
}
.hero__scroll-line{
  width:60px; height:1px;
  background:linear-gradient(90deg, var(--text-dim), transparent);
  position:relative; overflow:hidden;
}
.hero__scroll-line::after{
  content:"";
  position:absolute; left:-30%; top:0;
  width:30%; height:100%;
  background:var(--accent);
  animation:scrollLine 2.4s ease-in-out infinite;
}
@keyframes scrollLine{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(330%); }
}

/* Tablet ~900px — hide ghost if it overflows, scale strip */
@media (max-width: 900px){
  .hero{ padding-top:108px; padding-bottom:72px; }
  .hero__strip{ font-size:9.5px; gap:8px; padding:8px 14px; letter-spacing:.24em; }
  .hero__ghost{ font-size:clamp(140px, 30vw, 320px); opacity:.7; }
  .hero__stats{ grid-template-columns:repeat(3, minmax(0,1fr)); gap:0; }
  .stat{ padding:0 10px 0 0; }
  .stat:nth-child(2){ padding-left:10px; }
  .stat:last-child{ padding-left:10px; }
  .hero__scroll{ display:none; }
  .hero__video{ object-position:center 25%; }
  /* Layered headline scales — outline gets smaller, solid stays dominant */
  .hero__line--outline{ font-size:.55em; -webkit-text-stroke:1.5px #fff; }
  .hero__line--red{ font-size:.7em; }
}

/* Small tablet 720px — verify nothing overflows */
@media (max-width: 720px){
  .hero{ padding:100px 18px 64px; }
  .hero__strip{
    font-size:9px;
    letter-spacing:.18em;
    gap:6px;
    padding:7px 12px;
  }
  .hero__strip-item{ overflow:hidden; text-overflow:ellipsis; }
}

/* Mobile ≤540 — hide ghost. Headline stays BIG: clamp(48-95px). */
@media (max-width: 540px){
  .hero{
    padding-top:108px;
    padding-bottom:56px;
    align-items:flex-end;
    min-height:100svh;
  }
  .hero__strip{
    /* Compact: keep just name + role, hide the rest */
    top:80px;
    font-size:8.5px;
    letter-spacing:.18em;
    padding:7px 12px;
    gap:6px;
    overflow:hidden;
  }
  .hero__strip-item:nth-child(n+5){ display:none; }
  .hero__strip-dot:nth-of-type(n+3){ display:none; }
  /* Hide ghost — overflow guard */
  .hero__ghost{ display:none; }
  .hero__inner{
    gap:16px;
    grid-template-columns:minmax(0, 1fr);
  }
  .hero__edition{
    font-size:9.5px;
    letter-spacing:.22em;
    gap:10px;
  }
  .hero__ed-num{ font-size:12px; }
  .hero__ed-sep{ width:24px; }
  .hero__ed-issue{ font-size:9px; }
  /* MASSIVE on mobile too — clamp(48px, 14vw, 95px) per line. */
  .hero__title{
    font-size:clamp(48px, 14vw, 95px);
    line-height:.86;
    letter-spacing:-.02em;
    margin:4px 0;
  }
  .hero__line--outline{
    font-size:.55em;
    -webkit-text-stroke:1.2px #fff;
  }
  .hero__line--solid{
    font-size:1em;
    letter-spacing:-.04em;
  }
  .hero__line--red{ font-size:.72em; letter-spacing:-.03em; }
  /* Base: stack lede + CTAs */
  .hero__base{
    grid-template-columns:1fr;
    gap:14px;
  }
  .hero__lede{
    font-size:15.5px;
    line-height:1.5;
    max-width:38ch;
    color:rgba(255,255,255,.86);
    padding-left:12px;
  }
  /* CTAs full-width stacked, ≥48px touch */
  .hero__cta-row{
    flex-direction:column;
    gap:10px;
    margin-top:4px;
    width:100%;
  }
  .hero__cta-row .btn{
    width:100%;
    min-height:52px;
    padding:16px 22px;
    font-size:12.5px;
    letter-spacing:.16em;
  }
  /* Stats: 3-col, tighter */
  .hero__stats{
    grid-template-columns:repeat(3, minmax(0,1fr));
    padding-top:16px;
    margin-top:14px;
    max-width:100%;
  }
  .stat{ padding:0 6px 0 0; gap:2px; min-width:0; }
  .stat:nth-child(2){ padding-left:6px; }
  .stat:last-child{ padding-left:6px; padding-right:0; border-right:0; }
  .stat__num{
    font-size:clamp(1.6rem, 7.2vw, 2.4rem);
    line-height:.88;
  }
  .stat__lbl{
    font-size:8.5px;
    letter-spacing:.16em;
    line-height:1.2;
  }
}
@media (max-width:380px){
  .hero{ padding-top:104px; padding-bottom:52px; }
  .hero__title{ font-size:clamp(44px, 14.5vw, 70px); }
  .hero__lede{ font-size:15px; }
  .hero__strip{ font-size:8px; letter-spacing:.14em; }
  .stat__num{ font-size:clamp(1.4rem, 8vw, 2rem); }
  .stat__lbl{ font-size:8px; letter-spacing:.12em; }
}

/* =========================================================
   TICKER — bold word marquee
   ========================================================= */
.ticker{
  position:relative;
  border-block:1px solid var(--line);
  background:#050507;
  overflow:hidden;
  padding:18px 0;
}
.ticker__track{
  display:flex;
  width:max-content;
  animation:tickerRoll 32s linear infinite;
}
.ticker__group{
  display:flex; align-items:center; gap:32px;
  padding-right:32px;
  white-space:nowrap;
  font-family:var(--display);
  font-size:clamp(40px, 5.5vw, 78px);
  letter-spacing:.01em;
  color:var(--text);
  text-transform:uppercase;
  line-height:1;
}
.ticker__word{ display:inline-block; }
.ticker__word--out{
  color:transparent;
  -webkit-text-stroke:1.5px var(--text);
}
.ticker__star{
  color:var(--accent);
  font-size:.55em;
  transform:translateY(-.04em);
}
@keyframes tickerRoll{
  from{ transform:translateX(0); }
  to{   transform:translateX(-50%); }
}
.ticker:hover .ticker__track{ animation-play-state:paused; }

/* =========================================================
   ABOUT
   ========================================================= */
.about{
  padding:clamp(80px, 12vw, 160px) var(--pad);
  max-width:var(--maxw); margin:0 auto;
}
.about__inner{
  display:grid;
  grid-template-columns:minmax(0, .9fr) minmax(0, 1.1fr);
  gap:clamp(28px, 6vw, 80px);
  align-items:start;
}
.about__col-l{ position:sticky; top:120px; }
.about__title{
  margin:0;
  font-family:var(--display);
  font-size:clamp(2.6rem, 6.4vw, 5.2rem);
  line-height:.9;
  letter-spacing:-.005em;
  font-weight:400;
  text-transform:uppercase;
  color:#fff;
}
.about__hl{
  display:inline-block;
  position:relative;
  color:var(--accent);
}

.about__photo{
  position:relative;
  margin:0 0 30px;
  aspect-ratio: 4 / 5;
  max-width:340px;
  overflow:hidden;
  border:1px solid var(--line-2);
  background:#1a1a1a;
  box-shadow:
    0 40px 80px -30px rgba(0,0,0,.8),
    0 0 0 1px rgba(255,255,255,.04);
}
.about__photo img{
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 25%;
  filter:grayscale(.3) contrast(1.1) brightness(.9);
}
.about__photo-tone{
  position:absolute; inset:0;
  background:
    linear-gradient(135deg, rgba(197,18,31,.22) 0%, transparent 55%),
    linear-gradient(180deg, transparent 60%, rgba(0,0,0,.55) 100%);
  pointer-events:none;
  mix-blend-mode:multiply;
}

.about__lede{
  font-size:clamp(18px, 1.6vw, 22px);
  line-height:1.5;
  color:#fff;
  margin:0 0 22px;
  font-weight:500;
}
.about__body{
  font-size:16px;
  line-height:1.7;
  color:var(--text-dim);
  margin:0 0 30px;
  max-width:62ch;
}
.about__list{
  list-style:none; margin:0; padding:0;
  display:grid; gap:0;
  margin-top:34px;
  border-top:1px solid var(--line);
}
.about__list li{
  display:grid;
  grid-template-columns:60px 1fr;
  align-items:center;
  font-size:15px;
  color:var(--text);
  font-weight:500;
  padding:16px 0;
  border-bottom:1px solid var(--line);
  transition:background .25s, padding-left .3s;
}
.about__list li:hover{ padding-left:8px; background:rgba(197,18,31,.04); }
.about__list li span{
  font-family:var(--display);
  font-size:14px;
  color:var(--accent);
  letter-spacing:.12em;
}

@media (max-width: 820px){
  .about__inner{ grid-template-columns:1fr; }
  .about__col-l{ position:static; }
  .about__photo{ max-width:100%; }
}
@media (max-width:600px){
  .about__title{ font-size:clamp(2.4rem, 11vw, 4rem); }
  .about__lede{ font-size:17px; }
  .about__list li{ grid-template-columns:48px 1fr; padding:18px 0; font-size:14.5px; }
}

/* =========================================================
   IMPACT REVEAL
   ========================================================= */
.impact{
  position:relative;
  height:90vh;
  min-height:560px;
  display:grid; place-items:center;
  overflow:hidden;
  margin:0;
  border-block:1px solid var(--line);
  isolation:isolate;
}
.impact__video{
  position:absolute; inset:0;
  width:100%; height:100%;
  object-fit:cover;
  object-position:center 25%;
  filter:grayscale(.55) contrast(1.2) brightness(.4);
  transform:scale(1.06);
  z-index:0;
}
.impact__wash{
  position:absolute; inset:0;
  background:
    radial-gradient(closest-side, transparent 0%, rgba(0,0,0,.7) 80%),
    linear-gradient(0deg, var(--bg), transparent 25%, transparent 75%, var(--bg)),
    linear-gradient(120deg, rgba(197,18,31,.22), transparent 50%);
  z-index:1;
}
.impact__word{
  position:relative; z-index:2;
  margin:0;
  font-family:var(--display);
  font-size:clamp(3.2rem, 16vw, 18rem);
  line-height:.86;
  letter-spacing:-.015em;
  color:#fff;
  text-transform:uppercase;
  text-shadow:0 4px 60px rgba(0,0,0,.7);
  padding:0 16px;
  font-weight:400;
  max-width:100%;
  text-align:center;
  word-break:keep-all;
  overflow-wrap:normal;
}
/* Tablet 720 — scale impact word so it never overflows viewport */
@media (max-width:720px){
  .impact{ height:auto; min-height:520px; padding:90px 16px; }
  .impact__word{ font-size:clamp(3rem, 16vw, 8rem); padding:0 8px; }
}
@media (max-width:600px){
  .impact{ height:auto; min-height:420px; padding:80px 0; }
  .impact__word{ font-size:clamp(2.8rem, 17vw, 5rem); padding:0 12px; }
  .impact__sub{ font-size:11px; letter-spacing:.22em; bottom:24px; padding:0 16px; }
}
.impact__sub{
  position:absolute;
  bottom:clamp(24px, 6vh, 60px);
  left:0; right:0;
  text-align:center;
  font-size:12px; letter-spacing:.28em;
  color:rgba(255,255,255,.7);
  text-transform:uppercase;
  z-index:2;
  margin:0;
  font-weight:700;
}

/* =========================================================
   SERVICES — asymmetric bento with red accent line
   ========================================================= */
.services{
  padding:clamp(80px, 12vw, 160px) var(--pad);
  max-width:var(--maxw); margin:0 auto;
}
.services__head{
  display:flex; flex-direction:column;
  margin-bottom:clamp(40px, 6vw, 80px);
  max-width:880px;
}
.services__title{
  margin:0;
  font-family:var(--display);
  font-size:clamp(2.6rem, 6.4vw, 5.2rem);
  line-height:.9;
  letter-spacing:-.005em;
  font-weight:400;
  text-transform:uppercase;
  color:#fff;
}
.services__hl{ color:var(--accent); }

.bento{
  display:grid;
  grid-template-columns:repeat(12, minmax(0,1fr));
  grid-auto-flow:dense;
  grid-auto-rows: minmax(190px, auto);
  gap:14px;
}
.bento__card{
  position:relative;
  background:linear-gradient(160deg, var(--bg-card), var(--bg-elev));
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:28px;
  overflow:hidden;
  display:flex; flex-direction:column;
  justify-content:flex-end;
  gap:10px;
  transition:transform .5s cubic-bezier(.2,.8,.2,1), border-color .3s, background .3s;
  isolation:isolate;
}
.bento__card:hover{
  transform:translateY(-4px);
  border-color:var(--line-2);
}
.bento__line{
  position:absolute; left:0; right:auto; bottom:0;
  height:2px; width:0;
  background:var(--accent);
  transition:width .55s cubic-bezier(.2,.8,.2,1);
  z-index:3;
}
.bento__card:hover .bento__line{ width:100%; }

.bento__num{
  font-family:var(--display);
  font-size:13px;
  letter-spacing:.22em;
  color:var(--accent);
  margin-bottom:8px;
  font-weight:400;
}
.bento__h{
  margin:0;
  font-family:var(--display);
  font-size:clamp(1.6rem, 2.4vw, 2.4rem);
  line-height:1;
  font-weight:400;
  letter-spacing:.005em;
  color:#fff;
  text-transform:uppercase;
}
.bento__p{
  margin:0;
  font-size:14.5px;
  color:var(--text-dim);
  line-height:1.55;
  max-width:52ch;
}
.bento__cta{
  margin-top:14px;
  display:inline-flex; align-items:center; gap:10px;
  font-size:11px; font-weight:700;
  letter-spacing:.18em;
  text-transform:uppercase;
  padding:13px 22px;
  background:var(--accent);
  color:#fff;
  align-self:flex-start;
  transition:background .25s, transform .35s;
  min-height:44px;
  box-shadow:0 8px 22px -10px rgba(197,18,31,.65), inset 0 1px 0 rgba(255,255,255,.18);
}
.bento__cta:hover{ background:var(--accent-2); transform:translateX(2px); }

.bento__card--hero{
  grid-column:span 7;
  grid-row:span 2;
  min-height:480px;
  padding:36px;
}
.bento__photo{
  position:absolute; inset:0;
  background-position:center 18%;
  background-size:cover;
  filter:grayscale(.35) contrast(1.05) brightness(.45);
  transform:scale(1.04);
  transition:transform 1.2s cubic-bezier(.2,.8,.2,1), filter .6s;
  z-index:0;
}
.bento__photo--graphic{
  background:
    radial-gradient(80% 70% at 18% 100%, rgba(197,18,31,.55), transparent 60%),
    radial-gradient(60% 50% at 90% 0%, rgba(224,33,47,.32), transparent 60%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.025) 0 2px, transparent 2px 14px),
    linear-gradient(160deg, #1a0d0e 0%, #0e0e10 60%, #07070a 100%);
  filter:none;
  transform:scale(1);
}
.bento__card--hero:hover .bento__photo--graphic{
  transform:scale(1.02);
  filter:none;
}
.bento__card--hero::after{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(8,8,10,.0) 0%, rgba(8,8,10,.4) 55%, rgba(8,8,10,.95) 100%),
    linear-gradient(120deg, rgba(197,18,31,.25), transparent 55%);
  z-index:1;
}
.bento__card--hero .bento__inner{
  position:relative; z-index:2;
}
.bento__card--hero:hover .bento__photo{
  transform:scale(1.1);
  filter:grayscale(.15) contrast(1.1) brightness(.5);
}

.bento__card--b{ grid-column:span 5; grid-row:span 1; }
.bento__card--c{ grid-column:span 5; grid-row:span 1; }
.bento__card--wide{
  grid-column:span 12;
  grid-row:span 1;
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:24px;
  align-items:center;
  padding:32px;
  background:linear-gradient(135deg, #1a0d0e 0%, var(--bg-card) 60%);
  border-color:var(--line-2);
}
.bento__wide-l{ display:flex; flex-direction:column; gap:6px; }
.bento__wide-r{ border-left:1px solid var(--line-2); padding-left:24px; }

@media (max-width: 980px){
  .bento{ grid-template-columns:repeat(6, minmax(0,1fr)); gap:12px; }
  .bento__card--hero{ grid-column:span 6; grid-row:span 2; min-height:380px; }
  .bento__card--b, .bento__card--c{ grid-column:span 3; grid-row:span 1; }
  .bento__card--wide{ grid-column:span 6; grid-template-columns:1fr; }
  .bento__wide-r{ border-left:0; border-top:1px solid var(--line-2); padding-left:0; padding-top:18px; }
}
/* Mobile: keep proportional asymmetric layout — hero spans full row,
   the two small cards stay side-by-side, wide stays full. NO 1-col collapse. */
@media (max-width: 600px){
  .bento{ grid-template-columns:repeat(6, minmax(0,1fr)); gap:10px; grid-auto-rows:minmax(140px, auto); }
  .bento__card{ padding:18px; }
  .bento__card--hero{ grid-column:span 6; grid-row:span 2; min-height:300px; padding:22px; }
  .bento__card--b{ grid-column:span 3; grid-row:span 1; min-height:170px; }
  .bento__card--c{ grid-column:span 3; grid-row:span 1; min-height:170px; }
  .bento__card--wide{ grid-column:span 6; grid-template-columns:1fr; gap:12px; padding:20px; }
  .bento__wide-r{ border-left:0; border-top:1px solid var(--line-2); padding-left:0; padding-top:12px; }
  .bento__h{ font-size:clamp(1.05rem, 4.2vw, 1.5rem); }
  .bento__p{ font-size:13px; }
  .bento__num{ font-size:11px; margin-bottom:4px; }
  .bento__cta{ min-height:44px; padding:12px 16px; font-size:10.5px; letter-spacing:.16em; }
}
/* Floor: only collapse the two side-by-side cards below 380px */
@media (max-width: 380px){
  .bento__card--b, .bento__card--c{ grid-column:span 6; min-height:140px; }
}

/* Touch / no-hover: accent line always visible (replaces hover reveal) */
@media (hover: none){
  .bento__line{ width:36px; }
  .bento__card:hover{ transform:none; }
  .price:hover{ transform:none; }
}

/* =========================================================
   CLIENT RESULTS — editorial stat panel
   ========================================================= */
.transform{
  padding:clamp(80px, 12vw, 160px) var(--pad);
  max-width:var(--maxw); margin:0 auto;
  text-align:center;
}
.transform__head{
  margin-bottom:clamp(40px, 6vw, 60px);
  display:flex; flex-direction:column; align-items:center;
}
.transform__head .eyebrow{ justify-content:center; }
.transform__title{
  margin:0 0 16px;
  font-family:var(--display);
  font-size:clamp(2.6rem, 6.4vw, 5.2rem);
  line-height:.9;
  letter-spacing:-.005em;
  font-weight:400;
  text-transform:uppercase;
  color:#fff;
}
.transform__hl{ color:var(--accent); }
.transform__lede{
  font-size:15px;
  color:var(--text-dim);
  line-height:1.6;
  max-width:46ch;
  margin:0 auto 30px;
}
.transform__cta{ margin-top:28px; }

/* Editorial client-results stat panel */
.results{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  width:min(100%, 1200px);
  margin:0 auto;
  border-top:1px solid var(--line-2);
  border-bottom:1px solid var(--line-2);
  text-align:left;
}
.results__card{
  position:relative;
  padding:clamp(36px, 5vw, 60px) clamp(24px, 3.5vw, 44px);
  border-right:1px solid var(--line-2);
  display:flex; flex-direction:column; gap:14px;
  background:linear-gradient(180deg, transparent 0%, rgba(197,18,31,.02) 100%);
}
.results__card:last-child{ border-right:0; }
.results__card::before{
  content:"";
  position:absolute; top:0; left:0;
  width:32px; height:1px;
  background:var(--accent);
}
.results__num{
  margin:0;
  font-family:var(--display);
  font-size:clamp(4rem, 9vw, 7.6rem);
  line-height:.9;
  letter-spacing:-.02em;
  font-weight:400;
  color:#fff;
  text-transform:uppercase;
}
.results__unit{
  font-size:.42em;
  color:var(--accent);
  margin-left:.12em;
  letter-spacing:.02em;
  vertical-align:.18em;
}
.results__lbl{
  margin:0;
  font-size:11px;
  letter-spacing:.24em;
  text-transform:uppercase;
  color:#fff;
  font-weight:600;
}
.results__sub{
  margin:0;
  font-size:14px;
  line-height:1.55;
  color:var(--text-dim);
  max-width:30ch;
}

/* Tablet: keep 3-col, just tighter */
@media (max-width: 860px){
  .results{ grid-template-columns:repeat(3, minmax(0,1fr)); }
  .results__card{
    padding:clamp(24px, 4vw, 36px) clamp(14px, 2.4vw, 24px);
    gap:10px;
  }
  .results__num{ font-size:clamp(2.6rem, 9vw, 4.8rem); }
  .results__card::before{ width:24px; }
  .results__sub{ font-size:13px; }
}
/* Mobile: STILL 3-col proportional, smaller cards. Brief: keep ≥480px */
@media (max-width: 600px){
  .results{ grid-template-columns:repeat(3, minmax(0,1fr)); }
  .results__card{
    padding:24px 10px 22px;
    gap:8px;
  }
  .results__num{ font-size:clamp(1.9rem, 9vw, 3rem); line-height:.88; }
  .results__unit{ font-size:.34em; margin-left:.06em; }
  .results__lbl{ font-size:9.5px; letter-spacing:.18em; }
  .results__sub{ font-size:12px; line-height:1.45; }
  .results__card::before{ width:18px; }
}
/* Floor only: collapse to 1-col below 380px */
@media (max-width: 380px){
  .results{ grid-template-columns:1fr; }
  .results__card{
    border-right:0;
    border-bottom:1px solid var(--line-2);
    padding:22px 18px;
  }
  .results__card:last-child{ border-bottom:0; }
  .results__num{ font-size:clamp(2.6rem, 14vw, 3.6rem); }
}

/* =========================================================
   PRICING — heavy 3D-feel cards
   ========================================================= */
.pricing{
  padding:clamp(80px, 12vw, 160px) var(--pad);
  max-width:var(--maxw); margin:0 auto;
}
.pricing__head{ text-align:center; margin-bottom:clamp(40px, 6vw, 80px); }
.pricing__head .eyebrow{ justify-content:center; }
.pricing__title{
  margin:0;
  font-family:var(--display);
  font-size:clamp(2.6rem, 6.4vw, 5.2rem);
  line-height:.9;
  letter-spacing:-.005em;
  font-weight:400;
  text-transform:uppercase;
  color:#fff;
}
.pricing__hl{ color:var(--accent); }

.pricing__grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:14px;
  align-items:stretch;
}
.price{
  position:relative;
  background:linear-gradient(160deg, var(--bg-card) 0%, var(--bg-elev) 100%);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:36px 30px;
  display:flex; flex-direction:column;
  gap:18px;
  transition:transform .5s cubic-bezier(.2,.8,.2,1), border-color .3s, box-shadow .5s;
  box-shadow:
    0 20px 50px -25px rgba(0,0,0,.5),
    inset 0 1px 0 rgba(255,255,255,.04);
}
.price:hover{
  transform:translateY(-6px);
  border-color:var(--line-2);
  box-shadow:
    0 30px 70px -25px rgba(0,0,0,.7),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.price__name{
  margin:0;
  font-family:var(--display);
  font-size:clamp(1.7rem, 2.4vw, 2.2rem);
  font-weight:400;
  letter-spacing:.005em;
  text-transform:uppercase;
  color:#fff;
}
.price__sub{
  margin:-6px 0 0;
  font-size:13px;
  color:var(--text-dim);
  letter-spacing:.04em;
}
.price__amt{
  display:flex; align-items:baseline; gap:6px;
  border-bottom:1px solid var(--line);
  padding-bottom:18px;
}
.price__from{ font-size:11px; letter-spacing:.18em; text-transform:uppercase; color:var(--text-mute); font-weight:700; }
.price__num{
  font-family:var(--display);
  font-size:clamp(2.8rem, 4.8vw, 3.8rem);
  color:#fff;
  letter-spacing:-.01em;
}
.price__per{ font-size:13px; color:var(--text-dim); }
.price__list{
  list-style:none; margin:0; padding:0;
  display:grid; gap:10px;
  flex:1;
}
.price__list li{
  position:relative;
  padding-left:22px;
  font-size:14px;
  color:var(--text-dim);
  line-height:1.5;
}
.price__list li::before{
  content:"";
  position:absolute; left:0; top:.55em;
  width:12px; height:1px; background:var(--accent);
}

.price--hero{
  background:
    linear-gradient(160deg, #220c0e 0%, #15080a 60%, var(--bg-elev) 100%);
  border-color:rgba(197,18,31,.5);
  box-shadow:
    0 30px 70px -20px rgba(197,18,31,.35),
    0 0 0 1px rgba(197,18,31,.12),
    inset 0 1px 0 rgba(255,255,255,.06);
}
.price--hero:hover{
  box-shadow:
    0 40px 90px -20px rgba(197,18,31,.5),
    0 0 0 1px rgba(197,18,31,.2),
    inset 0 1px 0 rgba(255,255,255,.08);
}
.price--hero{ isolation:isolate; }
.price--hero::before{
  content:"";
  position:absolute; inset:0;
  border-radius:var(--r-md);
  background:linear-gradient(135deg, rgba(197,18,31,.4), transparent 50%);
  z-index:-1;
  opacity:.5;
  filter:blur(18px);
  pointer-events:none;
}
.price--hero .price__num{ color:#fff; }
.price__tag{
  position:absolute; top:-1px; right:18px;
  font-size:10px; letter-spacing:.22em;
  text-transform:uppercase;
  background:var(--accent);
  color:#fff;
  padding:6px 12px;
  font-weight:700;
  box-shadow:0 6px 14px -6px rgba(197,18,31,.7), inset 0 1px 0 rgba(255,255,255,.2);
}

.pricing__note{
  text-align:center;
  margin-top:28px;
  font-size:13px;
  color:var(--text-mute);
}

/* Tablet: keep 3-col, tighter padding */
@media (max-width: 900px){
  .pricing__grid{ grid-template-columns:repeat(3, minmax(0,1fr)); gap:10px; }
  .price{ padding:26px 18px; gap:14px; }
  .price__name{ font-size:clamp(1.2rem, 2.4vw, 1.6rem); }
  .price__num{ font-size:clamp(2rem, 4.6vw, 2.8rem); }
  .price__list li{ font-size:13px; padding-left:18px; }
}
/* Mobile: STILL 3-col, smaller. Brief: only collapse below 360px */
@media (max-width: 600px){
  .pricing__grid{ grid-template-columns:repeat(3, minmax(0,1fr)); gap:6px; }
  .price{ padding:18px 10px; gap:10px; border-radius:6px; }
  .price__name{ font-size:clamp(.95rem, 3.4vw, 1.2rem); line-height:1.05; }
  .price__sub{ font-size:11px; margin-top:-2px; }
  .price__amt{ padding-bottom:10px; gap:3px; flex-wrap:wrap; }
  .price__from{ font-size:9px; letter-spacing:.14em; flex-basis:100%; }
  .price__num{ font-size:clamp(1.4rem, 6.6vw, 2.2rem); line-height:.95; }
  .price__per{ font-size:11px; }
  .price__list{ gap:6px; }
  .price__list li{ font-size:11.5px; padding-left:14px; line-height:1.4; }
  .price__list li::before{ width:8px; top:.55em; }
  .price__tag{ font-size:8.5px; padding:4px 7px; letter-spacing:.16em; right:8px; }
  .price .btn{ font-size:10px; padding:10px 6px; min-height:44px; letter-spacing:.10em; gap:4px; }
  .pricing__note{ font-size:12px; margin-top:18px; }
}
/* Floor: collapse to 1-col only below 360px */
@media (max-width: 360px){
  .pricing__grid{ grid-template-columns:1fr; gap:10px; }
  .price{ padding:24px 18px; }
  .price__name{ font-size:1.4rem; }
  .price__num{ font-size:2.4rem; }
  .price__list li{ font-size:13px; padding-left:18px; }
}

/* =========================================================
   CONTACT — DM mega panel
   ========================================================= */
.contact{
  position:relative;
  padding:clamp(90px, 14vw, 200px) var(--pad);
  overflow:hidden;
  isolation:isolate;
  background:#050507;
}
.contact__bg{
  position:absolute; inset:0; z-index:-2;
  background:
    radial-gradient(70% 60% at 50% 20%, rgba(197,18,31,.4), transparent 70%),
    radial-gradient(40% 40% at 80% 80%, rgba(255,255,255,.03), transparent 70%),
    linear-gradient(180deg, var(--bg) 0%, #050507 100%);
}
.contact__noise{
  position:absolute; inset:0; z-index:-1;
  opacity:.07; mix-blend-mode:overlay;
  pointer-events:none;
}
.contact__inner{
  max-width:880px; margin:0 auto;
  text-align:center;
  display:flex; flex-direction:column; align-items:center;
}
.contact__inner .eyebrow{ justify-content:center; }
.contact__title{
  margin:0 0 18px;
  font-family:var(--display);
  font-size:clamp(3.2rem, 9vw, 8rem);
  line-height:.86;
  letter-spacing:-.015em;
  font-weight:400;
  color:#fff;
  text-transform:uppercase;
}
.contact__hl{ color:var(--accent); }
.contact__lede{
  font-size:clamp(15px, 1.4vw, 18px);
  color:var(--text-dim);
  line-height:1.55;
  max-width:54ch;
  margin:0 auto 40px;
}

.mega{
  position:relative;
  display:grid;
  grid-template-rows:auto auto auto;
  align-items:center; justify-items:center;
  gap:6px;
  padding:36px 40px;
  width:min(100%, 640px);
  background:
    linear-gradient(160deg, var(--accent) 0%, var(--accent-deep) 100%);
  color:#fff;
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--r-md);
  box-shadow:
    0 30px 80px -20px rgba(197,18,31,.6),
    inset 0 1px 0 rgba(255,255,255,.22),
    inset 0 -2px 0 rgba(0,0,0,.25);
  overflow:hidden;
  isolation:isolate;
  transition:transform .5s cubic-bezier(.2,.8,.2,1), box-shadow .5s;
  cursor:pointer;
  min-height:200px;
}
.mega::before{
  content:"";
  position:absolute; inset:-50%;
  background:radial-gradient(closest-side, rgba(255,255,255,.18), transparent 70%);
  pointer-events:none;
  z-index:0;
  opacity:0;
  transition:opacity .6s;
}
.mega:hover::before{ opacity:1; }
.mega:hover{
  box-shadow:
    0 40px 100px -20px rgba(224,33,47,.85),
    inset 0 1px 0 rgba(255,255,255,.28),
    inset 0 -2px 0 rgba(0,0,0,.3);
}
.mega__top{
  font-family:var(--body);
  font-size:11px; font-weight:700;
  letter-spacing:.36em;
  text-transform:uppercase;
  color:rgba(255,255,255,.7);
  z-index:1;
}
.mega__big{
  font-family:var(--display);
  font-size:clamp(3.6rem, 11vw, 7.2rem);
  line-height:.9;
  letter-spacing:-.01em;
  text-transform:uppercase;
  color:#fff;
  text-shadow:0 4px 24px rgba(0,0,0,.35);
  z-index:1;
  font-weight:400;
}
.mega__bot{
  display:flex; align-items:center; gap:12px;
  font-family:var(--body);
  font-size:13px;
  font-weight:600;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(255,255,255,.92);
  margin-top:6px;
  z-index:1;
  padding:10px 18px;
  border:1px solid rgba(255,255,255,.18);
  border-radius:2px;
  background:rgba(0,0,0,.18);
}
.mega__arrow{
  display:inline-block;
  transition:transform .35s cubic-bezier(.2,.8,.2,1);
}
.mega:hover .mega__arrow{ transform:translateX(6px); }

.contact__alt{
  margin-top:32px;
  width:min(100%, 720px);
  text-align:left;
}
.contact__alt summary{
  display:flex; align-items:center; justify-content:center;
  cursor:pointer;
  padding:14px 18px;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--text-dim);
  font-weight:700;
  border:1px solid var(--line-2);
  border-radius:2px;
  background:rgba(13,13,15,.6);
  transition:border-color .25s, color .25s, background .25s;
  list-style:none;
  text-align:center;
  min-height:48px;
}
.contact__alt summary::-webkit-details-marker{ display:none; }
.contact__alt summary:hover{
  border-color:#fff;
  color:#fff;
  background:rgba(255,255,255,.04);
}
.contact__alt[open] summary{ margin-bottom:14px; border-color:var(--accent); color:#fff; }

.contact__form{
  text-align:left;
  background:rgba(11,11,13,.85);
  border:1px solid var(--line-2);
  border-radius:var(--r-md);
  padding:30px;
  backdrop-filter:blur(8px);
  display:grid; gap:14px;
}
.contact__row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.field{ display:flex; flex-direction:column; gap:6px; }
.field__lbl{
  font-size:11px; letter-spacing:.20em;
  text-transform:uppercase;
  color:var(--text-dim); font-weight:700;
}
.field input{
  width:100%;
  padding:14px 16px;
  background:#08080a;
  border:1px solid var(--line);
  border-radius:2px;
  color:#fff;
  font:inherit;
  font-size:14px;
  transition:border-color .25s, background .25s;
  min-height:48px;
}
.field input:focus{
  outline:none;
  border-color:var(--accent);
  background:#0e0e10;
}
.check{
  display:flex; align-items:flex-start; gap:10px;
  font-size:12px; color:var(--text-dim); line-height:1.5;
  padding:6px 2px;
}
.check input{
  margin-top:2px;
  accent-color:var(--accent);
  width:18px; height:18px;
}
.check a{ color:#fff; text-decoration:underline; }
.contact__success{
  text-align:center;
  padding:14px; margin:0;
  background:rgba(80,180,90,.1);
  border:1px solid rgba(80,180,90,.3);
  color:#9bd9a3;
  border-radius:2px;
  font-size:14px;
}

@media (max-width: 600px){
  .contact{ padding-left:18px; padding-right:18px; }
  .contact__row{ grid-template-columns:1fr; }
  .contact__form{ padding:22px; }
  /* Keep mega CTA dramatic — scale proportionally, don't shrink to mini */
  .mega{
    padding:32px 18px;
    min-height:220px;
    gap:8px;
    width:100%;
    max-width:100%;
    box-sizing:border-box;
  }
  .mega__top{ font-size:10.5px; letter-spacing:.28em; }
  .mega__big{
    font-size:clamp(2.6rem, 13vw, 4.4rem);
    line-height:.88;
    word-break:keep-all;
    overflow-wrap:normal;
  }
  .mega__bot{
    font-size:11px;
    padding:11px 14px;
    min-height:44px;
    letter-spacing:.14em;
    flex-wrap:wrap;
    justify-content:center;
    text-align:center;
    max-width:100%;
  }
  .contact__alt summary{ min-height:52px; padding:16px 18px; }
}
@media (max-width: 380px){
  .mega{ padding:30px 16px; min-height:220px; }
  .mega__big{ font-size:clamp(2.4rem, 13vw, 3.6rem); }
  .mega__top{ font-size:9.5px; letter-spacing:.28em; }
}

/* Touch / no-hover: static glow replaces hover-radial on mega CTA */
@media (hover: none){
  .mega::before{ opacity:.6; }
  .mega:hover{ transform:none; }
  .mega:hover::before{ opacity:.6; }
}

/* =========================================================
   FOOTER
   ========================================================= */
.footer{
  position:relative;
  border-top:1px solid var(--line);
  padding:60px var(--pad) 36px;
  background:linear-gradient(180deg, #050507 0%, #020203 100%);
}
.footer__accent{
  position:absolute; left:0; right:0; top:0;
  height:2px;
  background:linear-gradient(90deg, transparent 0%, var(--accent) 50%, transparent 100%);
}
.footer__row{
  max-width:var(--maxw); margin:0 auto;
  display:flex; justify-content:space-between; align-items:center; gap:20px;
  flex-wrap:wrap;
  padding-bottom:30px;
  border-bottom:1px solid var(--line);
}
.footer__brand{
  display:flex; align-items:center; gap:12px;
  font-size:13px;
  color:var(--text-dim);
}
.footer__mark{
  width:30px; height:30px;
  display:grid; place-items:center;
  background:var(--accent); color:#fff;
  font-family:var(--display);
  font-size:13px; letter-spacing:.04em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.18);
}
.footer__nav{
  display:flex; gap:18px; flex-wrap:wrap;
  font-size:12px; letter-spacing:.16em;
  text-transform:uppercase; font-weight:600;
  color:var(--text-dim);
}
.footer__nav a{ transition:color .2s; padding:10px 0; min-height:40px; display:inline-flex; align-items:center; }
.footer__nav a:hover{ color:var(--accent); }
@media (max-width:600px){
  .footer{ padding:50px var(--pad) 32px; }
  .footer__row{ flex-direction:column; align-items:flex-start; gap:18px; }
  .footer__nav{ gap:14px 22px; }
}
.footer__imprint{
  max-width:var(--maxw); margin:30px auto 0;
  font-size:12px; color:var(--text-mute);
  display:flex; flex-direction:column; gap:6px;
}
.footer__imprint a{ color:var(--text-dim); text-decoration:underline; }
.footer__small{ margin:0; }

/* ---------- reduced-motion ---------- */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{
    animation-duration:.01ms !important;
    animation-iteration-count:1 !important;
    transition-duration:.01ms !important;
  }
  .ticker__track{ animation:none; }
  .hero__video, .impact__video{ display:none; }
  .hero{ background:linear-gradient(135deg, #1a0c0e, #08080a); }
}
