:root{
  --bg:#fafaf8;
  --ink:#0d0e11;
  --ink2:#23252c;
  --ink3:#6b7280;
  --ink4:#9ca3af;
  --line:#e5e7eb;
  --line2:#f3f4f6;
  --gold:#c49a2a;
  --gold-bg:#fefce8;
  --gold-border:#fde68a;
  --green:#16a34a;
  --green-bg:#f0fdf4;
  --blue:#2563eb;
  --red:#dc2626;
  --white:#ffffff;
  --r:10px;
  --max:1160px;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
html{overflow-x:clip;}
body{font-family:'Geist',sans-serif;background:var(--bg);color:var(--ink);overflow-x:clip;-webkit-font-smoothing:antialiased;}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--line);border-radius:2px;}

/* ── GRAIN OVERLAY ── */
body::before{
  content:'';position:fixed;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.03'/%3E%3C/svg%3E");
  pointer-events:none;z-index:0;opacity:.4;
}

/* ── LAYOUT ── */
.wrap{max-width:var(--max);margin:0 auto;padding:0 24px;position:relative;z-index:1;}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  padding:0 24px;
  background:rgba(250,250,248,.88);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--line);
}
.nav-inner{
  max-width:var(--max);margin:0 auto;
  display:flex;align-items:center;justify-content:space-between;
  height:60px;
}
.nav-logo{
  font-family:'Instrument Serif',serif;
  font-size:22px;
  color:var(--ink);
  text-decoration:none;
  display:flex;align-items:center;gap:6px;
}
.nav-logo span{color:var(--gold);}
.nav-logo sup{
  font-family:'Geist',sans-serif;
  font-size:10px;font-weight:700;
  background:var(--ink);color:var(--white);
  padding:1px 5px;border-radius:3px;
  letter-spacing:.06em;vertical-align:super;
}
.nav-links{display:flex;align-items:center;gap:28px;}
.nav-links a{
  font-size:13.5px;font-weight:400;
  color:var(--ink3);text-decoration:none;
  transition:color .15s;
}
.nav-links a:hover{color:var(--ink);}
.nav-cta{display:flex;align-items:center;gap:10px;}
.btn-ghost{
  font-size:13px;font-weight:500;
  color:var(--ink2);text-decoration:none;
  padding:7px 16px;border-radius:7px;
  border:1px solid var(--line);
  transition:all .15s;
}
.btn-ghost:hover{border-color:var(--ink3);color:var(--ink);}
.btn-primary{
  font-size:13px;font-weight:600;
  color:var(--white);
  background:var(--ink);
  padding:8px 18px;border-radius:7px;
  text-decoration:none;
  transition:all .2s;
  white-space:nowrap;
}
.btn-primary:hover{background:var(--ink2);transform:translateY(-1px);box-shadow:0 4px 12px rgba(13,14,17,.2);}

/* ── HERO ── */
.hero{
  padding:148px 0 100px;
  text-align:center;
  position:relative;
}
.hero::before{
  content:'';
  position:absolute;top:0;left:0;right:0;
  width:100%;height:500px;
  background:radial-gradient(ellipse at 50% 30%,rgba(196,154,42,.08) 0%,transparent 65%);
  pointer-events:none;
}
.hero-badge{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gold-bg);
  border:1px solid var(--gold-border);
  border-radius:20px;
  padding:5px 14px;
  margin-bottom:28px;
  font-size:12px;font-weight:600;
  color:var(--gold);
  letter-spacing:.04em;
}
.hero-badge::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--gold);
  box-shadow:0 0 8px rgba(196,154,42,.6);
  animation:pulse 2s infinite;
}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.hero h1{
  font-family:'Instrument Serif',serif;
  font-size:clamp(38px,6vw,72px);
  font-weight:400;
  line-height:1.08;
  letter-spacing:-.02em;
  color:var(--ink);
  max-width:820px;
  margin:0 auto 22px;
}
.hero h1 em{
  font-style:italic;
  color:var(--gold);
}
.hero p{
  font-size:clamp(15px,2vw,18px);
  color:var(--ink3);
  max-width:540px;
  margin:0 auto 40px;
  line-height:1.7;
  font-weight:300;
}
.hero-ctas{
  display:flex;align-items:center;justify-content:center;
  gap:12px;flex-wrap:wrap;margin-bottom:52px;
}
.btn-hero{
  font-size:15px;font-weight:600;
  color:var(--white);
  background:var(--ink);
  padding:13px 28px;border-radius:9px;
  text-decoration:none;
  transition:all .2s;
  display:inline-flex;align-items:center;gap:8px;
}
.btn-hero:hover{background:var(--ink2);transform:translateY(-2px);box-shadow:0 8px 24px rgba(13,14,17,.2);}
.btn-hero-outline{
  font-size:15px;font-weight:500;
  color:var(--ink2);
  background:transparent;
  padding:13px 28px;border-radius:9px;
  text-decoration:none;
  border:1.5px solid var(--line);
  transition:all .2s;
}
.btn-hero-outline:hover{border-color:var(--ink3);color:var(--ink);}
.hero-note{font-size:12px;color:var(--ink4);margin-top:14px;}
.hero-note strong{color:var(--green);font-weight:600;}

/* ── HERO VISUAL ── */
.hero-visual{
  max-width:900px;margin:0 auto;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:16px;
  box-shadow:0 24px 80px rgba(13,14,17,.1),0 1px 0 rgba(255,255,255,.8) inset;
  overflow:hidden;
}
.hv-bar{
  background:var(--line2);
  border-bottom:1px solid var(--line);
  padding:10px 16px;
  display:flex;align-items:center;gap:6px;
}
.hv-dot{width:10px;height:10px;border-radius:50%;}
.hv-url{
  margin-left:8px;flex:1;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:5px;
  padding:4px 10px;
  font-family:'Geist Mono',monospace;
  font-size:11px;
  color:var(--ink3);
  text-align:center;
}
.hv-body{padding:28px;text-align:left;}

/* Dashboard preview inside hero */
.dash-preview{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:10px;margin-bottom:16px;}
.dp-kpi{
  background:var(--bg);border:1px solid var(--line);
  border-radius:8px;padding:12px 14px;
}
.dp-kpi-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink4);margin-bottom:6px;}
.dp-kpi-val{font-family:'Geist Mono',monospace;font-size:20px;font-weight:600;color:var(--ink);}
.dp-kpi-sub{font-size:10px;color:var(--ink4);margin-top:3px;}
.dp-kpi.green .dp-kpi-val{color:var(--green);}
.dp-kpi.red .dp-kpi-val{color:var(--red);}
.dp-kpi.gold .dp-kpi-val{color:var(--gold);}

.dash-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;}
.dp-card{
  background:var(--bg);border:1px solid var(--line);
  border-radius:8px;padding:14px;
}
.dp-card-title{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink4);margin-bottom:10px;}
.dp-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:7px;}
.dp-bar-lbl{font-size:10px;color:var(--ink3);width:80px;flex-shrink:0;}
.dp-bar-track{flex:1;height:6px;background:var(--line);border-radius:3px;overflow:hidden;}
.dp-bar-fill{height:100%;border-radius:3px;}
.dp-bar-val{font-family:'Geist Mono',monospace;font-size:10px;color:var(--ink3);width:36px;text-align:right;}

.dp-cl-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;border-bottom:1px solid var(--line);font-size:11px;}
.dp-cl-row:last-child{border-bottom:none;}
.dp-cl-name{color:var(--ink2);font-weight:500;}
.dp-cl-tag{font-size:9px;font-weight:700;padding:2px 7px;border-radius:4px;}
.tag-ok{background:var(--green-bg);color:var(--green);}
.tag-w{background:#fef9c3;color:#a16207;}
.tag-r{background:#fef2f2;color:var(--red);}

/* ── SOCIAL PROOF ── */
.social-proof{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  padding:28px 0;
  text-align:center;
}
.sp-label{font-size:12px;color:var(--ink4);margin-bottom:20px;letter-spacing:.05em;text-transform:uppercase;font-weight:500;}
.sp-logos{
  display:flex;align-items:center;justify-content:center;
  gap:40px;flex-wrap:wrap;
}
.sp-logo{
  font-family:'Instrument Serif',serif;
  font-size:16px;color:var(--ink4);
  opacity:.5;letter-spacing:-.3px;
}

/* ── SECTION ── */
section{padding:96px 0;}
.section-tag{
  display:inline-block;
  font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:.12em;
  color:var(--gold);
  margin-bottom:14px;
}
.section-h{
  font-family:'Instrument Serif',serif;
  font-size:clamp(28px,4vw,48px);
  font-weight:400;
  line-height:1.15;
  letter-spacing:-.02em;
  color:var(--ink);
  margin-bottom:16px;
}
.section-h em{font-style:italic;color:var(--gold);}
.section-sub{
  font-size:16px;color:var(--ink3);
  line-height:1.7;font-weight:300;
  max-width:520px;
}

/* ── PROBLEMA ── */
.problem-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:40px;
  align-items:center;
  margin-top:56px;
}
.problem-list{display:flex;flex-direction:column;gap:18px;}
.prob-item{
  display:flex;gap:14px;
  padding:18px 20px;
  background:var(--white);
  border:1px solid var(--line);
  border-radius:10px;
  transition:border-color .2s,box-shadow .2s;
}
.prob-item:hover{border-color:var(--red);box-shadow:0 4px 16px rgba(220,38,38,.06);}
.prob-icon{
  width:36px;height:36px;
  border-radius:8px;
  background:#fef2f2;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;flex-shrink:0;
}
.prob-text h4{font-size:13.5px;font-weight:600;color:var(--ink);margin-bottom:4px;}
.prob-text p{font-size:12px;color:var(--ink3);line-height:1.6;}

.solution-box{
  background:var(--ink);
  border-radius:16px;
  padding:36px;
  color:var(--white);
}
.solution-box h3{
  font-family:'Instrument Serif',serif;
  font-size:26px;font-style:italic;
  margin-bottom:20px;
  line-height:1.2;
  color:var(--white);
}
.sol-item{
  display:flex;align-items:flex-start;gap:10px;
  margin-bottom:14px;
  font-size:13px;
  line-height:1.6;
  color:rgba(255,255,255,.75);
}
.sol-check{
  width:20px;height:20px;
  border-radius:50%;
  background:rgba(196,154,42,.2);
  border:1px solid rgba(196,154,42,.4);
  display:flex;align-items:center;justify-content:center;
  font-size:10px;flex-shrink:0;
  margin-top:1px;
  color:var(--gold);
}
.sol-cta{
  margin-top:28px;
  display:inline-flex;align-items:center;gap:8px;
  background:var(--gold);
  color:var(--ink);
  font-weight:700;font-size:13px;
  padding:11px 22px;border-radius:8px;
  text-decoration:none;
  transition:all .2s;
}
.sol-cta:hover{background:#d4a843;transform:translateY(-1px);}

/* ── FEATURES ── */
.features-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:20px;
  margin-top:56px;
}
.feat-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:12px;
  padding:26px;
  transition:all .22s;
  position:relative;
  overflow:hidden;
}
.feat-card::before{
  content:'';
  position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);
  opacity:0;transition:opacity .2s;
}
.feat-card:hover{border-color:rgba(196,154,42,.3);box-shadow:0 8px 28px rgba(13,14,17,.07);transform:translateY(-2px);}
.feat-card:hover::before{opacity:1;}
.feat-icon{
  width:42px;height:42px;border-radius:10px;
  background:var(--bg);border:1px solid var(--line);
  display:flex;align-items:center;justify-content:center;
  font-size:18px;margin-bottom:16px;
}
.feat-card h3{font-size:15px;font-weight:600;color:var(--ink);margin-bottom:8px;letter-spacing:-.2px;}
.feat-card p{font-size:12.5px;color:var(--ink3);line-height:1.65;}
.feat-tag{
  display:inline-block;
  font-size:10px;font-weight:700;
  text-transform:uppercase;letter-spacing:.06em;
  padding:2px 8px;border-radius:4px;
  margin-top:12px;
}
.ft-new{background:var(--gold-bg);color:var(--gold);}
.ft-pro{background:#ede9fe;color:#7c3aed;}
.ft-all{background:var(--green-bg);color:var(--green);}

/* ── HOW IT WORKS ── */
.hiw-bg{background:var(--ink);}
.hiw-bg .section-tag{color:rgba(196,154,42,.8);}
.hiw-bg .section-h{color:var(--white);}
.hiw-bg .section-h em{color:var(--gold);}
.hiw-bg .section-sub{color:rgba(255,255,255,.5);}

.hiw-steps{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:2px;
  margin-top:56px;
}
.hiw-step{
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);
  border-radius:12px;
  padding:28px 24px;
  position:relative;
}
.hiw-num{
  font-family:'Geist Mono',monospace;
  font-size:11px;font-weight:600;
  color:var(--gold);
  letter-spacing:.1em;
  margin-bottom:16px;
}
.hiw-step h3{
  font-size:15px;font-weight:600;
  color:var(--white);
  margin-bottom:8px;letter-spacing:-.2px;
}
.hiw-step p{font-size:12px;color:rgba(255,255,255,.45);line-height:1.7;}
.hiw-arrow{
  position:absolute;top:50%;right:-14px;
  transform:translateY(-50%);
  font-size:16px;color:rgba(255,255,255,.15);
  z-index:1;
}

/* ── PLANOS ── */
.plans-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:16px;
  margin-top:56px;
  align-items:start;
}
.plan-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:14px;
  padding:28px;
  position:relative;
}
.plan-card.featured{
  background:var(--ink);
  border-color:var(--ink);
  transform:scale(1.03);
  box-shadow:0 20px 60px rgba(13,14,17,.2);
}
.plan-badge{
  position:absolute;top:-12px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:var(--ink);
  font-size:10px;font-weight:700;
  letter-spacing:.08em;text-transform:uppercase;
  padding:3px 14px;border-radius:20px;
  white-space:nowrap;
}
.plan-name{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--ink3);margin-bottom:8px;}
.plan-card.featured .plan-name{color:rgba(255,255,255,.5);}
.plan-price{
  display:flex;align-items:baseline;gap:4px;
  margin-bottom:6px;
}
.plan-currency{font-size:14px;font-weight:600;color:var(--ink3);margin-top:6px;}
.plan-card.featured .plan-currency{color:rgba(255,255,255,.5);}
.plan-amount{
  font-family:'Geist Mono',monospace;
  font-size:40px;font-weight:700;
  color:var(--ink);letter-spacing:-1px;
}
.plan-card.featured .plan-amount{color:var(--white);}
.plan-period{font-size:12px;color:var(--ink4);margin-top:4px;font-weight:400;}
.plan-card.featured .plan-period{color:rgba(255,255,255,.35);}
.plan-desc{font-size:12px;color:var(--ink3);margin-bottom:20px;line-height:1.6;}
.plan-card.featured .plan-desc{color:rgba(255,255,255,.45);}
.plan-divider{height:1px;background:var(--line);margin:18px 0;}
.plan-card.featured .plan-divider{background:rgba(255,255,255,.1);}
.plan-features{display:flex;flex-direction:column;gap:10px;margin-bottom:24px;}
.pf-item{display:flex;align-items:flex-start;gap:9px;font-size:12.5px;color:var(--ink2);}
.plan-card.featured .pf-item{color:rgba(255,255,255,.8);}
.pf-icon{font-size:13px;flex-shrink:0;margin-top:1px;}
.pf-item.disabled{color:var(--ink4);text-decoration:line-through;}
.plan-card.featured .pf-item.disabled{color:rgba(255,255,255,.25);}
.plan-btn{
  display:block;text-align:center;text-decoration:none;
  font-size:13px;font-weight:600;
  padding:11px;border-radius:8px;
  transition:all .2s;
}
.plan-btn-outline{
  border:1.5px solid var(--line);color:var(--ink);
}
.plan-btn-outline:hover{border-color:var(--ink3);}
.plan-btn-solid{
  background:var(--gold);color:var(--ink);
}
.plan-btn-solid:hover{background:#d4a843;transform:translateY(-1px);box-shadow:0 4px 14px rgba(196,154,42,.3);}
.plan-btn-white{
  background:var(--white);color:var(--ink);
}
.plan-btn-white:hover{background:var(--bg);transform:translateY(-1px);}

.plan-clients-limit{
  font-family:'Geist Mono',monospace;
  font-size:11px;color:var(--ink4);
  margin-bottom:4px;letter-spacing:.04em;
}
.plan-card.featured .plan-clients-limit{color:rgba(255,255,255,.35);}

/* ── TESTIMONIALS ── */
.testi-grid{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:16px;
  margin-top:56px;
}
.testi-card{
  background:var(--white);
  border:1px solid var(--line);
  border-radius:12px;
  padding:24px;
}
.testi-stars{color:var(--gold);font-size:14px;margin-bottom:14px;letter-spacing:2px;}
.testi-text{
  font-size:13.5px;color:var(--ink2);
  line-height:1.7;font-style:italic;
  margin-bottom:18px;
}
.testi-author{display:flex;align-items:center;gap:10px;}
.testi-avatar{
  width:36px;height:36px;border-radius:50%;
  background:var(--ink);color:var(--white);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;font-weight:700;font-family:'Instrument Serif',serif;
  flex-shrink:0;
}
.testi-name{font-size:12px;font-weight:600;color:var(--ink);}
.testi-role{font-size:11px;color:var(--ink4);}

/* ── FAQ ── */
.faq-list{margin-top:48px;max-width:700px;}
.faq-item{
  border-bottom:1px solid var(--line);
  padding:20px 0;
  cursor:pointer;
}
.faq-q{
  display:flex;align-items:center;justify-content:space-between;
  font-size:14.5px;font-weight:500;color:var(--ink);
  gap:16px;
}
.faq-icon{
  width:24px;height:24px;border-radius:50%;
  background:var(--line2);
  display:flex;align-items:center;justify-content:center;
  font-size:14px;color:var(--ink3);flex-shrink:0;
  transition:all .2s;
}
.faq-item.open .faq-icon{background:var(--ink);color:var(--white);transform:rotate(45deg);}
.faq-a{
  font-size:13px;color:var(--ink3);line-height:1.75;
  margin-top:12px;display:none;
}
.faq-item.open .faq-a{display:block;}

/* ── CTA FINAL ── */
.cta-section{
  background:var(--ink);
  border-radius:20px;
  padding:72px 48px;
  text-align:center;
  position:relative;overflow:hidden;
  margin:80px 0;
}
.cta-section::before{
  content:'';position:absolute;
  top:0;left:50%;transform:translateX(-50%);
  width:600px;height:400px;
  background:radial-gradient(ellipse at 50% 0%,rgba(196,154,42,.15) 0%,transparent 60%);
  pointer-events:none;
}
.cta-section h2{
  font-family:'Instrument Serif',serif;
  font-size:clamp(28px,4vw,48px);
  font-weight:400;font-style:italic;
  color:var(--white);
  margin-bottom:16px;
  letter-spacing:-.02em;
  position:relative;
}
.cta-section p{
  font-size:16px;color:rgba(255,255,255,.5);
  margin-bottom:36px;font-weight:300;
  position:relative;
}
.cta-btns{
  display:flex;align-items:center;justify-content:center;
  gap:12px;flex-wrap:wrap;
  position:relative;
}
.btn-cta-main{
  font-size:15px;font-weight:700;
  background:var(--gold);color:var(--ink);
  padding:14px 32px;border-radius:9px;
  text-decoration:none;
  display:inline-flex;align-items:center;gap:8px;
  transition:all .2s;
}
.btn-cta-main:hover{background:#d4a843;transform:translateY(-2px);box-shadow:0 8px 24px rgba(196,154,42,.3);}
.btn-cta-ghost{
  font-size:14px;font-weight:500;
  color:rgba(255,255,255,.6);
  padding:14px 24px;border-radius:9px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.1);
  transition:all .2s;
}
.btn-cta-ghost:hover{border-color:rgba(255,255,255,.3);color:var(--white);}
.cta-note{
  font-size:12px;color:rgba(255,255,255,.3);
  margin-top:18px;position:relative;
}

/* ── FOOTER ── */
footer{
  border-top:1px solid var(--line);
  padding:40px 0;
}
.footer-inner{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:20px;
}
.footer-logo{
  font-family:'Instrument Serif',serif;
  font-size:18px;color:var(--ink3);
}
.footer-logo span{color:var(--gold);}
.footer-links{display:flex;gap:24px;}
.footer-links a{font-size:12px;color:var(--ink4);text-decoration:none;}
.footer-links a:hover{color:var(--ink3);}
.footer-copy{font-size:11px;color:var(--ink4);}

/* ── ANIMATIONS ── */
.fade-up{
  opacity:1;transform:translateY(0);
  transition:opacity .6s ease,transform .6s ease;
}
.fade-up.animate{opacity:0;transform:translateY(20px);pointer-events:none;}
.fade-up.animate.visible{opacity:1;transform:translateY(0);pointer-events:auto;}

/* ── PLANS GRID ── */
.plans-grid-wrap{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  align-items:start;
}

/* ── FAQ GRID ── */
.faq-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:start;
}

/* ── DEMO MODAL BODY ── */
.demo-body{
  display:grid;
  grid-template-columns:200px 1fr;
  height:480px;
  overflow:hidden;
}

/* ── RESPONSIVE ── */
@media(max-width:900px){
  .nav-links{display:none;}
  .problem-grid,.hiw-steps,.features-grid,.plans-grid,.testi-grid{grid-template-columns:1fr;}
  .plans-grid-wrap{grid-template-columns:1fr 1fr;}
  .plan-card.featured{transform:none;}
  .dash-preview{grid-template-columns:1fr 1fr;}
  .dash-row{grid-template-columns:1fr;}
  .hiw-arrow{display:none;}
  .cta-section{padding:48px 24px;}
  .hero{padding:110px 0 72px;}
  section{padding:64px 0;}
  .faq-grid{grid-template-columns:1fr;gap:32px;}
}
@media(max-width:640px){
  .plans-grid-wrap{grid-template-columns:1fr;}
  .demo-body{
    grid-template-columns:1fr;
    height:auto;
  }
  .demo-sidebar-mock{display:none;}
  .demo-content-mock{height:360px;overflow-y:auto;}
  .hero-visual{border-radius:10px;}
  .hv-body{padding:16px;}
  .modal-box{padding:24px 20px;}
  .cta-section{padding:40px 20px;border-radius:14px;}
  /* Demo modal full-screen no mobile */
  #modal-demo{padding:0;}
  #modal-demo .modal-box{
    max-width:100% !important;
    width:100%;
    height:100vh;
    max-height:100vh;
    border-radius:0 !important;
    overflow-y:auto;
    display:flex;
    flex-direction:column;
  }
  #modal-demo .demo-body{
    flex:1;
    height:auto;
    min-height:0;
  }
}
@media(max-width:480px){
  .hero-visual{display:none;}
  .hero{padding:100px 0 52px;}
  .hero h1{font-size:clamp(32px,9vw,48px);}
  .sp-logos{gap:20px;flex-wrap:wrap;}
  .hero-ctas{flex-direction:column;align-items:stretch;}
  .btn-hero,.btn-hero-outline{text-align:center;justify-content:center;}
  .wrap{padding:0 16px;}
  section{padding:52px 0;}
  .plan-card{padding:20px 18px;}
  .testi-card{padding:20px 18px;}
  .faq-q{font-size:13px;}
}

/* ══ MODALS & OVERLAYS ══ */
.overlay{
  position:fixed;inset:0;z-index:500;
  background:rgba(13,14,17,.6);
  backdrop-filter:blur(6px);
  display:flex;align-items:center;justify-content:center;
  padding:20px;
  opacity:0;pointer-events:none;
  transition:opacity .2s;
}
.overlay.show{opacity:1;pointer-events:auto;}
.modal-box{
  background:var(--white);
  border-radius:16px;
  padding:36px;
  width:100%;max-width:440px;
  box-shadow:0 32px 80px rgba(13,14,17,.2);
  transform:translateY(16px);
  transition:transform .25s cubic-bezier(.4,0,.2,1);
  position:relative;
}
.overlay.show .modal-box{transform:translateY(0);}
.modal-close{
  position:absolute;top:16px;right:16px;
  width:28px;height:28px;border-radius:50%;
  background:var(--line2);border:none;cursor:pointer;
  font-size:14px;color:var(--ink3);
  display:flex;align-items:center;justify-content:center;
  transition:background .15s;
}
.modal-close:hover{background:var(--line);}
.modal-logo{
  font-family:'Instrument Serif',serif;
  font-size:20px;color:var(--ink);margin-bottom:6px;
}
.modal-logo span{color:var(--gold);}
.modal-title{font-size:18px;font-weight:700;color:var(--ink);margin-bottom:4px;letter-spacing:-.3px;}
.modal-sub{font-size:13px;color:var(--ink3);margin-bottom:24px;line-height:1.5;}
.modal-input{
  width:100%;padding:11px 14px;
  border:1.5px solid var(--line);border-radius:8px;
  font-family:'Geist',sans-serif;font-size:14px;color:var(--ink);
  background:var(--bg);
  outline:none;transition:border-color .15s;margin-bottom:10px;
}
.modal-input:focus{border-color:var(--ink);}
.modal-input::placeholder{color:var(--ink4);}
.modal-select{
  width:100%;padding:11px 14px;
  border:1.5px solid var(--line);border-radius:8px;
  font-family:'Geist',sans-serif;font-size:14px;color:var(--ink);
  background:var(--bg);outline:none;cursor:pointer;
  appearance:none;margin-bottom:10px;
  background-image:url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236b7280' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;
}
.modal-btn{
  width:100%;padding:12px;border:none;border-radius:8px;
  font-family:'Geist',sans-serif;font-size:14px;font-weight:700;
  cursor:pointer;transition:all .2s;margin-top:4px;
}
.modal-btn-dark{background:var(--ink);color:var(--white);}
.modal-btn-dark:hover{background:var(--ink2);transform:translateY(-1px);}
.modal-btn-gold{background:var(--gold);color:var(--ink);}
.modal-btn-gold:hover{background:#d4a843;transform:translateY(-1px);}
.modal-divider{
  display:flex;align-items:center;gap:10px;
  font-size:11px;color:var(--ink4);margin:14px 0;
}
.modal-divider::before,.modal-divider::after{content:'';flex:1;height:1px;background:var(--line);}
.google-btn{
  width:100%;padding:11px;border:1.5px solid var(--line);border-radius:8px;
  background:var(--white);font-family:'Geist',sans-serif;font-size:13px;font-weight:500;
  color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .15s;text-decoration:none;
}
.google-btn:hover{border-color:var(--ink3);background:var(--bg);}
.modal-footer{font-size:11px;color:var(--ink4);text-align:center;margin-top:16px;line-height:1.6;}
.modal-footer a{color:var(--ink);font-weight:500;text-decoration:underline;cursor:pointer;}
.plan-pill{
  display:inline-flex;align-items:center;gap:6px;
  padding:5px 12px;border-radius:20px;margin-bottom:18px;
  font-size:12px;font-weight:600;
}
.plan-pill.basico{background:var(--line2);color:var(--ink3);}
.plan-pill.pro{background:#fefce8;color:var(--gold);}
.plan-pill.enterprise{background:#ede9fe;color:#7c3aed;}
.modal-trial-note{
  background:var(--green-bg);border:1px solid #bbf7d0;
  border-radius:8px;padding:10px 14px;
  font-size:12px;color:var(--green);
  display:flex;align-items:center;gap:8px;
  margin-bottom:16px;font-weight:500;
}
.step-indicator{
  display:flex;align-items:center;gap:6px;
  margin-bottom:20px;
}
.step-dot{
  width:8px;height:8px;border-radius:50%;
  background:var(--line);transition:background .2s;
}
.step-dot.active{background:var(--ink);}
.step-dot.done{background:var(--green);}
.success-icon{
  width:56px;height:56px;border-radius:50%;
  background:var(--green-bg);border:2px solid #bbf7d0;
  display:flex;align-items:center;justify-content:center;
  font-size:24px;margin:0 auto 16px;
}

/* ══ DEMO VIDEO MODAL ══ */
.demo-box{max-width:720px;padding:0;overflow:hidden;background:var(--ink);}
.demo-header{
  display:flex;align-items:center;justify-content:space-between;
  padding:16px 20px;border-bottom:1px solid rgba(255,255,255,.08);
}
.demo-header-title{font-size:13px;font-weight:600;color:rgba(255,255,255,.7);}
.demo-close{
  background:rgba(255,255,255,.08);border:none;color:rgba(255,255,255,.5);
  width:28px;height:28px;border-radius:50%;cursor:pointer;font-size:14px;
  display:flex;align-items:center;justify-content:center;transition:background .15s;
}
.demo-close:hover{background:rgba(255,255,255,.15);}
.demo-content{padding:32px;text-align:center;}
.demo-steps{
  display:flex;flex-direction:column;gap:12px;
  margin:24px 0;text-align:left;
}
.demo-step-item{
  display:flex;gap:12px;align-items:flex-start;
  padding:14px;background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.07);border-radius:8px;
  cursor:pointer;transition:border-color .15s;
}
.demo-step-item:hover{border-color:rgba(196,154,42,.4);}
.demo-step-num{
  width:28px;height:28px;border-radius:50%;
  background:rgba(196,154,42,.15);border:1px solid rgba(196,154,42,.3);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--gold);flex-shrink:0;
  font-family:'Geist Mono',monospace;
}
.demo-step-body h4{font-size:13px;font-weight:600;color:rgba(255,255,255,.9);margin-bottom:3px;}
.demo-step-body p{font-size:11px;color:rgba(255,255,255,.4);line-height:1.5;}

/* ══ WHATSAPP / CONTACT ══ */
.wa-box{max-width:400px;}
.wa-options{display:flex;flex-direction:column;gap:10px;margin-top:16px;}
.wa-option{
  display:flex;align-items:center;gap:12px;
  padding:14px;border:1.5px solid var(--line);border-radius:9px;
  cursor:pointer;transition:all .18s;text-decoration:none;color:var(--ink);
}
.wa-option:hover{border-color:var(--green);background:var(--green-bg);}
.wa-opt-icon{font-size:20px;width:36px;text-align:center;}
.wa-opt-title{font-size:13px;font-weight:600;}
.wa-opt-sub{font-size:11px;color:var(--ink3);}

/* ══ TOAST ══ */
.toast{
  position:fixed;bottom:24px;right:24px;z-index:600;
  background:var(--ink);color:var(--white);
  padding:12px 18px;border-radius:9px;
  font-size:13px;font-weight:500;
  display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 24px rgba(13,14,17,.3);
  transform:translateY(80px);opacity:0;
  transition:all .3s cubic-bezier(.4,0,.2,1);
  max-width:320px;
}
.toast.show{transform:translateY(0);opacity:1;}
.toast-icon{font-size:16px;}

/* ══ PAGE SECTIONS ══ */
.page-section{display:none;}
.page-section.active{display:block;}


/* ══ PLAN EXPAND ══ */
.plan-expand-btn{
  font-size:11px;font-weight:600;color:var(--ink3);
  border:1px solid var(--line);border-radius:6px;
  padding:6px 12px;text-align:center;cursor:pointer;
  margin-top:12px;transition:all .18s;
  user-select:none;
}
.plan-expand-btn:hover{border-color:var(--gold);color:var(--gold);}
.plan-details{animation:fadeIn .25s ease;}
@keyframes fadeIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}


/* ══ DEMO MODAL ANIMATED ══ */
@keyframes demoPulse{0%,100%{opacity:1;box-shadow:0 0 8px rgba(212,168,67,.7)}50%{opacity:.5;box-shadow:0 0 3px rgba(212,168,67,.3)}}
@keyframes slideIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes pitchNum{from{opacity:0;transform:scale(.85)}to{opacity:1;transform:scale(1)}}
@keyframes fadeInScreen{from{opacity:0}to{opacity:1}}

.demo-nav-item{
  padding:8px 16px;font-size:11px;color:rgba(255,255,255,.35);
  cursor:pointer;border-left:2px solid transparent;
  transition:all .15s;user-select:none;
  font-family:'Geist',sans-serif;
}
.demo-nav-item:hover{color:rgba(255,255,255,.6);background:rgba(255,255,255,.03);}
.active-nav{
  color:#d4a843 !important;
  border-left-color:#d4a843 !important;
  background:rgba(212,168,67,.06) !important;
}

.demo-screen{
  position:absolute;inset:0;
  background:#0d1020;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease;
}
.active-screen{opacity:1 !important;pointer-events:auto !important;}

.demo-kpi{
  background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);
  border-radius:8px;padding:10px 12px;
}
.demo-kpi-l{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:#46506e;margin-bottom:5px;}
.demo-kpi-v{font-family:'Geist Mono',monospace;font-size:17px;font-weight:600;letter-spacing:-.3px;}

.demo-client-card{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.06);
  border-radius:8px;
  animation:slideIn .4s ease both;
}

.demo-field-label{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:#46506e;margin-bottom:3px;}
.demo-field-val{font-size:12px;color:#dde2f2;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);border-radius:6px;padding:6px 10px;font-family:'Geist Mono',monospace;}

.demo-cl-item{
  display:flex;align-items:center;gap:9px;
  padding:9px 11px;border-radius:7px;border:1px solid rgba(255,255,255,.07);
  animation:slideIn .4s ease both;
}
.done-item{border-color:rgba(52,211,153,.15);background:rgba(52,211,153,.03);}
.urg-item{border-left:2px solid #f87171;background:rgba(248,113,113,.03);}
.pend-item{border-left:2px solid #fbbf24;background:rgba(251,191,36,.02);}
.demo-cl-check{
  width:18px;height:18px;border-radius:4px;
  display:flex;align-items:center;justify-content:center;
  font-size:9px;font-weight:700;flex-shrink:0;
}
.done{background:rgba(52,211,153,.15);color:#34d399;border:1px solid rgba(52,211,153,.3);}
.urg{background:rgba(248,113,113,.15);color:#f87171;border:1px solid rgba(248,113,113,.3);}
.pend{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);}
.demo-cl-title{font-size:11px;font-weight:500;color:#dde2f2;margin-bottom:2px;}
.done-title{text-decoration:line-through;color:#46506e !important;}
.demo-cl-sub{font-size:9px;color:#46506e;}

.demo-dot{
  width:6px;height:6px;border-radius:50%;
  background:rgba(255,255,255,.2);cursor:pointer;
  transition:all .2s;
}
.active-dot{background:#d4a843;width:18px;border-radius:3px;}
