:root{
  --bg:#06070B;
  --bg-2:#0B0D14;
  --surface:#10121C;
  --surface-soft:#15182A;
  --line:rgba(255,255,255,0.08);
  --line-soft:rgba(255,255,255,0.05);
  --text:#F3F4FA;
  --text-mute:#9BA0B8;
  --text-dim:#5C6178;
  --sun:#FF7A3D;
  --sun-soft:#FFC56B;
  --horizon:#5C8DFF;
  --horizon-deep:#2C4FCB;
  --violet:#9C7BFF;
  --r-sm:10px;
  --r-md:18px;
  --r-lg:30px;
  --ease:cubic-bezier(.16,.84,.32,1);
}

*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto;}
  *{animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important;}
}

html, body{
  background:var(--bg);
  scrollbar-width:none;
  -ms-overflow-style:none;
}
body::-webkit-scrollbar, html::-webkit-scrollbar{ display:none; width:0; height:0; }

body{
  font-family:'Inter', sans-serif;
  color:var(--text);
  -webkit-font-smoothing:antialiased;
  line-height:1.55;
  overflow-x:hidden;
  position:relative;
}

h1,h2,h3,h4{
  font-family:'Bricolage Grotesque', sans-serif;
  font-weight:600;
  letter-spacing:-0.025em;
  line-height:1.04;
  color:var(--text);
}

a{ color:inherit; text-decoration:none; }
img,svg{ display:block; max-width:100%; }
ul{ list-style:none; }

.mono{ font-family:'IBM Plex Mono', monospace; }

.wrap{
  max-width:1240px;
  margin:0 auto;
  padding:0 40px;
}
@media (max-width:720px){ .wrap{ padding:0 22px; } }

.eyebrow{
  font-family:'IBM Plex Mono', monospace;
  font-size:11.5px;
  font-weight:500;
  letter-spacing:0.16em;
  text-transform:uppercase;
  display:inline-flex;
  align-items:center;
  gap:9px;
  color:var(--sun-soft);
}
.eyebrow::before{
  content:"";
  width:20px; height:1.5px;
  background:linear-gradient(90deg, var(--sun), transparent);
  display:inline-block;
}

/* ===================== SCROLL PROGRESS ===================== */
.scroll-progress{
  position:fixed; top:0; left:0; right:0; height:2px; z-index:300;
  background:rgba(255,255,255,0.06);
}
.scroll-progress span{
  display:block; height:100%; width:0%;
  background:linear-gradient(90deg, var(--sun), var(--sun-soft), var(--horizon));
  box-shadow:0 0 16px 1px rgba(255,140,70,0.6);
  transition:width .08s linear;
}

/* ===================== TOP BAR ===================== */
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:200;
  padding:24px 0;
  transition:padding .35s var(--ease), background .35s var(--ease), backdrop-filter .35s var(--ease), border-color .35s var(--ease);
  border-bottom:1px solid transparent;
}
.topbar.scrolled{
  padding:16px 0;
  background:rgba(6,7,11,0.7);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid var(--line);
}
.topbar .wrap{ display:flex; align-items:center; justify-content:space-between; }
.logo{
  display:flex; align-items:center; gap:10px;
  font-family:'Bricolage Grotesque', sans-serif;
  font-weight:700; font-size:18px; letter-spacing:-0.01em;
}
.logo-mark{ width:28px; height:28px; flex-shrink:0; }
.top-cta{ display:flex; align-items:center; gap:18px; }
.top-login{ font-size:14px; font-weight:500; color:var(--text-mute); transition:color .2s ease; }
.top-login:hover{ color:var(--text); }

.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:'Bricolage Grotesque', sans-serif;
  font-weight:600; font-size:14.5px;
  padding:13px 25px;
  border-radius:999px;
  border:1px solid transparent;
  cursor:pointer;
  transition:transform .3s var(--ease), box-shadow .3s var(--ease), background .3s ease, border-color .3s ease, color .3s ease;
  white-space:nowrap;
}
.btn-primary{
  background:linear-gradient(120deg, var(--sun), #FF5B45);
  color:#0A0700;
  box-shadow:0 1px 1px rgba(255,255,255,0.3) inset, 0 10px 26px -8px rgba(255,122,61,0.55);
}
.btn-primary:hover{ transform:translateY(-2px); box-shadow:0 1px 1px rgba(255,255,255,0.35) inset, 0 16px 34px -8px rgba(255,122,61,0.7); }
.btn-ghost{
  background:transparent; border-color:var(--line); color:var(--text);
}
.btn-ghost:hover{ background:rgba(255,255,255,0.06); border-color:rgba(255,255,255,0.25); }
.btn-outline{
  background:transparent; border-color:var(--line); color:var(--text);
}
.btn-outline:hover{ border-color:var(--horizon); color:var(--horizon); }
.btn-block{ width:100%; }

/* ===================== RIGHT SIDE SECTION NAV ===================== */
.side-nav{
  position:fixed; right:38px; top:50%; transform:translateY(-50%);
  z-index:150;
  display:flex; flex-direction:column; align-items:flex-end; gap:16px;
}
.side-nav .sn-item{
  display:flex; align-items:center; gap:12px;
  cursor:pointer;
  background:none; border:none; padding:0;
}
.side-nav .sn-label{
  font-family:'IBM Plex Mono', monospace;
  font-size:11px; letter-spacing:0.05em;
  color:var(--text-dim);
  opacity:0; transform:translateX(8px);
  transition:opacity .3s ease, transform .3s ease, color .3s ease;
  white-space:nowrap;
}
.side-nav .sn-item:hover .sn-label{ opacity:1; transform:translateX(0); color:var(--text-mute); }
.side-nav .sn-dot{
  width:7px; height:7px; border-radius:50%;
  background:var(--text-dim);
  transition:background .35s ease, box-shadow .35s ease, transform .35s ease;
  flex-shrink:0;
}
.side-nav .sn-item.active .sn-label{
  opacity:1; transform:translateX(0);
  color:var(--text); font-weight:600;
}
.side-nav .sn-item.active .sn-dot{
  background:var(--sun);
  box-shadow:0 0 0 4px rgba(255,122,61,0.18), 0 0 14px 1px rgba(255,122,61,0.6);
  transform:scale(1.3);
}
@media (max-width:980px){ .side-nav{ display:none; } }

/* ===================== MOBILE MENU ===================== */
.burger{ display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:6px; }
.burger span{ width:22px; height:2px; background:#fff; border-radius:2px; transition:transform .25s ease, opacity .25s ease; }
@media (max-width:880px){
  .top-login{ display:none; }
  .burger{ display:flex; }
}
.mobile-menu{
  position:fixed; inset:0; z-index:199;
  background:var(--bg);
  display:flex; flex-direction:column; justify-content:center;
  padding:40px 28px; gap:22px;
  transform:translateY(-100%);
  transition:transform .45s var(--ease);
}
.mobile-menu.open{ transform:translateY(0); }
.mobile-menu a{ font-family:'Bricolage Grotesque',sans-serif; font-size:26px; font-weight:600; color:var(--text); }
.mobile-menu .btn{ margin-top:14px; width:fit-content; }

/* ===================== REVEAL ===================== */
.reveal{
  opacity:0; transform:translateY(40px) scale(.97); filter:blur(6px);
  transition:opacity 1s var(--ease), transform 1s var(--ease), filter 1s var(--ease);
}
.reveal.in{ opacity:1; transform:translateY(0) scale(1); filter:blur(0); }
.reveal-stagger > *{ transition-delay:calc(var(--i, 0) * 90ms); }

/* ===================== HERO ===================== */
.hero{
  position:relative;
  min-height:100vh;
  display:flex; flex-direction:column; justify-content:center;
  padding:160px 0 90px;
  overflow:hidden;
  background:
    radial-gradient(60% 50% at var(--mx,50%) var(--my,15%), rgba(255,122,61,0.16), transparent 60%),
    radial-gradient(70% 60% at 85% 90%, rgba(92,141,255,0.16), transparent 60%),
    var(--bg);
}
.hero-grid{
  position:absolute; inset:0; pointer-events:none;
  background-image:
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
  background-size:56px 56px;
  -webkit-mask-image:radial-gradient(65% 55% at 50% 30%, black, transparent 78%);
          mask-image:radial-gradient(65% 55% at 50% 30%, black, transparent 78%);
  transform:translateY(calc(var(--scroll, 0) * -40px));
}
.horizon-arc{
  position:absolute; left:50%; bottom:-32%;
  width:1400px; height:1400px;
  transform:translate(-50%, calc(var(--scroll, 0) * 60px)) rotate(calc(var(--scroll, 0) * 8deg));
  border-radius:50%;
  border:1px solid rgba(255,255,255,0.07);
  pointer-events:none;
}
.horizon-arc::before{
  content:"";
  position:absolute; inset:60px;
  border-radius:50%;
  border:1px dashed rgba(255,255,255,0.06);
}
.sun-orb{
  position:absolute; left:50%; bottom:-6%;
  width:230px; height:230px; margin-left:-115px;
  border-radius:50%;
  background:radial-gradient(circle at 38% 30%, var(--sun-soft), var(--sun) 55%, #B03B17 100%);
  box-shadow:0 0 90px 18px rgba(255,122,61,0.45), 0 0 220px 60px rgba(255,122,61,0.18);
  transform:translateY(calc(var(--scroll, 0) * -140px));
  pointer-events:none;
}

.hero-inner{ position:relative; z-index:3; text-align:center; max-width:920px; margin:0 auto; }
.hero .eyebrow{ justify-content:center; margin-bottom:26px; opacity:0; animation:rise .8s var(--ease) .1s forwards; }
.hero h1{
  font-size:clamp(40px, 7vw, 84px);
  display:flex; flex-wrap:wrap; justify-content:center; gap:0 .28em;
}
.hero h1 .word{
  display:inline-block;
  opacity:0; transform:translateY(28px);
  animation:rise .9s var(--ease) forwards;
}
.hero h1 em{
  font-style:normal;
  background:linear-gradient(100deg, var(--sun-soft) 0%, var(--sun) 35%, var(--horizon) 75%, var(--violet) 100%);
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
@keyframes rise{ to{ opacity:1; transform:translateY(0); } }

.hero p.lead{
  margin-top:26px; font-size:18.5px; color:var(--text-mute);
  max-width:580px; margin-left:auto; margin-right:auto;
  opacity:0; animation:rise .9s var(--ease) .7s forwards;
}
.hero-cta{
  margin-top:38px; display:flex; align-items:center; justify-content:center; gap:16px; flex-wrap:wrap;
  opacity:0; animation:rise .9s var(--ease) .85s forwards;
}
.hero-note{
  margin-top:20px; font-size:12.5px; color:var(--text-dim);
  font-family:'IBM Plex Mono', monospace;
  opacity:0; animation:rise .9s var(--ease) 1s forwards;
}

.scroll-cue{
  position:absolute; left:50%; bottom:36px; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  font-family:'IBM Plex Mono', monospace; font-size:10.5px; letter-spacing:0.14em;
  color:var(--text-dim); text-transform:uppercase;
  opacity:calc(1 - var(--scroll, 0) * 4);
}
.scroll-cue .line{ width:1px; height:34px; background:linear-gradient(180deg, var(--text-dim), transparent); animation:cue 1.8s ease-in-out infinite; }
@keyframes cue{ 0%,100%{ transform:scaleY(1); opacity:.5; } 50%{ transform:scaleY(.55); opacity:1; } }

/* ===================== TRUST STRIP ===================== */
.trust{ padding:0 0 100px; text-align:center; position:relative; z-index:3; }
.trust .eyebrow{ justify-content:center; margin-bottom:24px; }
.trust-row{ display:flex; align-items:center; justify-content:center; gap:12px; flex-wrap:wrap; }
.pill{
  font-family:'IBM Plex Mono', monospace; font-size:12.5px; font-weight:500;
  padding:9px 16px; border-radius:999px;
  border:1px solid var(--line); background:var(--surface);
  color:var(--text-mute);
  display:inline-flex; align-items:center; gap:8px;
  transition:border-color .3s ease, color .3s ease, transform .3s ease;
}
.pill:hover{ border-color:rgba(255,122,61,0.4); color:var(--text); transform:translateY(-2px); }
.pill .dot{ width:5px; height:5px; border-radius:50%; background:var(--horizon); }

/* ===================== SECTION GENERICS ===================== */
section{ padding:140px 0; position:relative; }
@media (max-width:720px){ section{ padding:90px 0; } }
.section-head{ max-width:640px; margin-bottom:68px; }
.section-head.center{ margin-left:auto; margin-right:auto; text-align:center; }
.section-head .eyebrow{ margin-bottom:18px; }
.section-head h2{ font-size:clamp(30px, 4.2vw, 46px); }
.section-head p{ margin-top:18px; font-size:17px; color:var(--text-mute); }

/* ===================== PROBLEM ===================== */
.problem-grid{
  display:grid; grid-template-columns:repeat(3,1fr); gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r-lg); overflow:hidden;
}
@media (max-width:880px){ .problem-grid{ grid-template-columns:1fr; } }
.problem-cell{
  background:var(--bg-2); padding:42px 34px; position:relative;
  transition:background .4s ease;
}
.problem-cell:hover{ background:var(--surface); }
.problem-cell .stat{
  font-family:'Bricolage Grotesque',sans-serif; font-size:46px; font-weight:700;
  background:linear-gradient(100deg, var(--sun-soft), var(--sun));
  -webkit-background-clip:text; background-clip:text; color:transparent;
}
.problem-cell h3{ font-size:19px; margin-top:16px; }
.problem-cell p{ margin-top:10px; color:var(--text-mute); font-size:14.5px; }

/* ===================== BENTO FEATURES ===================== */
.bento{ display:grid; grid-template-columns:repeat(6, 1fr); gap:18px; }
@media (max-width:980px){ .bento{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .bento{ grid-template-columns:1fr; } }

.card{
  background:var(--surface);
  border:1px solid var(--line);
  border-radius:var(--r-md);
  padding:34px;
  position:relative; overflow:hidden;
  transition:transform .45s var(--ease), border-color .4s ease, background .4s ease;
}
.card::before{
  content:""; position:absolute; inset:0; border-radius:inherit; padding:1px;
  background:linear-gradient(140deg, rgba(255,122,61,0), rgba(255,122,61,0));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  transition:background .4s ease; pointer-events:none;
}
.card:hover{ transform:translateY(-6px); border-color:rgba(255,255,255,0.16); background:var(--surface-soft); }
.card:hover::before{ background:linear-gradient(140deg, rgba(255,122,61,0.7), rgba(92,141,255,0.5)); }
.card-icon{
  width:46px; height:46px; border-radius:13px;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,0.05);
  border:1px solid var(--line);
  margin-bottom:24px;
}
.card-icon svg{ width:22px; height:22px; }
.card h3{ font-size:19.5px; margin-bottom:9px; }
.card p{ font-size:14.5px; color:var(--text-mute); }
.card .tag{
  font-family:'IBM Plex Mono',monospace; font-size:10.5px; color:var(--sun-soft);
  background:rgba(255,122,61,0.12); padding:5px 10px; border-radius:6px;
  display:inline-block; margin-bottom:18px; font-weight:500; letter-spacing:.04em;
}

.col-3{ grid-column:span 3; } .col-2{ grid-column:span 2; } .col-4{ grid-column:span 4; }
@media (max-width:980px){ .col-3,.col-2,.col-4{ grid-column:span 2; } }
@media (max-width:560px){ .col-3,.col-2,.col-4{ grid-column:span 1; } }

.card-feature{ background:linear-gradient(155deg, #1A1206, #0E0905); border-color:rgba(255,122,61,0.18); }
.card-feature .card-icon{ background:rgba(255,122,61,0.14); border-color:rgba(255,122,61,0.25); }
.mini-orbit{ position:absolute; right:-30px; top:-30px; width:180px; height:180px; opacity:0.7; }

/* ===================== INTEGRATIONS MARQUEE ===================== */
.integrations{ background:var(--bg-2); border-top:1px solid var(--line); border-bottom:1px solid var(--line); }
.marquee-wrap{
  width:100%; overflow:hidden;
  mask-image:linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
  -webkit-mask-image:linear-gradient(90deg, transparent, black 8%, black 92%, transparent);
}
.marquee{ display:flex; gap:14px; width:max-content; animation:scrollLeft 40s linear infinite; }
.marquee.rev{ animation:scrollRight 36s linear infinite; }
.marquee:hover{ animation-play-state:paused; }
@keyframes scrollLeft{ from{transform:translateX(0);} to{transform:translateX(-50%);} }
@keyframes scrollRight{ from{transform:translateX(-50%);} to{transform:translateX(0);} }
.chip{
  display:flex; align-items:center; gap:10px;
  background:var(--surface); border:1px solid var(--line); border-radius:14px;
  padding:16px 22px; font-family:'Bricolage Grotesque',sans-serif; font-weight:600; font-size:15px;
  white-space:nowrap;
}
.chip .dot{ width:8px; height:8px; border-radius:50%; }
.chip small{ display:block; font-family:'IBM Plex Mono',monospace; font-weight:400; font-size:10.5px; color:var(--text-dim); margin-top:2px; }
.marquee-rows{ display:flex; flex-direction:column; gap:14px; margin-top:56px; }
.int-categories{ display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:56px; }
@media (max-width:880px){ .int-categories{ grid-template-columns:repeat(2,1fr); } }
.int-cat{ border:1px solid var(--line); border-radius:14px; padding:22px; background:var(--surface); }
.int-cat .eyebrow{ margin-bottom:10px; }
.int-cat p{ font-size:13.5px; color:var(--text-mute); }

/* ===================== PROCESS (pinned highlight) ===================== */
.process-flow{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
@media (max-width:880px){ .process-flow{ grid-template-columns:1fr; gap:40px; } }
.process-step{
  padding:30px 26px; border-radius:var(--r-md); border:1px solid var(--line);
  background:var(--surface);
  transition:border-color .5s ease, background .5s ease, transform .5s var(--ease);
}
.process-step.active{ border-color:rgba(255,122,61,0.4); background:var(--surface-soft); transform:translateY(-4px); }
.process-step .step-num{
  width:50px; height:50px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-family:'IBM Plex Mono',monospace; font-weight:500; font-size:13px;
  border:1px solid var(--line); color:var(--text-mute);
  margin-bottom:24px; transition:all .5s ease;
}
.process-step.active .step-num{ color:#0A0700; background:linear-gradient(120deg, var(--sun-soft), var(--sun)); border-color:transparent; }
.process-step h3{ font-size:21px; margin-bottom:10px; }
.process-step p{ color:var(--text-mute); font-size:15px; }

/* ===================== USE CASES ===================== */
.uc-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media (max-width:880px){ .uc-grid{ grid-template-columns:1fr; } }
.uc-card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--r-md); padding:30px; }
.uc-card .eyebrow{ margin-bottom:14px; }
.uc-card h3{ font-size:19px; margin-bottom:10px; }
.uc-card p{ font-size:14.5px; color:var(--text-mute); margin-bottom:18px; }
.uc-list{ display:flex; flex-direction:column; gap:9px; }
.uc-list li{ font-size:13.5px; color:var(--text-mute); display:flex; gap:9px; align-items:flex-start; }
.uc-list svg{ width:15px; height:15px; flex-shrink:0; margin-top:2px; color:var(--horizon); }

/* ===================== PRICING ===================== */
.pricing-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; align-items:stretch; }
@media (max-width:880px){ .pricing-grid{ grid-template-columns:1fr; } }
.price-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--r-lg);
  padding:38px 32px; display:flex; flex-direction:column;
  transition:transform .4s var(--ease), border-color .4s ease;
}
.price-card:hover{ transform:translateY(-5px); }
.price-card.featured{
  background:linear-gradient(160deg, #1A1206, #120B16);
  border-color:rgba(255,122,61,0.3);
  transform:scale(1.035);
}
.price-card .badge{
  align-self:flex-start; font-family:'IBM Plex Mono',monospace; font-size:11px; font-weight:500;
  padding:5px 11px; border-radius:999px; margin-bottom:20px;
  background:rgba(92,141,255,0.14); color:var(--horizon);
}
.price-card.featured .badge{ background:rgba(255,122,61,0.16); color:var(--sun-soft); }
.price-card h3{ font-size:23px; }
.price-card .price-tag{ font-family:'Bricolage Grotesque',sans-serif; font-size:17px; font-weight:600; margin-top:10px; }
.price-card p.desc{ font-size:14px; color:var(--text-mute); margin-top:10px; margin-bottom:28px; }
.feat-list{ display:flex; flex-direction:column; gap:13px; margin-bottom:32px; flex:1; }
.feat-list li{ font-size:14px; display:flex; gap:10px; align-items:flex-start; color:var(--text-mute); }
.feat-list svg{ width:16px; height:16px; flex-shrink:0; margin-top:2px; color:var(--sun-soft); }
.price-card .btn{ width:100%; }

/* ===================== FAQ ===================== */
.faq-list{
  max-width:760px; margin:0 auto; display:flex; flex-direction:column; gap:1px;
  background:var(--line); border:1px solid var(--line); border-radius:var(--r-md); overflow:hidden;
}
details{ background:var(--bg-2); }
summary{
  list-style:none; cursor:pointer;
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:25px 28px;
  font-family:'Bricolage Grotesque',sans-serif; font-weight:600; font-size:16.5px;
}
summary::-webkit-details-marker{ display:none; }
summary .plus{
  width:26px; height:26px; border-radius:50%; border:1px solid var(--line);
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  position:relative; transition:transform .35s ease, background .35s ease, border-color .35s ease;
}
summary .plus::before, summary .plus::after{ content:""; position:absolute; background:var(--text); transition:transform .3s ease; }
summary .plus::before{ width:10px; height:1.5px; }
summary .plus::after{ width:1.5px; height:10px; }
details[open] summary .plus{ background:linear-gradient(120deg, var(--sun-soft), var(--sun)); border-color:transparent; transform:rotate(180deg); }
details[open] summary .plus::before, details[open] summary .plus::after{ background:#0A0700; }
details[open] summary .plus::after{ transform:scaleY(0); }
.faq-a{ padding:0 28px 28px; font-size:15px; color:var(--text-mute); max-width:600px; }

/* ===================== FINAL CTA ===================== */
.final-cta{ text-align:center; position:relative; overflow:hidden; }
.final-cta::before{
  content:""; position:absolute; left:50%; top:0; transform:translateX(-50%);
  width:1000px; height:1000px;
  background:radial-gradient(circle, rgba(255,122,61,0.22), transparent 60%);
  pointer-events:none;
}
.final-cta-inner{ position:relative; z-index:2; max-width:660px; margin:0 auto; }
.final-cta .eyebrow{ justify-content:center; margin-bottom:22px; }
.final-cta h2{ font-size:clamp(32px,4.8vw,50px); }
.final-cta p{ margin-top:18px; color:var(--text-mute); font-size:17px; }
.final-cta .hero-cta{ margin-top:38px; opacity:1; animation:none; }

/* ===================== FOOTER (with functions) ===================== */
footer{ background:var(--bg-2); border-top:1px solid var(--line); padding:80px 0 36px; }
.footer-top{ display:grid; grid-template-columns:1.3fr 1fr; gap:60px; padding-bottom:56px; border-bottom:1px solid var(--line); }
@media (max-width:880px){ .footer-top{ grid-template-columns:1fr; gap:40px; } }
.footer-brand .logo{ margin-bottom:18px; }
.footer-brand p{ font-size:14.5px; color:var(--text-mute); max-width:340px; line-height:1.7; margin-bottom:24px; }
.footer-brand .top-cta{ gap:14px; }

.footer-functions h4, .footer-col h4{
  font-size:12px; font-family:'IBM Plex Mono',monospace; font-weight:500; letter-spacing:0.08em;
  text-transform:uppercase; color:var(--text-dim); margin-bottom:20px;
}
.func-grid{ display:grid; grid-template-columns:repeat(2,1fr); gap:14px 28px; }
@media (max-width:560px){ .func-grid{ grid-template-columns:1fr; } }
.func-item{
  display:flex; align-items:center; gap:10px; font-size:14.5px; color:var(--text-mute);
  padding:10px 0; border-bottom:1px solid var(--line-soft);
  transition:color .25s ease, padding-left .25s ease;
}
.func-item:hover{ color:var(--text); padding-left:6px; }
.func-item .dot{ width:5px; height:5px; border-radius:50%; background:var(--sun); flex-shrink:0; }

.footer-bottom{
  padding-top:30px;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:14px;
  font-size:13px; color:var(--text-dim);
}
.footer-bottom a{ color:var(--text-dim); transition:color .2s ease; }
.footer-bottom a:hover{ color:var(--text); }
.footer-links{ display:flex; gap:24px; flex-wrap:wrap; }

.skip-link{ position:absolute; left:-9999px; top:0; background:#fff; color:#000; padding:10px 16px; z-index:1000; }
.skip-link:focus{ left:16px; top:16px; }

a:focus-visible, button:focus-visible, summary:focus-visible{
  outline:2px solid var(--sun-soft); outline-offset:3px; border-radius:4px;
}
