/* ============================================================
   Visible · by Ramos Labs · "misma casa, mas calida"
   Shares Ramos Labs base tokens (near-white, ink-teal) and
   ADDS a warm terracotta accent for CTAs, highlights & warmth.
   No build step. Plain CSS. Mobile-first. Reduced-motion safe.
   ============================================================ */

/* Self-hosted fonts (latin, variable): shared with the premium home */
@font-face {
  font-family: 'Inter';
  font-style: normal;
  font-weight: 400 800;
  font-display: swap;
  src: url('/assets/fonts/inter-latin-var.woff2') format('woff2');
}

:root {
  /* Neutral scale: shared with the home */
  --ink-900:#0B0E11;
  --ink-800:#16191D;
  --ink-700:#2A2F36;
  --ink-600:#3F454D;
  --ink-500:#5A626C;
  --ink-400:#828B96;
  --line:#E4E7EC;
  --line-strong:#D3D8DF;
  --paper:#FFFFFF;
  --paper-2:#F7F8FA;
  --paper-3:#EEF1F4;

  /* Trust anchor: same ink-teal as Ramos Labs (the "by Ramos Labs" thread) */
  --teal:#0E7C71;
  --teal-strong:#0A5F57;
  --teal-tint:#E6F2F0;

  /* WARM accent: terracotta/coral. The personality of Visible. */
  --warm:#E8623D;          /* decorative coral / large highlights (NOT for white body text) */
  --warm-strong:#CB4D2B;   /* hover / pressed (decorative) */
  --warm-soft:#FF8A63;     /* gradient top, friendly glow */
  --warm-tint:#FCEBE3;     /* faint warm fill behind icons/cards */
  --warm-tint-2:#F7D8C9;
  --amber:#F0A04B;         /* secondary warm, for the hero blob gradient */

  /* Accessible coral: white text reaches >=4.5:1 (AA normal text). Used for solid CTAs. */
  --warm-btn:#BF4A28;        /* white on this = 4.95:1 (AA) */
  --warm-btn-hover:#A23D1F;  /* white on this = 6.62:1 */
  /* Eyebrow coral that passes AA on white AND on the .section--band (#F7F8FA). */
  --warm-eyebrow:#B5421E;    /* 5.59:1 on white, 5.35:1 on band */

  --positive:#1E8E5A;
  --danger:#B42318;

  --radius-sm:10px;
  --radius:14px;
  --radius-lg:22px;
  --radius-xl:30px;

  --shadow-1:0 1px 2px rgba(11,14,17,.05);
  --shadow-2:0 8px 24px -8px rgba(11,14,17,.12), 0 2px 6px rgba(11,14,17,.05);
  --shadow-3:0 24px 60px -20px rgba(11,14,17,.18);
  --shadow-warm:0 18px 40px -16px rgba(203,77,43,.35);

  --ease:cubic-bezier(0.22,1,0.36,1);
  --t-fast:140ms var(--ease);
  --t-base:240ms var(--ease);

  --header-h:4.6rem;
  --container:70rem;
  --pad:1.25rem;

  --font-sans:'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

@media (min-width:640px){ :root{ --pad:1.75rem; } }
@media (min-width:1024px){ :root{ --pad:2rem; --header-h:5rem; } }

*,*::before,*::after{ box-sizing:border-box; margin:0; padding:0; }
html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
@media (prefers-reduced-motion:reduce){ html{ scroll-behavior:auto; } .paquetes-track{ scroll-behavior:auto; } }

body{
  font-family:var(--font-sans);
  background:var(--paper);
  color:var(--ink-900);
  line-height:1.6;
  font-size:1rem;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
button{ font:inherit; cursor:pointer; background:none; border:none; color:inherit; }
img,svg{ display:block; max-width:100%; }
::selection{ background:var(--warm-tint-2); color:var(--ink-900); }

:focus-visible{
  outline:2px solid var(--warm);
  outline-offset:2px;
  border-radius:4px;
}

section[id]{ scroll-margin-top:calc(var(--header-h) + 1.25rem); }

.container{ width:100%; max-width:var(--container); margin-inline:auto; padding-inline:var(--pad); }

.skip-link{
  position:absolute; top:-100%; left:1rem; z-index:200;
  padding:.6rem 1rem; background:var(--warm-btn); color:#fff;
  font-weight:700; border-radius:var(--radius-sm);
  transition:top var(--t-fast);
}
.skip-link:focus{ top:1rem; }

/* ============================================================
   HEADER
   ============================================================ */
.site-header{
  position:fixed; inset:0 0 auto 0; z-index:100;
  height:var(--header-h);
  background:rgba(255,255,255,.8);
  -webkit-backdrop-filter:blur(14px) saturate(1.4);
  backdrop-filter:blur(14px) saturate(1.4);
  border-bottom:1px solid transparent;
  transition:border-color var(--t-base), background var(--t-base);
}
.site-header.scrolled{ border-bottom-color:var(--line); background:rgba(255,255,255,.92); }
.header-inner{ display:flex; align-items:center; justify-content:space-between; gap:1rem; height:100%; }

/* Wordmark: "Visible" + small "by Ramos Labs" */
.brand{ display:flex; align-items:center; gap:.65rem; }
.brand-mark{ width:40px; height:40px; flex-shrink:0; border-radius:12px; box-shadow:var(--shadow-1); }
.brand-text{ display:flex; flex-direction:column; line-height:1.05; }
.brand-word{ font-weight:800; font-size:1.3rem; letter-spacing:-0.02em; color:var(--ink-900); }
.brand-sub{ font-weight:500; font-size:.72rem; letter-spacing:.01em; color:var(--ink-500); }

.header-tools{ display:flex; align-items:center; gap:.55rem; }

.header-home{
  display:none; font-size:.86rem; font-weight:500; color:var(--ink-500);
  padding:.5rem .7rem; border-radius:var(--radius-sm); transition:color var(--t-fast), background var(--t-fast);
}
.header-home:hover{ color:var(--ink-900); background:var(--paper-2); }
@media (min-width:720px){ .header-home{ display:inline-block; } }

.language-switch{ display:inline-flex; border:1px solid var(--line); border-radius:999px; overflow:hidden; }
.language-switch__button{
  display:inline-flex; align-items:center; justify-content:center;
  min-width:2.4rem; min-height:2.4rem; padding:.32rem .6rem;
  font-size:.74rem; font-weight:700; letter-spacing:.02em;
  color:var(--ink-500); transition:color var(--t-fast), background var(--t-fast);
}
.language-switch__button.is-active{ background:var(--ink-900); color:#fff; }

.wa-btn{
  display:inline-flex; align-items:center; gap:.45rem;
  padding:.52rem .95rem; border-radius:999px;
  white-space:nowrap;
  background:var(--warm-btn); color:#fff; font-weight:700; font-size:.9rem;
  box-shadow:var(--shadow-1);
  transition:background var(--t-fast), transform var(--t-fast);
}
.wa-btn:hover{ background:var(--warm-btn-hover); }
.wa-btn:active{ transform:scale(.97); }
.wa-btn svg{ width:17px; height:17px; fill:currentColor; flex-shrink:0; }
.wa-btn--header span{ display:none; }
@media (min-width:560px){ .wa-btn--header span{ display:inline; } }

/* Mobile: dock the header to the bottom (thumb zone) so the WhatsApp CTA is reachable */
@media (max-width:719px){
  .site-header{
    top:auto; bottom:0; height:auto;
    border-bottom:none; border-top:1px solid var(--line);
    background:rgba(255,255,255,.92);
    box-shadow:0 -10px 30px -16px rgba(11,14,17,.30);
    padding-bottom:env(safe-area-inset-bottom,0px);
  }
  .site-header.scrolled{ border-top-color:var(--line-strong); }
  .header-inner{ padding-block:.55rem; gap:.6rem; }
  .brand-mark{ width:34px; height:34px; }
  .brand-word{ font-size:1.12rem; }
  .brand-sub{ display:none; }
  .header-tools{ gap:.5rem; }
  .wa-btn--header{ padding:.6rem 1.05rem; font-size:.94rem; box-shadow:var(--shadow-warm); }
  .wa-btn--header span{ display:inline; }
  .wa-btn--header svg{ width:18px; height:18px; }
  body{ padding-bottom:calc(3.9rem + env(safe-area-inset-bottom,0px)); }
  section[id]{ scroll-margin-top:1rem; }
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.55rem;
  padding:.82rem 1.4rem; border-radius:999px;
  font-size:1rem; font-weight:700; letter-spacing:-0.005em;
  white-space:nowrap; max-width:100%;
  border:1px solid transparent;
  transition:background var(--t-fast), border-color var(--t-fast), transform var(--t-fast), color var(--t-fast), box-shadow var(--t-fast);
}
.btn:active{ transform:scale(.98); }
.btn svg{ width:19px; height:19px; fill:currentColor; flex-shrink:0; }
.btn-primary{ background:var(--warm-btn); color:#fff; box-shadow:var(--shadow-warm); }
.btn-primary:hover{ background:var(--warm-btn-hover); }
.btn-ghost{ background:var(--paper); color:var(--ink-900); border-color:var(--line-strong); }
.btn-ghost:hover{ border-color:var(--ink-900); background:var(--paper-2); }
.btn-lg{ padding:.95rem 1.7rem; font-size:1.05rem; }

/* ============================================================
   SECTIONS / TYPOGRAPHY
   ============================================================ */
.section{ padding-block:clamp(3.5rem, 7vw, 6rem); }
.section--band{ background:var(--paper-2); border-block:1px solid var(--line); }
.section--warm{ background:linear-gradient(180deg, var(--warm-tint) 0%, var(--paper) 100%); }

.section-header{ max-width:44rem; margin-bottom:2.6rem; }
.section-header--center{ margin-inline:auto; text-align:center; }
.eyebrow{
  display:inline-block; font-size:.76rem; font-weight:700; letter-spacing:.08em;
  text-transform:uppercase; color:var(--warm-eyebrow); margin-bottom:.9rem;
}
.eyebrow::before{ content:''; display:inline-block; width:1.4rem; height:2px; border-radius:2px; background:var(--warm); vertical-align:middle; margin-right:.55rem; transform:translateY(-3px); }
.section-title{
  font-size:clamp(1.75rem, 4vw, 2.7rem); font-weight:800; line-height:1.12;
  letter-spacing:-0.025em; color:var(--ink-900);
}
.section-sub{ margin-top:1rem; font-size:1.1rem; color:var(--ink-500); max-width:42rem; }
.section-header--center .section-sub{ margin-inline:auto; }
.warm-text{ color:var(--warm-strong); }

/* ============================================================
   HERO
   ============================================================ */
.hero{ position:relative; padding-top:calc(var(--header-h) + clamp(2rem,6vw,3.5rem)); padding-bottom:clamp(2.5rem,6vw,5rem); overflow:hidden; }
.hero::before{
  content:''; position:absolute; inset:0; z-index:-2; pointer-events:none;
  background:
    radial-gradient(42rem 30rem at 84% 0%, var(--warm-tint) 0%, transparent 58%),
    radial-gradient(34rem 28rem at 4% 24%, #FFF3EA 0%, transparent 60%),
    var(--paper);
}
.hero::after{
  content:''; position:absolute; inset:0; z-index:-1; pointer-events:none; opacity:.6;
  background-image:radial-gradient(rgba(232,98,61,.11) 1px, transparent 1.7px);
  background-size:24px 24px;
  -webkit-mask:radial-gradient(58% 56% at 66% 22%, #000 0%, transparent 76%);
  mask:radial-gradient(58% 56% at 66% 22%, #000 0%, transparent 76%);
}
.hero-grid{ display:grid; gap:3rem; align-items:center; }
@media (min-width:920px){ .hero-grid{ grid-template-columns:1.04fr .96fr; gap:3.5rem; } }

.hero-eyebrow{
  display:inline-flex; align-items:center; gap:.5rem; padding:.42rem .9rem;
  border:1px solid var(--warm-tint-2); background:rgba(255,255,255,.7); border-radius:999px;
  -webkit-backdrop-filter:blur(6px); backdrop-filter:blur(6px);
  font-size:.82rem; font-weight:600; color:var(--warm-eyebrow); box-shadow:var(--shadow-1);
}
.hero-eyebrow .dot{ width:7px; height:7px; border-radius:50%; background:var(--warm); flex-shrink:0; }
.hero-title{
  margin-top:1.3rem; font-size:clamp(2.35rem, 6.2vw, 3.7rem); font-weight:800;
  line-height:1.03; letter-spacing:-0.038em; color:var(--ink-900); text-wrap:balance;
}
.hero-title .warm{ color:var(--warm); }
.hero-lead{ margin-top:1.4rem; font-size:1.15rem; line-height:1.62; color:var(--ink-600); max-width:33rem; text-wrap:pretty; }
.hero-actions{ margin-top:2.1rem; display:flex; flex-wrap:wrap; align-items:center; gap:1rem 1.4rem; }
.hero-jump{ display:inline-flex; align-items:center; gap:.4rem; font-size:1rem; font-weight:700; color:var(--teal); }
.hero-jump span{ transition:transform var(--t-fast); }
.hero-jump:hover{ color:var(--teal-strong); }
.hero-jump:hover span{ transform:translateY(3px); }

/* ---- 3D device: a phone showing the business already "visible" ---- */
@property --ry{ syntax:'<angle>'; inherits:false; initial-value:0deg; }
@property --rx{ syntax:'<angle>'; inherits:false; initial-value:0deg; }
@property --ty{ syntax:'<length>'; inherits:false; initial-value:0px; }

.hero-art{ position:relative; width:100%; max-width:24rem; margin-inline:auto; perspective:1300px; }
.hero-art__glow{ position:absolute; inset:2% 2% 6%; z-index:0; border-radius:50%;
  background:radial-gradient(56% 50% at 58% 36%, var(--warm-soft) 0%, transparent 68%),
            radial-gradient(46% 44% at 32% 82%, #FFD7AE 0%, transparent 70%);
  filter:blur(7px); opacity:.6; }

.device{
  position:relative; z-index:1; margin-inline:auto; width:min(70%,15.5rem); aspect-ratio:9 / 18.7;
  --ry:-17deg; --rx:7deg; --ty:0px;
  border-radius:2.5rem; padding:.45rem;
  background:linear-gradient(150deg,#3a4047 0%,#0e1216 55%,#05080b 100%);
  box-shadow:
    inset 0 1px 1px rgba(255,255,255,.35), inset 0 -2px 6px rgba(0,0,0,.5),
    0 28px 50px -18px rgba(120,40,22,.40), var(--shadow-3);
  transform:rotateY(var(--ry)) rotateX(var(--rx)) rotateZ(-1deg) translateY(var(--ty));
  transform-style:preserve-3d; will-change:transform;
  transition:transform .35s var(--ease);
}
.device__screen{ position:relative; height:100%; border-radius:2.1rem; overflow:hidden;
  background:#fff; box-shadow:0 0 0 1.5px rgba(0,0,0,.55); }
.device__screen::after{ content:''; position:absolute; inset:0; pointer-events:none; z-index:6;
  background:linear-gradient(125deg, rgba(255,255,255,.30) 0%, rgba(255,255,255,0) 30%); }

.biz{ height:100%; display:flex; flex-direction:column; background:#fff; }
.biz__cover{ position:relative; height:30%; background:linear-gradient(135deg,var(--warm) 0%,var(--amber) 100%); }
.biz__logo{ position:absolute; left:.7rem; bottom:-1.05rem; width:2.7rem; height:2.7rem; border-radius:.85rem;
  background:#fff; color:var(--warm-strong); display:flex; align-items:center; justify-content:center;
  font-weight:800; font-size:1.25rem; box-shadow:var(--shadow-2); }
.biz__bar{ margin-top:1.45rem; padding:0 .75rem; display:flex; align-items:flex-start; justify-content:space-between; gap:.4rem; }
.biz__id{ display:flex; flex-direction:column; gap:.1rem; }
.biz__name{ font-weight:800; font-size:.8rem; letter-spacing:-.01em; color:var(--ink-900); }
.biz__meta{ display:flex; align-items:center; gap:.25rem; font-size:.6rem; color:var(--ink-500); }
.star{ width:.6rem; height:.6rem; background:#F5A623; display:inline-block;
  clip-path:polygon(50% 0,61% 35%,98% 35%,68% 57%,79% 91%,50% 70%,21% 91%,32% 57%,2% 35%,39% 35%); }
.biz__open{ flex-shrink:0; font-size:.54rem; font-weight:700; color:var(--positive);
  background:rgba(30,142,90,.13); padding:.12rem .38rem; border-radius:.4rem; }
.biz__actions{ display:flex; gap:.38rem; padding:.65rem .75rem .5rem; }
.biz__btn{ flex:1; text-align:center; font-size:.6rem; font-weight:700; padding:.38rem 0; border-radius:.55rem;
  border:1px solid var(--line-strong); color:var(--ink-700); }
.biz__btn--solid{ background:var(--warm); color:#fff; border-color:var(--warm); }
.biz__gallery{ flex:1; display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:1fr; gap:3px; padding:0 .5rem .5rem; }
.biz__gallery span{ border-radius:.4rem; background:linear-gradient(135deg,#FBE3D8,#F7D8C9); }
.biz__gallery span:nth-child(2){ background:linear-gradient(135deg,#E6F2F0,#CFE7E2); }
.biz__gallery span:nth-child(3){ background:linear-gradient(135deg,#FDEBD6,#F0A04B); }
.biz__gallery span:nth-child(4){ background:linear-gradient(135deg,#FFE7D2,#FFC99A); }
.biz__gallery span:nth-child(5){ background:linear-gradient(135deg,#E6F2F0,#BFE0D9); }
.biz__gallery span:nth-child(6){ background:linear-gradient(135deg,#FBE3D8,#F4815F); }

.float-chip{ position:absolute; z-index:3; display:flex; align-items:center; gap:.5rem;
  padding:.52rem .68rem; border-radius:.85rem; background:rgba(255,255,255,.95);
  -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
  border:1px solid rgba(255,255,255,.85); box-shadow:var(--shadow-2);
  font-size:.72rem; line-height:1.2; color:var(--ink-600); will-change:transform; }
.float-chip__txt{ display:flex; flex-direction:column; }
.float-chip__txt strong{ font-weight:800; color:var(--ink-900); font-size:.74rem; }
.float-chip__ico{ width:1.65rem; height:1.65rem; flex-shrink:0; border-radius:.5rem; display:flex; align-items:center; justify-content:center; background:var(--teal-tint); color:var(--teal-strong); }
.float-chip__ico svg{ width:.95rem; height:.95rem; }
.float-chip__ico--wa{ background:#25D366; color:#fff; }
.float-chip__stars{ color:#F5A623; font-size:.66rem; letter-spacing:1px; flex-shrink:0; }
.float-chip--found{ top:5%; left:-3%; }
.float-chip--review{ top:39%; right:-5%; }
.float-chip--order{ bottom:6%; left:-5%; }
@media (max-width:420px){
  .float-chip{ font-size:.66rem; padding:.42rem .55rem; }
  .float-chip__txt strong{ font-size:.68rem; }
  .float-chip--found{ left:-1%; } .float-chip--review{ right:-1%; } .float-chip--order{ left:-1%; }
}

@media (prefers-reduced-motion:no-preference){
  .device{ animation:deviceFloat 8s var(--ease) infinite; }
  .float-chip--found{ animation:chipFloat 6s var(--ease) infinite; }
  .float-chip--review{ animation:chipFloat 6.6s var(--ease) .4s infinite; }
  .float-chip--order{ animation:chipFloat 7.2s var(--ease) .8s infinite; }
}
@media (hover:hover) and (pointer:fine){
  .device, .float-chip{ animation:none !important; }
}
@keyframes deviceFloat{ 0%,100%{ --ty:0px; } 50%{ --ty:-10px; } }
@keyframes chipFloat{ 0%,100%{ transform:translateY(0); } 50%{ transform:translateY(-7px); } }

/* Mobile hero: big object ON TOP using the full top space (header is docked at the bottom),
   bold copy centered below. Placed AFTER the hero base so it wins the cascade. */
@media (max-width:719px){
  .hero{ padding-top:.3rem; padding-bottom:1.5rem; }
  .hero .container{ width:100%; }
  .hero-grid{ gap:1.1rem; }
  .hero-art{ order:1; width:fit-content; max-width:100%; margin:0 auto; }
  .device{ width:auto; height:min(47vh,420px); }
  .hero-art__glow{ opacity:.92; inset:-8% -12% 0; }
  .hero-copy{ order:2; text-align:center; }
  .hero-eyebrow{ margin-bottom:0; }
  .hero-title{ margin-top:.9rem; font-size:clamp(2.1rem,8.4vw,2.9rem); line-height:1.04; letter-spacing:-0.032em; }
  .hero-lead{ margin-top:.85rem; margin-inline:auto; max-width:30rem; font-size:1.04rem; }
  .hero-actions{ margin-top:1.3rem; justify-content:center; }
  /* Keep trust seals visible on mobile (content parity for AT), just compact + centered */
  .hero-trust{ margin-top:1.5rem; padding-top:1.1rem; justify-content:center; gap:.5rem 1.1rem; }
  .hero-trust span{ font-size:.82rem; }
}

.hero-trust{ margin-top:2.4rem; display:flex; flex-wrap:wrap; gap:.6rem 1.4rem; padding-top:1.5rem; border-top:1px solid var(--warm-tint-2); }
.hero-trust span{ display:inline-flex; align-items:center; gap:.45rem; font-size:.88rem; color:var(--ink-600); }
.hero-trust span::before{ content:''; width:16px; height:16px; flex-shrink:0; background:var(--teal); border-radius:50%;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 13l4 4L19 7' fill='none' stroke='%23000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/64% no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 13l4 4L19 7' fill='none' stroke='%23000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/64% no-repeat;
}

/* ============================================================
   "¿TE SUENA?" · empathy list
   ============================================================ */
.suena-grid{ display:grid; gap:1rem; }
@media (min-width:680px){ .suena-grid{ grid-template-columns:repeat(2,1fr); } }
.suena-item{
  display:flex; gap:.95rem; align-items:flex-start;
  padding:1.3rem 1.35rem; border:1px solid var(--line); border-radius:var(--radius);
  background:var(--paper); transition:border-color var(--t-fast), box-shadow var(--t-fast), transform var(--t-fast);
}
.suena-item:hover{ border-color:var(--warm-tint-2); box-shadow:var(--shadow-2); transform:translateY(-2px); }
.suena-item__ico{ width:36px; height:36px; flex-shrink:0; border-radius:50%; background:var(--warm-tint); display:flex; align-items:center; justify-content:center; }
.suena-item__ico svg{ width:19px; height:19px; stroke:var(--warm-strong); fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }
.suena-item p{ font-size:1rem; color:var(--ink-700); }

/* ============================================================
   PAQUETES
   ============================================================ */
/* Plans carousel — two modes:
   1) Fallback (no JS): a native scroll-snap row, real touch-swipe.
   2) Enhanced (.is-3d, added by JS): a 3D coverflow where neighbour
      cards recede behind the centred one, so it's obvious there's more.
   Arrows + dot indicators on top. */
.paquetes-carousel{ position:relative; max-width:64rem; margin-inline:auto; }

/* --- fallback scroller --- */
.paquetes-track{
  display:flex; align-items:stretch; gap:1.4rem;
  overflow-x:auto; overflow-y:hidden;
  scroll-snap-type:x mandatory; scroll-behavior:smooth;
  -webkit-overflow-scrolling:touch;
  padding:2rem .25rem 2.25rem;
  scrollbar-width:none; -ms-overflow-style:none;
}
.paquetes-track::-webkit-scrollbar{ display:none; }
.paquetes-track > .paquete{ scroll-snap-align:center; flex:0 0 auto; width:min(82vw, 21rem); }

/* --- enhanced 3D coverflow --- */
.paquetes-carousel.is-3d{ overflow-x:clip; }
.paquetes-carousel.is-3d .paquetes-stage{
  position:relative; padding-block:2rem;
  perspective:1600px; perspective-origin:50% 46%;
  touch-action:pan-y; cursor:grab;
  contain:layout style;
}
.paquetes-carousel.is-3d.is-dragging .paquetes-stage{ cursor:grabbing; }
.paquetes-carousel.is-3d .paquetes-track{
  display:block; position:relative; width:100%;
  overflow:visible; padding:0; gap:0;
  transform-style:preserve-3d;
}
.paquetes-carousel.is-3d .paquetes-track:focus-visible{ outline:none; }
.paquetes-carousel.is-3d .paquetes-track:focus-visible .paquete.is-active{ outline:2px solid var(--warm); outline-offset:4px; }
.paquetes-carousel.is-3d .paquetes-track > .paquete{
  position:absolute; top:0; left:50%; width:min(82vw, 21rem);
  transform:translateX(-50%);
  transition:transform .55s cubic-bezier(.22,.7,.2,1), opacity .45s ease;
  backface-visibility:hidden; contain:layout style;
  -webkit-user-select:none; user-select:none;
}
/* GPU layer promoted only while moving — never left on permanently */
.paquetes-carousel.is-3d .paquetes-track > .paquete.is-lift{ will-change:transform, opacity; }
.paquetes-carousel.is-3d.is-dragging .paquetes-track > .paquete{ transition:none; }
.paquetes-carousel.is-3d .paquete{ box-shadow:var(--shadow-2); }
.paquetes-carousel.is-3d .paquete.is-active{ box-shadow:var(--shadow-3); }
.paquetes-carousel.is-3d .paquete:not(.is-active){ cursor:pointer; }
@media (prefers-reduced-motion:reduce){
  .paquetes-carousel.is-3d .paquetes-track > .paquete{ transition-duration:.001s; }
}

.paquetes-nav{ display:none; }
@media (min-width:720px){
  .paquetes-carousel.is-ready .paquetes-nav{
    position:absolute; top:50%; transform:translateY(-50%); z-index:60;
    place-items:center; width:46px; height:46px; border-radius:999px;
    background:var(--paper); border:1px solid var(--line-strong); box-shadow:var(--shadow-2);
    color:var(--ink-700); cursor:pointer;
    transition:border-color var(--t-fast), color var(--t-fast), opacity var(--t-fast), background var(--t-fast);
  }
  .paquetes-carousel.is-ready .paquetes-nav{ display:grid; }
  .paquetes-carousel.is-ready .paquetes-nav--prev{ left:.25rem; }
  .paquetes-carousel.is-ready .paquetes-nav--next{ right:.25rem; }
  .paquetes-carousel.is-ready .paquetes-nav:hover{ border-color:var(--warm); color:var(--warm-strong); }
  .paquetes-carousel.is-ready .paquetes-nav:disabled{ opacity:0; pointer-events:none; }
}
.paquetes-nav svg{ width:22px; height:22px; fill:none; stroke:currentColor; stroke-width:2.2; stroke-linecap:round; stroke-linejoin:round; }

.paquetes-dots{ display:flex; justify-content:center; gap:.25rem; margin-top:.4rem; min-height:24px; }
/* 24x24 hit area (WCAG 2.5.8) around a small visual dot */
.paquetes-dots button{
  width:24px; height:24px; padding:0; border:none; background:none; cursor:pointer;
  display:grid; place-items:center;
}
.paquetes-dots button::before{
  content:''; width:9px; height:9px; border-radius:999px;
  background:var(--line-strong); transition:background var(--t-fast), width var(--t-fast);
}
.paquetes-dots button.is-rec::before{ background:var(--warm-tint-2); }
.paquetes-dots button[aria-current="true"]::before{ width:22px; background:var(--ink-700); }
.paquetes-dots button.is-rec[aria-current="true"]::before{ background:var(--warm); }

.paquete{
  position:relative; display:flex; flex-direction:column;
  border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:1.9rem 1.8rem; background:var(--paper);
  transition:border-color var(--t-base), box-shadow var(--t-base), transform var(--t-base);
}
.paquete:hover{ border-color:var(--line-strong); box-shadow:var(--shadow-2); transform:translateY(-3px); }
/* Recommended plan — extra punch: bolder ring, warmer fill, stronger glow */
.paquete--featured{
  border:2px solid var(--warm);
  background:linear-gradient(180deg, var(--warm-tint) 0%, var(--paper) 40%);
  box-shadow:0 22px 48px -18px rgba(203,77,43,.45);
  z-index:2;
}
.paquete--featured:hover{ border-color:var(--warm-strong); box-shadow:0 26px 56px -18px rgba(203,77,43,.52); }
/* push CTAs to a shared baseline across equal-height cards */
.paquetes-track .paquete__cta{ margin-top:auto; }
.paquetes-track .paquete > :nth-last-child(2){ margin-bottom:1.5rem; }
.paquete__flag{
  position:absolute; top:-.85rem; left:1.5rem;
  background:linear-gradient(90deg, var(--warm), var(--warm-strong)); color:#fff;
  font-size:.74rem; font-weight:700;
  letter-spacing:.04em; text-transform:uppercase; padding:.4rem .9rem; border-radius:999px;
  box-shadow:0 6px 16px -4px rgba(203,77,43,.5);
}
.paquete__name{ font-size:1.2rem; font-weight:800; letter-spacing:-0.01em; color:var(--ink-900); }
.paquete__price{ margin-top:.7rem; display:flex; align-items:baseline; flex-wrap:wrap; gap:.4rem; }
.paquete__price strong{ font-size:1.5rem; font-weight:800; letter-spacing:-0.02em; color:var(--warm-strong); }
.paquete__price span{ font-size:.84rem; font-weight:600; color:var(--ink-500); }
.paquete__pitch{ margin-top:.8rem; font-size:.98rem; color:var(--ink-600); }
.paquete__list{ list-style:none; margin-top:1.2rem; display:grid; gap:.75rem; }
.paquete__list li{ position:relative; padding-left:1.7rem; font-size:.94rem; line-height:1.45; color:var(--ink-700); }
.paquete__list li::before{
  content:''; position:absolute; left:0; top:.18rem; width:16px; height:16px;
  background:var(--teal);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 13l4 4L19 7' fill='none' stroke='%23000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 13l4 4L19 7' fill='none' stroke='%23000' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E") center/contain no-repeat;
}
.paquete__note{
  margin-top:1rem; padding:.75rem .85rem; border-radius:var(--radius-sm);
  background:var(--warm-tint); border:1px solid var(--warm-tint-2);
  font-size:.85rem; color:var(--ink-700); line-height:1.5;
  display:flex; gap:.55rem; align-items:flex-start;
}
.paquete__note-ico{ flex:0 0 auto; width:16px; height:16px; margin-top:.12rem; color:var(--warm-eyebrow); }
.paquete__note-ico svg{ width:100%; height:100%; display:block; fill:none; stroke:currentColor; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }
.paquete__cta{
  margin-top:1.5rem; display:inline-flex; align-items:center; justify-content:center; gap:.45rem;
  padding:.75rem 1rem; border-radius:999px; font-weight:700; font-size:.92rem;
  white-space:nowrap;
  background:var(--paper); color:var(--warm-eyebrow); border:1.5px solid var(--warm-tint-2);
  transition:background var(--t-fast), border-color var(--t-fast), color var(--t-fast);
}
.paquete__cta svg{ width:16px; height:16px; fill:currentColor; }
.paquete__cta:hover{ background:var(--warm-btn); border-color:var(--warm-btn); color:#fff; }
.paquete--featured .paquete__cta{ background:var(--warm-btn); border-color:var(--warm-btn); color:#fff; }
.paquete--featured .paquete__cta:hover{ background:var(--warm-btn-hover); border-color:var(--warm-btn-hover); }

.paquetes-foot{ margin-top:2rem; text-align:center; font-size:.92rem; color:var(--ink-500); max-width:50rem; margin-inline:auto; }

/* ============================================================
   CONFIANZA · trust seals
   ============================================================ */
.seals-grid{ display:grid; gap:1rem; }
@media (min-width:680px){ .seals-grid{ grid-template-columns:repeat(2,1fr); } }
.seal{
  display:flex; gap:1rem; align-items:flex-start;
  padding:1.5rem 1.4rem; border:1px solid var(--line); border-radius:var(--radius);
  background:var(--paper); transition:border-color var(--t-fast), box-shadow var(--t-fast);
}
.seal:hover{ border-color:var(--line-strong); box-shadow:var(--shadow-1); }
.seal__ico{ width:42px; height:42px; flex-shrink:0; border-radius:var(--radius-sm); background:var(--teal-tint); display:flex; align-items:center; justify-content:center; }
.seal__ico svg{ width:22px; height:22px; stroke:var(--teal-strong); fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
.seal p{ font-size:.98rem; color:var(--ink-700); padding-top:.35rem; }
.seal p strong{ color:var(--ink-900); font-weight:700; }

/* ============================================================
   CÓMO FUNCIONA · steps
   ============================================================ */
.como-grid{ display:grid; gap:2.5rem; align-items:center; }
@media (min-width:900px){ .como-grid{ grid-template-columns:.9fr 1.1fr; gap:3.5rem; } }

.como-stage{ position:relative; perspective:1300px; padding:.5rem 0; display:flex; justify-content:center; }
.como-glow{ position:absolute; inset:6% 6% 4%; z-index:0; border-radius:50%;
  background:radial-gradient(54% 50% at 50% 42%, var(--warm-soft) 0%, transparent 70%); filter:blur(8px); opacity:.5; }

.steps{ list-style:none; display:grid; gap:1.1rem; counter-reset:step; perspective:1100px; }
.step-card{
  position:relative; display:flex; align-items:flex-start; gap:1rem;
  border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:1.25rem 1.4rem; background:linear-gradient(150deg,#fff 0%,#FFFBF9 100%);
  transform-style:preserve-3d; will-change:transform;
  transform:rotateX(var(--rx,0deg)) rotateY(var(--ry,0deg));
  box-shadow:
    0 1px 2px rgba(11,14,17,.04),
    0 12px 22px -10px rgba(11,14,17,.14),
    0 26px 44px -24px rgba(232,98,61,.16);
  transition:box-shadow var(--t-base), border-color var(--t-base), transform .12s var(--ease);
}
.step-card::before{ /* soft top sheen for a glassy 3D feel */
  content:''; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background:linear-gradient(150deg, rgba(255,255,255,.6) 0%, rgba(255,255,255,0) 36%);
  transform:translateZ(1px);
}
.step-card:hover{
  border-color:var(--warm-tint-2);
  box-shadow:
    0 2px 4px rgba(11,14,17,.05),
    0 20px 32px -12px rgba(11,14,17,.20),
    0 38px 60px -26px rgba(232,98,61,.26);
}
.step-card__num{
  position:relative; width:2.7rem; height:2.7rem; flex-shrink:0; border-radius:50%;
  background:radial-gradient(120% 120% at 30% 25%, var(--warm-soft) 0%, var(--warm) 55%, var(--warm-strong) 100%);
  color:#fff; display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; font-weight:800;
  transform:translateZ(40px);
  box-shadow:0 8px 16px -4px rgba(203,77,43,.5), inset 0 1px 1px rgba(255,255,255,.4);
}
.step-card p{ font-size:1.02rem; color:var(--ink-700); padding-top:.4rem; transform:translateZ(20px); }

/* Animated WhatsApp chat inside the 3D phone */
.device--chat{ width:min(76%,16rem); --ry:15deg; --rx:6deg;
  transform:rotateY(var(--ry)) rotateX(var(--rx)) rotateZ(1deg) translateY(var(--ty)); }
@media (prefers-reduced-motion:no-preference){ .device--chat{ animation:deviceFloatR 8s var(--ease) infinite; } }
@keyframes deviceFloatR{ 0%,100%{ --ty:0px; } 50%{ --ty:-10px; } }

.chat{ height:100%; display:flex; flex-direction:column; background:#ECE5DD; }
.chat__top{ display:flex; align-items:center; gap:.5rem; padding:.65rem .65rem; background:linear-gradient(180deg,#0E7C71,#0A5F57); color:#fff; }
.chat__avatar{ width:1.75rem; height:1.75rem; border-radius:50%; background:rgba(255,255,255,.22); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:.8rem; flex-shrink:0; }
.chat__who{ display:flex; flex-direction:column; line-height:1.1; flex:1; }
.chat__who strong{ font-size:.78rem; font-weight:700; }
.chat__who small{ font-size:.58rem; opacity:.85; }
.chat__wa{ width:1.15rem; height:1.15rem; opacity:.92; flex-shrink:0; }
.chat__wa svg{ width:100%; height:100%; }
.chat__body{ flex:1; padding:.65rem .55rem; display:flex; flex-direction:column; justify-content:flex-end; gap:.4rem; overflow:hidden;
  background-image:radial-gradient(rgba(0,0,0,.035) 1px, transparent 1px); background-size:14px 14px; }
.chat__msg{ max-width:84%; padding:.42rem .58rem; border-radius:.8rem; font-size:.67rem; line-height:1.3; color:var(--ink-800); box-shadow:0 1px 1px rgba(0,0,0,.08); }
.chat__msg--in{ align-self:flex-start; background:#fff; border-top-left-radius:.2rem; }
.chat__msg--out{ align-self:flex-end; background:#DCF8C6; border-top-right-radius:.2rem; }
.chat__typing{ align-self:flex-start; background:#fff; padding:.5rem .65rem; border-radius:.8rem; border-top-left-radius:.2rem; display:inline-flex; gap:.22rem; box-shadow:0 1px 1px rgba(0,0,0,.08); }
.chat__typing i{ width:.32rem; height:.32rem; border-radius:50%; background:var(--ink-400); animation:chatTyping 1.2s infinite; }
.chat__typing i:nth-child(2){ animation-delay:.18s; }
.chat__typing i:nth-child(3){ animation-delay:.36s; }
@keyframes chatTyping{ 0%,60%,100%{ transform:translateY(0); opacity:.45; } 30%{ transform:translateY(-3px); opacity:1; } }

/* JS-driven sequential reveal (static fallback when no JS / reduced motion) */
.chat--anim .chat__msg{ display:none; }
.chat--anim .chat__msg.is-in{ display:block; animation:msgIn .32s var(--ease) both; }
@keyframes msgIn{ from{ opacity:0; transform:translateY(8px) scale(.96); } to{ opacity:1; transform:none; } }

/* ============================================================
   FAQ
   ============================================================ */
.faq-list{ max-width:46rem; margin-inline:auto; }
.faq-list details{ border:1px solid var(--line); border-radius:var(--radius); margin-bottom:.8rem; background:var(--paper); transition:border-color var(--t-fast), box-shadow var(--t-fast); }
.faq-list details[open]{ border-color:var(--warm-tint-2); box-shadow:var(--shadow-1); }
.faq-list summary{ list-style:none; cursor:pointer; padding:1.2rem 3rem 1.2rem 1.3rem; position:relative; font-size:1.05rem; font-weight:700; color:var(--ink-900); }
.faq-list summary::-webkit-details-marker{ display:none; }
.faq-list summary::after{
  content:''; position:absolute; right:1.3rem; top:50%; width:14px; height:14px; transform:translateY(-50%);
  background:var(--warm);
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 5v14M5 12h14' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 5v14M5 12h14' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat;
  transition:transform var(--t-fast);
}
.faq-list details[open] summary::after{
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 12h14' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 12h14' fill='none' stroke='%23000' stroke-width='2.5' stroke-linecap='round'/%3E%3C/svg%3E") center/contain no-repeat;
}
.faq-list details p{ padding:0 1.3rem 1.3rem; color:var(--ink-600); font-size:1rem; }

/* ============================================================
   CTA FINAL
   ============================================================ */
.cta-section{ padding-block:clamp(3.5rem,7vw,5.5rem); position:relative; overflow:hidden;
  background:linear-gradient(135deg, var(--warm-btn) 0%, var(--warm-btn-hover) 100%); color:#fff; }
.cta-section::before{
  content:''; position:absolute; inset:0; z-index:0; opacity:.32; pointer-events:none;
  background:radial-gradient(40rem 22rem at 80% -10%, var(--warm) 0%, transparent 60%);
}
.cta-inner{ position:relative; z-index:1; max-width:44rem; margin-inline:auto; text-align:center; }
.cta-title{ font-size:clamp(1.8rem,4vw,2.6rem); font-weight:800; line-height:1.12; letter-spacing:-0.025em; }
.cta-desc{ margin-top:1.1rem; font-size:1.15rem; color:#fff; }
.cta-section .btn{ margin-top:2rem; background:#fff; color:var(--warm-eyebrow); box-shadow:0 18px 40px -16px rgba(0,0,0,.4); }
.cta-section .btn:hover{ background:var(--paper-2); color:var(--warm-eyebrow); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{ border-top:1px solid var(--line); background:var(--paper-2); padding-block:2.5rem; }
.footer-inner{ display:flex; flex-wrap:wrap; gap:1.2rem 2rem; justify-content:space-between; align-items:center; }
.footer-brand{ display:flex; flex-direction:column; gap:.25rem; }
.footer-word{ font-weight:800; font-size:1.05rem; letter-spacing:-0.01em; }
.footer-word span{ font-weight:500; font-size:.82rem; color:var(--ink-500); }
.footer-copyright{ font-size:.84rem; color:var(--ink-500); margin-top:.2rem; }
.footer-back{
  display:inline-flex; align-items:center; gap:.4rem; font-size:.92rem; font-weight:600; color:var(--teal);
  max-width:30rem;
}
.footer-back:hover{ color:var(--teal-strong); }

/* ============================================================
   REVEAL MOTION
   ============================================================ */
.reveal{ opacity:0; transform:translateY(16px); transition:opacity .55s var(--ease), transform .55s var(--ease); }
.reveal.is-visible{ opacity:1; transform:none; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0 0 0 0); clip-path:inset(50%); white-space:nowrap; border:0; }
/* Hero paints immediately (LCP not gated on JS) */
.hero .reveal{ opacity:1; transform:none; }
@media (prefers-reduced-motion:no-preference){
  .hero .reveal{ animation:heroRise .6s var(--ease) both; }
}
@keyframes heroRise{ from{ transform:translateY(12px); } to{ transform:none; } }

@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  .hero-art{ animation:none; }
  *,*::before,*::after{ animation-duration:.001ms !important; animation-iteration-count:1 !important; transition-duration:.001ms !important; }
}
