/* =========================================================
   DuaLLs — Landing Page
   Automação que conversa. Design que conecta.
   ========================================================= */

:root{
  --cream:   #f5f1ea;
  --orange:  #ff4b00;
  --blue:    #0a5bff;
  --tan:     #d9c8b0;
  --ink:     #0d0d0d;

  --cream-2: #ece5d8;
  --ink-2:   #141312;
  --ink-3:   #1c1a17;
  --line:    rgba(245,241,234,.14);
  --line-dark: rgba(13,13,13,.14);

  --font-display: "Fraunces", Georgia, serif;
  --font-body:    "Space Grotesk", system-ui, sans-serif;
  --font-mono:    "Space Mono", ui-monospace, monospace;

  --container: 1240px;
  --radius: 4px;
  --ease: cubic-bezier(.22,1,.36,1);
}

/* ---------- RESET ---------- */
*{ margin:0; padding:0; box-sizing:border-box; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body{
  font-family:var(--font-body);
  background:var(--ink);
  color:var(--cream);
  line-height:1.55;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
ul{ list-style:none; }
button{ font:inherit; cursor:pointer; border:none; background:none; color:inherit; }
::selection{ background:var(--orange); color:var(--cream); }

.accent-orange{ color:var(--orange); }
.accent-blue{ color:var(--blue); }

/* ---------- GRAIN OVERLAY ---------- */
.grain{
  position:fixed; inset:0; z-index:9000; 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='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------- SCROLL PROGRESS ---------- */
.scroll-progress{
  position:fixed; top:0; left:0; height:3px; width:0%;
  background:linear-gradient(90deg,var(--orange),var(--blue));
  z-index:8000; transition:width .1s linear;
}

/* ---------- CONTAINER ---------- */
.container{ width:min(100% - 48px, var(--container)); margin-inline:auto; }
.container--narrow{ max-width:820px; }

/* =========================================================
   PRELOADER
   ========================================================= */
.preloader{
  position:fixed; inset:0; z-index:10000;
  background:var(--ink);
  display:grid; place-items:center;
  transition:opacity .45s ease;
}
.preloader__inner{ text-align:center; position:relative; z-index:2; width:min(320px,80vw); }
.preloader__icon{ position:relative; width:92px; height:92px; margin:0 auto 20px; }
.preloader__icon img{
  width:100%; height:100%; object-fit:contain;
  animation:floaty 2s var(--ease) infinite;
  filter:drop-shadow(0 0 24px rgba(255,75,0,.25));
}
.preloader__pulse{
  position:absolute; inset:-16px; border-radius:50%;
  border:1px solid rgba(245,241,234,.18);
  animation:pulsate 1.5s ease-out infinite;
}
.preloader__wordmark{
  font-family:var(--font-display);
  font-weight:900; font-size:2rem; letter-spacing:.5px;
  color:var(--cream); margin-bottom:18px;
  opacity:0; animation:fadeUp .4s .1s var(--ease) forwards;
}
.preloader__bar{
  width:100%; height:3px; background:rgba(245,241,234,.12);
  border-radius:99px; overflow:hidden; margin-bottom:12px;
}
.preloader__fill{
  display:block; height:100%; width:0%;
  background:linear-gradient(90deg,var(--orange),var(--blue));
  transition:width .12s ease;
}
.preloader__meta{
  display:flex; justify-content:space-between; gap:12px;
  font-family:var(--font-mono); font-size:.62rem;
  text-transform:uppercase; letter-spacing:.08em;
  color:var(--tan);
}
.preloader__slogan{ max-width:78%; text-align:left; opacity:.7; }
.preloader.is-done{ opacity:0; pointer-events:none; }

/* =========================================================
   BUTTONS
   ========================================================= */
.btn{
  --bg:var(--orange); --fg:#fff;
  position:relative; display:inline-flex; align-items:center; gap:.55em;
  font-family:var(--font-mono); font-weight:700;
  font-size:.82rem; text-transform:uppercase; letter-spacing:.04em;
  padding:.92em 1.5em; border-radius:99px;
  background:var(--bg); color:var(--fg);
  border:2px solid transparent;
  transition:transform .35s var(--ease), background .3s ease, color .3s ease, box-shadow .3s ease;
  will-change:transform; isolation:isolate; overflow:hidden; line-height:1;
}
.btn::after{
  content:""; position:absolute; inset:0; z-index:-1;
  background:var(--ink); transform:translateY(101%);
  transition:transform .4s var(--ease);
}
.btn:hover{ transform:translateY(-3px); box-shadow:0 14px 30px -12px rgba(0,0,0,.5); }
.btn__arrow{ width:1.15em; height:1.15em; transition:transform .3s var(--ease); }
.btn:hover .btn__arrow{ transform:translateX(4px); }

/* Primary (orange) — hover fills dark, text stays cream (readable) */
.btn--primary{ --bg:var(--orange); --fg:#fff; }
.btn--primary:hover{ color:var(--cream); }
.btn--primary:hover::after{ transform:translateY(0); }

/* Blue */
.btn--blue{ --bg:var(--blue); --fg:#fff; }
.btn--blue:hover{ color:#fff; }
.btn--blue:hover::after{ transform:translateY(0); background:var(--ink); }

/* Dark (for use on orange featured card) */
.btn--dark{ --bg:var(--ink); --fg:var(--cream); }
.btn--dark::after{ background:var(--cream); }
.btn--dark:hover{ color:var(--ink); }
.btn--dark:hover::after{ transform:translateY(0); }

/* Ghost (on dark bg) */
.btn--ghost{ background:transparent; color:var(--cream); border-color:rgba(245,241,234,.4); }
.btn--ghost::after{ background:var(--cream); }
.btn--ghost:hover{ color:var(--ink); border-color:var(--cream); }
.btn--ghost:hover::after{ transform:translateY(0); }

/* Ghost on light bg */
.btn--ghost-dark{ background:transparent; color:var(--ink); border-color:rgba(13,13,13,.35); }
.btn--ghost-dark::after{ background:var(--ink); }
.btn--ghost-dark:hover{ color:var(--cream); border-color:var(--ink); }
.btn--ghost-dark:hover::after{ transform:translateY(0); }

.btn--lg{ font-size:.9rem; padding:1.1em 1.9em; }

/* =========================================================
   HEADER
   ========================================================= */
.site-header{
  position:fixed; top:0; left:0; right:0; z-index:7000;
  transition:background .4s ease, box-shadow .4s ease, padding .4s ease, border-color .4s ease;
  padding:14px 0; border-bottom:1px solid transparent;
}
.site-header.is-scrolled{
  background:rgba(13,13,13,.82);
  backdrop-filter:blur(14px) saturate(140%);
  border-color:var(--line);
  box-shadow:0 8px 30px -20px rgba(0,0,0,.9);
  padding:8px 0;
}
.site-header__inner{
  width:min(100% - 48px, 1340px); margin-inline:auto;
  display:flex; align-items:center; justify-content:space-between; gap:24px;
}
.brand{ display:flex; align-items:center; flex-shrink:0; }
.brand__img{ height:60px; width:auto; transition:height .4s ease; filter:drop-shadow(0 2px 10px rgba(0,0,0,.4)); }
.site-header.is-scrolled .brand__img{ height:48px; }

.nav{ display:flex; align-items:center; gap:34px; }
.nav__link{
  font-family:var(--font-mono); font-size:.78rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.04em;
  color:var(--cream); position:relative; padding:4px 0; opacity:.85;
  transition:opacity .25s ease;
}
.nav__link::after{ content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px; background:var(--orange); transition:width .3s var(--ease); }
.nav__link:hover{ opacity:1; }
.nav__link:hover::after{ width:100%; }
.nav__link--mobile-cta{ display:none; padding:.95em 1.7em; }

.nav-toggle{ display:none; flex-direction:column; gap:5px; padding:8px; z-index:20; }
.nav-toggle span{ width:26px; height:2px; background:var(--cream); border-radius:2px; transition:.3s var(--ease); }
.nav-toggle.is-active span:nth-child(1){ transform:translateY(7px) rotate(45deg); }
.nav-toggle.is-active span:nth-child(2){ opacity:0; }
.nav-toggle.is-active span:nth-child(3){ transform:translateY(-7px) rotate(-45deg); }

/* =========================================================
   HERO
   ========================================================= */
.hero{
  position:relative; padding:180px 0 90px;
  background:
    radial-gradient(120% 90% at 80% -10%, rgba(10,91,255,.16), transparent 55%),
    radial-gradient(110% 80% at 0% 0%, rgba(255,75,0,.14), transparent 50%),
    var(--ink);
  overflow:hidden;
}
.hero__bg{ position:absolute; inset:0; z-index:0; pointer-events:none; }
.blob{ position:absolute; border-radius:50%; filter:blur(8px); opacity:.16; mix-blend-mode:screen; }
.blob--orange{ width:520px; height:520px; background:var(--orange); top:-160px; left:-120px; animation:drift 18s ease-in-out infinite; }
.blob--blue{ width:560px; height:560px; background:var(--blue); bottom:-220px; right:-160px; animation:drift 22s ease-in-out infinite reverse; }
.grid-lines{
  position:absolute; inset:0;
  background-image:
    linear-gradient(rgba(245,241,234,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,241,234,.04) 1px, transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 30%, #000, transparent 75%);
          mask-image:radial-gradient(circle at 50% 30%, #000, transparent 75%);
}
.hero__grid{
  position:relative; z-index:2;
  width:min(100% - 48px, var(--container)); margin-inline:auto;
  display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:.6em;
  font-family:var(--font-mono); font-size:.72rem; font-weight:700;
  text-transform:uppercase; letter-spacing:.12em; color:var(--tan);
  padding:.5em .9em; border:1px solid var(--line); border-radius:99px;
  background:rgba(245,241,234,.03);
}
.eyebrow .spark{ width:1em; height:1em; color:var(--orange); }

.hero__title{
  font-family:var(--font-display); font-weight:900; font-optical-sizing:auto;
  font-size:clamp(2.7rem, 6.4vw, 5.4rem); line-height:.98; letter-spacing:-.015em;
  margin:24px 0 26px; font-variation-settings:"SOFT" 0,"WONK" 1;
}
.hero__title .line{ display:block; }
.mark{ position:relative; display:inline-block; color:#fff; padding:0 .08em; z-index:0; }
.mark--orange::before{ content:""; position:absolute; inset:.12em -.04em .08em; background:var(--orange); z-index:-1; transform:skewX(-4deg); }
.ink-wrap{ position:relative; display:inline-block; color:var(--cream); }
.ink-wrap .ink{ position:absolute; left:-2%; bottom:-.16em; width:104%; height:.4em; color:var(--orange); overflow:visible; }
.ink-wrap .ink path{ stroke-dasharray:600; stroke-dashoffset:600; }
.is-visible .ink-wrap .ink path{ animation:draw .9s .4s var(--ease) forwards; }

.hero__sub{ font-size:clamp(1.02rem,1.5vw,1.18rem); color:rgba(245,241,234,.82); max-width:44ch; margin-bottom:32px; }
.hero__sub strong{ color:var(--cream); }
.hero__cta{ display:flex; flex-wrap:wrap; gap:14px; margin-bottom:46px; }

.hero__stats{ display:flex; flex-wrap:wrap; gap:14px 40px; padding-top:28px; border-top:1px solid var(--line); }
.stat{ display:flex; flex-direction:column; gap:2px; }
.stat__num{ font-family:var(--font-display); font-weight:800; font-size:2rem; line-height:1; color:var(--cream); }
.stat__label{ font-family:var(--font-mono); font-size:.64rem; text-transform:uppercase; letter-spacing:.06em; color:var(--tan); }

/* hero media — frameless image floating on dark */
.hero__media{ position:relative; }
.hero__media-inner{ position:relative; }
.hero__halo{
  position:absolute; inset:6% 8%; z-index:0; border-radius:50%;
  background:radial-gradient(circle at 38% 40%, rgba(255,75,0,.30), transparent 58%),
             radial-gradient(circle at 70% 62%, rgba(10,91,255,.30), transparent 58%);
  filter:blur(30px);
}
.hero__img{
  position:relative; z-index:1; width:100%;
  filter:drop-shadow(0 30px 50px rgba(0,0,0,.55));
}
.hero__label{
  position:absolute; z-index:2;
  font-family:var(--font-mono); font-weight:700; font-size:.7rem;
  text-transform:uppercase; letter-spacing:.04em; color:var(--cream);
  padding:.55em .85em; border-radius:99px;
  background:rgba(13,13,13,.78); border:1px solid var(--line);
  backdrop-filter:blur(6px); box-shadow:0 10px 22px -12px rgba(0,0,0,.7);
  white-space:nowrap;
}
.hero__label--tl{ top:6%; left:-4%; color:var(--orange); animation:floaty 4s ease-in-out infinite; }
.hero__label--r{ top:42%; right:-8%; animation:floaty 4.6s ease-in-out infinite .5s; }
.hero__label--blue{ color:var(--blue); }
.hero__label--b{ bottom:10%; left:8%; animation:floaty 4.3s ease-in-out infinite .9s; }
.hero__sig{
  position:absolute; bottom:-30px; right:2%; z-index:2;
  font-family:var(--font-display); font-style:italic; font-size:1.15rem; color:var(--tan); opacity:.85;
}

/* =========================================================
   MARQUEE (refined, seamless infinite)
   ========================================================= */
.marquee{ overflow:hidden; background:var(--orange); border-block:2px solid var(--ink); }
.marquee__track{ display:flex; width:max-content; animation:marquee 38s linear infinite; }
.marquee:hover .marquee__track{ animation-play-state:paused; }
.marquee__group{ display:flex; align-items:center; flex-shrink:0; padding:13px 0; }
.marquee__group span{
  font-family:var(--font-mono); font-weight:700; font-size:.82rem;
  text-transform:uppercase; letter-spacing:.18em; color:var(--ink); white-space:nowrap; padding:0 .2em;
}
.marquee__group i{ font-style:normal; color:var(--cream); font-size:.7rem; padding:0 1.4em; }

/* =========================================================
   SECTION SHELL
   ========================================================= */
.section{ position:relative; padding:clamp(64px,9vw,120px) 0; overflow:hidden; }
.section--dark{ background:var(--ink); color:var(--cream); }
.section--dark::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.5;
  background:radial-gradient(80% 60% at 100% 0%, rgba(10,91,255,.08), transparent 60%),
             radial-gradient(70% 50% at 0% 100%, rgba(255,75,0,.07), transparent 60%);
}
.section--cream{ background:var(--cream); color:var(--ink); }
.section--cream::before{
  content:""; position:absolute; inset:0; pointer-events:none; opacity:.6;
  background-image:radial-gradient(rgba(13,13,13,.05) 1px, transparent 1px);
  background-size:22px 22px;
  -webkit-mask-image:linear-gradient(180deg,#000,transparent 40%);
          mask-image:linear-gradient(180deg,#000,transparent 40%);
}
.section > .container{ position:relative; z-index:2; }

.section__head{ max-width:760px; margin-bottom:54px; }
.section__eyebrow{
  display:inline-block; font-family:var(--font-mono); font-weight:700;
  font-size:.74rem; text-transform:uppercase; letter-spacing:.14em;
  color:var(--orange); margin-bottom:18px;
}
.section__title{
  font-family:var(--font-display); font-weight:900;
  font-size:clamp(2rem,4.6vw,3.5rem); line-height:1.02; letter-spacing:-.015em;
  font-variation-settings:"SOFT" 0,"WONK" 1;
}
.section--dark .section__title{ color:var(--cream); }
.section__lead{ margin-top:18px; font-size:clamp(1rem,1.4vw,1.14rem); max-width:60ch; }
.section--dark .section__lead{ color:rgba(245,241,234,.78); }
.section--cream .section__lead{ color:rgba(13,13,13,.72); }

/* =========================================================
   FRONTS (Solução)
   ========================================================= */
.fronts__grid{ display:grid; grid-template-columns:1fr auto 1fr; gap:28px; align-items:stretch; }
.front{
  position:relative; padding:38px 34px 34px; border-radius:6px;
  background:var(--ink-2); border:1px solid var(--line);
  overflow:hidden; transition:transform .4s var(--ease), border-color .4s ease;
}
.front::after{
  content:""; position:absolute; top:0; right:0; width:64px; height:64px;
  background:linear-gradient(225deg, currentColor 0 50%, transparent 50%); opacity:.14;
}
.front--auto{ color:var(--orange); }
.front--web{ color:var(--blue); }
.front::before{ content:""; position:absolute; top:0; left:0; right:0; height:4px; background:currentColor; }
.front:hover{ transform:translateY(-6px); }
.front--auto:hover{ border-color:rgba(255,75,0,.5); }
.front--web:hover{ border-color:rgba(10,91,255,.5); }
.front__top{ display:flex; align-items:center; gap:16px; margin-bottom:18px; }
.front__num{ font-family:var(--font-display); font-weight:900; font-size:3.4rem; line-height:.8; color:currentColor; }
.front__tag{ font-family:var(--font-mono); font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.06em; color:var(--tan); }
.front__title{ font-family:var(--font-display); font-weight:800; font-size:1.7rem; line-height:1.08; margin-bottom:14px; color:var(--cream); }
.front__title em{ font-style:italic; }
.front__desc{ color:rgba(245,241,234,.74); margin-bottom:22px; }
.front__list{ display:flex; flex-direction:column; gap:11px; margin-bottom:28px; }
.front__list li{ position:relative; padding-left:28px; font-size:.96rem; color:rgba(245,241,234,.9); }
.front__list li::before{ content:""; position:absolute; left:0; top:.5em; width:13px; height:13px; border-radius:50%; background:currentColor; box-shadow:0 0 0 3px rgba(255,255,255,.06); }
.front__cta{ font-family:var(--font-mono); font-weight:700; font-size:.82rem; text-transform:uppercase; letter-spacing:.04em; color:currentColor; display:inline-block; transition:letter-spacing .3s ease; }
.front__cta:hover{ letter-spacing:.08em; }

.fronts__connector{ display:grid; place-items:center; }
.fronts__plus{
  font-family:var(--font-display); font-weight:900; font-size:2.4rem;
  width:62px; height:62px; border-radius:50%; display:grid; place-items:center;
  background:var(--ink); border:1px dashed var(--tan); color:var(--cream);
  animation:spin 18s linear infinite;
}
.fronts__band{
  margin-top:34px; padding:26px 34px; border-radius:6px;
  background:linear-gradient(100deg, rgba(10,91,255,.12), rgba(255,75,0,.1));
  border:1px solid var(--line);
  display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;
}
.fronts__band p{ font-size:1.05rem; }
.fronts__band strong{ color:var(--orange); }

/* =========================================================
   CALCULATOR
   ========================================================= */
.calc__grid{ display:grid; grid-template-columns:.85fr 1.15fr; gap:48px; align-items:start; }
.calc__intro .section__lead{ margin-bottom:24px; }
.calc__intro .section__lead strong{ color:var(--orange); }
.calc__checks{ display:flex; flex-direction:column; gap:12px; }
.calc__checks li{ position:relative; padding-left:30px; font-size:.96rem; color:rgba(13,13,13,.82); }
.calc__checks li::before{ content:"✓"; position:absolute; left:0; top:0; color:var(--orange); font-weight:700; }

.calc__panel{
  position:relative; border-radius:8px; overflow:hidden;
  background:var(--ink); color:var(--cream);
  padding:clamp(24px,3vw,36px);
  box-shadow:0 40px 80px -50px rgba(13,13,13,.6);
}
.calc__panel::before{ content:""; position:absolute; top:0; left:0; right:0; height:5px; background:linear-gradient(90deg,var(--orange),var(--blue)); }
.calc__panel::after{ content:""; position:absolute; top:0; right:0; width:74px; height:74px; background:linear-gradient(225deg,var(--orange) 0 50%, transparent 50%); opacity:.9; }
.calc__panel-head{ display:flex; align-items:center; justify-content:space-between; font-family:var(--font-mono); font-size:.72rem; text-transform:uppercase; letter-spacing:.1em; color:var(--tan); margin-bottom:24px; }
.calc__dots{ display:flex; gap:6px; }
.calc__dots i{ width:9px; height:9px; border-radius:50%; background:var(--tan); opacity:.5; }
.calc__dots i:first-child{ background:var(--orange); opacity:1; }
.calc__dots i:nth-child(2){ background:var(--blue); opacity:1; }

.calc__panel-label{ font-family:var(--font-mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.05em; color:var(--cream); margin-bottom:14px; }
.calc__roles{ display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-bottom:28px; }
.calc__role{
  display:flex; flex-direction:column; gap:3px; text-align:left;
  padding:12px 14px; border-radius:6px;
  background:rgba(245,241,234,.04); border:1px solid var(--line);
  font-family:var(--font-body); font-weight:600; font-size:.92rem; color:var(--cream);
  transition:background .25s ease, border-color .25s ease, transform .2s ease;
  position:relative;
}
.calc__role small{ font-family:var(--font-mono); font-size:.68rem; color:var(--tan); letter-spacing:.02em; }
.calc__role::after{
  content:""; position:absolute; top:12px; right:12px; width:16px; height:16px; border-radius:50%;
  border:1.5px solid var(--line); transition:.25s ease;
}
.calc__role:hover{ border-color:rgba(255,75,0,.5); transform:translateY(-2px); }
.calc__role.is-on{ background:rgba(255,75,0,.14); border-color:var(--orange); }
.calc__role.is-on::after{ background:var(--orange); border-color:var(--orange); box-shadow:inset 0 0 0 2px var(--ink); }
.calc__role.is-on small{ color:rgba(245,241,234,.85); }

.calc__compare{ display:flex; flex-direction:column; gap:14px; margin-bottom:24px; }
.calc__bar-label{ font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:var(--tan); display:block; margin-bottom:5px; }
.calc__bar-value{ font-family:var(--font-display); font-weight:800; font-size:1.5rem; display:block; margin-bottom:8px; }
.calc__bar-fill{ display:block; height:12px; border-radius:99px; background:var(--orange); width:100%; transition:width .8s var(--ease); }
.calc__bar-fill--ai{ background:var(--blue); }

.calc__savings{ display:flex; gap:16px; margin-bottom:24px; flex-wrap:wrap; }
.calc__save{ flex:1; min-width:150px; padding:20px; border-radius:6px; background:rgba(245,241,234,.05); border:1px solid var(--line); }
.calc__save-label{ font-family:var(--font-mono); font-size:.7rem; text-transform:uppercase; letter-spacing:.06em; color:var(--tan); display:block; margin-bottom:8px; }
.calc__save-num{ font-family:var(--font-display); font-weight:900; font-size:clamp(1.7rem,3.2vw,2.4rem); line-height:1; display:block; }
.calc__cta{ width:100%; justify-content:center; }
.calc__foot{ margin-top:14px; font-family:var(--font-mono); font-size:.72rem; color:var(--tan); text-align:center; }
.calc__foot strong{ color:var(--cream); }

.calc__disclaimer{ margin-top:26px; font-size:.78rem; color:rgba(13,13,13,.5); line-height:1.5; max-width:80ch; }

/* =========================================================
   PROCESS
   ========================================================= */
.process__list{ display:flex; flex-direction:column; }
.process__item{
  display:grid; grid-template-columns:230px 1fr 1fr; gap:30px; align-items:center;
  padding:30px 0; border-top:1px solid var(--line);
}
.process__item:last-child{ border-bottom:1px solid var(--line); }
.process__order{ font-family:var(--font-display); font-weight:900; font-style:italic; font-size:clamp(1.8rem,3vw,2.6rem); color:var(--orange); line-height:1; transition:transform .3s var(--ease); }
.process__item:nth-child(even) .process__order{ color:var(--blue); }
.process__item:hover .process__order{ transform:translateX(20px); }
.process__body{ display:flex; flex-direction:column; gap:12px; }
.process__title{ font-family:var(--font-display); font-weight:800; font-size:clamp(1.3rem,2.2vw,1.8rem); color:var(--cream); line-height:1.05; }
.process__title em{ font-style:italic; }
.process__pill{ align-self:flex-start; font-family:var(--font-mono); font-size:.66rem; font-weight:700; text-transform:uppercase; letter-spacing:.08em; color:var(--tan); padding:.4em .8em; border:1px solid var(--line); border-radius:99px; }
.process__desc{ color:rgba(245,241,234,.72); font-size:.96rem; }
.process__cta{ margin-top:46px; text-align:center; }

/* =========================================================
   PLANS (Ofertas)
   ========================================================= */
.plans__grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; align-items:stretch; }
.plan{
  position:relative; padding:38px 32px 34px; border-radius:8px;
  background:var(--ink); color:var(--cream); border:1px solid var(--line);
  display:flex; flex-direction:column;
  transition:transform .4s var(--ease), box-shadow .4s ease, border-color .3s ease;
}
.plan:hover{ transform:translateY(-8px); border-color:rgba(255,75,0,.45); }
.plan__label{ font-family:var(--font-mono); font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--tan); margin-bottom:14px; }
.plan__name{ font-family:var(--font-display); font-weight:800; font-size:1.9rem; margin-bottom:10px; }
.plan__name em{ font-style:italic; }
.plan__tagline{ color:rgba(245,241,234,.72); margin-bottom:26px; min-height:72px; font-size:.96rem; }
.plan__list{ display:flex; flex-direction:column; gap:13px; margin-bottom:32px; flex:1; }
.plan__list li{ position:relative; padding-left:28px; font-size:.95rem; color:rgba(245,241,234,.88); }
.plan__list li::before{ content:"✦"; position:absolute; left:0; top:0; color:var(--orange); font-size:.85rem; }
.plan__list li strong{ font-weight:700; color:#fff; }
.plan__cta{ width:100%; justify-content:center; }
.plan .plan__cta.btn--ghost{ border-color:rgba(245,241,234,.55); color:var(--cream); }
/* A & C ghost CTAs fill with their accent on hover (never white) */
.plans__grid .plan:first-child .plan__cta::after{ background:var(--orange); }
.plans__grid .plan:first-child .plan__cta:hover{ color:#fff; border-color:var(--orange); }
.plans__grid .plan:last-child .plan__cta::after{ background:var(--blue); }
.plans__grid .plan:last-child .plan__cta:hover{ color:#fff; border-color:var(--blue); }

/* Featured B — DARK card (fully readable) with gradient orange→blue border */
.plan--featured{
  background:var(--ink-2); color:var(--cream); border-color:transparent;
  transform:scale(1.04); z-index:3;
  box-shadow:0 40px 80px -34px rgba(255,75,0,.5);
}
.plan--featured::before{
  content:""; position:absolute; inset:0; border-radius:8px; padding:2px;
  background:linear-gradient(135deg,var(--orange),var(--blue));
  -webkit-mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask:linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite:xor; mask-composite:exclude; pointer-events:none;
}
.plan--featured:hover{ transform:scale(1.04) translateY(-8px); border-color:transparent; }
.plan__badge{
  position:absolute; top:-15px; left:50%; transform:translateX(-50%); z-index:4;
  font-family:var(--font-mono); font-weight:700; font-size:.7rem;
  text-transform:uppercase; letter-spacing:.05em;
  background:var(--orange); color:#fff; padding:.55em 1.1em; border-radius:99px;
  white-space:nowrap; box-shadow:0 10px 24px -10px rgba(255,75,0,.6);
}
.plan--featured .plan__label{ color:var(--tan); }
.plan--featured .plan__name{ color:var(--cream); }
.plan--featured .plan__tagline{ color:rgba(245,241,234,.8); }
.plan--featured .plan__list li{ color:rgba(245,241,234,.92); }
.plan--featured .plan__list li strong{ color:#fff; }
.plan--featured .plan__list li::before{ content:"✦"; color:var(--orange); }
/* featured CTA: stays solid orange on hover (no white flash), just lifts */
.plan--featured .plan__cta:hover{ color:#fff; filter:brightness(1.06); }
.plan--featured .plan__cta:hover::after{ transform:translateY(101%); }

.plans__note{ text-align:center; margin-top:38px; color:rgba(13,13,13,.7); font-size:1rem; }
.plans__note a{ color:var(--orange); font-weight:700; text-decoration:underline; text-underline-offset:3px; }

/* =========================================================
   FAQ (clean editorial list)
   ========================================================= */
.faq__list{ display:flex; flex-direction:column; }
.faq__item{ border-top:1px solid var(--line); }
.faq__item:last-child{ border-bottom:1px solid var(--line); }
.faq__q{
  display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding:26px 6px; cursor:pointer; list-style:none;
  font-family:var(--font-display); font-weight:700; font-size:clamp(1.1rem,1.9vw,1.4rem);
  color:var(--cream); transition:color .25s ease, padding-left .3s var(--ease);
}
.faq__q::-webkit-details-marker{ display:none; }
.faq__item[open] .faq__q,.faq__q:hover{ color:var(--orange); }
.faq__q:hover{ padding-left:12px; }
.faq__plus{ position:relative; width:22px; height:22px; flex-shrink:0; }
.faq__plus::before,.faq__plus::after{ content:""; position:absolute; top:50%; left:50%; background:var(--orange); border-radius:2px; transform:translate(-50%,-50%); transition:transform .3s var(--ease); }
.faq__plus::before{ width:18px; height:2.5px; }
.faq__plus::after{ width:2.5px; height:18px; }
.faq__item[open] .faq__plus::after{ transform:translate(-50%,-50%) scaleY(0); }
.faq__a{ padding:0 6px 26px; color:rgba(245,241,234,.78); max-width:70ch; }
.faq__a strong{ color:var(--cream); }

/* =========================================================
   FINAL CTA
   ========================================================= */
.final-cta{ position:relative; padding:clamp(80px,11vw,140px) 0; overflow:hidden; background:var(--ink); text-align:center; }
.final-cta__watermark{
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--font-display); font-weight:900; font-size:clamp(7rem,26vw,24rem);
  color:rgba(245,241,234,.035); white-space:nowrap; pointer-events:none; user-select:none; z-index:0;
}
.final-cta__blob{ position:absolute; border-radius:50%; filter:blur(50px); opacity:.35; }
.final-cta__blob--orange{ width:480px; height:480px; background:var(--orange); top:-180px; left:-120px; }
.final-cta__blob--blue{ width:520px; height:520px; background:var(--blue); bottom:-220px; right:-140px; }
.final-cta__inner{ position:relative; z-index:2; }

/* animated icon */
.final-cta__icon{ position:relative; width:120px; height:120px; margin:0 auto 30px; }
.final-cta__icon img{ position:relative; z-index:2; width:84px; height:84px; margin:18px auto 0; object-fit:contain; animation:iconBob 3.2s var(--ease) infinite; filter:drop-shadow(0 0 30px rgba(255,75,0,.35)); }
.final-cta__orbit{ position:absolute; inset:0; border-radius:50%; border:1px dashed rgba(245,241,234,.18); animation:spin 14s linear infinite; }
.final-cta__orbit--2{ inset:14px; border-color:rgba(255,75,0,.25); animation:spin 9s linear infinite reverse; }

.final-cta__title{ font-family:var(--font-display); font-weight:900; font-size:clamp(2.1rem,5.2vw,3.8rem); line-height:1.04; letter-spacing:-.015em; font-variation-settings:"SOFT" 0,"WONK" 1; color:var(--cream); margin-bottom:18px; }
.final-cta__sub{ font-size:clamp(1rem,1.5vw,1.18rem); color:rgba(245,241,234,.8); max-width:56ch; margin:0 auto 36px; }
.final-cta__actions{ display:flex; justify-content:center; gap:14px; flex-wrap:wrap; margin-bottom:34px; }
.final-cta__trust{ display:flex; justify-content:center; gap:14px 30px; flex-wrap:wrap; }
.final-cta__trust li{ font-family:var(--font-mono); font-size:.74rem; text-transform:uppercase; letter-spacing:.06em; color:var(--tan); position:relative; padding-left:22px; }
.final-cta__trust li::before{ content:"✓"; position:absolute; left:0; color:var(--orange); font-weight:700; }

/* =========================================================
   FOOTER
   ========================================================= */
.site-footer{ position:relative; background:var(--ink); color:var(--cream); padding:80px 0 36px; border-top:1px solid var(--line); overflow:hidden; }
.site-footer::before{
  content:""; position:absolute; inset:0; z-index:0; pointer-events:none; opacity:.7;
  background-image:
    linear-gradient(rgba(245,241,234,.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(245,241,234,.055) 1px, transparent 1px);
  background-size:60px 60px;
  -webkit-mask-image:radial-gradient(120% 95% at 50% 100%, #000, transparent 72%);
          mask-image:radial-gradient(120% 95% at 50% 100%, #000, transparent 72%);
}
.site-footer .container{ position:relative; z-index:2; }
.footer__logo-link{ display:inline-block; transition:transform .3s var(--ease); }
.footer__logo-link:hover{ transform:translateY(-3px); }
.footer__top{ display:grid; grid-template-columns:1.4fr 1fr; gap:48px; padding-bottom:48px; border-bottom:1px solid var(--line); }
.footer__logo{ height:160px; width:auto; margin-bottom:20px; filter:drop-shadow(0 6px 24px rgba(0,0,0,.5)); }
.footer__slogan{ font-family:var(--font-display); font-style:italic; font-size:1.2rem; color:var(--tan); max-width:36ch; }
.footer__cols{ display:grid; grid-template-columns:1fr 1fr; gap:36px; }
.footer__col h4{ font-family:var(--font-mono); font-size:.74rem; font-weight:700; text-transform:uppercase; letter-spacing:.1em; color:var(--orange); margin-bottom:18px; }
.footer__col a{ display:block; font-size:.96rem; color:rgba(245,241,234,.82); margin-bottom:12px; transition:color .25s ease, padding-left .25s ease; }
.footer__col a:hover{ color:var(--cream); padding-left:6px; }
.footer__bottom{ display:flex; align-items:center; justify-content:space-between; gap:20px; padding-top:30px; flex-wrap:wrap; }
.footer__copy{ font-family:var(--font-mono); font-size:.78rem; color:var(--tan); }
.footer__ig{ display:inline-flex; align-items:center; gap:9px; font-family:var(--font-mono); font-size:.78rem; font-weight:700; text-transform:uppercase; letter-spacing:.05em; color:var(--cream); padding:.6em 1.1em; border:1px solid var(--line); border-radius:99px; transition:border-color .3s ease, background .3s ease; }
.footer__ig svg{ width:18px; height:18px; }
.footer__ig:hover{ background:linear-gradient(120deg,var(--orange),var(--blue)); border-color:transparent; }

/* =========================================================
   WHATSAPP FLOAT
   ========================================================= */
.wa-float{
  position:fixed; right:22px; bottom:22px; z-index:7500;
  width:60px; height:60px; border-radius:50%;
  background:#25d366; color:#fff; display:grid; place-items:center;
  box-shadow:0 14px 30px -8px rgba(37,211,102,.6); transition:transform .3s var(--ease);
}
.wa-float svg{ width:34px; height:34px; position:relative; z-index:2; }
.wa-float:hover{ transform:scale(1.08) rotate(-4deg); }
.wa-float__pulse{ position:absolute; inset:0; border-radius:50%; background:#25d366; z-index:1; animation:waPulse 2.4s ease-out infinite; }

/* =========================================================
   REVEAL / ANIMATIONS
   ========================================================= */
.reveal{ opacity:0; transform:translateY(34px); transition:opacity .8s var(--ease), transform .8s var(--ease); will-change:transform,opacity; }
.reveal.is-visible{ opacity:1; transform:none; }

@keyframes floaty{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-10px); } }
@keyframes iconBob{ 0%,100%{ transform:translateY(0) rotate(-3deg); } 50%{ transform:translateY(-12px) rotate(3deg); } }
@keyframes twinkle{ 0%,100%{ transform:scale(.7); opacity:.5; } 50%{ transform:scale(1.15); opacity:1; } }
@keyframes pulsate{ 0%{ transform:scale(.8); opacity:.8; } 100%{ transform:scale(1.4); opacity:0; } }
@keyframes fadeUp{ from{ opacity:0; transform:translateY(16px); } to{ opacity:1; transform:none; } }
@keyframes marquee{ from{ transform:translateX(0); } to{ transform:translateX(-50%); } }
@keyframes drift{ 0%,100%{ transform:translate(0,0); } 50%{ transform:translate(40px,30px); } }
@keyframes spin{ from{ transform:rotate(0); } to{ transform:rotate(360deg); } }
@keyframes draw{ to{ stroke-dashoffset:0; } }
@keyframes waPulse{ 0%{ transform:scale(1); opacity:.6; } 100%{ transform:scale(1.8); opacity:0; } }

/* =========================================================
   RESPONSIVE
   ========================================================= */
@media (max-width:1080px){
  .hero__grid{ grid-template-columns:1fr; gap:64px; }
  .hero__media{ max-width:460px; margin-inline:auto; }
  .fronts__grid{ grid-template-columns:1fr; }
  .fronts__connector{ padding:6px 0; }
  .fronts__plus{ animation:none; }
  .calc__grid{ grid-template-columns:1fr; gap:36px; }
  .process__item{ grid-template-columns:160px 1fr; grid-template-areas:"order body" "order desc"; gap:8px 24px; align-items:start; }
  .process__order{ grid-area:order; }
  .process__body{ grid-area:body; }
  .process__desc{ grid-area:desc; }
  .plans__grid{ grid-template-columns:1fr; max-width:480px; margin-inline:auto; }
  .plan--featured{ transform:none; order:-1; }
  .plan--featured:hover{ transform:translateY(-8px); }
  .plan__tagline{ min-height:0; }
  .footer__top{ grid-template-columns:1fr; gap:36px; }
}

@media (max-width:760px){
  .brand__img{ height:50px; }
  .site-header.is-scrolled .brand__img{ height:42px; }
  .header-cta{ display:none; }
  .nav-toggle{ display:flex; }
  .nav{
    position:fixed; inset:0 0 0 auto; width:min(82vw,360px);
    flex-direction:column; align-items:flex-start; justify-content:center; gap:26px;
    background:var(--ink-2); padding:60px 40px; border-left:1px solid var(--line);
    transform:translateX(100%); transition:transform .45s var(--ease); z-index:10;
  }
  .nav.is-open{ transform:translateX(0); }
  .nav__link{ font-size:1.05rem; }
  .nav__link--mobile-cta{ display:inline-flex; margin-top:8px; }
  .hero{ padding:130px 0 80px; }
  .hero__stats{ gap:18px 28px; }
  .stat__num{ font-size:1.6rem; }
  .hero__label--tl{ left:0; }
  .hero__label--r{ right:0; }
  .calc__roles{ grid-template-columns:1fr; }
  .calc__savings{ flex-direction:column; }
  .process__item{ grid-template-columns:1fr; grid-template-areas:"order" "body" "desc"; gap:10px; }
  .footer__cols{ grid-template-columns:1fr; }
  .footer__logo{ height:96px; }
  .footer__bottom{ flex-direction:column; align-items:flex-start; }
  .marquee__group span{ font-size:.74rem; letter-spacing:.12em; }
}

@media (max-width:420px){
  .container{ width:calc(100% - 32px); }
}

/* Reduced motion */
@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
}
