/* ============================================================
   IZAQUIEL SOUZA — Landing Page de Campanha
   Sistema visual: navy institucional + verde/amarelo (Brasil)
   sobre fundo claro. Tipografia condensada + sans neutra.
   ============================================================ */

:root{
  /* Marca (cores amostradas do logotipo) */
  --navy:        #003078;
  --navy-deep:   #001b47;
  --navy-700:    #0a3f93;
  --navy-300:    #5b7fc4;
  --green:       #0c8a44;
  --green-deep:  #066731;
  --yellow:      #f0d818;
  --yellow-deep: #e0bf00;

  /* Neutros */
  --ink:    #0f1b2e;
  --ink-60: #44546b;
  --ink-40: #76859a;
  --line:   #e2e6ed;
  --paper:  #f4f6f9;
  --cloud:  #ffffff;

  /* Tipografia (sobrescrita via Tweaks) */
  --font-head: "Saira Condensed", system-ui, sans-serif;
  --font-body: "Mulish", system-ui, sans-serif;

  /* CTA (sobrescrito via Tweaks) */
  --cta-bg:    var(--navy);
  --cta-bg-h:  var(--navy-deep);
  --cta-fg:    #ffffff;

  --maxw: 1200px;
  --radius: 18px;
  --shadow: 0 24px 60px -28px rgba(0,32,90,.45);
  --shadow-sm: 0 10px 30px -16px rgba(15,27,46,.35);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body{
  margin:0;
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--paper);
  font-size:18px;
  line-height:1.6;
}
img{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }

h1,h2,h3,h4,.head{
  font-family:var(--font-head);
  font-weight:700;
  line-height:.98;
  letter-spacing:-.01em;
  margin:0;
  text-transform:uppercase;
}

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 28px; }
@media (max-width:560px){ .wrap{ padding:0 18px; } }
.section{ padding:clamp(64px,9vw,128px) 0; position:relative; }

/* Reveal on scroll */
.reveal{ opacity:0; transform:translateY(28px); transition:opacity .8s cubic-bezier(.2,.7,.2,1), transform .8s 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; } .reveal.d4{ transition-delay:.32s; }
@media (prefers-reduced-motion: reduce){ .reveal{ opacity:1 !important; transform:none !important; } }

/* Eyebrow / kicker */
.kicker{
  font-family:var(--font-head);
  text-transform:uppercase;
  letter-spacing:.16em;
  font-weight:600;
  font-size:.82rem;
  color:var(--green);
  display:inline-flex; align-items:center; gap:.6em;
}
.kicker::before{ content:""; width:26px; height:2px; background:var(--green); display:inline-block; }
.kicker.on-dark{ color:var(--yellow); }
.kicker.on-dark::before{ background:var(--yellow); }

/* Buttons */
.btn{
  display:inline-flex; align-items:center; gap:.7em;
  font-family:var(--font-head); text-transform:uppercase;
  font-weight:600; letter-spacing:.04em; font-size:1.02rem;
  padding:18px 30px; border-radius:999px; border:0; cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
  background:var(--cta-bg); color:var(--cta-fg);
  box-shadow:0 14px 30px -14px color-mix(in srgb, var(--cta-bg) 70%, transparent);
}
.btn:hover{ transform:translateY(-2px); background:var(--cta-bg-h); }
.btn .arw{ display:grid; place-items:center; width:26px; height:26px; border-radius:50%;
  background:rgba(255,255,255,.18); font-size:.9em; transition:transform .2s ease; }
.btn:hover .arw{ transform:translate(2px,-2px); }
.btn.ghost{ background:transparent; color:var(--navy); box-shadow:none; border:1.5px solid var(--navy); }
.btn.ghost:hover{ background:var(--navy); color:#fff; }
.btn.lg{ padding:21px 36px; font-size:1.12rem; }

/* ===================== NAV ===================== */
.nav{
  position:relative; z-index:5;
  background:transparent; border:0;
}
.nav.scrolled{ background:transparent; }
.nav .row{ display:flex; align-items:center; justify-content:space-between; height:96px; }
.nav .logo{ height:46px; width:auto; }
.nav .links{ display:flex; gap:30px; align-items:center; }
.nav .links a{ font-weight:700; font-size:.95rem; color:rgba(255,255,255,.82); transition:color .15s; }
.nav .links a:hover{ color:var(--yellow); }
.nav .navcta{ padding:13px 22px; font-size:.92rem; white-space:nowrap; }
.nav .burger{ display:none; background:none; border:0; cursor:pointer; }
.nav .burger span{ display:block; width:26px; height:2.5px; background:#fff; margin:5px 0; border-radius:2px; }
@media (max-width:920px){
  .nav .links{ display:none; }
  .nav .burger{ display:none; }
  .nav .row{ height:70px; }
  .nav .logo{ height:30px; }
  .nav .navcta{ padding:11px 16px; font-size:.8rem; }
}

/* logo dentro do hero */
.hero-logo{ height:64px; width:auto; margin-bottom:26px; display:block; }
@media (max-width:560px){ .hero-logo{ height:48px; margin-bottom:18px; } }

/* ===================== HERO ===================== */
.hero{ position:relative; overflow:hidden; padding-top:0; color:#fff;
  background:
    linear-gradient(100deg, rgba(0,18,52,.88) 0%, rgba(0,22,60,.45) 48%, rgba(0,30,84,.22) 100%),
    url('assets/header-bg.jpg') center/cover no-repeat;
}
.hero.section{ padding-bottom:0; }
.hero > .grid{ margin-top:clamp(16px,3vw,40px); }
.hero .grid{
  display:grid; grid-template-columns:1.05fr .95fr; gap:30px; align-items:center;
}
.hero .grid > *{ min-width:0; }
.hero h1{ overflow-wrap:break-word; }
.hero .badge{
  display:inline-flex; align-items:center; gap:10px; background:#fff;
  border:1px solid var(--line); border-radius:999px; padding:8px 16px 8px 8px;
  font-weight:800; font-size:.82rem; color:var(--navy); box-shadow:var(--shadow-sm);
  text-transform:uppercase; letter-spacing:.04em;
}
.hero .badge .pin{ background:var(--green); color:#fff; border-radius:999px; padding:5px 11px; font-size:.74rem; letter-spacing:.06em; }
.hero h1{
  font-size:clamp(2.2rem,5.6vw,72px);
  color:#fff; margin:22px 0 0; text-wrap:balance;
}
.hero h1 em{ font-style:normal; color:var(--yellow); }
/* rotating headline word */
.hero-rotator{ min-height:1.05em; display:block; overflow:hidden; }
.rot-word{ display:inline-block; animation:rotWordIn .55s cubic-bezier(.2,.7,.2,1) both; }
.rot-word::after{ content:""; }
@keyframes rotWordIn{
  from{ opacity:0; transform:translateY(.55em); }
  to{ opacity:1; transform:none; }
}
@media (prefers-reduced-motion: reduce){ .rot-word{ animation:none; } }
.hero .sub{ font-size:16px; color:#cfdcff; max-width:calc(52ch + 56px); margin:20px 0 0; line-height:1.6; }
.hero .slogan{
  display:inline-block; margin-top:24px; font-family:var(--font-head);
  text-transform:uppercase; letter-spacing:.04em; font-weight:700; color:#fff;
  font-size:1.05rem; border-left:4px solid var(--yellow); padding-left:14px;
}
.hero .cta-row{ display:grid; grid-template-columns:1fr 1fr; gap:14px; margin-top:30px; }
.hero .cta-row .btn{ justify-content:center; text-align:center; white-space:nowrap;
  padding:12px 20px; font-size:.98rem; }
.hero .ministats{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-top:42px; }
.hero .ministats .n{ font-family:var(--font-head); font-size:clamp(1.5rem,3.4vw,2rem); color:var(--yellow); font-weight:700; line-height:1; }
.hero .ministats .l{ font-size:clamp(.72rem,1.6vw,.84rem); color:#aebfdd; font-weight:700; margin-top:5px; text-transform:uppercase; letter-spacing:.03em; }

/* photo composition */
.hero .photo-wrap{ position:relative; min-height:660px; display:flex; align-items:flex-end; justify-content:center; align-self:end; }
.hero .blob{ display:none; }
.hero .ring{ display:none; }
.hero .photo{ position:relative; z-index:3; height:min(820px,84vh); width:auto; object-fit:contain;
  filter:drop-shadow(0 36px 48px rgba(0,12,40,.55)); }
.hero .float-card{
  position:absolute; z-index:4; right:-6px; top:54%;
  background:rgba(255,255,255,.6); backdrop-filter:blur(14px); -webkit-backdrop-filter:blur(14px);
  border-radius:16px; padding:14px 18px;
  box-shadow:0 20px 40px -22px rgba(0,12,40,.7); display:flex; align-items:center; gap:12px;
  border:1px solid rgba(255,255,255,.45);
}
.hero .float-card .ic{ width:42px; height:42px; border-radius:11px; background:var(--navy); color:var(--yellow);
  display:grid; place-items:center; font-family:var(--font-head); font-weight:700; font-size:1.1rem; }
.hero .float-card .t{ font-weight:800; font-size:.96rem; color:var(--navy); line-height:1.15; }
.hero .float-card .s{ font-size:.78rem; color:#2a3b56; }
.hero .float-card.tl{ left:-10px; top:20%; right:auto; }

@media (max-width:900px){
  .hero .grid{ grid-template-columns:1fr; gap:10px; }
  .hero .photo-wrap{ min-height:0; margin-top:24px; }
  .hero .photo{ height:min(560px,68vh); }
  .hero .float-card.tl{ left:0; }
  .hero .float-card{ right:0; }
}
@media (max-width:560px){
  .hero h1{ font-size:clamp(1.85rem,8.4vw,2.5rem); }
  .hero .cta-row{ grid-template-columns:1fr; }
  .hero .cta-row .btn{ white-space:normal; }
  .hero .ministats{ gap:14px; }
  .hero .float-card{ padding:10px 12px; gap:9px; }
  .hero .float-card .ic{ width:34px; height:34px; font-size:.92rem; }
  .hero .float-card .t{ font-size:.84rem; }
  .hero .float-card .s{ font-size:.7rem; }
}

/* ===================== STRIP / VALUES ===================== */
.strip{ background:var(--navy); color:#fff; }
.strip .inner{ display:grid; grid-template-columns:repeat(3,1fr); gap:0; }
.strip .cell{ padding:38px 30px; border-right:1px solid rgba(255,255,255,.12); }
.strip .cell:last-child{ border-right:0; }
.strip .cell h3{ color:#fff; font-size:1.5rem; }
.strip .cell .num{ font-family:var(--font-head); color:var(--yellow); font-size:1.1rem; font-weight:700; }
.strip .cell p{ margin:.5em 0 0; color:rgba(255,255,255,.78); font-size:.98rem; }
@media (max-width:820px){ .strip .inner{ grid-template-columns:1fr; } .strip .cell{ border-right:0; border-bottom:1px solid rgba(255,255,255,.12); } }

/* ===================== DIFERENÇA (split lines) ===================== */
.diff .diff-top{ display:grid; grid-template-columns:1.05fr .95fr; gap:48px; align-items:center; }
.diff .diff-img{ position:relative; }
.diff .diff-img img{ width:100%; height:auto; border-radius:14px; }
.diff h2{ font-size:clamp(2rem,4.6vw,3.4rem); color:var(--navy); max-width:18ch; }
.diff .lead{ font-size:16px; color:var(--ink-60); max-width:none; margin-top:20px; }
.diff .lead p{ margin:0 0 1em; }
.diff .lead p:last-child{ margin-bottom:0; }
.diff .pairs{ margin-top:50px; display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
@media (max-width:880px){ .diff .diff-top{ grid-template-columns:1fr; gap:24px; } .diff .diff-img{ max-width:460px; } }
.diff .pair{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:30px; box-shadow:var(--shadow-sm); }
.diff .pair .top{ color:var(--ink-40); font-weight:700; }
.diff .pair .bot{ font-family:var(--font-head); font-size:1.7rem; color:var(--navy); margin-top:8px; text-transform:none; line-height:1.05; }
.diff .punch{ margin:60px auto 0; font-family:var(--font-head); font-size:clamp(1.6rem,3.4vw,2.6rem); color:var(--navy); text-transform:none; max-width:none; width:100%; text-align:center; line-height:1.06; }
.diff .punch em{ font-style:normal; color:var(--green); }
@media (max-width:820px){ .diff .pairs{ grid-template-columns:1fr; } }

/* ===================== DOR + SOLUÇÃO ===================== */
.pain{ background:var(--navy-deep); color:#fff; position:relative; overflow:hidden; }
.pain::after{ content:""; position:absolute; right:-120px; top:-120px; width:420px; height:420px; border-radius:50%;
  background:radial-gradient(circle, rgba(12,138,68,.4), transparent 70%); }
.pain h2{ color:#fff; font-size:clamp(2rem,4.6vw,3.2rem); max-width:20ch; }
.pain .pain-grid{ display:grid; grid-template-columns:1fr 360px; gap:54px; align-items:start; margin-top:40px; }
.pain .pain-img{ position:relative; }
.pain .pain-img img{ width:100%; max-width:360px; height:auto; filter:drop-shadow(0 30px 50px rgba(0,0,0,.5)); }
.pain .q-list{ margin-top:0; display:grid; gap:2px; max-width:920px; }
.pain .q{ display:flex; gap:18px; padding:22px 4px; border-bottom:1px solid rgba(255,255,255,.13); font-size:1.16rem; align-items:flex-start; }
.pain .q .mk{ color:var(--yellow); font-family:var(--font-head); font-weight:700; font-size:1.2rem; flex:none; }
.pain .close{ margin-top:40px; font-size:1.3rem; color:#cfdcff; max-width:48ch; }
.pain .close strong{ color:var(--yellow); }
@media (max-width:880px){ .pain .pain-grid{ grid-template-columns:1fr; gap:34px; } .pain .pain-img{ max-width:340px; margin:0 auto; } }

/* ===================== TIMELINE (horizontal) ===================== */
.timeline{ background:var(--cloud); overflow-x:clip; }
.timeline .hd{ display:flex; justify-content:space-between; align-items:flex-end; gap:20px; flex-wrap:wrap; }
.timeline h2{ font-size:clamp(2rem,4.6vw,3.2rem); color:var(--navy); }
.tl-nav{ display:flex; gap:12px; }
.tl-nav button{ width:54px; height:54px; border-radius:50%; border:1.5px solid var(--navy); background:#fff; color:var(--navy);
  font-size:1.3rem; cursor:pointer; transition:all .18s; display:grid; place-items:center; }
.tl-nav button:hover{ background:var(--navy); color:#fff; }
.tl-nav button:disabled{ opacity:.3; cursor:default; }
.tl-track-wrap{ margin-top:40px; position:relative; width:100vw; margin-left:calc(50% - 50vw); }
.tl-line{ position:absolute; left:0; right:0; top:21px; height:2px; background:var(--line); z-index:0; }
.tl-track{ display:flex; gap:24px; overflow-x:auto; scroll-behavior:smooth;
  padding:12px 0 18px; scrollbar-width:none;
  padding-inline:max(28px, calc(50vw - 600px));
  scroll-padding-inline:max(28px, calc(50vw - 600px)); }
.tl-track::-webkit-scrollbar{ display:none; }
.tl-card{ flex:0 0 320px; scroll-snap-align:start; }
.tl-dot{ width:18px; height:18px; border-radius:50%; background:var(--yellow); border:4px solid #fff;
  box-shadow:0 0 0 2px var(--navy); position:relative; z-index:2; margin-bottom:26px; }
.tl-card.key .tl-dot{ background:var(--green); box-shadow:0 0 0 2px var(--green); }
.tl-card .yr{ font-family:var(--font-head); font-weight:700; color:var(--green); letter-spacing:.04em; font-size:.95rem; }
.tl-card h4{ font-size:1.35rem; color:var(--navy); margin:6px 0 0; text-transform:none; line-height:1.08; }
.tl-card p{ font-size:1rem; color:var(--ink-60); margin:12px 0 0; }
.tl-card .place{ font-size:.8rem; color:var(--ink-40); font-weight:800; text-transform:uppercase; letter-spacing:.06em; margin-top:4px; }

/* ===================== PROVA SOCIAL ===================== */
.proof{ background:var(--paper); }
.proof .cards{ display:grid; grid-template-columns:repeat(5,1fr); gap:18px; }
.proof .c{ background:#fff; border:1px solid var(--line); border-radius:16px; padding:26px 22px; box-shadow:var(--shadow-sm); }
.proof .c .ic{ width:46px; height:46px; border-radius:12px; background:var(--navy); color:#fff; display:grid; place-items:center; margin-bottom:16px; }
.proof .c .ic svg{ width:24px; height:24px; stroke:#fff; }
.proof .c h4{ font-size:1.08rem; color:var(--navy); text-transform:none; line-height:1.12; }
.proof .c p{ font-size:.86rem; color:var(--ink-60); margin:6px 0 0; }
@media (max-width:1000px){ .proof .cards{ grid-template-columns:repeat(2,1fr); } }
@media (max-width:560px){ .proof .cards{ grid-template-columns:1fr; } }

/* ===================== PERFIL ===================== */
.profile .grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:54px; align-items:center; }
.profile .pimg{ position:relative; }
.profile .pimg .bg{ position:absolute; inset:auto 6% 0 6%; height:88%; border-radius:24px; background:linear-gradient(160deg,var(--navy),var(--navy-deep)); }
.profile .pimg .bg::after{ content:""; position:absolute; left:0; right:0; bottom:0; height:8px; background:linear-gradient(90deg,var(--green) 0 33%, var(--yellow) 33% 66%, var(--navy-700) 66% 100%); border-radius:0 0 24px 24px; }
.profile .pimg img{ position:relative; z-index:2; margin:0 auto; height:520px; width:auto; filter:drop-shadow(0 26px 36px rgba(0,27,71,.35)); }
.profile h2{ font-size:clamp(2rem,4.4vw,3rem); color:var(--navy); }
.profile .lead{ color:var(--ink-60); font-size:1.15rem; margin-top:16px; }
.profile .creds{ margin-top:28px; display:grid; grid-template-columns:1fr 1fr; gap:12px 28px; }
.profile .creds li{ list-style:none; display:flex; gap:11px; align-items:flex-start; font-size:1rem; padding:8px 0; border-bottom:1px solid var(--line); }
.profile .creds li .ck{ color:var(--green); flex:none; font-weight:800; }
.profile ul{ margin:0; padding:0; }
@media (max-width:880px){ .profile .grid{ grid-template-columns:1fr; gap:30px; } .profile .creds{ grid-template-columns:1fr; } .profile .pimg img{ height:420px; } }

/* ===================== COMPROMISSO (quote) ===================== */
.commit{ color:#fff; position:relative; overflow:hidden;
  background:
    linear-gradient(100deg, rgba(0,16,46,.74) 0%, rgba(0,20,58,.52) 50%, rgba(0,22,64,.6) 100%),
    url('assets/commit-bg.jpg') center/cover no-repeat;
}
.commit .wrap{ max-width:960px; text-align:center; }
.commit .mark{ font-family:var(--font-head); font-size:11rem; line-height:.6; color:var(--yellow); opacity:.9; }
.commit blockquote{ margin:0 auto; font-family:var(--font-head); text-transform:none; font-weight:600;
  font-size:clamp(1.7rem,3.6vw,2.9rem); line-height:1.12; max-width:none; }
.commit .by{ margin-top:26px; font-weight:800; letter-spacing:.04em; color:var(--yellow); text-transform:uppercase; font-family:var(--font-head); }
.commit .note{ margin:30px auto 0; color:#e6eeff; font-size:1.12rem; max-width:none; }

/* ===================== CTA + FORM ===================== */
.signup{ background:var(--paper); }
.signup .card{ background:#fff; border:1px solid var(--line); border-radius:26px; box-shadow:var(--shadow); overflow:hidden;
  display:grid; grid-template-columns:1fr 1fr; }
.signup .left{ padding:clamp(34px,4vw,58px); background:linear-gradient(165deg,var(--navy),var(--navy-deep)); color:#fff; position:relative; }
.signup .left .flag{ position:absolute; top:0; left:0; right:0; height:7px; background:linear-gradient(90deg,var(--green) 0 33%,var(--yellow) 33% 66%,var(--navy-700) 66% 100%); }
.signup .left h2{ color:#fff; font-size:clamp(2rem,3.6vw,2.9rem); }
.signup .left p{ color:#cfdcff; margin-top:16px; font-size:1.12rem; }
.signup .left .slg{ margin-top:auto; padding-top:34px; font-family:var(--font-head); color:var(--yellow); text-transform:uppercase; letter-spacing:.04em; font-weight:700; }
.signup .right{ padding:clamp(34px,4vw,58px); }
.fld{ margin-bottom:18px; }
.fld label{ display:block; font-weight:800; font-size:.86rem; color:var(--navy); margin-bottom:7px; text-transform:uppercase; letter-spacing:.04em; }
.fld input, .fld select{ width:100%; padding:15px 16px; border:1.5px solid var(--line); border-radius:12px; font-family:inherit; font-size:1rem; color:var(--ink); background:#fff; transition:border .15s, box-shadow .15s; }
.fld input:focus, .fld select:focus{ outline:0; border-color:var(--navy); box-shadow:0 0 0 4px rgba(0,48,120,.1); }
.signup .two{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.consent{ display:flex; gap:10px; align-items:flex-start; font-size:.82rem; color:var(--ink-60); margin:6px 0 20px; }
.consent input{ margin-top:3px; }
.signup .btn{ width:100%; justify-content:center; }
.signup .ok{ text-align:center; padding:30px 10px; }
.signup .ok .big{ font-family:var(--font-head); color:var(--green); font-size:2rem; }
@media (max-width:820px){ .signup .card{ grid-template-columns:1fr; } .signup .two{ grid-template-columns:1fr; } }

/* ===================== FAQ ===================== */
.faq h2{ font-size:clamp(2rem,4.4vw,3rem); color:var(--navy); }
.faq .items{ margin-top:36px; max-width:900px; }
.faq .it{ border-bottom:1px solid var(--line); }
.faq .it button{ width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:24px 0;
  display:flex; justify-content:space-between; gap:20px; align-items:center;
  font-family:var(--font-head); font-weight:700; font-size:1.3rem; color:var(--navy); text-transform:none; }
.faq .it .ans{ overflow:hidden; max-height:0; transition:max-height .35s ease; }
.faq .it .ans p{ padding:0 0 24px; color:var(--ink-60); font-size:1.08rem; margin:0; max-width:72ch; }
.faq .it .pm{ flex:none; width:34px; height:34px; border-radius:50%; border:1.5px solid var(--navy); display:grid; place-items:center; font-size:1.3rem; transition:transform .3s, background .2s, color .2s; }
.faq .it.open .pm{ background:var(--navy); color:#fff; transform:rotate(45deg); }

/* ===================== FINAL CTA ===================== */
.final{ background:var(--navy-deep); color:#fff; text-align:center; position:relative; overflow:hidden; }
.final::before{ content:""; position:absolute; inset:0; background:radial-gradient(70% 90% at 50% 0%, rgba(12,138,68,.28), transparent 60%); }
.final .inner{ position:relative; z-index:2; max-width:820px; margin:0 auto; }
.final h2{ font-size:clamp(2.2rem,5.2vw,4rem); color:#fff; }
.final h2 em{ font-style:normal; color:var(--yellow); }
.final p{ color:#cfdcff; font-size:1.2rem; margin-top:24px; }
.final .slogan-big{ margin-top:36px; font-family:var(--font-head); text-transform:uppercase; letter-spacing:.05em; color:var(--yellow); font-size:1.2rem; font-weight:700; }
.final .btn{ margin-top:34px; }

/* ===================== FOOTER ===================== */
.foot{ background:#02132f; color:#9fb3d6; padding:60px 0 36px; }
.foot .top{ display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; align-items:flex-start; }
.foot .logo{ height:40px; }
.foot .contacts{ display:flex; gap:30px; flex-wrap:wrap; }
.foot .contacts a{ display:flex; align-items:center; gap:10px; color:#cfdcff; font-weight:700; }
.foot .contacts a:hover{ color:var(--yellow); }
.foot .slogan{ font-family:var(--font-head); text-transform:uppercase; letter-spacing:.05em; color:#fff; font-size:1.1rem; font-weight:700; }
.foot hr{ border:0; border-top:1px solid rgba(255,255,255,.1); margin:34px 0 22px; }
.foot .legal{ font-size:.8rem; color:#6f86ad; max-width:80ch; line-height:1.6; }
.foot .legal a{ color:#9fb3d6; text-decoration:underline; }

/* ===================== Ajustes finos (ed. direta consolidada) ===================== */
.diff.section{ padding:48px 0; }
.timeline.section{ padding:48px 0 4px; }
.commit.section{ padding:80px 0; }
.signup.section{ padding:28px 0 58px; }
.final.section{ padding:48px 0; }
@media (min-width:901px){
  .hero.section{ min-height:744px; }
  .hero-logo{ height:93px; }
  .hero h1.hero-rotator{ font-size:92px; }
  .hero .sub{ max-width:665px; }
  .timeline .hd h2{ font-size:71px; }
  .diff h2{ max-width:667px; }
  .final h2{ font-size:54px; }
}

/* ===================== WhatsApp float ===================== */
.wfloat{ position:fixed; right:22px; bottom:22px; z-index:60; width:60px; height:60px; border-radius:50%;
  background:var(--green); display:grid; place-items:center; box-shadow:0 14px 30px -10px rgba(12,138,68,.7);
  transition:transform .18s; }
.wfloat:hover{ transform:scale(1.08); }
.wfloat svg{ width:32px; height:32px; fill:#fff; }
