/* =========================================================
   HERO DASHBOARD — animated AI agent mockup
   ========================================================= */
.dash-stage{
  position:relative; width:100%; height:100%;
  min-height:500px;
  perspective: 1400px;
}

/* Skeleton placeholders that render before React/Babel finish */
.dash-skeleton{position:relative;width:100%;min-height:500px}
.dsk{position:absolute;border-radius:22px;background:linear-gradient(110deg, rgba(255,252,243,.55) 30%, rgba(255,252,243,.85) 50%, rgba(255,252,243,.55) 70%);background-size:200% 100%;animation:dskShimmer 1.8s ease-in-out infinite;border:1px solid rgba(255,255,255,.55);box-shadow:0 1px 0 rgba(255,255,255,.9) inset, 0 24px 60px -22px rgba(20,17,12,.22)}
.dsk-chat{width:280px;height:320px;left:0;top:0;transform:rotate(-1.5deg)}
.dsk-agent{width:230px;height:200px;right:0;top:14px;transform:rotate(1.5deg)}
.dsk-metric{width:190px;height:110px;left:18px;bottom:0;transform:rotate(-1.5deg)}
.dsk-cal{width:230px;height:80px;right:18px;bottom:14px;transform:rotate(1.5deg)}
@keyframes dskShimmer{0%,100%{background-position:0% 0}50%{background-position:-150% 0}}
@media (prefers-reduced-motion:reduce){ .dsk{animation:none} }
@media (max-width:560px){
  .dash-skeleton{min-height:auto;display:flex;flex-direction:column;gap:14px;padding:8px 6px 12px}
  .dsk{position:relative;width:100%;left:auto;right:auto;top:auto;bottom:auto;transform:none}
  .dsk-chat{height:280px}.dsk-agent{height:180px}.dsk-metric{height:100px}.dsk-cal{height:70px}
}

.dash-orbit{
  position:absolute; border-radius:50%;
  filter: blur(40px); pointer-events:none;
}
.dash-orbit-a{ width:340px; height:340px; background:radial-gradient(circle, rgba(31,61,43,.22), transparent 70%); top:-40px; left:-30px; animation:driftA 12s ease-in-out infinite alternate}
.dash-orbit-b{ width:280px; height:280px; background:radial-gradient(circle, rgba(184,115,51,.20), transparent 70%); bottom:-30px; right:-20px; animation:driftB 14s ease-in-out infinite alternate}
@keyframes driftA{from{transform:translate(0,0)}to{transform:translate(20px,-15px)}}
@keyframes driftB{from{transform:translate(0,0)}to{transform:translate(-18px,12px)}}

.dash-card{
  position:absolute; border-radius:22px;
  transform-style: preserve-3d;
  will-change: transform;
  animation: floatY 7s ease-in-out infinite alternate;
  /* stronger separation between overlapping cards */
  box-shadow:
    0 1px 0 rgba(255,255,255,.9) inset,
    0 24px 60px -22px rgba(20,17,12,.35),
    0 6px 14px -6px rgba(20,17,12,.18);
}
/* desync float durations so cards don't breathe in unison (Emil: details compound) */
.dash-chat{ animation-duration: 6.5s }
.dash-agent{ animation-duration: 7.5s }
.dash-metric{ animation-duration: 7s }
.dash-cal{ animation-duration: 8s }
@keyframes floatY{from{transform:translateY(0)}to{transform:translateY(-8px)}}

/* MAIN CHAT — top-left, focal point */
.dash-chat{
  width: 280px;
  left: 0; top: 0;
  padding: 14px 14px 12px;
  transform: rotate(-1.5deg);
  animation-delay: -1s;
  z-index: 2;
}
.dash-head{display:flex;align-items:center;gap:10px;padding-bottom:12px;border-bottom:1px solid rgba(20,17,12,.07)}
.dash-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;background:linear-gradient(135deg,#25D366,#128C7E);position:relative}
.dash-dot::before{content:""; position:absolute; inset:0; border-radius:50%; background:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'><path d='M20.5 3.5a11 11 0 0 0-17.4 13.2L1.5 22l5.5-1.5a11 11 0 0 0 16.5-9.5 11 11 0 0 0-3-7.5ZM12.5 19.5a9 9 0 0 1-4.6-1.3l-.3-.2-3.4 1 .9-3.3-.2-.3a9 9 0 1 1 7.6 4.1Z'/></svg>") center/55% no-repeat}
.dash-head-info{flex:1;min-width:0}
.dash-head-title{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.dash-head-sub{font-size:11px;color:var(--muted);margin-top:1px}
.live-pill{display:inline-flex;align-items:center;gap:5px;color:var(--accent);font-weight:500}
.lp-dot{width:6px;height:6px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 0 rgba(31,61,43,.5);animation:pulseDot 1.6s ease-out infinite}
@keyframes pulseDot{0%{box-shadow:0 0 0 0 rgba(31,61,43,.5)}100%{box-shadow:0 0 0 8px rgba(31,61,43,0)}}
.dash-head-time{font-size:11px;color:var(--muted-2)}

.dash-chat-body{padding:14px 4px 8px;display:flex;flex-direction:column;gap:8px;min-height:200px}
.bubble{
  max-width: 88%;
  padding: 9px 12px;
  border-radius: 14px;
  font-size: 13px; line-height:1.4;
  letter-spacing:-.005em;
  position:relative;
  word-break:break-word;
}
.bubble-in{
  background: #FFF;
  color: var(--ink);
  border: 1px solid rgba(20,17,12,.06);
  border-top-left-radius: 4px;
  align-self:flex-start;
  box-shadow: 0 1px 2px rgba(20,17,12,.04);
}
.bubble-out{
  background: linear-gradient(135deg, #DCF8C6, #BFEFA4);
  color: #1A2B1A;
  border-top-right-radius: 4px;
  align-self:flex-end;
  padding-right: 30px;
}
.bubble-out .check{
  position:absolute; right:8px; bottom:6px;
  color:#2A6FDB; width:14px; height:10px;
}
.bubble-out .check svg{width:100%;height:100%}
.bubble-typing{padding:10px 14px;display:inline-flex;gap:4px;align-items:center;min-height:30px}
.bubble-typing .t-dot{width:6px;height:6px;border-radius:50%;background:rgba(26,43,26,.5);animation:tdot 1.2s ease-in-out infinite}
.bubble-typing .t-dot:nth-child(2){animation-delay:.15s}
.bubble-typing .t-dot:nth-child(3){animation-delay:.3s}
@keyframes tdot{0%,100%{transform:translateY(0);opacity:.4}50%{transform:translateY(-3px);opacity:1}}

.bubble-in{animation: bubbleIn .4s cubic-bezier(.2,.7,.2,1)}
@keyframes bubbleIn{from{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:none}}

.dash-input{
  margin-top:8px; padding:10px 14px;
  background:rgba(20,17,12,.04);
  border-radius:999px;
  display:flex;align-items:center;justify-content:space-between;
  font-size:12px;color:var(--muted-2);
}
.dash-input-send{width:24px;height:24px;border-radius:50%;background:var(--accent);color:var(--paper);display:flex;align-items:center;justify-content:center}
.dash-input-send svg{width:12px;height:12px}

/* AGENT THINKING — top-right, aligned with chat */
.dash-agent{
  width: 230px;
  right: 0; top: 14px;
  padding: 16px 16px 14px;
  transform: rotate(1.5deg);
  animation-delay: -3s;
  z-index: 2;
}
.agent-head{display:flex;align-items:center;gap:12px;padding-bottom:14px;border-bottom:1px solid rgba(20,17,12,.07);margin-bottom:14px}
.agent-spark{
  width:36px;height:36px;border-radius:11px;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:var(--paper);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.agent-spark svg{width:18px;height:18px;animation:spin 8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.agent-title{font-size:13px;font-weight:600;color:var(--ink);letter-spacing:-.01em}
.agent-sub{font-size:11.5px;color:var(--muted);margin-top:1px}

.agent-steps{display:flex;flex-direction:column;gap:10px}
.agent-step{
  display:flex;align-items:center;gap:10px;
  font-size:12.5px;color:var(--muted);
  transition:color .3s;
}
.agent-step.done{color:var(--ink)}
.as-ico{width:20px;height:20px;border-radius:50%;background:rgba(20,17,12,.06);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .3s,color .3s}
.agent-step.done .as-ico{background:var(--accent);color:var(--paper)}
.as-ico svg{width:12px;height:12px}
.as-spinner{
  width:10px;height:10px;border-radius:50%;
  border:1.5px solid rgba(20,17,12,.18);
  border-top-color:var(--accent);
  animation:spin 1s linear infinite;
}

/* METRIC — bottom-left, offset inward */
.dash-metric{
  width: 190px;
  left: 18px; bottom: 0;
  padding: 14px 16px;
  transform: rotate(-1.5deg);
  animation-delay: -5s;
  z-index: 2;
}
.metric-label{font-size:11px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.metric-row{display:flex;align-items:baseline;gap:8px;margin-top:6px}
.metric-num{font-family:var(--font-italic);font-style:italic;font-size:36px;line-height:1;color:var(--ink);letter-spacing:-.02em;transition:transform .35s}
.dash-metric.pulse .metric-num{transform:scale(1.06)}
.metric-delta{font-size:11.5px;color:var(--accent);font-weight:600;padding:2px 6px;border-radius:6px;background:rgba(31,61,43,.08)}
.sparkline{width:100%;height:34px;margin-top:8px;display:block}

/* CAL — bottom-right, slightly elevated for visual rhythm */
.dash-cal{
  width: 230px;
  right: 18px; bottom: 14px;
  padding: 14px 16px;
  transform: rotate(1.5deg);
  animation-delay: -6s;
  z-index: 2;
  opacity: 1;
  transition: transform .5s;
}
.dash-cal.on{opacity:1}
.cal-row{display:flex;align-items:center;gap:12px}
.cal-date{
  background:var(--ink);color:var(--paper);
  border-radius:12px;padding:8px 10px;text-align:center;min-width:54px;
}
.cal-day{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,252,243,.7)}
.cal-num{font-family:var(--font-italic);font-style:italic;font-size:18px;line-height:1.1;margin-top:2px}
.cal-info{flex:1;min-width:0}
.cal-title{font-size:13px;color:var(--ink);font-weight:500;letter-spacing:-.01em}
.cal-sub{font-size:11px;color:var(--accent);margin-top:2px}
.cal-tick{width:26px;height:26px;border-radius:50%;background:var(--accent);color:var(--paper);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.cal-tick svg{width:13px;height:13px}

@media (max-width:1040px){
  .dash-stage{min-height:500px}
  .dash-chat{width:270px;left:0;top:0}
  .dash-agent{width:220px;right:0;top:14px}
  .dash-metric{width:180px;left:14px;bottom:0}
  .dash-cal{width:220px;right:14px;bottom:14px}
}
@media (max-width:560px){
  /* Stack dashboard cards vertically — abandon absolute positioning that causes overlap on narrow screens */
  .dash-stage{
    min-height:0; height:auto;
    display:flex; flex-direction:column; gap:14px;
    padding:8px 6px 12px;
    perspective:none;
  }
  .dash-stage > .dash-card{
    position:relative; width:100%; max-width:100%;
    left:auto; right:auto; top:auto; bottom:auto;
    transform:none !important;
    animation:none;
  }
  .dash-orbit{display:none}
  .dash-cal{opacity:1}
  .dash-chat-body{min-height:140px}
}

/* =========================================================
   WIZARD MODAL
   ========================================================= */
.modal-overlay{position:fixed;inset:0;background:rgba(20,17,12,.45);backdrop-filter:blur(8px);z-index:100;display:none;align-items:center;justify-content:center;padding:20px}
.modal-overlay.open{display:flex;animation:fadeIn .25s ease}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}

.wizard{
  position:relative;
  width:100%; max-width:560px;
  border-radius:28px;
  padding:36px 40px 32px;
  animation: modalIn .5s cubic-bezier(.2,.7,.2,1);
  background: linear-gradient(180deg, rgba(255,252,243,.96), rgba(255,252,243,.92));
}
@keyframes modalIn{from{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:none}}
.wizard-close{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:var(--muted);transition:color .2s,background .2s}
.wizard-close:hover{color:var(--ink);background:rgba(20,17,12,.06)}
.wizard-close svg{width:18px;height:18px}

.wizard-progress{
  display:flex;gap:6px;margin-bottom:24px;
}
.wp-step{flex:1;height:3px;border-radius:2px;background:rgba(20,17,12,.10);overflow:hidden;position:relative}
.wp-step::after{content:"";position:absolute;inset:0;background:var(--accent);transform:scaleX(0);transform-origin:left;transition:transform .55s cubic-bezier(.2,.7,.2,1)}
.wp-step.done::after{transform:scaleX(1)}
.wp-step.active::after{transform:scaleX(1);background:linear-gradient(90deg,var(--accent),var(--copper-2))}

.wizard-step-num{font-family:var(--font-italic);font-style:italic;font-size:14px;color:var(--accent);letter-spacing:.04em}
.wizard h3{font-family:var(--font-display);font-size:28px;letter-spacing:-.02em;margin:6px 0 8px;font-weight:380;line-height:1.1}
.wizard p.lead{font-size:14px;color:var(--muted);line-height:1.55;margin-bottom:22px}

.wf-grid{display:flex;flex-direction:column;gap:12px}
.wf-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media (max-width:480px){.wf-row{grid-template-columns:1fr}}

.wf{display:flex;flex-direction:column;gap:6px}
.wf label{font-size:11.5px;color:var(--muted);font-weight:500;letter-spacing:.04em;text-transform:uppercase}
.wf input,.wf textarea,.wf select{
  background:rgba(255,255,255,.7);
  border:1px solid var(--line-2);
  border-radius:12px;
  padding:13px 14px;
  font-family:var(--font-body);font-size:14.5px;color:var(--ink);
  transition:border-color .2s,background .2s,box-shadow .2s;
  font-weight:400;
}
.wf textarea{resize:vertical;min-height:90px;font-family:var(--font-body)}
.wf input:focus,.wf textarea:focus,.wf select:focus{outline:none;border-color:var(--accent);background:#FFF;box-shadow:0 0 0 4px rgba(31,61,43,.08)}

/* radio chips */
.chip-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px}
@media (max-width:480px){.chip-row{grid-template-columns:1fr}}
.chip{
  display:flex;align-items:center;gap:10px;
  padding:14px 16px;border-radius:14px;
  border:1px solid var(--line-2);background:rgba(255,255,255,.55);
  cursor:pointer; transition:all .25s;
  font-size:14px;color:var(--ink-2);
  text-align:left;
}
.chip:hover{background:rgba(255,255,255,.85);border-color:var(--line-strong)}
.chip.on{background:var(--ink);border-color:var(--ink);color:var(--paper)}
.chip.on .chip-radio{background:var(--paper);border-color:var(--paper)}
.chip.on .chip-radio::after{background:var(--ink)}
.chip-radio{width:18px;height:18px;border-radius:50%;border:1.5px solid var(--line-strong);position:relative;flex-shrink:0;transition:all .25s}
.chip-radio::after{content:"";position:absolute;inset:3px;border-radius:50%;background:transparent;transition:background .25s}
.chip .chip-ico{width:24px;height:24px;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;color:inherit;opacity:.7}

.wizard-foot{display:flex;justify-content:space-between;gap:10px;margin-top:24px;align-items:center}
.wz-back{font-size:13px;color:var(--muted);padding:10px 14px;border-radius:999px;transition:color .2s,background .2s}
.wz-back:hover{color:var(--ink);background:rgba(20,17,12,.04)}
.wz-back.hidden{visibility:hidden}
.wz-next{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--ink);color:var(--paper);
  padding:12px 22px;border-radius:999px;font-size:14px;font-weight:500;
  transition:transform .25s,background .25s;
}
.wz-next:hover{transform:translateY(-1px);background:var(--accent)}
.wz-next svg{width:14px;height:14px}
.wz-next[disabled]{opacity:.4;cursor:not-allowed;transform:none}
.wz-next:active:not([disabled]){transform:scale(.97)}
.wz-back:active:not([disabled]){transform:scale(.97)}
/* Loading spinner inside Enviando… button (active when text matches via :has) */
.wz-next.sending::before, .wz-next[aria-busy="true"]::before{
  content:""; display:inline-block; width:12px; height:12px;
  border:1.5px solid currentColor; border-top-color:transparent; border-radius:50%;
  animation: spin .7s linear infinite; margin-right:6px; vertical-align:-1px;
}

.wz-step-anim{animation:stepIn .45s cubic-bezier(.2,.7,.2,1)}
@keyframes stepIn{from{opacity:0;transform:translateX(20px)}to{opacity:1;transform:none}}

.wz-success{text-align:center;padding:14px 8px 8px}
.wz-success .tick-circle{
  width:74px;height:74px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),var(--accent-2));
  color:var(--paper);
  display:inline-flex;align-items:center;justify-content:center;
  margin-bottom:18px;
  animation:tickPop .6s cubic-bezier(.2,.7,.2,1);
  box-shadow:0 12px 32px -10px rgba(31,61,43,.5);
}
.wz-success .tick-circle svg{width:36px;height:36px}
@keyframes tickPop{from{transform:scale(.5);opacity:0}to{transform:none;opacity:1}}

/* =========================================================
   TWEAKS overrides (panel comes from starter)
   ========================================================= */
.vy-theme-dark {
  --bg:#0B0B0D; --bg-2:#0E0E12; --bg-3:#15151A; --paper:#F5F1E8;
  --ink:#F5F1E8; --ink-2:#E8E3D7; --muted:#A8A8A2; --muted-2:#8B8B86;
  --line:rgba(245,241,232,.08); --line-2:rgba(245,241,232,.14); --line-strong:rgba(245,241,232,.22);
  --accent:#D4B996; --accent-2:#C9A87C; --accent-soft:rgba(212,185,150,.10);
  --copper:#7B5BBF; --copper-2:#9B7BDF;
}
.vy-theme-dark .glass{
  background:linear-gradient(180deg, rgba(245,241,232,.035), rgba(245,241,232,.015));
  border-color:rgba(245,241,232,.08);
  box-shadow:inset 0 1px 0 rgba(255,255,255,.06), 0 22px 48px -22px rgba(0,0,0,.6);
}
.vy-theme-dark .glass-strong{
  background:linear-gradient(180deg, rgba(245,241,232,.055), rgba(245,241,232,.025));
}
.vy-theme-dark .page-bg{
  background:
    radial-gradient(1000px 800px at 10% -10%, rgba(123,91,191,.18), transparent 60%),
    radial-gradient(900px 700px at 100% 0%, rgba(212,185,150,.10), transparent 55%),
    var(--bg);
}
.vy-theme-dark #auroraCanvas{mix-blend-mode:screen;opacity:.6}
.vy-theme-dark .bubble-in{background:#FFF;color:#0B0B0D;border-color:transparent}
.vy-theme-dark .nav-cta{background:var(--ink);color:var(--bg)}
.vy-theme-dark .nav-cta:hover{background:var(--accent);color:var(--bg)}
.vy-theme-dark .btn-primary{background:var(--ink);color:var(--bg)}
.vy-theme-dark .btn-primary:hover{background:var(--accent);color:var(--bg)}
.vy-theme-dark .price-cta.solid{background:var(--ink);color:var(--bg)}
.vy-theme-dark .price-cta.solid:hover{background:var(--accent);color:var(--bg)}
.vy-theme-dark .demo-card:hover .demo-meta .arrow{background:var(--accent);border-color:var(--accent)}
.vy-theme-dark .demo-card:hover .demo-meta .arrow svg{color:var(--bg)}
.vy-theme-dark footer{background:rgba(20,17,12,.4)}

/* accent variants */
.vy-accent-cobalt{ --accent:#1E3A8A; --accent-2:#3B5BB5; --accent-soft:rgba(30,58,138,.08)}
.vy-accent-burgundy{ --accent:#7B1E2E; --accent-2:#A23A4D; --accent-soft:rgba(123,30,46,.08)}
.vy-accent-violet{ --accent:#4A2B8A; --accent-2:#6B47B0; --accent-soft:rgba(74,43,138,.08)}
.vy-accent-copper{ --accent:#9C5A2C; --accent-2:#B87333; --accent-soft:rgba(156,90,44,.08)}

/* =========================================================
   HERO ROTATING WORD
   ========================================================= */
.rotator{
  position:relative;
  display:inline-block;
  vertical-align:baseline;
  height:1.05em;
  line-height:1;
  overflow:hidden;
  color: var(--accent);
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  letter-spacing:-.01em;
  white-space:nowrap;
  transition: width .55s cubic-bezier(.22,.61,.36,1);
  vertical-align: -0.04em;
  padding-right: .04em;
  min-width: 4ch;
}
.rotator::after{
  content:"";
  position:absolute; left:0; right:.04em; bottom:-.04em;
  height: .06em;
  background: linear-gradient(90deg, transparent 0%, var(--accent) 12%, var(--accent) 88%, transparent 100%);
  opacity:.35;
  border-radius:2px;
}
.rotator .r-word{
  position:relative;
  display:inline-block;
  opacity:1;
  transition: opacity .28s ease;
  will-change: opacity;
}
@media (prefers-reduced-motion: reduce){
  .rotator, .rotator .r-word{ transition:none !important; }
}

/* =========================================================
   CAPACIDADES — Performance viz
   ========================================================= */
.perf-card{
  width:100%;border-radius:20px;
  background:linear-gradient(160deg, rgba(255,252,243,.7), rgba(236,230,216,.5));
  border:1px solid rgba(31,61,43,.1);
  padding:18px;
  box-shadow:0 30px 80px -40px rgba(31,61,43,.35), inset 0 1px 0 rgba(255,255,255,.7);
  backdrop-filter:blur(20px);
}
.perf-browser{
  border-radius:14px;background:#FCFAF4;border:1px solid rgba(31,61,43,.08);
  overflow:hidden;
}
.perf-bar{
  display:flex;align-items:center;gap:10px;padding:11px 14px;
  background:rgba(31,61,43,.04);border-bottom:1px solid rgba(31,61,43,.06);
}
.perf-dots{display:inline-flex;gap:5px}
.perf-dots i{width:9px;height:9px;border-radius:50%;background:rgba(31,61,43,.22);display:block}
.perf-dots i:nth-child(1){background:#E66B5A}
.perf-dots i:nth-child(2){background:#E5B847}
.perf-dots i:nth-child(3){background:#3DBA70}
.perf-url{flex:1;font-family:var(--font-mono,JetBrains Mono,monospace);font-size:11px;color:var(--ink);letter-spacing:.02em;text-align:center;opacity:.65}
.perf-lock svg{width:13px;height:13px;color:rgba(31,61,43,.4)}
.perf-body{padding:28px 24px 26px;display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:center}
.perf-gauge{position:relative;width:140px;height:140px;flex:none}
.perf-gauge svg{width:100%;height:100%}
.perf-arc{transition:stroke-dashoffset 1.8s cubic-bezier(.2,.7,.2,1)}
.perf-card.run .perf-arc{stroke-dashoffset:6.28}
.perf-score{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:42px;color:#1F3D2B;font-weight:400;letter-spacing:-.02em}
.perf-label{position:absolute;left:0;right:0;bottom:-22px;text-align:center;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.perf-stats{display:flex;flex-direction:column;gap:11px;font-size:12.5px}
.perf-stat{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:8px;border-bottom:1px dashed rgba(31,61,43,.12)}
.perf-stat .k{color:var(--muted);letter-spacing:.04em}
.perf-stat .v{font-family:var(--font-display);font-size:18px;color:var(--ink);letter-spacing:-.01em}
.perf-bars{margin-top:8px;display:flex;flex-direction:column;gap:8px}
.pb-row{display:flex;align-items:center;gap:10px;font-size:10.5px;color:var(--muted);letter-spacing:.06em}
.pb-lbl{width:62px;text-transform:uppercase}
.pb-track{flex:1;height:6px;border-radius:99px;background:rgba(31,61,43,.08);overflow:hidden}
.pb-fill{height:100%;width:0;border-radius:99px;transition:width 1.6s cubic-bezier(.2,.7,.2,1)}
.pb-fill.you{background:linear-gradient(90deg,#1F3D2B,#2A8C5A)}
.pb-fill.avg{background:rgba(31,61,43,.28)}
.perf-card.run .pb-fill.you{width:96%}
.perf-card.run .pb-fill.avg{width:42%}
@media (max-width:560px){
  .perf-body{grid-template-columns:1fr;text-align:center;gap:36px;padding:24px 18px 22px}
  .perf-gauge{margin:0 auto}
  .pb-lbl{width:auto;min-width:62px}
}

/* =========================================================
   CAPACIDADES — WhatsApp chat viz
   ========================================================= */
.wa-card{
  width:100%;max-width:420px;margin:0 auto;
  border-radius:24px;background:#0B141A;
  padding:14px 14px 18px;
  box-shadow:0 40px 90px -40px rgba(11,20,26,.5), inset 0 1px 0 rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.06);
  overflow:hidden;
}
.wa-head{
  display:flex;align-items:center;gap:11px;padding:6px 8px 12px;border-bottom:1px solid rgba(255,255,255,.06);
}
.wa-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#B87333,#E5B847);display:flex;align-items:center;justify-content:center;color:#0B141A;font-family:var(--font-display);font-size:16px;font-weight:500;flex:none}
.wa-meta{flex:1;display:flex;flex-direction:column;line-height:1.25;min-width:0}
.wa-name{color:#E9EDEF;font-size:13.5px;letter-spacing:-.005em}
.wa-sub{color:#7A8C99;font-size:10.5px;display:inline-flex;align-items:center;gap:5px;margin-top:2px}
.wa-online{width:6px;height:6px;border-radius:50%;background:#3DBA70;box-shadow:0 0 0 0 rgba(61,186,112,.6);animation:waPulse 2s ease-out infinite}
@keyframes waPulse{0%{box-shadow:0 0 0 0 rgba(61,186,112,.55)}70%{box-shadow:0 0 0 8px rgba(61,186,112,0)}100%{box-shadow:0 0 0 0 rgba(61,186,112,0)}}
.wa-time{color:#7A8C99;font-size:11px;font-family:var(--font-mono,JetBrains Mono,monospace);letter-spacing:.04em}
.wa-thread{display:flex;flex-direction:column;gap:8px;padding:16px 4px 6px;min-height:340px;background:
  radial-gradient(circle at 30% 20%, rgba(255,255,255,.025), transparent 60%),
  radial-gradient(circle at 70% 80%, rgba(255,255,255,.02), transparent 50%),
  #0B141A;
  border-radius:0 0 16px 16px;margin:0 -8px;padding-left:14px;padding-right:14px;
}
.wa-msg{
  max-width:78%;padding:9px 12px 10px;border-radius:14px;font-size:13px;line-height:1.4;color:#E9EDEF;
  opacity:0;transform:translateY(8px);transition:opacity .35s ease, transform .45s cubic-bezier(.2,.7,.2,1);
  word-wrap:break-word;
}
.wa-msg.in{background:#202C33;border-top-left-radius:4px;align-self:flex-start}
.wa-msg.out{background:#054D40;border-top-right-radius:4px;align-self:flex-end;color:#E9F2EE}
.wa-msg.show{opacity:1;transform:none}
.wa-sub2{display:block;margin-top:4px;font-size:11px;color:rgba(233,242,238,.6);letter-spacing:.02em}
.wa-typing{
  align-self:flex-start;background:#202C33;border-radius:14px;border-top-left-radius:4px;
  padding:11px 14px;display:none;gap:4px;
}
.wa-typing.show{display:inline-flex}
.wa-typing span{width:6px;height:6px;border-radius:50%;background:#7A8C99;animation:waType 1.1s ease-in-out infinite}
.wa-typing span:nth-child(2){animation-delay:.18s}
.wa-typing span:nth-child(3){animation-delay:.36s}
@keyframes waType{0%,80%,100%{opacity:.3;transform:translateY(0)}40%{opacity:1;transform:translateY(-3px)}}
.wa-toast{
  margin-top:6px;align-self:stretch;
  display:flex;align-items:center;gap:9px;
  padding:11px 14px;border-radius:12px;
  background:rgba(61,186,112,.14);color:#7AE0A4;border:1px solid rgba(61,186,112,.28);
  font-size:12px;letter-spacing:.01em;
  opacity:0;transform:translateY(8px);transition:opacity .4s ease, transform .5s cubic-bezier(.2,.7,.2,1);
}
.wa-toast.show{opacity:1;transform:none}
.wa-toast svg{width:14px;height:14px;flex:none}

/* WhatsApp viz container override */
.chess-vis:has(.wa-card),
.chess-vis:has(.ba-card){
  aspect-ratio:auto;height:auto;overflow:visible;padding:0;background:transparent;box-shadow:none;border:0;
}

/* =========================================================
   BEFORE / AFTER WEB TRANSFORMATION
   ========================================================= */
.ba-card{width:100%;display:flex;flex-direction:column;gap:14px}
.ba-browser{
  border-radius:16px;background:#fff;
  border:1px solid rgba(31,61,43,.1);
  overflow:hidden;
  box-shadow:0 30px 80px -40px rgba(31,61,43,.35);
}
.ba-bar{display:flex;align-items:center;gap:10px;padding:11px 14px;background:#F6F2E8;border-bottom:1px solid rgba(31,61,43,.06)}
.ba-dots{display:inline-flex;gap:5px}
.ba-dots i{width:9px;height:9px;border-radius:50%;display:block}
.ba-dots i:nth-child(1){background:#E66B5A}
.ba-dots i:nth-child(2){background:#E5B847}
.ba-dots i:nth-child(3){background:#3DBA70}
.ba-url{flex:1;font-family:var(--font-mono,JetBrains Mono,monospace);font-size:11px;color:var(--ink);text-align:center;opacity:.6}
.ba-lock svg{width:13px;height:13px;color:rgba(31,61,43,.4)}

.ba-stage{position:relative;aspect-ratio:5/3.4;background:#fff;overflow:hidden}
.ba-page{position:absolute;inset:0}

/* BEFORE — chaotic */
.ba-before{
  background:linear-gradient(180deg,#FFF3B0 0%, #FFD1DC 60%, #C7E8FF 100%);
  padding:14px 16px;color:#222;font-family:Arial, sans-serif;font-size:11px;
}
.bb-hero{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}
.bb-logo{font-family:"Comic Sans MS","Brush Script MT",cursive;font-size:16px;font-weight:700;color:#E0144C;text-shadow:1px 1px 0 #ffe066}
.bb-nav{display:flex;gap:8px;font-size:9px;color:#0050b3;text-decoration:underline}
.bb-banner{
  background:#fff;border:2px dashed #E0144C;border-radius:4px;padding:10px 8px;text-align:center;margin-bottom:10px;
}
.bb-banner h4{font-family:Impact,"Arial Black",sans-serif;font-size:18px;color:#E0144C;letter-spacing:0;margin:0 0 4px;line-height:1.05}
.bb-banner p{font-size:10px;color:#222;margin:0 0 8px}
.bb-banner button{background:#ffea00;border:2px solid #000;font-weight:900;font-size:10px;padding:5px 10px;font-family:Arial,sans-serif;color:#000;text-transform:uppercase;cursor:pointer;border-radius:0}
.bb-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;margin-bottom:10px}
.bb-card-mini{background:#fff;border:1px solid #999;padding:6px;text-align:center;display:flex;flex-direction:column;gap:4px}
.bb-card-mini .ph{display:block;height:32px;background:repeating-linear-gradient(45deg,#ddd 0 6px,#eee 6px 12px);border:1px solid #aaa}
.bb-card-mini .lbl{font-size:9px;font-weight:700;color:#444}
.bb-foot{font-size:9px;color:#0050b3;text-align:center;text-decoration:underline}

/* AFTER — our work */
.ba-after{
  background:
    radial-gradient(circle at 85% 0%, rgba(184,115,51,.08), transparent 50%),
    radial-gradient(circle at 0% 90%, rgba(31,61,43,.05), transparent 55%),
    #FCFAF4;
  padding:16px 18px;color:var(--ink);
  clip-path:inset(0 100% 0 0);
  transition:clip-path 1.6s cubic-bezier(.7,.05,.2,1);
}
.ba-card.run .ba-after{clip-path:inset(0 0 0 0)}
.aa-nav{display:flex;align-items:center;gap:10px;margin-bottom:14px;font-size:11px;padding-bottom:10px;border-bottom:1px solid rgba(31,61,43,.08)}
.aa-mark{font-family:var(--font-italic,Instrument Serif,serif);font-style:italic;font-size:20px;color:#1F3D2B;line-height:1}
.aa-name{font-family:var(--font-display,Fraunces,serif);font-size:14px;letter-spacing:-.01em;margin-right:4px}
.aa-pills{display:flex;gap:5px;flex:1}
.aa-pill{font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:4px 8px;border:1px solid rgba(31,61,43,.12);border-radius:99px}
.aa-cta{font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:#FCFAF4;background:#1F3D2B;padding:6px 11px;border-radius:99px;font-weight:500}
.aa-split{display:grid;grid-template-columns:.95fr 1.05fr;gap:14px;align-items:start}
.aa-left{display:flex;flex-direction:column;gap:12px}
.aa-eyebrow{font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.aa-left h4{font-family:var(--font-display,Fraunces,serif);font-size:32px;line-height:.95;letter-spacing:-.03em;margin:0;font-weight:380;color:#1F3D2B}
.aa-left h4 em{font-family:var(--font-italic,Instrument Serif,serif);font-style:italic;color:#B87333;font-weight:400}
.aa-resv{
  margin-top:4px;background:#fff;border:1px solid rgba(31,61,43,.1);
  border-radius:10px;padding:10px 12px;
  box-shadow:0 8px 24px -16px rgba(31,61,43,.25);
  display:flex;flex-direction:column;gap:6px;
}
.aa-resv-row{display:flex;justify-content:space-between;align-items:baseline;font-size:10px}
.aa-resv-row .aa-k{color:var(--muted);letter-spacing:.08em;text-transform:uppercase;font-size:8.5px}
.aa-resv-row .aa-v{font-family:var(--font-display,Fraunces,serif);font-size:13px;color:#1F3D2B;letter-spacing:-.01em}
.aa-resv-btn{margin-top:4px;border:0;background:#B87333;color:#FCFAF4;font-size:9px;letter-spacing:.14em;text-transform:uppercase;padding:7px 0;border-radius:6px;font-family:inherit;font-weight:600;cursor:pointer}
.aa-right{display:flex;flex-direction:column;gap:8px}
.aa-hero-img{
  position:relative;aspect-ratio:4/3.6;border-radius:10px;overflow:hidden;
  background:
    radial-gradient(circle at 40% 60%, rgba(184,115,51,.55), transparent 55%),
    radial-gradient(circle at 70% 30%, rgba(229,184,71,.55), transparent 50%),
    radial-gradient(circle at 20% 20%, rgba(31,61,43,.4), transparent 60%),
    linear-gradient(135deg,#3a2818,#5c3a1f 50%,#8b6234);
  border:1px solid rgba(31,61,43,.12);
}
.aa-img-tag{
  position:absolute;top:8px;left:8px;font-size:8px;letter-spacing:.18em;text-transform:uppercase;
  color:#FCFAF4;background:rgba(0,0,0,.4);backdrop-filter:blur(6px);padding:4px 8px;border-radius:99px;
}
.aa-img-price{
  position:absolute;bottom:8px;right:8px;font-family:var(--font-italic,Instrument Serif,serif);
  font-style:italic;font-size:14px;color:#FCFAF4;
  background:rgba(31,61,43,.5);backdrop-filter:blur(6px);padding:3px 10px;border-radius:99px;
}
.aa-mini-row{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.aa-mini{aspect-ratio:1/1;border-radius:6px;border:1px solid rgba(31,61,43,.1)}
.aa-mini.m1{background:radial-gradient(circle at 60% 40%,rgba(229,184,71,.6),rgba(184,115,51,.3) 60%,rgba(31,61,43,.4))}
.aa-mini.m2{background:radial-gradient(circle at 30% 60%,rgba(255,255,255,.5),rgba(184,115,51,.45) 55%,rgba(58,40,24,.7))}
.aa-mini.m3{background:radial-gradient(circle at 70% 70%,rgba(184,115,51,.5),rgba(31,61,43,.5) 60%,rgba(11,20,26,.7))}

/* Handle (sweeper) */
.ba-handle{
  position:absolute;top:0;bottom:0;left:0;width:2px;background:#fff;
  box-shadow:0 0 0 1px rgba(31,61,43,.18), 0 6px 20px rgba(31,61,43,.18);
  transition:left 1.6s cubic-bezier(.7,.05,.2,1);
  pointer-events:none;
}
.ba-card.run .ba-handle{left:100%}
.ba-handle-pill{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  width:30px;height:30px;border-radius:50%;background:#1F3D2B;color:#FCFAF4;
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 6px 20px rgba(31,61,43,.3);
}
.ba-handle-pill svg{width:14px;height:14px}

/* Labels */
.ba-labels{display:flex;justify-content:space-between;align-items:center;padding:0 4px}
.ba-tag{font-size:10px;letter-spacing:.16em;text-transform:uppercase;padding:6px 12px;border-radius:99px;font-weight:500}
.tag-before{background:rgba(224,20,76,.08);color:#9B1240;border:1px solid rgba(224,20,76,.18)}
.tag-after{background:rgba(31,61,43,.08);color:#1F3D2B;border:1px solid rgba(31,61,43,.18)}

@media (prefers-reduced-motion:reduce){
  .ba-after,.ba-handle{transition:none !important}
}
@media (max-width:560px){
  .aa-hero h4{font-size:22px}
  .bb-banner h4{font-size:15px}
}

@media (prefers-reduced-motion:reduce){
  .perf-arc, .pb-fill{transition:none !important}
  .wa-msg,.wa-toast{transition:none !important;opacity:1 !important;transform:none !important}
}
/* Force rotator onto its own line so width changes don't shift the H1 */
.hero-h1 .word:has(.rotator){
  display:block;
  margin-top:.04em;
}
/* On narrow screens, allow rotator to wrap if word is long, and constrain to viewport width */
@media (max-width:720px){
  .rotator{
    white-space:normal;
    max-width:100%;
    width:auto !important;
    height:auto;
    line-height:1.05;
    overflow:visible;
  }
  .rotator .r-word{display:inline}
  .rotator::after{display:none}
}

/* =========================================================
   HERO TAIL — "Entregadas en 7 días."
   ========================================================= */
.hero-tail{
  margin-top: 14px;
  font-family: var(--font-display);
  font-size: clamp(28px, 3.4vw, 48px);
  font-weight: 380;
  line-height: 1.05;
  letter-spacing: -.02em;
  color: var(--muted);
  text-wrap: balance;
}
.hero-tail .it{
  font-style: italic;
  font-weight: 500;
  color: var(--paper);
  background: var(--accent);
  padding: .04em .22em .08em;
  border-radius: .14em;
  box-shadow: 0 6px 22px -8px var(--accent);
  display:inline-block;
  transform: rotate(-1.2deg);
  margin: 0 .04em;
}

/* =========================================================
   FUNDADOR BANNER — primera promoción
   ========================================================= */
.fundador-wrap{
  padding: 40px 0 80px;
}
.fundador-card{
  display:grid;
  grid-template-columns: 1.4fr .9fr;
  gap: 40px;
  align-items:center;
  padding: 40px 44px;
  border-radius: 24px;
  position:relative;
  overflow:hidden;
}
.fundador-card::before{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(circle at 95% 50%, var(--accent-soft), transparent 60%);
  pointer-events:none;
}
.fundador-left{ position:relative; z-index:1; max-width: 560px; }
.fundador-left h3{
  font-family: var(--font-display);
  font-size: clamp(26px, 2.6vw, 36px);
  font-weight: 380;
  line-height: 1.12;
  letter-spacing: -.015em;
  color: var(--ink);
  margin: 14px 0 14px;
  text-wrap: balance;
}
.fundador-left h3 .it{
  font-style: italic;
  font-weight: 400;
  color: var(--accent);
}
.fundador-left p{
  font-size: 15px;
  line-height: 1.6;
  color: var(--muted);
  max-width: 52ch;
}
.fundador-right{
  position:relative; z-index:1;
  display:flex; flex-direction:column;
  align-items:flex-start; gap: 22px;
}
.fundador-counter{
  padding: 18px 24px;
  border-radius: 18px;
  background: rgba(20,17,12,.04);
  border: 1px solid rgba(20,17,12,.08);
  display:inline-flex; flex-direction:column; gap:6px;
}
.fundador-counter .big{
  font-family: var(--font-display);
  font-weight: 380;
  font-size: 56px;
  line-height: 1;
  letter-spacing: -.04em;
  display:flex; align-items:baseline;
}
.fundador-counter .big .acc{ color: var(--accent); font-style: italic; }
.fundador-counter .big .slash{
  margin: 0 8px;
  color: var(--muted-2);
  font-size: 36px;
}
.fundador-counter .big .total{ color: var(--muted-2); font-size: 36px; }
.fundador-counter .lab{
  font-size: 11px;
  color: var(--muted-2);
  letter-spacing: .08em;
  text-transform: uppercase;
  font-weight: 500;
}

@media (max-width: 880px){
  .fundador-card{ grid-template-columns: 1fr; padding: 30px 26px; gap: 26px; }
  .fundador-right{ align-items: stretch; }
  .fundador-counter{ align-self: flex-start; }
}
