/* -------------
   Design Tokens
----------------*/
:root{
  --bg: #0b0c10;
  --bg-soft: #0f1117;
  --panel: rgba(255,255,255,.06);
  --card: rgba(255,255,255,.08);
  --border: rgba(255,255,255,.12);
  --ring: rgba(253,186,116,.45);
  --text: #e5e7eb;
  --muted: #a1a1aa;
  --accent: #f59e0b;      /* amber */
  --accent-2: #8b5cf6;    /* violet */
  --radius: 18px;
  --shadow: 0 10px 30px rgba(0,0,0,.35);
  --container: 1200px;
}

/* Base */
*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: 'Plus Jakarta Sans', ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: radial-gradient(1000px 600px at 20% -10%, rgba(139,92,246,.25), transparent 60%),
              radial-gradient(1200px 700px at 110% 10%, rgba(245,158,11,.2), transparent 60%),
              linear-gradient(180deg, #0b0c10 0%, #0f1117 100%);
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
p{line-height:1.7}
h1,h2,h3{line-height:1.15;margin:0 0 6px 0}
h1{font-size:clamp(32px, 6vw, 56px);letter-spacing:-.02em}
h2{font-size:clamp(22px, 4vw, 32px)}
h3{font-size:clamp(18px, 2.5vw, 22px)}
small,.small{font-size:.92rem}
.tiny{font-size:.82rem}
.muted{color:var(--muted)}
.mt-12{margin-top:12px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.p-24{padding:24px}

.container{max-width:var(--container);margin:0 auto;padding:0 24px}
.section{padding: clamp(56px, 10vw, 96px) 0; position:relative}
.section__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px;flex-wrap:wrap}

/* Visual sprinkles */
.grad{background: linear-gradient(90deg, var(--accent), var(--accent-2)); -webkit-background-clip:text; background-clip:text; color:transparent}
.eyebrow{font-size:.9rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}
.eyebrow.orange{color:#fbbf24}
.pill{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);background:rgba(255,255,255,.06);backdrop-filter:blur(8px);border-radius:999px;padding:6px 12px;font-weight:600}

/* Cards & Buttons */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow)}
.btn{display:inline-flex;align-items:center;gap:10px;background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#111;padding:12px 16px;border-radius:14px;font-weight:700;border:1px solid transparent;transition:transform .15s ease, filter .15s ease}
.btn:hover{transform:translateY(-1px);filter:saturate(1.1)}
.btn--ghost{background:transparent;color:var(--text);border-color:var(--border)}
.btn--ghost:hover{background:rgba(255,255,255,.06)}
.btn--small{padding:8px 12px;border-radius:12px;font-weight:600}
.btn--xl{font-size:1.05rem;padding:14px 20px;border-radius:16px}
.icon{transform:translateY(1px)}

/* Grid helpers */
.grid{display:grid;gap:24px}
.grid-2{grid-template-columns:1fr 1fr}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-contact{grid-template-columns: 1.1fr 1fr}
@media (max-width: 980px){.grid-3,.grid-2,.grid-contact{grid-template-columns:1fr}}

/* NAV */
.nav{position:sticky;top:0;z-index:60;background:rgba(15,17,23,.6);backdrop-filter: blur(10px);border-bottom:1px solid var(--border)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:10px;font-weight:800}
.brand__logo{width:36px;height:36px;border-radius:12px;background:linear-gradient(180deg, #111, #1b1b1b);display:grid;place-items:center;color:#fff;border:1px solid rgba(255,255,255,.12);box-shadow:0 4px 14px rgba(0,0,0,.4)}
.menu{display:flex;gap:24px;align-items:center}
.menu a{opacity:.9} .menu a:hover{opacity:.7}
.burger{display:none;gap:6px;flex-direction:column;background:transparent;border:0}
.burger span{width:22px;height:2px;background:#fff;border-radius:2px}
.nav__cta{display:flex;gap:10px;align-items:center}
.hide-sm{display:flex}
.hide-lg{display:none}
@media (max-width: 860px){
  .burger{display:flex}
  .menu{position:fixed;inset:64px 16px auto 16px;background:var(--bg-soft);border:1px solid var(--border);border-radius:14px;padding:14px;display:none;flex-direction:column;gap:12px}
  .menu.is-open{display:flex}
  .hide-sm{display:none}
  .hide-lg{display:inline-flex}
}

/* HERO */
.hero__grid{display:grid;grid-template-columns:1.1fr 1fr;gap:32px;align-items:center}
.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:16px}
.kpis{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:18px}
.kpi{padding:18px;text-align:center}
.kpi__v{font-weight:800;font-size:clamp(26px,4vw,36px)}
.kpi__k{font-size:.85rem;color:var(--muted)}
.video{aspect-ratio:16/9;display:grid;place-items:center;background:linear-gradient(180deg,#0e1117,#0f172a);border-radius:14px;overflow:hidden;border:1px solid var(--border)}
.video__btn{position:relative;border:0;background:#fff;color:#111;border-radius:999px;padding:10px 14px;font-weight:700;cursor:pointer}
.tilt{transition:transform .2s ease;transform-style:preserve-3d;will-change:transform}

/* Marquee */
.marquee{position:relative;overflow:hidden;width:100vw;margin-left:calc(-50vw + 50%);margin-top:28px}
.marquee__track{display:flex;gap:48px;white-space:nowrap;animation:marq 22s linear infinite;padding:12px 8vw;color:#cbd5e1;letter-spacing:.35em;font-size:.9rem;min-width:200%}
.marquee__fade{position:absolute;top:0;bottom:0;width:10vw;pointer-events:none;z-index:2}
.marquee__fade.left{left:0;background:linear-gradient(90deg, rgba(15,17,23,1), rgba(15,17,23,0))}
.marquee__fade.right{right:0;background:linear-gradient(270deg, rgba(15,17,23,1), rgba(15,17,23,0))}
@keyframes marq{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Testimonials */
.testimonials{padding:24px}
.testi__viewport{overflow:hidden}
.testi__track{display:flex;transition:transform .5s ease}
.testi{min-width:100%}
.stars{color:#fbbf24}
.quote{margin:8px 0 6px 0}
.who{color:var(--muted);font-size:.95rem}
.dots{display:flex;gap:8px;margin-top:14px;justify-content:center}
.dot{width:28px;height:8px;border-radius:999px;background:rgba(255,255,255,.15);border:0;cursor:pointer}
.dot.is-active{background:#fff}

/* Pricing */
.plan{padding:24px}
.plan__row{display:flex;align-items:baseline;justify-content:space-between}
.price{font-weight:800;font-size:clamp(20px,3vw,28px)}
.plan--featured{outline:2px solid var(--accent);background:linear-gradient(180deg, rgba(245,158,11,.08), transparent), var(--card)}

/* CTA */
.cta{position:relative;text-align:center;padding:36px;overflow:hidden}
.cta__blob{position:absolute;right:-60px;top:-60px;width:180px;height:180px;background:rgba(245,158,11,.4);filter:blur(50px);border-radius:50%;animation:pulse 6s infinite}
@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.1)}100%{transform:scale(1)}}

/* FAQ */
.faq{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:14px}
.faq summary{cursor:pointer;font-weight:700;list-style:none}
.faq summary::-webkit-details-marker{display:none}
.faq[open]{background:rgba(255,255,255,.1)}

/* Contact */
.contact{display:flex;flex-direction:column;gap:10px;margin-top:16px}
.contact a{display:inline-flex;align-items:center;gap:8px}
#contact-form input, #contact-form textarea{width:100%;border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:.95rem;background:rgba(255,255,255,.04);color:var(--text)}
#contact-form textarea{height:120px;resize:vertical}
.success{color:#22c55e;margin-top:8px}

/* Footer & float CTA */
.footer{border-top:1px solid var(--border);padding:40px 0;margin-top:24px;background:rgba(0,0,0,.2)}
.footer__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;font-size:.95rem;color:#c3c3c9;flex-wrap:wrap}
.footer__left{display:flex;align-items:center;gap:8px}
.footer__links{display:flex;gap:18px}
.float-cta{position:fixed;right:18px;bottom:18px;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(90deg,var(--accent),var(--accent-2));color:#111;border-radius:999px;padding:12px 16px;font-weight:800;box-shadow:var(--shadow);transition:transform .15s ease}
.float-cta:hover{transform:translateY(-2px)}

/* Decorations */
.decor{position:fixed;pointer-events:none;z-index:-1;filter:blur(60px);border-radius:50%}
.decor--a{right:-120px;top:-120px;width:320px;height:320px;background:rgba(245,158,11,.35)}
.decor--b{left:-120px;top:160px;width:320px;height:320px;background:rgba(139,92,246,.35)}
.gridlines{position:fixed;inset:0;z-index:-2;background:
  linear-gradient(transparent 39px, rgba(255,255,255,.04) 40px) repeat-y,
  linear-gradient(90deg, transparent 39px, rgba(255,255,255,.04) 40px) repeat-x;
  background-size: 40px 40px, 40px 40px;
  mask-image: radial-gradient(70% 70% at 50% 20%, black, transparent 70%);
}

/* Progress */
.progress{position:fixed;top:0;left:0;right:0;height:3px;background:rgba(255,255,255,.06);z-index:80}
.progress__bar{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--accent),var(--accent-2))}

/* Reveal animations */
.reveal{opacity:0;transform:translateY(10px);transition:opacity .6s ease, transform .6s ease}
.reveal.is-visible{opacity:1;transform:translateY(0)}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  .marquee__track{animation:none}
  .tilt,.reveal{transition:none}
}


/* Contact form layout improvements */
#contact-form{display:grid;gap:16px}
#contact-form .row-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:700px){#contact-form .row-2{grid-template-columns:1fr}}
#contact-form button.btn{justify-self:start}


/* --- Contact form layout fixes --- */
#contact-form .grid{grid-template-columns:1fr 1fr; align-items:start}
#contact-form textarea{grid-column:1 / -1}
#contact-form .btn{justify-self:end}
@media (max-width: 700px){
  #contact-form .grid{grid-template-columns:1fr}
  #contact-form .btn{justify-self:stretch}
}

/* make the contact card slightly more opaque to avoid background bleed-through */
#contacto .card{background:rgba(255,255,255,.10);backdrop-filter: blur(8px)}

