﻿:root{
  --m-blue:#205679;
  --m-blue-strong:#2b74ff;
  --m-cyan:#22d3ee;
  --m-ink:#1D1D1B;
  --m-white:#ffffff;
}

body{
  font-family:'Inter',sans-serif;
  background:
    radial-gradient(1000px 500px at 15% 10%, rgba(43,116,255,.18), transparent 55%),
    radial-gradient(900px 500px at 85% 12%, rgba(34,211,238,.18), transparent 55%),
    radial-gradient(circle at top middle, #ffffff 0%, #f7f9fc 45%, #eef4fb 100%);
  color:var(--m-ink);
}

body.lang-es [data-lang="en"]{ display:none !important; }
body.lang-en [data-lang="es"]{ display:none !important; }
body.lang-es [data-lang="es"]{ display:inline; }
body.lang-en [data-lang="en"]{ display:inline; }
body.lang-es :where(h1,h2,h3,h4,p,div,article,section,header,main,footer,ul,ol,li)[data-lang="es"]{ display:block !important; }
body.lang-en :where(h1,h2,h3,h4,p,div,article,section,header,main,footer,ul,ol,li)[data-lang="en"]{ display:block !important; }

.glass-panel{
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 22px 60px rgba(0,0,0,.08);
}

.hero-text-gradient{
  background:linear-gradient(90deg,var(--m-blue-strong) 0%,var(--m-cyan) 60%,var(--m-blue) 100%);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.typewriter-word{
  display:inline-block;
  min-width:0;
  transition:color .2s ease, text-shadow .2s ease;
}
.typewriter-line{
  display:block;
  margin-top:.12em;
}
.hero-two-lines{ display:block; }
.hero-line-1,
.hero-line-2{ display:block; }
.hero-line-2{ margin-top:.16em; }
.typewriter-word--proforma{
  color:#205679;
  text-shadow:0 8px 20px rgba(32,86,121,.2);
}
.typewriter-word--factura{
  color:#16a34a;
  text-shadow:0 8px 20px rgba(22,163,74,.24);
}
.typewriter-word--invoice{
  color:#16a34a;
  text-shadow:0 8px 20px rgba(22,163,74,.24);
}
.typewriter-word--orden{
  color:#f97316;
  text-shadow:0 8px 20px rgba(249,115,22,.24);
}
.typewriter-word--purchase{
  color:#f97316;
  text-shadow:0 8px 20px rgba(249,115,22,.24);
}
.typewriter-cursor{
  display:inline-block;
  width:2px;
  height:1em;
  margin-left:4px;
  background:#205679;
  vertical-align:-2px;
  animation:caretBlink .9s step-end infinite;
}
@keyframes caretBlink{
  0%,49%{ opacity:1; }
  50%,100%{ opacity:0; }
}

.btn-primary{
  background:linear-gradient(135deg,var(--m-blue-strong) 0%,var(--m-cyan) 100%);
  color:white;
  box-shadow:0 14px 30px rgba(43,116,255,.25);
  transition:transform .18s ease,box-shadow .18s ease,filter .18s ease;
}
.btn-primary:hover{
  transform:translateY(-1px);
  filter:saturate(1.05);
  box-shadow:0 18px 38px rgba(43,116,255,.30);
}

.btn-ghost{
  background:rgba(255,255,255,.65);
  border:1px solid rgba(15,23,42,.12);
  transition:transform .18s ease,background .18s ease;
}
.btn-ghost:hover{ transform:translateY(-1px); background:rgba(255,255,255,.9); }

.pill{ border:1px solid rgba(15,23,42,.10); background:rgba(255,255,255,.75); }
.format-strip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:8px 12px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.1);
  background:rgba(255,255,255,.78);
  box-shadow:0 12px 28px rgba(11,18,32,.08);
  margin-bottom:2.8rem;
}
.format-label{
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#334155;
}
.format-pill{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:5px 9px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.1);
  background:#fff;
  font-size:11px;
  font-weight:700;
  color:#1f2937;
}
.format-icon{
  width:14px;
  height:14px;
  border-radius:4px;
  display:inline-block;
}
.format-icon--pdf{ background:linear-gradient(135deg,#ef4444,#f97316); }
.format-icon--xlsx{ background:linear-gradient(135deg,#10b981,#22c55e); }
.format-icon--csv{ background:linear-gradient(135deg,#3b82f6,#06b6d4); }
.cta-gradient{ background:linear-gradient(135deg,#071022 0%,#0b1a33 45%,#0a2740 100%); box-shadow:0 30px 90px rgba(11,18,32,.18); }
.soft-ring{ background:radial-gradient(circle at 30% 30%, rgba(43,116,255,.22), transparent 55%),radial-gradient(circle at 70% 70%, rgba(34,211,238,.18), transparent 55%); }
.google-mark{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:20px;
  height:20px;
}
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); border:0; }
.hidden{ display:none; }

.conversion-module{
  margin:0 auto 3.1rem;
  max-width:940px;
  border-radius:28px;
  border:1px solid rgba(255,255,255,.65);
  background:rgba(255,255,255,.78);
  backdrop-filter:blur(14px);
  box-shadow:0 30px 90px rgba(11,18,32,.12);
  padding:1rem;
  text-align:left;
}

.step-header{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  margin-bottom:10px;
}
.step-chip{
  font-size:12px;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#205679;
  background:rgba(32,86,121,.1);
  border:1px solid rgba(32,86,121,.2);
  border-radius:999px;
  padding:6px 10px;
}
.step-dots{ display:flex; gap:8px; }
.step-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:rgba(31,79,111,.25);
  transition:all .25s ease;
}
.step-dot.active{
  background:#205679;
  box-shadow:0 0 0 5px rgba(32,86,121,.12);
}

.step-card{
  border:1px solid rgba(15,23,42,.08);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,255,255,.82));
  padding:1rem;
  transition:opacity .3s ease, transform .3s ease;
}

.conversion-title{
  margin:0 0 .35rem;
  font-size:clamp(1.25rem,2.1vw,1.9rem);
  font-weight:800;
  letter-spacing:-.01em;
  color:#1D1D1B;
}
.conversion-subtitle{
  margin:0 0 .8rem;
  color:#475569;
  line-height:1.5;
}

.dropzone{
  border-radius:16px;
  border:1px dashed rgba(29,29,27,.22);
  background:linear-gradient(180deg, rgba(255,255,255,.92), rgba(255,255,255,.7));
  padding:1rem;
  cursor:pointer;
  transition:border-color .2s ease, box-shadow .2s ease, transform .2s ease;
}
.dropzone:hover{ transform:translateY(-1px); }
.dropzone.is-dragover{
  border-color:rgba(32,86,121,.55);
  box-shadow:0 24px 60px rgba(43,116,255,.2);
}

.dropzone-illustration{ display:flex; gap:10px; margin-bottom:10px; }
.file-logo{
  width:44px;
  height:52px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.14);
  background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(241,245,249,.95));
  box-shadow:0 10px 24px rgba(11,18,32,.08);
  display:flex;
  align-items:flex-end;
  justify-content:center;
  padding:6px;
  position:relative;
}
.file-logo::before{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:13px;
  height:13px;
  border-top-right-radius:12px;
  border-bottom-left-radius:7px;
  background:rgba(148,163,184,.22);
}
.file-logo-badge{
  width:100%;
  text-align:center;
  font-size:9px;
  line-height:1;
  font-weight:800;
  letter-spacing:.06em;
  padding:4px 2px;
  border-radius:7px;
  color:#fff;
}
.file-logo--pdf .file-logo-badge{ background:linear-gradient(135deg,#ef4444,#f97316); }
.file-logo--xlsx .file-logo-badge{ background:linear-gradient(135deg,#16a34a,#22c55e); }
.file-logo--csv .file-logo-badge{ background:linear-gradient(135deg,#2563eb,#06b6d4); }

.drop-title{ margin:0 0 5px; font-weight:700; color:#111827; }
.drop-hint{ margin:0 0 10px; font-size:12px; color:#64748b; }
.plan-teaser{
  margin:0 0 10px;
  font-size:13px;
  color:#205679;
  font-weight:600;
}
.drop-actions{ display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.upload-btn{ border:none; border-radius:12px; padding:12px 14px; font-weight:700; text-align:center; display:inline-flex; justify-content:center; align-items:center; }
.upload-status{ margin-top:10px; font-size:13px; color:#334155; min-height:20px; }

.progress{
  height:8px;
  margin-top:8px;
  border-radius:999px;
  overflow:hidden;
  border:1px solid rgba(15,23,42,.1);
  background:rgba(255,255,255,.75);
}
.progress span{
  display:block;
  width:0;
  height:100%;
  background:linear-gradient(90deg,var(--m-blue-strong),var(--m-cyan));
  transition:width .25s linear;
}

.mini-preview{
  margin-top:12px;
  border:1px solid rgba(15,23,42,.1);
  border-radius:14px;
  overflow:hidden;
  background:rgba(255,255,255,.88);
}
.mini-row{
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  font-size:13px;
  padding:9px 10px;
  border-top:1px solid rgba(15,23,42,.08);
}
.mini-head{ border-top:0; font-weight:700; background:rgba(43,116,255,.08); }

.btn-google{
  width:100%;
  display:flex;
  justify-content:center;
  align-items:center;
  gap:10px;
  border:1px solid rgba(15,23,42,.12);
  border-radius:12px;
  background:#fff;
  padding:12px;
  font-weight:700;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.btn-google:hover{
  transform:translateY(-1px);
  border-color:rgba(32,86,121,.28);
  box-shadow:0 12px 26px rgba(32,86,121,.14);
}
.auth-sep{
  display:flex;
  align-items:center;
  justify-content:center;
  color:#64748b;
  margin:10px 0;
}
.email-form{ display:grid; gap:10px; }
.email-form input{
  width:100%;
  border:1px solid rgba(15,23,42,.12);
  border-radius:12px;
  padding:11px 12px;
}
.forgot-password-link{
  justify-self:start;
  border:0;
  background:transparent;
  color:#205679;
  font-size:13px;
  font-weight:600;
  padding:0;
  cursor:pointer;
  text-decoration:underline;
  text-underline-offset:3px;
}
.auth-error{
  color:#b91c1c;
  font-size:13px;
  text-align:left;
}
.auth-error.is-success{
  color:#166534;
}

.plan-grid{
  margin:10px 0;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.plan-card{
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.88);
  border-radius:14px;
  padding:10px;
  cursor:pointer;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.plan-card:hover{ transform:translateY(-2px); box-shadow:0 12px 30px rgba(11,18,32,.12); }
.plan-card.selected{
  border-color:rgba(32,86,121,.45);
  box-shadow:0 0 0 4px rgba(32,86,121,.12);
}
.plan-card h4{ margin:0; font-size:16px; }
.plan-price{ margin:2px 0 8px; font-weight:700; color:#205679; }
.plan-card ul{ margin:0; padding-left:18px; font-size:12px; color:#475569; }

.flow-section{
  max-width:980px;
  margin:3rem auto 5rem;
  text-align:left;
}
.flow-head h2{
  margin:0;
  font-size:clamp(32px,4vw,46px);
  line-height:1.05;
  letter-spacing:-.02em;
  font-weight:800;
  color:#1D1D1B;
}
.flow-head p{
  margin:.6rem 0 0;
  color:#475569;
  font-size:18px;
}
.flow-grid{
  margin-top:1.2rem;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
  position:relative;
}
.flow-grid::before{
  content:"";
  position:absolute;
  left:8%;
  right:8%;
  top:32px;
  height:2px;
  background:linear-gradient(90deg,rgba(32,86,121,.25),rgba(34,211,238,.3),rgba(32,86,121,.25));
  z-index:0;
}
.flow-card{
  position:relative;
  z-index:1;
  border:1px solid rgba(15,23,42,.1);
  border-radius:22px;
  background:linear-gradient(140deg, rgba(255,255,255,.92), rgba(242,248,255,.84));
  box-shadow:0 16px 46px rgba(11,18,32,.08);
  padding:1rem;
  transition:transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.flow-card:hover{
  transform:translateY(-2px);
  border-color:rgba(32,86,121,.28);
  box-shadow:0 20px 52px rgba(11,18,32,.12);
}
.flow-index{
  width:36px;
  height:36px;
  border-radius:11px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
  font-size:14px;
  color:#205679;
  background:rgba(32,86,121,.12);
  border:1px solid rgba(32,86,121,.18);
  margin-bottom:.7rem;
}
.flow-card h3{
  margin:0;
  font-size:22px;
  font-weight:700;
  color:#1f2937;
}
.flow-card p{
  margin:.45rem 0 0;
  color:#475569;
  line-height:1.6;
  font-size:15px;
}
.flow-illu{
  margin-top:12px;
  border:1px solid rgba(15,23,42,.1);
  border-radius:16px;
  background:linear-gradient(145deg, rgba(210,228,247,.45), rgba(198,236,242,.45));
  padding:10px;
}
.flow-illu--upload{
  background:linear-gradient(145deg, rgba(198,220,248,.5), rgba(198,236,242,.5));
}
.flow-file-row{
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:#475569;
}
.flow-status{
  border:1px solid rgba(15,23,42,.1);
  background:rgba(255,255,255,.75);
  border-radius:999px;
  padding:4px 8px;
  font-weight:600;
  white-space:nowrap;
}
.flow-progress{
  margin-top:10px;
  height:8px;
  border-radius:999px;
  background:rgba(255,255,255,.75);
  border:1px solid rgba(15,23,42,.1);
  overflow:hidden;
}
.flow-progress-bar{
  display:block;
  height:100%;
  width:0;
  background:linear-gradient(90deg,#3b82f6,#22d3ee);
  animation:importFill 2.2s ease-in-out infinite;
}
.flow-chip-row{
  display:flex;
  align-items:center;
  gap:8px;
  flex-wrap:wrap;
}
.flow-chip{
  font-size:12px;
  border:1px solid rgba(15,23,42,.1);
  background:rgba(255,255,255,.82);
  border-radius:999px;
  padding:4px 9px;
  color:#475569;
  font-weight:600;
}
.flow-mini-table{
  margin-top:8px;
  display:grid;
  gap:6px;
}
.flow-mini-row{
  display:grid;
  grid-template-columns:1fr auto auto;
  align-items:center;
  gap:8px;
  border:1px solid rgba(15,23,42,.1);
  background:rgba(255,255,255,.85);
  border-radius:12px;
  padding:7px 10px;
  color:#334155;
}
.flow-green{ color:#059669; font-weight:700; }
.flow-blue{ color:#2563eb; font-weight:700; }
.flow-note{
  margin:8px 0 0;
  font-size:12px;
  color:#64748b;
}
.flow-proof{
  margin:1rem 0 0;
  color:#205679;
  font-weight:600;
  font-size:14px;
}
.capabilities-block{
  margin-top:2.1rem;
  border:none;
  border-radius:0;
  padding:8px 0 0;
  background:transparent;
  box-shadow:none;
}
.capabilities-head{
  text-align:center;
}
.capabilities-head h3{
  margin:0;
  font-size:clamp(30px,3.4vw,44px);
  line-height:1.08;
  letter-spacing:-.02em;
  font-weight:800;
  color:#1f2937;
}
.capabilities-head p{
  margin:10px auto 0;
  max-width:68ch;
  font-size:17px;
  line-height:1.55;
  color:#475569;
}
.cap-chip-row{
  margin:14px 0 0;
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center;
}
.cap-grid{
  margin-top:14px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:12px;
}
.cap-grid--lite{
  margin-top:10px;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:18px 22px;
}
.cap-grid--lite .cap-item{
  grid-column:span 2;
}
.cap-grid--lite .cap-item:nth-child(4){
  grid-column:2 / span 2;
}
.cap-grid--lite .cap-item:nth-child(5){
  grid-column:4 / span 2;
}
.cap-card{
  border:1px solid rgba(15,23,42,.1);
  border-radius:18px;
  padding:14px 12px;
  background:linear-gradient(145deg, rgba(255,255,255,.96), rgba(242,248,255,.9));
  text-align:center;
  box-shadow:0 12px 26px rgba(11,18,32,.06);
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.cap-item{
  text-align:center;
  padding:4px 8px;
}
.cap-item-icon{
  width:36px;
  height:36px;
  margin:0 auto 10px;
  border-radius:11px;
  border:1px solid rgba(15,23,42,.1);
  background:rgba(255,255,255,.72);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#205679;
  font-weight:800;
  font-size:16px;
}
.cap-item h4{
  margin:0;
  font-size:20px;
  line-height:1.15;
  letter-spacing:-.01em;
  font-weight:800;
  color:#1f2937;
}
.cap-item p{
  margin:8px auto 0;
  max-width:32ch;
  font-size:15px;
  line-height:1.6;
  color:#64748b;
}
.cap-card:hover{
  transform:translateY(-2px);
  border-color:rgba(32,86,121,.25);
  box-shadow:0 16px 30px rgba(11,18,32,.10);
}
.cap-icon{
  width:42px;
  height:42px;
  margin:0 auto 10px;
  border-radius:12px;
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.86);
  display:flex;
  align-items:center;
  justify-content:center;
  color:#205679;
  font-weight:800;
  font-size:18px;
}
.cap-card h4{
  margin:0;
  font-size:21px;
  line-height:1.1;
  letter-spacing:-.01em;
  font-weight:800;
  color:#1f2937;
}
.cap-card p{
  margin:8px 0 0;
  font-size:15px;
  line-height:1.55;
  color:#475569;
}

.impact-section{
  max-width:980px;
  margin:3.1rem auto 3rem;
}
.metrics-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:30px;
}
.metric-card{
  border:none;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  padding:0;
  text-align:center;
}
.metric-value{
  margin:0;
  font-weight:800;
  color:#205679;
  font-size:46px;
  line-height:1;
}
.metric-counter{
  display:inline-block;
  min-width:120px;
  text-shadow:0 6px 18px rgba(43,116,255,.18);
}
.metric-counter--error{
  color:#ef4444;
  text-shadow:0 8px 22px rgba(239,68,68,.28);
}
.metric-counter--ok{
  color:#205679;
  text-shadow:0 8px 22px rgba(43,116,255,.28);
}
.metric-counter--masked{
  filter:blur(3.5px);
  opacity:.85;
  letter-spacing:.08em;
}
.metric-label{
  margin:.6rem auto 0;
  max-width:32ch;
  color:#475569;
  font-size:16px;
  line-height:1.55;
}

.before-after{
  margin-top:2.2rem;
  border:1px solid rgba(15,23,42,.1);
  border-radius:22px;
  background:linear-gradient(145deg, rgba(255,255,255,.9), rgba(243,249,255,.86));
  box-shadow:0 18px 52px rgba(11,18,32,.09);
  padding:16px;
  text-align:left;
}
.before-after h3{
  margin:0 0 10px;
  font-size:24px;
  font-weight:800;
  letter-spacing:-.01em;
  color:#1f2937;
}
.mascot-story{
  margin:0 0 12px;
  border:1px solid rgba(15,23,42,.1);
  border-radius:20px;
  background:linear-gradient(145deg, rgba(255,255,255,.95), rgba(240,248,255,.88));
  padding:16px;
  display:grid;
  grid-template-columns:220px 1fr;
  gap:16px;
  align-items:center;
  position:relative;
  overflow:hidden;
}
.mascot-story::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    radial-gradient(480px 220px at 0% 50%, rgba(239,68,68,.10), transparent 65%),
    radial-gradient(520px 240px at 100% 50%, rgba(32,86,121,.14), transparent 65%);
  pointer-events:none;
}
.mascot-stage{
  position:relative;
  z-index:1;
  margin:0 auto;
  width:190px;
  height:190px;
  border-radius:20px;
  background:linear-gradient(160deg, rgba(255,255,255,.96), rgba(237,244,252,.95));
  border:1px solid rgba(15,23,42,.08);
  box-shadow:0 18px 42px rgba(15,23,42,.12);
  overflow:hidden;
}
.mascot-stage::after{
  content:"";
  position:absolute;
  inset:auto 14px 10px;
  height:14px;
  border-radius:999px;
  background:radial-gradient(circle, rgba(15,23,42,.16), rgba(15,23,42,0) 72%);
  pointer-events:none;
}
.mascot{
  position:absolute;
  inset:0;
  opacity:0;
  transform:translateY(4px) scale(.96);
  transition:opacity .38s ease, transform .38s ease, filter .38s ease;
  filter:saturate(.88);
}
.mascot.is-visible{
  opacity:1;
  transform:translateY(0) scale(1);
  filter:saturate(1.04);
}
.mascot img{
  width:100%;
  height:100%;
  object-fit:contain;
}
.mascot--fallback{
  display:flex;
  align-items:center;
  justify-content:center;
  background:linear-gradient(145deg, rgba(248,250,252,.95), rgba(226,232,240,.9));
}
.mascot--fallback img{
  display:none;
}
.mascot--fallback::after{
  content:"📦";
  font-size:42px;
  line-height:1;
  filter:drop-shadow(0 8px 14px rgba(15,23,42,.15));
}
.mascot-copy{
  text-align:left;
  position:relative;
  z-index:1;
  display:grid;
  gap:8px;
}
.mascot-state{
  margin:0;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#475569;
}
.mascot-kpi{
  margin:0;
  font-size:clamp(34px, 4.4vw, 58px);
  line-height:1;
  font-weight:900;
  letter-spacing:-.01em;
  transition:color .25s ease, text-shadow .25s ease, transform .25s ease;
}
.mascot-kpi--bad{
  color:#dc2626;
  text-shadow:0 10px 28px rgba(220,38,38,.24);
  transform:translateY(0);
}
.mascot-kpi--good{
  color:#205679;
  text-shadow:0 10px 28px rgba(43,116,255,.24);
  transform:translateY(-1px);
}
.mascot-kpi--pulse{
  animation:mascotKpiPulse .34s ease-out;
}
.mascot-note{
  margin:0;
  color:#475569;
  font-size:17px;
  line-height:1.45;
  max-width:46ch;
}
.ba-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:10px;
}
.ba-col{
  border:1px solid rgba(15,23,42,.1);
  border-radius:14px;
  background:#fff;
  padding:10px 12px;
}
.ba-col--before{
  background:rgba(255,255,255,.9);
}
.ba-col--after{
  background:rgba(236,253,245,.7);
  border-color:rgba(16,185,129,.25);
}
.ba-title{
  margin:0 0 8px;
  font-size:13px;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-weight:800;
  color:#334155;
}
.ba-col ul{
  margin:0;
  padding-left:18px;
  color:#475569;
  line-height:1.6;
  font-size:14px;
}

.integration-strip{
  margin-top:12px;
  display:flex;
  align-items:center;
  flex-wrap:wrap;
  gap:8px;
  border:1px solid rgba(15,23,42,.1);
  border-radius:999px;
  background:rgba(255,255,255,.82);
  box-shadow:0 10px 24px rgba(11,18,32,.07);
  padding:8px 10px;
}
.integration-strip--highlight{
  margin-top:16px;
  background:linear-gradient(145deg, rgba(255,255,255,.92), rgba(238,247,255,.86));
  border-color:rgba(32,86,121,.16);
  box-shadow:0 14px 32px rgba(32,86,121,.10);
}
.integration-subcopy{
  margin:10px 4px 0;
  color:#475569;
  font-size:14px;
  font-weight:600;
}
.integration-title{
  font-size:11px;
  font-weight:800;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:#334155;
  padding:0 2px;
}
.integration-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:5px 10px;
  border-radius:999px;
  border:1px solid rgba(15,23,42,.1);
  background:#fff;
  font-size:12px;
  font-weight:700;
  color:#1f2937;
}
.integration-benefits{
  margin-top:10px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:10px;
}
.integration-benefit{
  border:1px solid rgba(15,23,42,.1);
  border-radius:14px;
  background:linear-gradient(145deg, rgba(255,255,255,.92), rgba(241,248,255,.88));
  box-shadow:0 12px 28px rgba(11,18,32,.07);
  padding:10px 12px;
  display:flex;
  gap:8px;
  align-items:flex-start;
}
.integration-benefit-dot{
  width:8px;
  height:8px;
  margin-top:6px;
  border-radius:999px;
  background:#22c55e;
  box-shadow:0 0 0 6px rgba(34,197,94,.12);
  flex:0 0 auto;
}
.integration-benefit p{
  margin:0;
  color:#334155;
  font-size:13px;
  line-height:1.45;
  font-weight:600;
}

.activity-section{
  max-width:980px;
  margin:3rem auto 2.2rem;
}
.cta-block{
  margin-top:2.4rem;
  margin-bottom:3rem !important;
}
.faq-section{
  max-width:980px;
  margin:3rem auto 2.6rem;
  text-align:left;
}
.faq-head h2{
  margin:0;
  font-size:clamp(28px, 3.4vw, 40px);
  line-height:1.1;
  letter-spacing:-.02em;
  color:#1f2937;
  font-weight:800;
}
.faq-list{
  margin-top:14px;
  display:grid;
  gap:10px;
}
.faq-item{
  border:1px solid rgba(15,23,42,.1);
  border-radius:16px;
  background:linear-gradient(145deg, rgba(255,255,255,.92), rgba(241,248,255,.88));
  box-shadow:0 12px 26px rgba(11,18,32,.06);
  padding:0;
  overflow:hidden;
}
.faq-question{
  list-style:none;
  cursor:pointer;
  padding:13px 14px;
  font-size:18px;
  font-weight:700;
  color:#1f2937;
}
.faq-question::-webkit-details-marker{
  display:none;
}
.faq-answer{
  margin:0;
  padding:0 14px 14px;
  color:#475569;
  font-size:15px;
  line-height:1.6;
}
.activity-shell{
  border:1px solid rgba(15,23,42,.1);
  border-radius:20px;
  background:linear-gradient(145deg, rgba(255,255,255,.92), rgba(235,247,255,.84));
  box-shadow:0 16px 44px rgba(11,18,32,.08);
  padding:12px;
  overflow:hidden;
  position:relative;
}
.activity-shell::before{
  content:"";
  position:absolute;
  inset:-40% -10% auto -10%;
  height:140px;
  background:radial-gradient(circle at 30% 50%, rgba(43,116,255,.16), transparent 60%);
  pointer-events:none;
}
.activity-title-row{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom:10px;
  position:relative;
  z-index:1;
}
.activity-title-row h3{
  margin:0;
  font-size:20px;
  font-weight:800;
  letter-spacing:-.01em;
  color:#1f2937;
}
.activity-live{
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.9);
  border-radius:999px;
  padding:5px 9px;
  font-size:11px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
  color:#334155;
}
.activity-live-dot{
  width:8px;
  height:8px;
  border-radius:999px;
  background:#22c55e;
  box-shadow:0 0 0 0 rgba(34,197,94,.35);
  animation:livePulse 1.8s ease-in-out infinite;
}
.activity-lane{
  display:flex;
  align-items:center;
  gap:10px;
  width:max-content;
  animation:laneScroll 22s linear infinite;
  position:relative;
  z-index:1;
}
.activity-item{
  border:1px solid rgba(15,23,42,.12);
  background:rgba(255,255,255,.94);
  border-radius:999px;
  padding:7px 12px;
  font-size:12px;
  font-weight:700;
  color:#1f2937;
  white-space:nowrap;
  box-shadow:0 8px 22px rgba(11,18,32,.06);
}

@keyframes laneScroll{
  0%{ transform:translateX(0); }
  100%{ transform:translateX(-50%); }
}
@keyframes importFill{
  0%{ width:0%; }
  70%{ width:86%; }
  100%{ width:100%; }
}
@keyframes livePulse{
  0%{ box-shadow:0 0 0 0 rgba(34,197,94,.35); }
  70%{ box-shadow:0 0 0 8px rgba(34,197,94,0); }
  100%{ box-shadow:0 0 0 0 rgba(34,197,94,0); }
}
@keyframes mascotKpiPulse{
  0%{ transform:scale(.97); }
  100%{ transform:scale(1); }
}
.waitlist-wrap{
  margin-top:1rem;
}

.reveal{
  opacity:0;
  transform:translateY(16px);
  transition:opacity .6s ease, transform .6s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

@media (max-width: 900px){
  .plan-grid{ grid-template-columns:1fr; }
  .flow-grid{
    grid-template-columns:1fr;
  }
  .flow-grid::before{
    display:none;
  }
  .metrics-grid{
    grid-template-columns:1fr;
  }
  .ba-grid{
    grid-template-columns:1fr;
  }
  .mascot-story{
    grid-template-columns:1fr;
    text-align:center;
  }
  .mascot-stage{
    width:100%;
    max-width:190px;
  }
  .mascot-copy{
    text-align:center;
  }
  .mascot-note{
    max-width:none;
  }
  .activity-title-row{
    flex-direction:column;
    align-items:flex-start;
  }
  .integration-benefits{
    grid-template-columns:1fr;
  }
  .cap-grid{
    grid-template-columns:1fr;
  }
  .cap-grid--lite{
    grid-template-columns:1fr;
    gap:14px;
  }
  .cap-grid--lite .cap-item,
  .cap-grid--lite .cap-item:nth-child(4),
  .cap-grid--lite .cap-item:nth-child(5){
    grid-column:auto;
  }
}
@media (max-width: 720px){
  .drop-actions{ grid-template-columns:1fr; }
  .format-strip{ display:flex; flex-wrap:wrap; justify-content:center; }
  .hero-line-2{ margin-top:.22em; }
}

@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; }
  .reveal{ opacity:1; transform:none; }
  .activity-lane{ transform:none; }
  .flow-progress-bar{ width:100%; }
}
