/* ===================================================================
   AQUII TEM — Landing institucional
   Marca: neon lime #BFFF00 · preto #0B0B0B · Barlow
   =================================================================== */

/* ---------- tokens ---------- */
:root{
  --lime:#BFFF00;
  --lime-dim:#a6e000;
  --ink:#0B0B0B;
  --ink-2:#111311;
  --ink-3:#171a16;
  --ink-card:#16181500;
  --line:rgba(191,255,0,.14);
  --line-soft:rgba(255,255,255,.08);
  --white:#F4F7EE;
  --mut:#9aa093;
  --mut-2:#6f746a;

  --ff-disp:"Barlow Condensed", "Barlow", system-ui, sans-serif;
  --ff-body:"Barlow", system-ui, sans-serif;
  --ff-semi:"Barlow Semi Condensed","Barlow",sans-serif;

  --r:18px;
  --r-lg:26px;
  --container:1240px;
  --ease:cubic-bezier(.22,1,.36,1);
  --ease-out:cubic-bezier(.16,1,.3,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:auto;-webkit-text-size-adjust:100%}
html.lenis,html.lenis body{height:auto}
.lenis.lenis-smooth{scroll-behavior:auto!important}
.lenis.lenis-stopped{overflow:hidden}

body{
  font-family:var(--ff-body);
  background:var(--ink);
  color:var(--white);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
::selection{background:var(--lime);color:var(--ink)}

.container{width:min(100% - 40px,var(--container));margin-inline:auto}

/* ---------- atmosphere ---------- */
.grain{
  position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.bg-orbs{position:fixed;inset:0;z-index:0;pointer-events:none;overflow:hidden}
.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.16}
.orb--1{width:520px;height:520px;background:var(--lime);top:-160px;right:-120px}
.orb--2{width:460px;height:460px;background:#1f6f00;bottom:-160px;left:-140px;opacity:.22}

.scroll-progress{position:fixed;top:0;left:0;width:100%;height:3px;z-index:9999;background:transparent}
.scroll-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--lime),#7bf000);box-shadow:0 0 12px var(--lime)}

/* ---------- preloader ---------- */
.preloader{position:fixed;inset:0;z-index:9998;display:grid;place-items:center;background:var(--ink);transition:opacity .6s var(--ease),visibility .6s}
.preloader.done{opacity:0;visibility:hidden;pointer-events:none}
.preloader__inner{display:flex;flex-direction:column;align-items:center;gap:18px}
.pin--load{width:64px;animation:floatY 2.4s ease-in-out infinite}
.preloader__word{font-family:var(--ff-disp);font-weight:900;font-size:2rem;letter-spacing:.04em;text-transform:uppercase;color:var(--white)}
.preloader__word em{color:var(--lime);font-style:normal}
.preloader__bar{width:140px;height:3px;border-radius:3px;background:var(--line-soft);overflow:hidden}
.preloader__bar i{display:block;height:100%;width:40%;background:var(--lime);border-radius:3px;animation:loadbar 1.1s var(--ease) infinite}
@keyframes loadbar{0%{transform:translateX(-120%)}100%{transform:translateX(360%)}}

/* ---------- brand pin + wordmark ---------- */
.pin{width:42px;height:auto;display:block}
.brand{display:inline-flex;align-items:center;gap:10px}
.brand__pin{width:30px}
.brand__name{
  font-family:var(--ff-disp);font-weight:900;font-size:1.5rem;letter-spacing:.01em;
  line-height:.82;color:var(--white);text-transform:uppercase;
}
.brand__name em{color:var(--lime);font-style:normal}
/* small slot keeps the header height/menu stable; the logo floats absolute, hanging down */
.brand--img{position:relative;gap:0;width:88px;height:56px;flex:0 0 auto}
.brand__logo{
  position:absolute;left:50%;top:2px;z-index:2;height:128px;width:auto;transform-origin:center;
  will-change:transform;animation:logobob 4.5s ease-in-out infinite;
  transition:height .4s var(--ease),filter .35s var(--ease);
  filter:drop-shadow(0 10px 20px rgba(0,0,0,.55));
}
@keyframes logobob{
  0%,100%{transform:translateX(-50%) rotate(-2.5deg)}
  50%{transform:translateX(-50%) translateY(-7px) rotate(2.5deg)}
}
.brand--img:hover .brand__logo{filter:drop-shadow(0 14px 26px rgba(191,255,0,.45))}

/* compact brand (pin + wordmark, like the footer) shown when the bar minimizes */
.brand__compact{display:none;align-items:center;gap:9px}
.brand__compact .brand__pin{width:32px}
.nav.scrolled .brand--img{width:auto}
.nav.scrolled .brand__logo{display:none}
.nav.scrolled .brand__compact{display:inline-flex;animation:brandIn .4s var(--ease) both}
@keyframes brandIn{from{opacity:0;transform:translateX(-6px)}to{opacity:1;transform:none}}

/* green radial animation behind the logo (centered on the logo) — fades out when the bar is compact */
.brand__radar{position:absolute;left:50%;top:66px;width:0;height:0;z-index:1;pointer-events:none;transition:opacity .35s var(--ease)}
.nav.scrolled .brand__radar{opacity:0}
.brand__radar::before{content:"";position:absolute;left:-90px;top:-90px;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle,rgba(191,255,0,.36),rgba(191,255,0,.07) 46%,transparent 68%);animation:brandglow 3.6s ease-in-out infinite}
.brand__radar i{position:absolute;left:-50px;top:-50px;width:100px;height:100px;border-radius:50%;border:1.5px solid rgba(191,255,0,.5);box-shadow:0 0 24px rgba(191,255,0,.22);opacity:0;animation:brandring 5.4s var(--ease) infinite}
.brand__radar i:nth-child(2){animation-delay:1.8s}
.brand__radar i:nth-child(3){animation-delay:3.6s}
@keyframes brandglow{0%,100%{opacity:.35;transform:scale(.82)}50%{opacity:.8;transform:scale(1.12)}}
@keyframes brandring{0%{transform:scale(.45);opacity:0}14%{opacity:.7}100%{transform:scale(2.6);opacity:0}}
@media (prefers-reduced-motion:reduce){.brand__logo{animation:none}.brand__radar{display:none}}

/* ---------- buttons ---------- */
.btn{
  position:relative;display:inline-flex;align-items:center;justify-content:center;gap:.5em;
  font-family:var(--ff-semi);font-weight:700;font-size:1rem;letter-spacing:.01em;
  padding:.92em 1.5em;border-radius:100px;line-height:1;white-space:nowrap;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),background .3s,color .3s;
  will-change:transform;
}
.btn__ico{width:1.1em;height:1.1em}
.btn--sm{padding:.7em 1.15em;font-size:.92rem}
.btn--lg{padding:1.08em 1.8em;font-size:1.08rem}
.btn--lime{background:var(--lime);color:var(--ink);box-shadow:0 10px 30px -10px rgba(191,255,0,.6)}
.btn--lime:hover{box-shadow:0 16px 44px -10px rgba(191,255,0,.85);transform:translateY(-2px)}
.btn--ghost{background:rgba(255,255,255,.04);color:var(--white);border:1px solid rgba(255,255,255,.16)}
.btn--ghost:hover{border-color:var(--lime);color:var(--lime);transform:translateY(-2px)}
.btn--dark{background:var(--ink);color:var(--lime);box-shadow:0 12px 34px -12px rgba(0,0,0,.6)}
.btn--dark:hover{transform:translateY(-2px);box-shadow:0 18px 44px -12px rgba(0,0,0,.7)}
.btn .btn__ico{transition:transform .35s var(--ease)}
.btn:hover .btn__ico{transform:translateX(4px)}

/* ---------- nav ---------- */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:900;
  padding:18px 0;
  transition:background .4s var(--ease),backdrop-filter .4s,padding .4s,border-color .4s;
  border-bottom:1px solid transparent;
}
.nav__inner{
  width:min(100% - 40px,var(--container));margin-inline:auto;
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav.scrolled{
  background:rgba(11,11,11,.72);backdrop-filter:blur(16px) saturate(1.3);
  border-bottom-color:var(--line-soft);padding-top:12px;padding-bottom:12px;
}
.nav__links{display:flex;gap:30px}
.nav__links a{
  font-family:var(--ff-semi);font-weight:600;font-size:.96rem;color:var(--mut);
  position:relative;transition:color .25s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:-6px;width:0;height:2px;background:var(--lime);transition:width .3s var(--ease)}
.nav__links a:hover{color:var(--white)}
.nav__links a:hover::after{width:100%}
.nav__burger{display:none;flex-direction:column;gap:5px;padding:8px}
.nav__burger span{width:24px;height:2px;background:var(--white);border-radius:2px;transition:.3s var(--ease)}
.nav.open .nav__burger span:first-child{transform:translateY(3.5px) rotate(45deg)}
.nav.open .nav__burger span:last-child{transform:translateY(-3.5px) rotate(-45deg)}

.drawer{
  position:fixed;inset:0 0 0 auto;width:min(82vw,340px);z-index:899;
  background:var(--ink-2);border-left:1px solid var(--line-soft);
  display:flex;flex-direction:column;gap:6px;justify-content:center;padding:40px 34px;
  transform:translateX(100%);transition:transform .5s var(--ease);
}
.drawer.open{transform:translateX(0)}
.drawer a{font-family:var(--ff-disp);font-weight:700;font-size:1.7rem;text-transform:uppercase;color:var(--white);padding:8px 0}
.drawer a.btn{margin-top:20px;font-size:1rem;text-transform:none;justify-content:center}

/* ===================================================================
   HERO
   =================================================================== */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;padding:120px 0 70px;overflow:hidden}
.hero__grid{
  position:absolute;inset:0;z-index:0;opacity:.5;
  background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(ellipse 80% 70% at 50% 35%,#000 30%,transparent 78%);
          mask-image:radial-gradient(ellipse 80% 70% at 50% 35%,#000 30%,transparent 78%);
}
.hero__inner{
  position:relative;z-index:2;width:min(100% - 40px,var(--container));margin-inline:auto;
  display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;
}
.badge{
  display:inline-flex;align-items:center;gap:9px;
  font-family:var(--ff-semi);font-weight:600;font-size:.86rem;letter-spacing:.04em;text-transform:uppercase;
  padding:.55em 1em;border:1px solid var(--line);border-radius:100px;color:var(--lime);
  background:rgba(191,255,0,.05);
}
.badge__dot{width:8px;height:8px;border-radius:50%;background:var(--lime);box-shadow:0 0 0 0 rgba(191,255,0,.6);animation:pulse 2.4s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(191,255,0,.55)}70%{box-shadow:0 0 0 10px rgba(191,255,0,0)}100%{box-shadow:0 0 0 0 rgba(191,255,0,0)}}

.hero__title{
  font-family:var(--ff-disp);font-weight:900;text-transform:uppercase;
  font-size:clamp(3.4rem,8.5vw,7.4rem);line-height:.9;letter-spacing:-.01em;margin:.36em 0 .28em;
}
.hero__title .line{display:block;overflow:hidden}
.hero__title .line--accent{color:var(--lime)}
.hero__title .stroke{
  color:transparent;-webkit-text-stroke:2px var(--lime);
  text-shadow:0 0 36px rgba(191,255,0,.35);
}
.hero__sub{max-width:30em;font-size:clamp(1.05rem,1.4vw,1.22rem);color:var(--mut);font-weight:400}
.hero__sub strong{color:var(--white);font-weight:600}
.hero__actions{display:flex;flex-wrap:wrap;gap:14px;margin:30px 0 26px}
.hero__chips{list-style:none;display:flex;flex-wrap:wrap;gap:9px}
.chip{
  display:inline-block;font-family:var(--ff-semi);font-weight:500;font-size:.84rem;color:var(--mut);
  padding:.45em .9em;border:1px solid var(--line-soft);border-radius:100px;transition:.25s var(--ease);
}
.hero__chips li:hover .chip{border-color:var(--lime);color:var(--lime);transform:translateY(-2px)}

/* hero visual */
.hero__visual{position:relative;aspect-ratio:1/1.05;display:flex;align-items:center;justify-content:center}
.hero__photo{
  position:relative;width:86%;height:86%;border-radius:32px;overflow:visible;
  background:radial-gradient(120% 120% at 30% 10%,#243000,#0d0f0b 60%);
  border:1px solid var(--line);
  box-shadow:0 40px 90px -40px rgba(0,0,0,.8),inset 0 0 0 1px rgba(255,255,255,.02);
}
/* subtle lime glow behind the cut-out crew */
.hero__photo-glow{
  position:absolute;left:50%;top:42%;width:78%;height:70%;transform:translate(-50%,-50%);
  background:radial-gradient(circle,rgba(191,255,0,.22),transparent 65%);filter:blur(20px);z-index:0;border-radius:50%;
}
/* rotating slides — crossfade between professionals */
.hero__slide{position:absolute;inset:0;z-index:2;opacity:0;visibility:hidden;transition:opacity 1.1s var(--ease),visibility 1.1s var(--ease);pointer-events:none}
.hero__slide.is-active{opacity:1;visibility:visible}
/* subject breaks OUT of the box for depth */
.hero__photo-img{
  position:absolute;inset:0;z-index:2;
  width:100%;height:100%;
  object-fit:contain;object-position:center bottom;
  transform:scale(1.2);transform-origin:bottom center;
  filter:drop-shadow(0 26px 32px rgba(0,0,0,.6));
}
/* big radial radar behind the whole photo card */
.hero__radar{position:absolute;left:50%;top:50%;width:0;height:0;z-index:0;transform:translate(-50%,-50%);pointer-events:none}
.hero__radar i{position:absolute;left:50%;top:50%;width:150px;height:150px;margin:-75px 0 0 -75px;border-radius:50%;border:2px solid rgba(191,255,0,.6);box-shadow:0 0 50px rgba(191,255,0,.28),inset 0 0 44px rgba(191,255,0,.12);opacity:0;animation:radar 10s var(--ease) infinite}
.hero__radar i:nth-child(2){animation-delay:3.33s}
.hero__radar i:nth-child(3){animation-delay:6.66s}
.hero__radar::after{content:"";position:absolute;left:50%;top:50%;width:760px;height:760px;margin:-380px 0 0 -380px;border-radius:50%;background:conic-gradient(from 0deg,rgba(191,255,0,.16),rgba(191,255,0,.03) 30%,transparent 44%);-webkit-mask-image:radial-gradient(circle,#000 0 70%,transparent 72%);mask-image:radial-gradient(circle,#000 0 70%,transparent 72%);animation:sweep 12s linear infinite;opacity:.5}
.hero__radar::before{content:"";position:absolute;left:50%;top:50%;width:280px;height:280px;margin:-140px 0 0 -140px;border-radius:50%;background:radial-gradient(circle,rgba(191,255,0,.16),transparent 65%);animation:coreglow 7s ease-in-out infinite}
@media (prefers-reduced-motion:reduce){.hero__radar{display:none}}
.hero__pin{
  position:absolute;top:2%;right:6%;width:78px;z-index:3;
  filter:drop-shadow(0 18px 30px rgba(0,0,0,.55));animation:floatY 5s ease-in-out infinite;
}
@keyframes floatY{0%,100%{transform:translateY(0) rotate(-4deg)}50%{transform:translateY(-16px) rotate(2deg)}}

.floatcard{
  position:absolute;z-index:4;display:flex;align-items:center;gap:11px;
  background:rgba(20,22,18,.82);backdrop-filter:blur(12px);
  border:1px solid var(--line);border-radius:16px;padding:12px 15px;
  box-shadow:0 22px 50px -22px rgba(0,0,0,.85);
}
.floatcard strong{display:block;font-family:var(--ff-semi);font-weight:700;font-size:.92rem;line-height:1.15}
.floatcard small{color:var(--mut);font-size:.76rem}
.floatcard--a{left:-4%;top:18%}
.floatcard--b{right:-6%;bottom:14%}
.floatcard__ico{display:grid;place-items:center;width:30px;height:30px;border-radius:50%;background:var(--lime);color:var(--ink);font-weight:900;font-size:.9rem}
.floatcard__avatars{display:flex}
.floatcard__avatars i{width:26px;height:26px;border-radius:50%;border:2px solid var(--ink-2);margin-left:-9px;background:linear-gradient(135deg,var(--lime),#3a6b00)}
.floatcard__avatars i:first-child{margin-left:0}

.hero__scroll{position:absolute;left:50%;bottom:26px;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--mut-2);font-family:var(--ff-semi);font-size:.72rem;letter-spacing:.3em;text-transform:uppercase}
.hero__scroll-line{width:1px;height:40px;background:linear-gradient(var(--lime),transparent);position:relative;overflow:hidden}
.hero__scroll-line::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--lime);animation:scrolldot 1.8s var(--ease) infinite}
@keyframes scrolldot{0%{top:-50%}100%{top:120%}}

/* ---------- placeholders ---------- */
.placeholder{position:relative;display:grid;place-items:center}
.placeholder::before{
  content:"";position:absolute;inset:0;
  background-image:repeating-linear-gradient(45deg,rgba(191,255,0,.06) 0 12px,transparent 12px 24px);
  border-radius:inherit;
}
.placeholder__tag{
  position:relative;z-index:1;font-family:var(--ff-semi);font-weight:600;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--lime);background:rgba(11,11,11,.7);padding:.5em .9em;border:1px dashed var(--line);border-radius:8px;
}
.placeholder--dark .placeholder__tag{color:var(--ink);background:rgba(191,255,0,.85);border-color:rgba(0,0,0,.2)}

/* ===================================================================
   MARQUEE
   =================================================================== */
.marquee{
  border-top:1px solid var(--line-soft);border-bottom:1px solid var(--line-soft);
  padding:22px 0;overflow:hidden;background:var(--ink-2);
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
          mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
}
.marquee__track{display:flex;align-items:center;gap:34px;width:max-content;white-space:nowrap;will-change:transform}
.marquee__track span{font-family:var(--ff-disp);font-weight:800;font-size:clamp(1.5rem,3vw,2.3rem);text-transform:uppercase;color:transparent;-webkit-text-stroke:1px rgba(244,247,238,.35)}
.marquee__track .star{-webkit-text-stroke:0;color:var(--lime);font-size:1.2rem}

/* ===================================================================
   STATS
   =================================================================== */
.stats{padding:88px 0;border-bottom:1px solid var(--line-soft)}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.stat{padding:8px 6px}
.stat__num{font-family:var(--ff-disp);font-weight:900;font-size:clamp(2.8rem,5vw,4.4rem);line-height:.9;color:var(--lime);display:block}
.stat__city{font-size:clamp(1.7rem,3vw,2.5rem);color:var(--white)}
.stat__label{display:block;margin-top:8px;color:var(--mut);font-size:.96rem;max-width:14em}
.stat--city{border-left:2px solid var(--line)}

/* ===================================================================
   SECTION HEADS
   =================================================================== */
.sec-head{max-width:46rem;margin-bottom:54px}
.eyebrow{font-family:var(--ff-semi);font-weight:600;font-size:.84rem;letter-spacing:.22em;text-transform:uppercase;color:var(--lime)}
.eyebrow--dark{color:var(--ink)}
.sec-title{font-family:var(--ff-disp);font-weight:900;text-transform:uppercase;font-size:clamp(2.2rem,5vw,4rem);line-height:.95;letter-spacing:-.01em;margin:.32em 0}
.sec-title .hl{color:var(--lime)}
.sec-title--dark{color:var(--ink)}
.sec-title .hl-dark{color:var(--ink);position:relative;display:inline-block}
.sec-title .hl-dark::after{content:"";position:absolute;left:-2%;bottom:.08em;width:104%;height:.16em;background:rgba(11,11,11,.25)}
.sec-lead{font-size:clamp(1.02rem,1.3vw,1.18rem);color:var(--mut);max-width:38em}
.sec-lead strong{color:var(--white);font-weight:600}

/* ===================================================================
   HOW
   =================================================================== */
.how{padding:96px 0}
.how__steps{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:26px;perspective:1300px}
.how__line{position:absolute;top:54px;left:8%;width:84%;height:2px;background:repeating-linear-gradient(90deg,var(--line) 0 8px,transparent 8px 16px);z-index:0}
.step{
  position:relative;z-index:1;overflow:hidden;background:var(--ink-2);border:1px solid var(--line-soft);
  border-radius:var(--r-lg);padding:34px 28px 30px;
  transform-style:preserve-3d;will-change:transform;
  transition:border-color .45s var(--ease),box-shadow .55s var(--ease),background .45s var(--ease);
}
/* cursor-following spotlight (Motion-style pointer transform) */
.step::before{content:"";position:absolute;inset:0;z-index:0;opacity:0;pointer-events:none;border-radius:inherit;
  background:radial-gradient(440px circle at var(--mx,50%) var(--my,50%),rgba(191,255,0,.16),transparent 58%);
  transition:opacity .4s var(--ease)}
.step:hover::before{opacity:1}
/* sheen sweep on enter */
.step__sheen{content:"";position:absolute;top:0;left:-65%;width:45%;height:100%;z-index:1;pointer-events:none;
  background:linear-gradient(105deg,transparent,rgba(255,255,255,.07),transparent);transform:skewX(-18deg)}
.step:hover .step__sheen{animation:sheen .9s var(--ease)}
@keyframes sheen{from{left:-65%}to{left:135%}}
.step:hover{border-color:var(--lime);background:linear-gradient(180deg,rgba(191,255,0,.05),var(--ink-2) 60%);
  box-shadow:0 38px 72px -34px rgba(0,0,0,.85),0 0 0 1px rgba(191,255,0,.22),0 22px 60px -34px rgba(191,255,0,.32)}
.step__num,.step__ico,.step h3,.step p{position:relative;z-index:2}
.step__num{display:inline-block;font-family:var(--ff-disp);font-weight:900;font-size:1rem;color:var(--lime);letter-spacing:.1em;
  transition:transform .5s var(--ease),text-shadow .4s var(--ease)}
.step:hover .step__num{transform:translateZ(26px) translateX(2px);text-shadow:0 0 18px rgba(191,255,0,.6)}
.step__ico{width:54px;height:54px;border-radius:15px;display:grid;place-items:center;background:rgba(191,255,0,.08);border:1px solid var(--line);margin:14px 0 18px;color:var(--lime);
  transition:transform .5s cubic-bezier(.34,1.56,.64,1),background .4s var(--ease),color .4s var(--ease),box-shadow .4s var(--ease)}
.step__ico svg{width:26px;height:26px}
.step:hover .step__ico{background:var(--lime);color:var(--ink);transform:translateZ(40px) rotate(-8deg) scale(1.1);box-shadow:0 16px 30px -10px rgba(191,255,0,.5)}
.step h3{font-family:var(--ff-disp);font-weight:800;font-size:1.6rem;text-transform:uppercase;letter-spacing:-.01em;margin-bottom:8px;
  transition:transform .5s var(--ease),color .35s var(--ease)}
.step:hover h3{transform:translateZ(30px)}
.step p{color:var(--mut);font-size:1rem;transition:transform .5s var(--ease),color .35s var(--ease)}
.step:hover p{transform:translateZ(16px);color:#b9c0ad}

/* ===================================================================
   CATEGORIAS
   =================================================================== */
.cats{padding:96px 0}
.cats__grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;perspective:1300px}
.cat{
  position:relative;overflow:hidden;background:var(--ink-2);border:1px solid var(--line-soft);
  border-radius:var(--r);padding:26px 22px 24px;cursor:default;outline:none;
  transform-style:preserve-3d;will-change:transform;
  transition:border-color .45s var(--ease),box-shadow .5s var(--ease),background .45s var(--ease);
}
/* cursor-following spotlight */
.cat::before{content:"";position:absolute;inset:0;z-index:0;opacity:0;pointer-events:none;border-radius:inherit;
  background:radial-gradient(360px circle at var(--mx,50%) var(--my,50%),rgba(191,255,0,.18),transparent 60%);
  transition:opacity .4s var(--ease)}
.cat:hover::before,.cat:focus-visible::before{opacity:1}
.cat:hover,.cat:focus-visible{border-color:var(--lime);
  box-shadow:0 32px 62px -34px rgba(0,0,0,.85),0 0 0 1px rgba(191,255,0,.2),0 18px 52px -34px rgba(191,255,0,.32)}
.cat__icon,.cat h3,.cat p,.cat__count{position:relative;z-index:2}
.cat__icon{display:inline-grid;place-items:center;width:50px;height:50px;border-radius:14px;background:rgba(191,255,0,.07);border:1px solid var(--line);color:var(--lime);
  transition:transform .5s cubic-bezier(.34,1.56,.64,1),background .4s var(--ease),color .4s var(--ease),box-shadow .4s var(--ease)}
.cat__icon svg{width:26px;height:26px}
.cat:hover .cat__icon,.cat:focus-visible .cat__icon{background:var(--lime);color:var(--ink);transform:translateZ(34px) rotate(-8deg) scale(1.1);box-shadow:0 14px 26px -10px rgba(191,255,0,.5)}
.cat h3{font-family:var(--ff-disp);font-weight:800;font-size:1.32rem;text-transform:uppercase;line-height:1;margin:16px 0 8px;letter-spacing:-.005em;transition:transform .5s var(--ease)}
.cat:hover h3,.cat:focus-visible h3{transform:translateZ(26px)}
.cat p{color:var(--mut);font-size:.86rem;min-height:2.4em;transition:transform .5s var(--ease)}
.cat:hover p,.cat:focus-visible p{transform:translateZ(15px)}
.cat__count{display:inline-block;margin-top:14px;font-family:var(--ff-semi);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.05em;color:var(--lime);padding:.4em .8em;border:1px solid var(--line);border-radius:100px;transition:transform .5s var(--ease)}
.cat:hover .cat__count,.cat:focus-visible .cat__count{transform:translateZ(20px)}
.cat--delivery{background:linear-gradient(160deg,rgba(191,255,0,.12),var(--ink-2))}

/* ===================================================================
   DIFERENCIAIS — bento
   =================================================================== */
.diff{padding:96px 0}
.bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:minmax(180px,auto);gap:18px}
.bento__card{
  position:relative;overflow:hidden;background:var(--ink-2);border:1px solid var(--line-soft);
  border-radius:var(--r-lg);padding:30px 28px;display:flex;flex-direction:column;transition:.4s var(--ease);
}
.bento__card:hover{border-color:var(--line);transform:translateY(-4px)}
.bento--big{position:relative;overflow:visible;grid-column:span 2;grid-row:span 2;background:linear-gradient(165deg,rgba(191,255,0,.1),var(--ink-2) 55%);justify-content:flex-end}
.bento--big::after{content:"";position:absolute;inset:0;border-radius:inherit;box-shadow:inset 0 0 0 1px var(--line-soft);pointer-events:none}
.bento__media{position:absolute;top:-9%;left:50%;transform:translateX(-50%);width:74%;max-width:440px;z-index:1;pointer-events:none}
.bento__media-img{transform-origin:center}
.bento__media-img{width:100%;height:auto;filter:drop-shadow(0 22px 34px rgba(0,0,0,.5));animation:floatY 6s ease-in-out infinite}
.bento--big .bento__ico,.bento--big h3,.bento--big p,.bento--big .bento__pill{position:relative;z-index:2}
.bento--wide{grid-column:span 2}
.bento__card:not(.bento--big):not(.bento--wide){grid-column:span 1}
.bento__ico{margin-bottom:auto;display:inline-grid;place-items:center;width:52px;height:52px;border-radius:14px;background:rgba(191,255,0,.08);border:1px solid var(--line);color:var(--lime)}
.bento__ico svg{width:27px;height:27px}
.bento--big .bento__ico{width:64px;height:64px}
.bento--big .bento__ico svg{width:34px;height:34px}
.bento__card h3{font-family:var(--ff-disp);font-weight:800;font-size:1.5rem;text-transform:uppercase;margin:18px 0 8px;letter-spacing:-.01em}
.bento--big h3{font-size:2.2rem}
.bento__card p{color:var(--mut);font-size:.98rem}
.bento--big p{font-size:1.08rem;max-width:30em}
.bento__pill{align-self:flex-start;margin-top:16px;font-family:var(--ff-semi);font-weight:600;font-size:.74rem;text-transform:uppercase;letter-spacing:.06em;color:var(--ink);background:var(--lime);padding:.45em .9em;border-radius:100px}

/* fill the bento: 3rd & 4th small cards live in rows 1-2 right column */
.bento__card:nth-child(2){grid-column:3}
.bento__card:nth-child(3){grid-column:4}
.bento--wide{grid-column:3 / span 2}

/* ===================================================================
   PARA PRESTADORES
   =================================================================== */
.prov{position:relative;padding:104px 0;background:var(--lime);color:var(--ink);overflow:hidden}
.prov__bg{position:absolute;inset:0;opacity:.5;background-image:linear-gradient(rgba(11,11,11,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(11,11,11,.05) 1px,transparent 1px);background-size:48px 48px;-webkit-mask-image:radial-gradient(circle at 70% 50%,#000,transparent 75%);mask-image:radial-gradient(circle at 70% 50%,#000,transparent 75%)}
.prov__inner{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.prov__lead{font-size:1.16rem;font-weight:500;max-width:30em;margin:18px 0 26px;color:#1c1f14}
.prov__list{list-style:none;display:flex;flex-direction:column;gap:14px;margin-bottom:32px}
.prov__list li{display:flex;align-items:center;gap:13px;font-size:1.05rem;font-weight:500;font-family:var(--ff-semi)}
.prov__list li span{display:grid;place-items:center;flex:0 0 auto;width:38px;height:38px;border-radius:11px;background:var(--ink);font-size:1.05rem}
.prov__visual{position:relative;aspect-ratio:4/4.4}
.prov__photo{position:relative;width:100%;height:100%;border-radius:28px;overflow:hidden;background:radial-gradient(120% 100% at 60% 0,#1a1d12,#000 70%);border:2px solid var(--ink);box-shadow:18px 18px 0 rgba(11,11,11,.12)}
.prov__photo-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%;transform:scale(1.1);transform-origin:center top;filter:drop-shadow(0 20px 30px rgba(0,0,0,.4))}
.prov__badge{position:absolute;left:-22px;bottom:34px;background:var(--ink);color:var(--lime);border-radius:16px;padding:14px 20px;text-align:center;box-shadow:0 22px 44px -18px rgba(0,0,0,.5)}
.prov__badge strong{display:block;font-family:var(--ff-disp);font-weight:900;font-size:2rem;line-height:1}
.prov__badge small{font-size:.78rem;color:var(--white)}

/* ===================================================================
   TRUST
   =================================================================== */
.trust{padding:104px 0}
.trust__inner{display:grid;grid-template-columns:.9fr 1.1fr;gap:60px;align-items:center}
.idcard{position:relative;background:var(--ink-2);border:1px solid var(--line);border-radius:var(--r-lg);padding:24px;box-shadow:0 40px 80px -40px rgba(0,0,0,.8);max-width:420px}
.idcard__head{display:flex;align-items:center;gap:10px;font-family:var(--ff-semi);font-weight:600;font-size:.9rem;color:var(--lime);padding-bottom:18px;border-bottom:1px solid var(--line-soft)}
.idcard__chip{width:26px;height:19px;border-radius:5px;background:linear-gradient(135deg,var(--lime),#5e8a00)}
.idcard__body{display:flex;gap:18px;margin-top:20px}
.idcard__photo{position:relative;flex:0 0 120px;height:150px;border-radius:14px;overflow:hidden;background:radial-gradient(circle at 50% 25%,#2a3a10,#0d0f0b 75%)}
.idcard__photo-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center 12%}
.idcard__lines{flex:1;display:flex;flex-direction:column;gap:13px;justify-content:center}
.idcard__lines i{height:11px;border-radius:6px;background:rgba(255,255,255,.08)}
.idcard__lines i:nth-child(1){width:90%}
.idcard__lines i:nth-child(2){width:70%}
.idcard__lines i:nth-child(3){width:82%;background:rgba(191,255,0,.25)}
.idcard__seal{position:absolute;right:-16px;top:-16px;display:flex;align-items:center;gap:6px;background:var(--lime);color:var(--ink);font-family:var(--ff-semi);font-weight:700;font-size:.86rem;padding:.55em .95em;border-radius:100px;box-shadow:0 14px 30px -10px rgba(191,255,0,.6)}
.idcard__seal svg{width:15px;height:15px}
.trust__tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:26px}
.trust__tags span{font-family:var(--ff-semi);font-weight:600;font-size:.84rem;color:var(--white);padding:.5em 1em;border:1px solid var(--line);border-radius:100px;background:rgba(191,255,0,.04)}

/* ===================================================================
   CITY
   =================================================================== */
.city{padding:96px 0}
.city__inner{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.city__next{margin-top:18px;color:var(--mut);font-size:1.05rem}
.city__next strong{color:var(--lime)}
.city .btn{margin-top:26px}
.map{position:relative;aspect-ratio:1/.92;border-radius:var(--r-lg);background:radial-gradient(110% 110% at 50% 42%,#11150d,#070806);border:1px solid var(--line-soft);overflow:hidden}
.map__img{position:absolute;inset:0;display:block;z-index:1}
.map__img img{width:100%;height:100%;object-fit:cover;object-position:center;opacity:1;
  -webkit-mask-image:radial-gradient(120% 110% at 50% 45%,#000 45%,transparent 88%);
          mask-image:radial-gradient(120% 110% at 50% 45%,#000 45%,transparent 88%);
  filter:drop-shadow(0 0 14px rgba(191,255,0,.18));
}
.map__grid{position:absolute;inset:0;z-index:2;background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);background-size:40px 40px;opacity:.25}
.map__pin{position:absolute;left:50%;top:48.5%;transform:translate(-50%,-100%);z-index:3}
.map__pin .pin{width:58px;filter:drop-shadow(0 14px 22px rgba(0,0,0,.6))}
.map__pulse{position:absolute;left:50%;bottom:6px;width:18px;height:18px;border-radius:50%;background:var(--lime);transform:translateX(-50%);opacity:.5;animation:ping 2.6s var(--ease) infinite}
@keyframes ping{0%{transform:translateX(-50%) scale(.4);opacity:.6}80%,100%{transform:translateX(-50%) scale(4.2);opacity:0}}
.map__label{position:absolute;left:50%;top:50%;z-index:4;transform:translate(-50%,16px);font-family:var(--ff-semi);font-weight:700;font-size:.92rem;color:var(--white);background:rgba(11,11,11,.78);backdrop-filter:blur(4px);padding:.4em .85em;border:1px solid var(--line);border-radius:100px;white-space:nowrap}
/* radial radar animation centered on the pin */
.map__radar{position:absolute;left:50%;top:48.5%;width:0;height:0;z-index:3;transform:translate(-50%,-50%);pointer-events:none}
.map__radar i{position:absolute;left:50%;top:50%;width:70px;height:70px;margin:-35px 0 0 -35px;border-radius:50%;border:1.5px solid rgba(191,255,0,.45);box-shadow:0 0 18px rgba(191,255,0,.2),inset 0 0 16px rgba(191,255,0,.12);opacity:0;animation:radar 9s var(--ease) infinite}
.map__radar i:nth-child(2){animation-delay:3s}
.map__radar i:nth-child(3){animation-delay:6s}
@keyframes radar{0%{transform:scale(.18);opacity:0}10%{opacity:.5}65%{opacity:.18}100%{transform:scale(8);opacity:0}}
/* rotating sweep beam */
.map__radar::after{content:"";position:absolute;left:50%;top:50%;width:540px;height:540px;margin:-270px 0 0 -270px;border-radius:50%;background:conic-gradient(from 0deg,rgba(191,255,0,.2),rgba(191,255,0,.04) 28%,transparent 42%);-webkit-mask-image:radial-gradient(circle,#000 0 70%,transparent 72%);mask-image:radial-gradient(circle,#000 0 70%,transparent 72%);animation:sweep 11s linear infinite;opacity:.55}
@keyframes sweep{to{transform:rotate(360deg)}}
/* soft pulsing core glow under the pin */
.map__radar::before{content:"";position:absolute;left:50%;top:50%;width:160px;height:160px;margin:-80px 0 0 -80px;border-radius:50%;background:radial-gradient(circle,rgba(191,255,0,.22),transparent 65%);animation:coreglow 7s ease-in-out infinite}
@keyframes coreglow{0%,100%{opacity:.25;transform:scale(.9)}50%{opacity:.45;transform:scale(1.1)}}
@media (prefers-reduced-motion:reduce){.map__radar{display:none}}

/* ===================================================================
   FAQ
   =================================================================== */
.faq{padding:96px 0}
.faq__list{max-width:860px;margin-inline:auto;display:flex;flex-direction:column;gap:12px}
.qa{background:var(--ink-2);border:1px solid var(--line-soft);border-radius:var(--r);overflow:hidden;transition:border-color .3s}
.qa[open]{border-color:var(--line)}
.qa summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:16px;
  font-family:var(--ff-disp);font-weight:700;font-size:clamp(1.15rem,2vw,1.45rem);text-transform:uppercase;letter-spacing:-.005em;
  padding:22px 24px;
}
.qa summary::-webkit-details-marker{display:none}
.qa__plus{position:relative;flex:0 0 auto;width:22px;height:22px}
.qa__plus::before,.qa__plus::after{content:"";position:absolute;background:var(--lime);border-radius:2px;transition:transform .35s var(--ease)}
.qa__plus::before{left:0;top:10px;width:22px;height:2px}
.qa__plus::after{left:10px;top:0;width:2px;height:22px}
.qa[open] .qa__plus::after{transform:rotate(90deg);opacity:0}
.qa__body{max-height:0;overflow:hidden;transition:max-height .45s var(--ease)}
.qa__body p{padding:0 24px 24px;color:var(--mut);font-size:1.02rem;max-width:60ch}

/* ===================================================================
   CTA
   =================================================================== */
.cta{position:relative;padding:120px 0;text-align:center;overflow:hidden;border-top:1px solid var(--line-soft)}
.cta__glow{position:absolute;left:50%;top:30%;width:680px;height:680px;transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(191,255,0,.16),transparent 62%);pointer-events:none}
.cta__inner{position:relative;display:flex;flex-direction:column;align-items:center}
.cta__pin{width:64px;margin-bottom:24px;filter:drop-shadow(0 16px 30px rgba(0,0,0,.5))}
.cta__title{font-family:var(--ff-disp);font-weight:900;text-transform:uppercase;font-size:clamp(2.6rem,7vw,5.6rem);line-height:.92}
.cta__title .stroke{color:transparent;-webkit-text-stroke:2px var(--lime)}
.cta__lead{color:var(--mut);font-size:1.16rem;margin:16px 0 36px;max-width:34em}
.cta__form{width:min(100%,560px)}
.cta__toggle{display:inline-flex;gap:4px;background:var(--ink-2);border:1px solid var(--line-soft);border-radius:100px;padding:5px;margin-bottom:18px}
.cta__toggle button{font-family:var(--ff-semi);font-weight:600;font-size:.94rem;color:var(--mut);padding:.62em 1.3em;border-radius:100px;transition:.3s var(--ease)}
.cta__toggle button.is-active{background:var(--lime);color:var(--ink)}
.cta__fields{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.cta__fields .btn{grid-column:1 / -1;width:100%}
.cta__field{position:relative;min-width:0;display:flex;align-items:center}
.cta__field-ico{position:absolute;left:1.15em;width:1.15em;height:1.15em;color:var(--mut-2);pointer-events:none;transition:color .3s}
.cta__field:focus-within .cta__field-ico{color:var(--lime)}
.cta__fields input{
  width:100%;min-width:0;font-family:var(--ff-body);font-size:1rem;color:var(--white);
  background:var(--ink-2);border:1px solid var(--line-soft);border-radius:100px;padding:1.05em 1.3em 1.05em 2.9em;transition:border-color .3s,box-shadow .3s;
}
.cta__fields input::placeholder{color:var(--mut-2)}
.cta__fields input:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 4px rgba(191,255,0,.1)}
.cta__note{display:inline-flex;align-items:center;gap:7px;margin-top:18px;color:var(--mut-2);font-size:.88rem}
.cta__note-ico{width:1.05em;height:1.05em;color:var(--lime);flex:0 0 auto}
.cta__note strong{color:var(--mut)}
.cta__success{margin-top:18px;color:var(--lime);font-family:var(--ff-semi);font-weight:600;font-size:1rem}
.cta__error{margin-top:14px;color:#ff6b6b;font-family:var(--ff-semi);font-weight:600;font-size:.92rem}
/* select de categoria (prestador) — abre para baixo (campo no topo do form) */
.cta__field--cat{position:relative;display:flex;align-items:center}
.cta__field--cat[hidden]{display:none} /* a classe sobrescreveria o [hidden] do UA */
.cta__field--cat:focus-within .cta__field-ico{color:var(--lime)}
.cta__select{width:100%;min-width:0;display:flex;align-items:center;justify-content:space-between;gap:10px;font-family:var(--ff-body);font-size:1rem;color:var(--white);text-align:left;cursor:pointer;background:var(--ink-2);border:1px solid var(--line-soft);border-radius:100px;padding:1.05em 1.3em 1.05em 2.9em;transition:border-color .3s,box-shadow .3s}
.cta__select:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 4px rgba(191,255,0,.1)}
.cta__select[aria-expanded="true"]{border-color:var(--lime)}
.cta__select.is-placeholder .cta__select-label{color:var(--mut-2)}
.cta__select-label{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cta__select-caret{flex:0 0 auto;width:1.05em;height:1.05em;color:var(--mut-2);transition:transform .25s,color .3s}
.cta__select[aria-expanded="true"] .cta__select-caret{transform:rotate(180deg);color:var(--lime)}
.cat-results{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:31;margin:0;padding:6px;list-style:none;background:var(--ink-2);border:1px solid var(--line);border-radius:14px;max-height:236px;overflow:auto;box-shadow:0 24px 50px -24px rgba(0,0,0,.85)}
.cat-results li{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:9px;cursor:pointer;font-family:var(--ff-semi);font-size:.92rem;color:var(--white)}
.cat-results li:hover,.cat-results li[aria-selected="true"]{background:rgba(191,255,0,.12);color:var(--lime)}

/* combobox de cidade */
.cta__field--city{position:relative;display:flex;align-items:center}
/* abre para CIMA: o campo cidade é o último e o .modal__panel tem overflow-y:auto,
   que recortaria um dropdown aberto para baixo */
.city-results{position:absolute;bottom:calc(100% + 6px);left:0;right:0;z-index:30;margin:0;padding:6px;list-style:none;background:var(--ink-2);border:1px solid var(--line);border-radius:14px;max-height:198px;overflow:auto;box-shadow:0 -22px 50px -24px rgba(0,0,0,.85)}
.city-results li{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 12px;border-radius:9px;cursor:pointer;font-family:var(--ff-semi);font-size:.92rem;color:var(--white)}
.city-results li span{color:var(--mut-2);font-size:.74rem;font-weight:700}
.city-results li:hover{background:rgba(191,255,0,.12);color:var(--lime)}
.city-results li:hover span{color:var(--lime)}
.cta__choices{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:4px}

/* ===================================================================
   LEAD MODAL
   =================================================================== */
.modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:24px;visibility:hidden;opacity:0;transition:opacity .4s var(--ease),visibility .4s var(--ease)}
.modal.open{visibility:visible;opacity:1}
.modal__overlay{position:absolute;inset:0;background:rgba(5,6,4,.72);backdrop-filter:blur(8px) saturate(1.1)}
.modal__card{
  position:relative;z-index:1;display:grid;grid-template-columns:1.05fr 1fr;
  width:min(100%,920px);max-height:92vh;overflow:hidden;border-radius:28px;
  background:var(--ink-2);border:1px solid var(--line);
  box-shadow:0 50px 120px -40px rgba(0,0,0,.9),0 0 0 1px rgba(191,255,0,.05);
  transform:translateY(26px) scale(.97);opacity:0;transition:transform .5s var(--ease-out),opacity .5s var(--ease-out)}
.modal.open .modal__card{transform:none;opacity:1}

.modal__close{position:absolute;top:16px;right:16px;z-index:3;display:grid;place-items:center;width:40px;height:40px;border-radius:50%;color:var(--white);background:rgba(255,255,255,.06);border:1px solid var(--line-soft);transition:.25s var(--ease)}
.modal__close:hover{background:var(--lime);color:var(--ink);transform:rotate(90deg)}
.modal__close svg{width:18px;height:18px}

/* aside */
.modal__aside{position:relative;overflow:hidden;padding:42px 38px;display:flex;flex-direction:column;justify-content:center;background:radial-gradient(120% 100% at 20% 0,#1d2410,#0c0e08 62%);border-right:1px solid var(--line-soft)}
.modal__aside-inner{position:relative;z-index:2}
.modal__radar{position:absolute;left:30%;top:42%;width:0;height:0;z-index:1;pointer-events:none}
.modal__radar i{position:absolute;left:0;top:0;width:120px;height:120px;margin:-60px 0 0 -60px;border-radius:50%;border:1.5px solid rgba(191,255,0,.34);box-shadow:0 0 36px rgba(191,255,0,.14);opacity:0;animation:radar 9s var(--ease) infinite}
.modal__radar i:nth-child(2){animation-delay:3s}
.modal__radar i:nth-child(3){animation-delay:6s}
.modal__pin{width:48px;margin-bottom:18px;filter:drop-shadow(0 12px 22px rgba(0,0,0,.5))}
.modal__title{font-family:var(--ff-disp);font-weight:900;text-transform:uppercase;font-size:clamp(1.9rem,3vw,2.6rem);line-height:.95;letter-spacing:-.01em}
.modal__title .stroke{color:transparent;-webkit-text-stroke:1.5px var(--lime)}
.modal__lead{color:var(--mut);font-size:1rem;margin:14px 0 22px;max-width:24em}
.modal__perks{list-style:none;display:flex;flex-direction:column;gap:11px;margin-bottom:24px}
.modal__perks li{display:flex;align-items:center;gap:10px;font-family:var(--ff-semi);font-weight:500;font-size:.96rem;color:var(--white)}
.modal__perks li span{display:grid;place-items:center;flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:rgba(191,255,0,.14);color:var(--lime);font-size:.8rem;font-weight:900}
.modal__badge{display:inline-flex;align-items:center;gap:9px;font-family:var(--ff-semi);font-weight:600;font-size:.78rem;letter-spacing:.04em;text-transform:uppercase;padding:.5em 1em;border:1px solid var(--line);border-radius:100px;color:var(--lime);background:rgba(191,255,0,.05)}

/* panel */
.modal__panel{padding:42px 38px;display:flex;flex-direction:column;justify-content:center;overflow-y:auto}
.modal__eyebrow{font-family:var(--ff-semi);font-weight:600;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mut-2);display:block;margin-bottom:14px}
.modal__panel .cta__toggle{display:flex;width:100%;margin-bottom:14px}
.modal__panel .cta__toggle button{flex:1;text-align:center}
.modal__hint{color:var(--mut);font-size:.94rem;margin-bottom:18px}
.modal__hint strong{color:var(--lime)}
.modal__panel .cta__fields{grid-template-columns:1fr;gap:11px}
.modal__panel .cta__note{margin-top:16px}
html.modal-open{overflow:hidden}

/* ===================================================================
   FOOTER
   =================================================================== */
.footer{border-top:1px solid var(--line-soft);background:var(--ink-2);padding:64px 0 28px}
.footer__inner{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.1fr;gap:34px}
.footer__brand .brand{margin-bottom:16px}
.footer__tag{color:var(--mut);font-size:.96rem;max-width:24em}
.footer__col h4{font-family:var(--ff-semi);font-weight:700;font-size:.82rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mut-2);margin-bottom:16px}
.footer__col a{display:block;color:var(--mut);font-size:.98rem;padding:5px 0;transition:color .25s,padding-left .25s}
.footer__col a:hover{color:var(--lime);padding-left:5px}
.footer__social{display:flex;gap:10px;margin-bottom:16px}
.footer__social a{display:grid;place-items:center;width:40px;height:40px;border-radius:12px;border:1px solid var(--line-soft);color:var(--white);transition:.3s var(--ease);padding:0}
.footer__social a:hover{border-color:var(--lime);color:var(--lime);transform:translateY(-3px)}
.footer__social svg{width:20px;height:20px}
.footer__mini{color:var(--mut);font-size:.92rem}
.footer__bottom{display:flex;justify-content:space-between;gap:16px;margin-top:48px;padding-top:24px;border-top:1px solid var(--line-soft);color:var(--mut-2);font-size:.86rem}

/* ===================================================================
   REVEAL ANIMATIONS
   =================================================================== */
html.js [data-rv]{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease-out),transform .9s var(--ease-out)}
html.js [data-rv].in{opacity:1;transform:none}
/* no-JS / fallback: never hide content */
html:not(.js) [data-rv]{opacity:1;transform:none}
.hero__title .line span,.hero__title .line{will-change:transform}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important}
  [data-rv]{opacity:1;transform:none}
}

/* ===================================================================
   RESPONSIVE
   =================================================================== */
@media (max-width:1080px){
  .cats__grid{grid-template-columns:repeat(3,1fr)}
  .stats__grid{grid-template-columns:repeat(2,1fr);gap:34px 24px}
}
@media (max-width:900px){
  .nav__links,.nav__cta{display:none}
  .nav__burger{display:flex}
  .brand__logo{height:96px}
  .nav.scrolled .brand__logo{height:46px}
  .brand__radar{top:50px}
  .brand__radar::before{left:-72px;top:-72px;width:144px;height:144px}
  .brand__radar i{left:-40px;top:-40px;width:80px;height:80px}
  .hero__inner{grid-template-columns:1fr;gap:10px}
  .hero__visual{order:-1;width:100%;aspect-ratio:1/1;max-width:420px;margin:0 auto}
  .hero__photo-img{transform:scale(1.05)}
  .hero__pin{width:58px}
  .hero__title{font-size:clamp(3rem,13vw,5rem)}
  .how__steps{grid-template-columns:1fr}
  .how__line{display:none}
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento--big,.bento--wide{grid-column:span 2!important}
  .bento--big{min-height:340px}
  .bento__media{width:62%;top:-5%}
  .bento__card:nth-child(2),.bento__card:nth-child(3){grid-column:auto}
  .prov__inner,.trust__inner,.city__inner{grid-template-columns:1fr;gap:40px}
  .modal__card{grid-template-columns:1fr;max-height:90vh;overflow-y:auto}
  .modal__aside{padding:34px 30px 26px;border-right:none;border-bottom:1px solid var(--line-soft)}
  .modal__aside .modal__perks{display:none}
  .modal__lead{margin-bottom:6px}
  .modal__panel{padding:28px 30px 34px}
  .trust__visual{max-width:420px;margin:0 auto}
  .prov__visual{width:100%;max-width:420px;margin:0 auto}
  .footer__inner{grid-template-columns:1fr 1fr}
}
@media (max-width:560px){
  .cats__grid{grid-template-columns:1fr 1fr}
  .stats__grid{grid-template-columns:1fr 1fr}
  .bento{grid-template-columns:1fr}
  .bento--big,.bento--wide{grid-column:span 1!important}
  .footer__inner{grid-template-columns:1fr}
  .footer__bottom{flex-direction:column;text-align:center}
  .hero__actions .btn{flex:1 1 100%}
  .cta__fields{grid-template-columns:1fr}
  .cta__field{width:100%}
  .floatcard--a{display:none}
  .floatcard--b{right:-2%}
}
