/* ===========================================================
   ELEVA CLEAN FLORIPA — Landing page styles
   =========================================================== */

:root{
  /* True black — driven by tweaks (slider adds slight violet tint if increased) */
  --bgDark: 0%;          /* lightness for deepest bg, tweakable */
  --bg-0: #000000;
  --bg-1: #050208;
  --bg-2: #0a040e;
  --panel: rgba(20, 8, 28, 0.5);
  --panel-line: oklch(70% 0.14 320 / 0.18);

  /* Brand accents */
  --violet:  #A855F7;
  --magenta: #E040FB;
  --violet-soft: #c89bff;
  --pink-soft: #ff86e8;
  /* --accent + --accent-2 are remapped by the Accent tweak */
  --accent:   var(--violet);
  --accent-2: var(--magenta);
  --accent-grad: linear-gradient(100deg, var(--accent), var(--accent-2));

  /* Green CTA */
  --green-a: #2ECC71;
  --green-b: #00E676;
  --green-grad: linear-gradient(100deg, var(--green-a), var(--green-b));

  --ink: #ffffff;
  --ink-dim: oklch(86% 0.02 320 / 0.74);
  --ink-faint: oklch(80% 0.03 320 / 0.5);

  /* Type — swapped by vibe + font tweak */
  --f-logo: "Saira", system-ui, sans-serif;
  --f-display: "Poppins", system-ui, sans-serif;
  --f-body: "Inter", system-ui, sans-serif;
  --display-weight: 800;
  --display-tracking: -0.02em;
  --display-transform: none;

  --maxw: 1180px;
  --radius: 22px;
  --radius-lg: 30px;
}

/* ---- VIBE: ELEGANT ---- */
[data-vibe="elegant"]{
  --f-display: "Cormorant Garamond", Georgia, serif;
  --f-body: "Jost", system-ui, sans-serif;
  --display-weight: 600;
  --display-tracking: 0.005em;
  --display-transform: none;
}

/* ---- FONT PAIRING tweak overrides (applied on top of vibe) ---- */
[data-fonts="modern"]{ --f-display:"Poppins",sans-serif; --f-body:"Inter",sans-serif; --display-weight:800; }
[data-fonts="editorial"]{ --f-display:"Cormorant Garamond",serif; --f-body:"Jost",sans-serif; --display-weight:600; }
[data-fonts="condensed"]{ --f-display:"Oswald",sans-serif; --f-body:"Inter",sans-serif; --display-weight:700; --display-transform:uppercase; --display-tracking:0.01em; }

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family:var(--f-body);
  color:var(--ink);
  background:var(--bg-0);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
  line-height:1.55;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; }

/* pure black page with subtle violet glow accents only */
.page{
  position:relative;
  background:
    radial-gradient(900px 600px at 82% 2%, oklch(45% 0.22 330 / 0.18), transparent 60%),
    radial-gradient(800px 700px at 8% 22%, oklch(40% 0.2 300 / 0.12), transparent 58%),
    #000000;
  overflow:hidden;
}

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 24px; }

/* ---------- Typography helpers ---------- */
.display{
  font-family:var(--f-display);
  font-weight:var(--display-weight);
  letter-spacing:var(--display-tracking);
  text-transform:var(--display-transform);
  line-height:1.04;
  text-wrap:balance;
  margin:0;
}
.eyebrow{
  font-family:var(--f-body);
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.32em;
  font-size:.72rem;
  color:var(--violet-soft);
}
.grad-text{
  background:var(--accent-grad);
  -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.pink{ color:var(--pink-soft); }
.vio{ color:var(--violet-soft); }
.lead{ color:var(--ink-dim); font-size:1.12rem; }

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.6em;
  border:none; border-radius:999px;
  font-family:var(--f-body); font-weight:800;
  letter-spacing:.06em; text-transform:uppercase;
  font-size:1rem; padding:1.15em 2.2em;
  color:#06371d; background:var(--green-grad);
  box-shadow:0 0 0 0 rgba(0,230,118,.5), 0 18px 40px -12px rgba(0,230,118,.6);
  transition:transform .18s ease, box-shadow .25s ease, filter .2s ease;
  position:relative; overflow:hidden;
}
.btn::after{
  content:""; position:absolute; top:0; left:-120%; width:55%; height:100%;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.55),transparent);
  transform:skewX(-18deg); transition:left .6s ease;
}
.btn:hover{ transform:translateY(-2px); box-shadow:0 0 34px -2px rgba(0,230,118,.55), 0 22px 46px -12px rgba(0,230,118,.7); }
.btn:hover::after{ left:130%; }
.btn:active{ transform:translateY(0); }
.btn-lg{ font-size:1.08rem; padding:1.25em 2.6em; }
.btn-full{ width:100%; }

/* CTA style tweak variants */
[data-cta="solid"] .btn{ background:var(--green-a); box-shadow:0 14px 30px -14px rgba(46,204,113,.7); }
[data-cta="solid"] .btn::after{ display:none; }
[data-cta="outline"] .btn{
  background:transparent; color:#aef7cf;
  box-shadow:inset 0 0 0 2px rgba(0,230,118,.8);
}
[data-cta="outline"] .btn::after{ display:none; }
[data-cta="outline"] .btn:hover{ background:rgba(0,230,118,.1); }

.btn-ghost{
  background:transparent; color:var(--ink);
  box-shadow:inset 0 0 0 1.5px var(--panel-line);
  text-transform:none; letter-spacing:0; font-weight:600;
}
.btn-ghost::after{ display:none; }
.btn-ghost:hover{ box-shadow:inset 0 0 0 1.5px var(--violet); transform:translateY(-1px); }

/* ---------- Chips ---------- */
.chip{
  display:inline-flex; align-items:center; gap:.6em;
  padding:.6em 1.15em; border-radius:999px;
  background:oklch(30% 0.12 320 / 0.5);
  box-shadow:inset 0 0 0 1px var(--panel-line);
  font-size:.82rem; font-weight:600; letter-spacing:.02em;
  color:var(--ink); backdrop-filter:blur(6px);
}
.chip .dot{ width:7px; height:7px; border-radius:50%; background:var(--accent); box-shadow:0 0 10px var(--accent); }
.chip svg{ width:16px; height:16px; color:var(--violet-soft); }

/* ---------- Announcement bar ---------- */
.announce{
  position:sticky; top:0; z-index:60;
  text-align:center; padding:.7em 16px;
  font-weight:700; font-size:.84rem; letter-spacing:.01em; color:#1a0322;
  background:linear-gradient(90deg, #ff9a8b, #c44be6 55%, #a855f7);
  background-size:200% 100%;
  animation:slidebg 8s linear infinite;
}
@keyframes slidebg{ to{ background-position:200% 0; } }

/* ---------- Sticky CTA bar (mobile/scroll) ---------- */
.sticky-cta{
  position:fixed; left:0; right:0; bottom:0; z-index:70;
  padding:12px 16px calc(12px + env(safe-area-inset-bottom));
  background:linear-gradient(0deg, var(--bg-0), oklch(12% 0.06 320 / 0.85) 70%, transparent);
  display:flex; gap:12px; align-items:center; justify-content:center;
  transform:translateY(120%); transition:transform .35s cubic-bezier(.2,.7,.2,1);
  backdrop-filter:blur(8px);
}
.sticky-cta.show{ transform:translateY(0); }
.sticky-cta .meta{ font-size:.78rem; color:var(--ink-dim); line-height:1.25; }
.sticky-cta .meta b{ color:#fff; }
.sticky-cta .btn{ padding:.95em 1.6em; font-size:.82rem; white-space:nowrap; }
@media(max-width:560px){ .sticky-cta .meta{ display:none; } .sticky-cta .btn{ width:100%; } }

/* ---------- Sections ---------- */
section{ position:relative; }
.sec{ padding:clamp(64px,9vw,128px) 0; }
.sec-tight{ padding:clamp(44px,6vw,84px) 0; }
.center{ text-align:center; }
.sec-head{ max-width:760px; margin:0 auto clamp(36px,5vw,60px); }
.sec-head.left{ margin-left:0; }
.h-xl{ font-size:clamp(2.5rem,7vw,5rem); }
.h-lg{ font-size:clamp(2rem,5vw,3.6rem); }
.h-md{ font-size:clamp(1.6rem,3.6vw,2.6rem); }

.divider-line{
  width:64px; height:2px; margin:18px auto;
  background:var(--accent-grad); border-radius:2px;
}

/* ---------- HERO ---------- */
.hero{ padding-top:clamp(40px,6vw,72px); padding-bottom:clamp(48px,7vw,96px); }
.hero-grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:clamp(32px,5vw,64px);
  align-items:center;
}
@media(max-width:900px){ .hero-grid{ grid-template-columns:1fr; text-align:center; } }

/* ELEVA logotype */
.logomark{ display:inline-flex; flex-direction:column; align-items:flex-start; gap:6px; }
@media(max-width:900px){ .logomark{ align-items:center; } }
.logo-eleva{
  font-family:var(--f-logo); font-weight:300;
  font-size:clamp(2.6rem,6vw,4.3rem); line-height:.9;
  letter-spacing:.34em; text-indent:.34em;
  color:#fff; text-shadow:0 0 30px oklch(70% 0.18 320 / 0.45);
}
.logo-clean{
  display:flex; align-items:center; gap:14px;
  font-family:var(--f-logo); font-weight:400;
  letter-spacing:.5em; text-indent:.5em;
  font-size:clamp(.8rem,1.8vw,1.05rem); color:var(--ink-dim);
}
.logo-clean::before, .logo-clean::after{
  content:""; height:1px; width:34px; background:linear-gradient(90deg,transparent,var(--violet-soft),transparent);
}
.hero-h1{ font-size:clamp(2.2rem,5.2vw,3.9rem); margin:.5em 0 .4em; }
.hero-sub{ font-size:clamp(1rem,1.5vw,1.2rem); color:var(--ink-dim); max-width:52ch; }
@media(max-width:900px){ .hero-sub{ margin-inline:auto; } }
.hero-meta{ display:flex; flex-wrap:wrap; gap:12px; margin:26px 0 30px; }
@media(max-width:900px){ .hero-meta{ justify-content:center; } }
.hero-cta-row{ display:flex; flex-wrap:wrap; gap:14px; align-items:center; }
@media(max-width:900px){ .hero-cta-row{ justify-content:center; } }
.hero-microcopy{ margin-top:14px; font-size:.82rem; color:var(--ink-faint); }

.hero-art{ position:relative; }
.hero-art .poster{
  border-radius:var(--radius-lg); overflow:hidden;
  box-shadow:0 40px 90px -30px rgba(0,0,0,.8), 0 0 0 1px var(--panel-line);
  transform:perspective(1200px) rotateY(-4deg);
}
.hero-art::before{
  content:""; position:absolute; inset:-12% -8% -8% -12%; z-index:-1;
  background:radial-gradient(closest-side, oklch(50% 0.25 330 / 0.5), transparent 72%);
  filter:blur(8px);
}

/* ---------- Generic media frame / placeholder ---------- */
.media{
  border-radius:var(--radius); overflow:hidden; position:relative;
  box-shadow:0 30px 70px -28px rgba(0,0,0,.75), 0 0 0 1px var(--panel-line);
}
.ph{
  position:relative; border-radius:var(--radius);
  background:
    repeating-linear-gradient(135deg, oklch(28% 0.08 320 / .55) 0 12px, oklch(22% 0.07 320 / .55) 12px 24px);
  box-shadow:inset 0 0 0 1px var(--panel-line);
  display:flex; align-items:center; justify-content:center; text-align:center;
  color:var(--ink-faint); font-family:"Saira",monospace; font-size:.72rem;
  letter-spacing:.12em; text-transform:uppercase; padding:14px;
}

/* ---------- Value / opening block ---------- */
.value-grid{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(30px,5vw,64px); align-items:center; }
@media(max-width:880px){ .value-grid{ grid-template-columns:1fr; } }
.value-copy p{ color:var(--ink-dim); font-size:1.06rem; margin:0 0 1.1em; }
.value-copy p strong{ color:#fff; font-weight:700; }
.value-kicker{ font-style:italic; font-family:var(--f-display); font-size:1.35rem; color:#fff; }

/* ---------- Pain list ---------- */
.pain-list{ display:grid; gap:14px; max-width:820px; margin:0 auto; }
.pain{
  display:flex; gap:16px; align-items:flex-start;
  padding:18px 22px; border-radius:18px;
  background:var(--panel); box-shadow:inset 0 0 0 1px var(--panel-line);
  transition:transform .2s ease, box-shadow .2s ease;
}
.pain:hover{ transform:translateX(4px); box-shadow:inset 0 0 0 1px oklch(70% 0.16 330 / 0.4); }
.pain .x{
  flex:none; width:28px; height:28px; border-radius:50%;
  display:grid; place-items:center; margin-top:1px;
  background:oklch(40% 0.18 20 / 0.3); color:#ff9bb0; font-weight:800; font-size:.9rem;
  box-shadow:inset 0 0 0 1px oklch(60% 0.2 20 / 0.4);
}
.pain p{ margin:0; color:var(--ink-dim); }
.pain-note{ text-align:center; margin-top:26px; font-size:1.05rem; color:#fff; }

/* ---------- Pillars ---------- */
.pillars{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
@media(max-width:820px){ .pillars{ grid-template-columns:1fr; } }
.pillar{
  position:relative; padding:34px 28px 30px; border-radius:var(--radius);
  background:linear-gradient(180deg, oklch(20% 0.07 320 / .8), oklch(13% 0.05 320 / .85));
  box-shadow:inset 0 0 0 1px var(--panel-line);
  overflow:hidden; transition:transform .25s ease, box-shadow .25s ease;
}
.pillar::before{
  content:""; position:absolute; inset:0 0 auto 0; height:3px; background:var(--accent-grad);
  opacity:.9;
}
.pillar:hover{ transform:translateY(-6px); box-shadow:inset 0 0 0 1px oklch(72% 0.16 330 / .5), 0 26px 50px -26px rgba(0,0,0,.7); }
.pillar .ico{
  width:58px; height:58px; border-radius:16px; display:grid; place-items:center; margin-bottom:20px;
  background:radial-gradient(circle at 30% 25%, oklch(55% 0.2 320), oklch(35% 0.18 322));
  box-shadow:0 12px 26px -10px oklch(45% 0.22 320 / .8), inset 0 0 0 1px rgba(255,255,255,.15);
}
.pillar .ico svg{ width:28px; height:28px; color:#fff; }
.pillar h3{ font-family:var(--f-display); font-weight:var(--display-weight); font-size:1.45rem; margin:0 0 .5em; }
.pillar p{ margin:0; color:var(--ink-dim); font-size:.98rem; }
.pillar .num{
  position:absolute; top:18px; right:22px; font-family:var(--f-display);
  font-size:2.4rem; font-weight:800; color:oklch(60% 0.2 320 / .22);
}

/* immersion stat band */
.stat-band{
  margin-top:38px; display:flex; flex-wrap:wrap; gap:14px 40px; align-items:center; justify-content:center;
  padding:26px 30px; border-radius:var(--radius);
  background:linear-gradient(100deg, oklch(26% 0.12 320 / .55), oklch(20% 0.14 330 / .45));
  box-shadow:inset 0 0 0 1px var(--panel-line);
}
.stat-band .big{ font-family:var(--f-display); font-weight:800; font-size:clamp(2rem,5vw,3rem); }
.stat-band p{ margin:0; color:var(--ink-dim); max-width:48ch; }

/* ---------- Benefits ---------- */
.benefits{ display:grid; grid-template-columns:1fr 1fr; gap:14px 24px; }
@media(max-width:760px){ .benefits{ grid-template-columns:1fr; } }
.benefit{ display:flex; gap:14px; align-items:flex-start; padding:8px 4px; }
.benefit .ck{
  flex:none; width:30px; height:30px; border-radius:9px; display:grid; place-items:center;
  background:linear-gradient(135deg, var(--green-a), var(--green-b)); color:#06371d;
  box-shadow:0 8px 18px -8px rgba(0,230,118,.7);
}
.benefit .ck svg{ width:17px; height:17px; }
.benefit p{ margin:0; color:var(--ink-dim); }
.benefit p b{ color:#fff; }

/* ---------- Carousel (speakers / testimonials) ---------- */
.carousel{ position:relative; }
.carousel-track{
  display:flex; gap:20px; overflow-x:auto; scroll-snap-type:x mandatory;
  padding:6px 2px 22px; scrollbar-width:none; -webkit-overflow-scrolling:touch;
}
.carousel-track::-webkit-scrollbar{ display:none; }
.carousel-nav{ display:flex; gap:10px; justify-content:center; margin-top:6px; }
.cbtn{
  width:48px; height:48px; border-radius:50%;
  background:var(--panel); color:#fff; box-shadow:inset 0 0 0 1px var(--panel-line);
  display:grid; place-items:center; transition:.2s;
}
.cbtn:hover{ box-shadow:inset 0 0 0 1px var(--violet); transform:translateY(-2px); color:var(--violet-soft); }
.cbtn svg{ width:20px; height:20px; }

/* Speaker card */
.spk{
  flex:0 0 300px; scroll-snap-align:center; border-radius:var(--radius);
  background:linear-gradient(180deg, #0a040d, #050207);
  box-shadow:inset 0 0 0 1px var(--panel-line); overflow:hidden;
  transition:transform .25s ease, box-shadow .25s ease;
}
@media(max-width:560px){ .spk{ flex-basis:80vw; } }
.spk:hover{ transform:translateY(-5px); box-shadow:inset 0 0 0 1px oklch(70% 0.16 330 / .5), 0 24px 50px -26px rgba(0,0,0,.7); }
.spk .photo{ aspect-ratio:4/4.2; position:relative; overflow:hidden; background:#fff; }
.spk .photo img{ width:100%; height:100%; object-fit:cover; object-position:center center; position:relative; z-index:1; }
.spk .photo .ph{ position:absolute; inset:0; border-radius:0; }
.spk .photo::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 65%, #000 100%); z-index:2; }
.spk .body{ padding:20px 22px 24px; }
.spk .tag{ font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:var(--violet-soft); font-weight:700; }
.spk h3{ font-family:var(--f-display); font-weight:var(--display-weight); font-size:1.45rem; margin:.25em 0 .4em; }
.spk p{ margin:0; color:var(--ink-dim); font-size:.92rem; }
.spk .star{ color:var(--magenta); font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; font-weight:700; margin-top:12px; display:inline-block; }

/* Speaker vertical stack */
.spk-stack{ display:flex; flex-direction:column; gap:28px; max-width:940px; margin:0 auto; }
.spk-row{
  display:grid; grid-template-columns:240px 1fr; overflow:hidden;
  border-radius:var(--radius); border:1px solid oklch(70% 0.14 330 / .15);
  background:linear-gradient(135deg, oklch(12% 0.05 320 / .95), oklch(9% 0.035 322));
  transition:transform .25s ease, box-shadow .25s ease;
}
.spk-row:hover{ transform:translateY(-3px); box-shadow:0 20px 50px -20px oklch(45% 0.2 330 / .5), inset 0 0 0 1px oklch(70% 0.16 330 / .3); }
@media(max-width:680px){ .spk-row{ grid-template-columns:1fr; } }
.spk-photo{ position:relative; overflow:hidden; min-height:280px; background:#ffffff; }
.spk-photo img{ width:100%; height:100%; object-fit:cover; object-position:center top; display:block; }
.spk-photo .ph{ position:absolute; inset:0; display:flex; align-items:center; justify-content:center; color:var(--ink-faint); font-size:.8rem; font-family:monospace; text-align:center; padding:20px; }
.spk-body{ padding:30px 36px; display:flex; flex-direction:column; justify-content:center; gap:10px; }
.spk-body .tag{ font-size:.65rem; letter-spacing:.18em; text-transform:uppercase; color:var(--violet-soft); font-weight:700; }
.spk-body h3{ font-family:var(--f-display); font-weight:var(--display-weight); font-size:1.7rem; margin:0; line-height:1.1; }
.spk-body p{ margin:0; color:var(--ink-dim); font-size:.95rem; line-height:1.65; }
.spk-body .star{ color:var(--magenta); font-size:.68rem; letter-spacing:.2em; text-transform:uppercase; font-weight:700; display:inline-block; margin-bottom:2px; }
@media(max-width:680px){ .spk-photo{ min-height:240px; } .spk-body{ padding:22px 24px; } }

/* Testimonial card */
.tst{
  flex:0 0 360px; scroll-snap-align:center; border-radius:var(--radius);
  padding:28px 28px 26px;
  background:linear-gradient(180deg, oklch(19% 0.07 320 / .85), oklch(12% 0.05 322 / .9));
  box-shadow:inset 0 0 0 1px var(--panel-line);
  display:flex; flex-direction:column; gap:16px;
}
@media(max-width:560px){ .tst{ flex-basis:84vw; } }
.tst .quote{ font-size:1.05rem; color:#fff; line-height:1.5; }
.tst .quote .hl{ background:linear-gradient(transparent 60%, oklch(60% 0.2 320 / .35) 0); }
.tst .who{ display:flex; align-items:center; gap:14px; margin-top:auto; }
.tst .av{ width:46px; height:46px; border-radius:50%; flex:none; background:repeating-linear-gradient(135deg, oklch(40% 0.12 320) 0 6px, oklch(32% 0.1 320) 6px 12px); box-shadow:inset 0 0 0 1px var(--panel-line); }
.tst .who b{ display:block; font-size:.95rem; }
.tst .who span{ font-size:.8rem; color:var(--ink-faint); }
.stars{ color:#ffd166; letter-spacing:.1em; font-size:.9rem; }

/* ---------- Numbers strip ---------- */
.numbers{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
@media(max-width:720px){ .numbers{ grid-template-columns:1fr; } }
.numbers .n{
  text-align:center; padding:28px 20px; border-radius:var(--radius);
  background:var(--panel); box-shadow:inset 0 0 0 1px var(--panel-line);
}
.numbers .n .v{ font-family:var(--f-display); font-weight:800; font-size:clamp(2rem,5vw,3rem); }
.numbers .n .l{ color:var(--ink-dim); font-size:.92rem; margin-top:4px; }

/* ---------- Offer ---------- */
#oferta{ background:linear-gradient(180deg, oklch(22% 0.14 310 / .85) 0%, oklch(16% 0.1 310 / .6) 100%); border-radius:32px; margin:20px 0; }
.offer-grid{ display:grid; grid-template-columns:1fr 1fr; gap:24px; align-items:stretch; max-width:920px; margin:0 auto; }
@media(max-width:820px){ .offer-grid{ grid-template-columns:1fr; } }
.tier{
  position:relative; border-radius:var(--radius-lg); padding:34px 32px 36px;
  background:linear-gradient(180deg, oklch(18% 0.06 320 / .9), oklch(12% 0.045 322 / .92));
  box-shadow:inset 0 0 0 1px var(--panel-line);
  display:flex; flex-direction:column; gap:18px;
}
.tier.diamond{
  background:linear-gradient(180deg, oklch(26% 0.12 322 / .92), oklch(15% 0.08 320 / .95));
  box-shadow:inset 0 0 0 1.5px oklch(72% 0.16 330 / .55), 0 30px 70px -30px oklch(45% 0.2 330 / .7);
}
.tier .badge{
  position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--accent-grad); color:#fff; font-size:.7rem; font-weight:800;
  letter-spacing:.16em; text-transform:uppercase; padding:.55em 1.3em; border-radius:999px;
  box-shadow:0 10px 24px -8px oklch(50% 0.2 330 / .8);
}
.tier .t-name{ display:flex; align-items:center; gap:10px; font-family:var(--f-display); font-weight:var(--display-weight); font-size:1.6rem; }
.tier .t-name .ic{ font-size:1.4rem; }
.tier .price{ display:flex; align-items:baseline; gap:10px; flex-wrap:wrap; }
.tier .price .from{ color:var(--ink-faint); text-decoration:line-through; font-size:1rem; }
.tier .price .now{ font-family:var(--f-display); font-weight:800; font-size:2.6rem; line-height:1; }
.tier .price .now small{ font-size:1rem; font-weight:700; }
.tier .install{ color:var(--ink-dim); font-size:.86rem; margin-top:-6px; }
.tier ul{ list-style:none; margin:0; padding:0; display:grid; gap:11px; }
.tier li{ display:flex; gap:11px; align-items:flex-start; color:var(--ink-dim); font-size:.96rem; }
.tier li svg{ flex:none; width:18px; height:18px; color:var(--green-b); margin-top:2px; }
.tier li.mute{ color:var(--ink-faint); }
.tier .btn{ margin-top:auto; }
.anchor-note{ text-align:center; max-width:680px; margin:30px auto 0; color:var(--ink-faint); font-size:.92rem; }

/* Offer urgency banner */
.offer-urgency-banner{
  background:linear-gradient(135deg, oklch(28% 0.22 310), oklch(22% 0.17 295));
  border:1.5px solid oklch(65% 0.28 320 / .55);
  border-radius:18px;
  padding:22px 36px;
  text-align:center;
  font-size:1.08rem;
  font-weight:700;
  color:#fff;
  margin-bottom:52px;
  box-shadow:0 0 60px oklch(50% 0.26 310 / .35), inset 0 1px 0 oklch(70% 0.2 330 / .3);
  letter-spacing:.01em;
  text-wrap:pretty;
}
.lote-tag{ font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; font-weight:800; color:var(--violet-soft); margin-bottom:4px; }
.lote-perk{ font-size:.9rem; color:var(--ink-dim); margin-top:-4px; }
@media(max-width:600px){ .offer-urgency-banner{ padding:18px 20px; font-size:.95rem; } }

/* ---------- Objections (accordion) ---------- */
.acc{ max-width:820px; margin:0 auto; display:grid; gap:12px; }
.acc-item{
  border-radius:16px; background:var(--panel); box-shadow:inset 0 0 0 1px var(--panel-line);
  overflow:hidden;
}
.acc-q{
  width:100%; text-align:left; background:none; border:none; color:#fff;
  padding:20px 22px; display:flex; align-items:center; gap:14px; justify-content:space-between;
  font-family:var(--f-body); font-weight:700; font-size:1.04rem;
}
.acc-q .qi{ flex:none; width:26px; height:26px; border-radius:50%; display:grid; place-items:center;
  background:var(--accent-grad); color:#fff; transition:transform .3s ease; font-size:1.1rem; line-height:0; }
.acc-item.open .qi{ transform:rotate(45deg); }
.acc-a{ max-height:0; overflow:hidden; transition:max-height .35s ease; }
.acc-a-inner{ padding:0 22px 22px; color:var(--ink-dim); }
.acc-q .q-emoji{ margin-right:2px; }

/* ---------- Guarantee ---------- */
.guarantee{
  max-width:880px; margin:0 auto; text-align:center; padding:clamp(36px,5vw,56px);
  border-radius:var(--radius-lg); position:relative; overflow:hidden;
  background:linear-gradient(135deg, oklch(24% 0.1 320 / .7), oklch(15% 0.07 330 / .7));
  box-shadow:inset 0 0 0 1px var(--panel-line);
}
.guarantee .shield{
  width:84px; height:84px; margin:0 auto 22px; border-radius:24px; display:grid; place-items:center;
  background:radial-gradient(circle at 30% 25%, oklch(60% 0.2 330), oklch(38% 0.18 322));
  box-shadow:0 18px 40px -14px oklch(45% 0.22 330 / .8), inset 0 0 0 1px rgba(255,255,255,.18);
}
.guarantee .shield svg{ width:42px; height:42px; color:#fff; }
.guarantee p{ color:var(--ink-dim); max-width:60ch; margin:0 auto; font-size:1.06rem; }

/* ---------- Urgency ---------- */
.urgency{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; max-width:980px; margin:0 auto; }
@media(max-width:760px){ .urgency{ grid-template-columns:1fr; } }
.urg{
  padding:26px 24px; border-radius:var(--radius);
  background:linear-gradient(180deg, oklch(20% 0.08 20 / .35), oklch(14% 0.05 320 / .6));
  box-shadow:inset 0 0 0 1px oklch(60% 0.18 20 / .25);
}
.urg .ico{ width:42px; height:42px; border-radius:12px; display:grid; place-items:center; margin-bottom:14px;
  background:oklch(45% 0.2 25 / .35); color:#ff9bb0; box-shadow:inset 0 0 0 1px oklch(60% 0.2 25 / .4); }
.urg .ico svg{ width:22px; height:22px; }
.urg h4{ margin:0 0 .4em; font-size:1.1rem; }
.urg p{ margin:0; color:var(--ink-dim); font-size:.93rem; }

/* ---------- Final CTA + form ---------- */
.final{
  position:relative; overflow:hidden;
  background:
    radial-gradient(900px 500px at 50% 0%, oklch(40% 0.2 330 / .4), transparent 60%),
    linear-gradient(180deg, var(--bg-1), var(--bg-0));
}
.form-card{
  max-width:560px; margin:30px auto 0; padding:30px; border-radius:var(--radius-lg);
  background:oklch(16% 0.05 320 / .8); box-shadow:inset 0 0 0 1px var(--panel-line);
  backdrop-filter:blur(8px);
}
.field{ margin-bottom:14px; }
.field label{ display:block; font-size:.78rem; letter-spacing:.04em; color:var(--ink-dim); margin:0 0 7px 4px; font-weight:600; }
.input-wrap{
  display:flex; align-items:center; gap:10px; padding:0 16px;
  background:#fff; border-radius:14px; box-shadow:0 0 0 2px transparent;
  transition:box-shadow .18s ease;
}
.input-wrap:focus-within{ box-shadow:0 0 0 2px var(--violet); }
.input-wrap.err{ box-shadow:0 0 0 2px #ff6b81; }
.input-wrap .ldg{ color:#9a6; display:flex; }
.input-wrap .flag{ font-size:1.1rem; }
.input-wrap svg{ width:20px; height:20px; flex:none; }
.input-wrap input{
  flex:1; border:none; outline:none; background:none; padding:15px 0;
  font-family:var(--f-body); font-size:1rem; color:#1a0322;
}
.input-wrap input::placeholder{ color:#9a93a0; }
.err-msg{ color:#ff97a8; font-size:.76rem; margin:6px 0 0 4px; min-height:1em; }
.form-ok{ text-align:center; padding:20px 10px; }
.form-ok .big{ font-family:var(--f-display); font-weight:var(--display-weight); font-size:1.8rem; margin-bottom:8px; }
.form-ok p{ color:var(--ink-dim); margin:0; }
.consent{ font-size:.72rem; color:var(--ink-faint); text-align:center; margin-top:14px; }

/* ---------- PS / Footer ---------- */
.ps{ max-width:780px; margin:0 auto; padding:30px 32px; border-radius:var(--radius);
  background:var(--panel); box-shadow:inset 0 0 0 1px var(--panel-line); }
.ps b{ color:#fff; }
.ps .label{ font-family:var(--f-display); font-weight:800; color:var(--violet-soft); font-size:1.1rem; }
footer.foot{ padding:40px 0 120px; text-align:center; color:var(--ink-faint); font-size:.84rem; }
footer.foot .logo-clean{ justify-content:center; margin:0 auto 14px; opacity:.7; }

/* ---------- Sponsors ---------- */
.sponsors-sec{ position:relative; }
.sponsors-row{
  display:flex; flex-wrap:wrap; gap:28px;
  align-items:stretch; justify-content:center;
  max-width:860px; margin:0 auto;
}
.sponsor-logo{
  position:relative;
  flex:1 1 220px; max-width:260px;
  background:#ffffff;
  border-radius:20px;
  padding:26px 30px;
  display:flex; align-items:center; justify-content:center;
  min-height:150px;
  box-shadow:0 10px 40px -12px oklch(0% 0 0 / .55), inset 0 0 0 1px oklch(70% 0.16 330 / .12);
  transition:transform .28s ease, box-shadow .28s ease;
  overflow:hidden;
}
.sponsor-logo::before{
  content:""; position:absolute; inset:0; border-radius:20px; padding:1.5px;
  background:linear-gradient(135deg, oklch(70% 0.2 320 / .5), transparent 50%, oklch(70% 0.2 290 / .4));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude;
  opacity:0; transition:opacity .28s ease;
}
.sponsor-logo:hover{ transform:translateY(-6px); box-shadow:0 26px 60px -18px oklch(45% 0.2 330 / .55), inset 0 0 0 1px oklch(70% 0.16 330 / .2); }
.sponsor-logo:hover::before{ opacity:1; }
.sponsor-logo img{ max-height:104px; max-width:190px; width:auto; object-fit:contain; display:block; }
.sponsor-logo:nth-child(1) img{ max-height:72px; max-width:210px; }
@media(max-width:560px){
  .sponsors-row{ gap:18px; }
  .sponsor-logo{ flex-basis:140px; min-height:118px; padding:20px; }
  .sponsor-logo img{ max-height:80px; max-width:130px; }
  .sponsor-logo:nth-child(1) img{ max-height:40px; }
}

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

/* decorative section separators */
.sep{ height:1px; background:linear-gradient(90deg,transparent,var(--violet),var(--magenta),transparent); opacity:.45; margin:0 auto; max-width:var(--maxw); }
