/* ====== MejorIA / MIA — landing producción (self-contained) ====== */
@import url("../fonts/fonts.css");

:root{
  --ink:#183040; --teal:#30C8C0; --cyan:#00D1C2; --green:#20C058;
  --deep:#127f7a; --deep2:#0C6E66; --gray:#516470; --muted:#7c8a93;
  --bg:#F5F8FA; --dark:#0f2330; --line:rgba(24,48,64,.08);
  --shadow-card:0 20px 44px -28px rgba(24,48,64,.2);
  --shadow-lift:0 30px 56px -26px rgba(24,48,64,.32);
  --grad:linear-gradient(135deg,#30C8C0,#00D1C2);
  --maxw:1160px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; font-family:'Montserrat',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  color:var(--ink); background:#fff; -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
  font-size:16px; line-height:1.5;
}
img,video{max-width:100%; display:block;}
a{color:inherit;}
::selection{background:var(--teal); color:var(--ink);}
h1,h2,h3,h4{font-family:'Poppins',sans-serif; margin:0;}
.wrap{max-width:var(--maxw); margin:0 auto; padding-left:clamp(18px,4vw,40px); padding-right:clamp(18px,4vw,40px);}
.eyebrow{font-size:13px; font-weight:700; letter-spacing:.12em; text-transform:uppercase; color:var(--deep); margin-bottom:12px;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0;}
/* Accesibilidad: foco de teclado visible (WCAG 2.4.7) */
a:focus-visible, button:focus-visible, [tabindex]:focus-visible, .faq__q:focus-visible, .toggle button:focus-visible{
  outline:3px solid var(--deep); outline-offset:3px; border-radius:6px;
}
.btn-dark:focus-visible, .sec--dark a:focus-visible, .wa-float:focus-visible{ outline-color:#fff; }
:focus{ outline:none; } /* solo mostramos el anillo en navegación por teclado */

/* ---- botones ---- */
.btn{display:inline-flex; align-items:center; gap:10px; font-family:'Poppins',sans-serif; font-weight:600;
  text-decoration:none; border:none; cursor:pointer; border-radius:999px; transition:transform .25s ease, box-shadow .25s ease;}
.btn:hover{transform:translateY(-2px);}
.btn svg{display:block;}
.btn-primary{background:var(--teal); color:var(--dark); padding:11px 22px; font-size:15px; box-shadow:0 14px 30px -12px rgba(48,200,192,.65);}
.btn-lg{padding:16px 30px; font-size:18px;}
.btn-dark{background:var(--dark); color:#fff; padding:16px 28px; font-size:16px; box-shadow:0 14px 30px -14px rgba(15,35,48,.55);}
.btn-ghostline{background:#fff; color:var(--ink); border:1px solid var(--line); padding:13px 22px; font-size:15px; box-shadow:var(--shadow-card);}
.btn-wa{background:#25D366; color:#fff; padding:15px 26px; font-size:16px; box-shadow:0 14px 30px -12px rgba(37,211,102,.5);}
.btn-wa:hover{background:#20bd5b;}

/* ---- nav ---- */
.nav{position:sticky; top:0; z-index:50; backdrop-filter:saturate(180%) blur(14px);
  background:rgba(255,255,255,.82); border-bottom:1px solid rgba(24,48,64,.06);}
.nav .wrap{display:flex; align-items:center; justify-content:space-between; gap:20px; padding-top:14px; padding-bottom:14px;}
.nav__logo{height:clamp(34px,5.6vw,46px); width:auto;}
.nav__links{display:flex; align-items:center; gap:clamp(16px,2.2vw,30px); white-space:nowrap; flex-shrink:0;}
.nav__links a{color:var(--ink); text-decoration:none; font-size:14.5px; font-weight:600; transition:color .2s;}
.nav__links a:hover{color:var(--deep);}
@media (max-width:860px){ .nav__links{display:none;} }
/* Desplegable de guías en el nav */
.nav__drop{position:relative;}
.nav__drop-btn{display:inline-flex; align-items:center; gap:5px; background:none; border:none; padding:0; cursor:pointer; font-family:'Montserrat',sans-serif; font-size:14.5px; font-weight:600; color:var(--ink); transition:color .2s; white-space:nowrap;}
.nav__drop-btn:hover,.nav__drop:hover .nav__drop-btn,.nav__drop:focus-within .nav__drop-btn{color:var(--deep);}
.nav__chev{transition:transform .25s;}
.nav__drop:hover .nav__chev,.nav__drop:focus-within .nav__chev,.nav__drop.open .nav__chev{transform:rotate(180deg);}
.nav__drop::after{content:""; position:absolute; left:-12px; right:-12px; top:100%; height:16px;}
.nav__drop-menu{position:absolute; top:calc(100% + 12px); left:50%; transform:translateX(-50%) translateY(8px); min-width:248px; background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:0 26px 54px -22px rgba(15,35,48,.45); padding:8px; opacity:0; visibility:hidden; transition:opacity .2s, transform .2s; z-index:60;}
.nav__drop:hover .nav__drop-menu,.nav__drop:focus-within .nav__drop-menu,.nav__drop.open .nav__drop-menu{opacity:1; visibility:visible; transform:translateX(-50%) translateY(0);}
.nav__drop-menu a{display:block; padding:11px 13px; border-radius:11px; text-decoration:none; color:var(--ink); font-size:14.5px; font-weight:700; line-height:1.25; transition:background .18s, color .18s;}
.nav__drop-menu a .sub{display:block; font-weight:500; font-size:12px; color:var(--gray); margin-top:2px;}
.nav__drop-menu a:hover{background:var(--bg); color:var(--deep);}

/* ---- reveal ---- */
[data-reveal]{opacity:0; transform:translateY(28px); transition:opacity .7s cubic-bezier(.22,.61,.36,1), transform .7s cubic-bezier(.22,.61,.36,1); will-change:opacity,transform;}
[data-reveal].in{opacity:1; transform:none;}
.no-js [data-reveal]{opacity:1; transform:none;}
@media (prefers-reduced-motion:reduce){
  [data-reveal]{opacity:1!important; transform:none!important;}
  *{animation:none!important; transition:none!important; scroll-behavior:auto!important;}
}

/* ====== HERO ====== */
.hero{position:relative; width:100%; min-height:clamp(620px,92vh,920px); display:flex; align-items:center; overflow:hidden; background:#dceefa;}
.hero__video{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; object-position:72% center; z-index:0;}
.hero__veil{position:absolute; inset:0; z-index:1;
  background:linear-gradient(100deg,rgba(248,252,254,.98) 0%,rgba(248,252,254,.95) 30%,rgba(248,252,254,.66) 48%,rgba(248,252,254,.2) 62%,rgba(248,252,254,0) 76%);}
.hero .wrap{position:relative; z-index:2; width:100%; padding-top:clamp(34px,6vw,72px); padding-bottom:clamp(34px,6vw,72px);}
.hero__inner{max-width:560px;}
.hero h1{font-weight:700; font-size:clamp(31px,5.2vw,56px); line-height:1.07; letter-spacing:-.025em; margin:0 0 14px; color:var(--ink);}
.hero__lead{font-size:clamp(16.5px,2vw,20px); line-height:1.55; color:#3f5360; max-width:470px; margin:0 0 14px; font-weight:600;}
.hero__lead strong{color:var(--ink); font-weight:700;}
.hero__diff{color:var(--deep); font-weight:700;}
.hero__cta{display:flex; flex-wrap:wrap; align-items:center; gap:14px; margin:22px 0 18px;}
.hero__micro{font-size:14px; color:var(--gray); font-weight:600;}
.hero__stats{display:flex; flex-wrap:wrap; gap:26px; padding-top:18px; border-top:1px solid rgba(24,48,64,.12);}
.hero__stats .n{font-family:'Poppins',sans-serif; font-weight:700; font-size:23px; color:var(--ink);}
.hero__stats .l{font-size:13px; color:var(--gray); font-weight:600;}
@media (max-width:760px){
  /* Overlay tipo desktop: el vídeo de MIA llena el hero (autoplay+loop) y el texto va
     ENCIMA, a la IZQUIERDA, sobre un velo horizontal que deja a MIA nítida a la derecha */
  .hero{min-height:clamp(540px,88vh,720px);}
  .hero__video{object-position:66% center;}
  .hero__veil{background:linear-gradient(94deg,rgba(245,248,250,.99) 0%,rgba(245,248,250,.98) 34%,rgba(245,248,250,.82) 50%,rgba(245,248,250,.34) 66%,rgba(245,248,250,0) 82%);}
  .hero .wrap{padding-top:clamp(28px,7vw,52px); padding-bottom:clamp(28px,7vw,52px);}
  .hero__inner{max-width:64%;}
  .hero h1{font-size:clamp(25px,6.4vw,40px);}
  .hero__lead{max-width:100%;}
}

/* trust strip (garantías arriba) */
.trustbar{background:#fff; border-bottom:1px solid var(--line);}
.trustbar .wrap{display:flex; flex-wrap:wrap; gap:14px 28px; justify-content:center; padding-top:16px; padding-bottom:16px;}
.trustbar .item{display:inline-flex; align-items:center; gap:9px; font-size:14px; font-weight:600; color:var(--ink);}
.trustbar .item svg{color:var(--green); flex:none;}

/* ====== SECTION base ====== */
section{position:relative;}
.sec{padding-top:clamp(40px,5.5vw,72px); padding-bottom:clamp(40px,5.5vw,72px);}
.sec--bg{background:var(--bg);}
.sec--dark{background:var(--dark); color:#fff;}
.sec-head{text-align:center; max-width:620px; margin:0 auto clamp(34px,5vw,56px);}
.sec-head h2{font-weight:700; font-size:clamp(28px,4.6vw,46px); line-height:1.08; letter-spacing:-.025em; color:var(--ink);}
.sec--dark .sec-head h2{color:#fff;}

/* ====== PROBADOR (scroll-driven chat) ====== */
.probador{position:relative; height:300vh; background:var(--bg);}
.probador__sticky{position:sticky; top:0; height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center; padding:24px 18px; overflow:hidden;}
.probador__glow1{position:absolute; width:min(560px,60vw); aspect-ratio:1; border-radius:50%; background:radial-gradient(circle,rgba(48,200,192,.16),transparent 66%); top:4%; left:4%; pointer-events:none;}
.probador__glow2{position:absolute; width:min(520px,55vw); aspect-ratio:1; border-radius:50%; background:radial-gradient(circle,rgba(0,209,194,.14),transparent 66%); bottom:2%; right:4%; pointer-events:none;}
.probador__head{text-align:center; margin-bottom:clamp(8px,1.8vh,18px); max-width:560px; position:relative; z-index:2;}
.probador__head h2{font-weight:700; font-size:clamp(23px,4vw,38px); line-height:1.1; letter-spacing:-.02em; color:var(--ink);}
/* Grid 1fr·auto·1fr → el móvil (columna central) queda SIEMPRE centrado, sin importar el ancho de los laterales */
.probador__stage{display:grid; grid-template-columns:1fr auto 1fr; align-items:center; column-gap:clamp(0px,4vw,52px); width:100%; max-width:1040px; margin:0 auto; position:relative; z-index:2;}

.stepper{display:flex; flex-direction:column; gap:20px; width:212px; flex:none; justify-self:end;}
.stepper .step{display:flex; align-items:center; gap:14px;}
.stepper .dot{width:30px; height:30px; flex:none; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:13px; font-weight:700; font-family:'Poppins',sans-serif; background:#e3eaee; color:#9aa8b0; transition:all .4s cubic-bezier(.22,.61,.36,1);}
.stepper .lbl{font-size:14.5px; font-weight:600; color:#9aa8b0; transition:color .4s, font-weight .4s;}
.stepper .step.on .dot{background:var(--teal); color:var(--dark);}
.stepper .step.on .lbl{color:#3f8f8a;}
.stepper .step.active .dot{box-shadow:0 0 0 5px rgba(48,200,192,.18); transform:scale(1.08);}
.stepper .step.active .lbl{color:var(--ink); font-weight:700;}

/* phone */
.phone{position:relative; width:min(330px,86vw); aspect-ratio:330/660; max-height:min(620px,64vh); background:var(--dark); border-radius:42px; padding:11px; flex:none;
  box-shadow:0 40px 80px -28px rgba(24,48,64,.5),0 0 0 1px rgba(24,48,64,.06);}
.phone__notch{position:absolute; top:18px; left:50%; transform:translateX(-50%); width:108px; height:26px; background:var(--dark); border-radius:0 0 16px 16px; z-index:6;}
.phone__scr{position:relative; width:100%; height:100%; background:#EAF0F2; border-radius:32px; overflow:hidden; display:flex; flex-direction:column;}
.chat__top{display:flex; align-items:center; gap:10px; padding:30px 14px 12px; background:#fff; border-bottom:1px solid rgba(24,48,64,.06); z-index:4;}
.chat__av{width:38px; height:38px; border-radius:50%; overflow:hidden; flex:none; box-shadow:0 0 0 2px rgba(48,200,192,.3); background:#d7eeec;}
.chat__name{font-family:'Poppins',sans-serif; font-weight:600; font-size:15px; color:var(--ink); line-height:1.1;}
.chat__on{font-size:11.5px; color:var(--green); font-weight:600; display:flex; align-items:center; gap:5px;}
.chat__on i{width:6px; height:6px; border-radius:50%; background:var(--green); display:inline-block;}
.chat__icons{display:flex; gap:12px; color:#9aa8b0; margin-left:auto;}
.chat__body{flex:1; display:flex; flex-direction:column; justify-content:flex-end; gap:8px; padding:14px 12px 16px; overflow:hidden; background:linear-gradient(180deg,#EAF0F2,#F5F8FA);}

.bubble{animation:bubble .4s ease both; font-size:13.5px; line-height:1.42; font-weight:500;}
.bubble.hidden{display:none;}
.b-user{align-self:flex-end; max-width:80%; background:#D8F3EF; color:var(--dark); padding:9px 13px; border-radius:16px 16px 4px 16px; box-shadow:0 1px 2px rgba(24,48,64,.07);}
.b-mia{align-self:flex-start; max-width:86%; background:#fff; color:var(--dark); padding:9px 13px; border-radius:16px 16px 16px 4px; box-shadow:0 1px 2px rgba(24,48,64,.07);}
.b-file{align-self:flex-end; max-width:78%; background:#fff; padding:8px; border-radius:14px 14px 4px 14px; box-shadow:0 1px 3px rgba(24,48,64,.1);}
.b-file .row{display:flex; align-items:center; gap:9px; padding:6px;}
.b-file .ic{width:34px; height:42px; border-radius:5px; background:var(--grad); display:flex; align-items:center; justify-content:center; color:#fff; flex:none;}
.b-file .fn{font-size:12.5px; font-weight:600; color:var(--ink);}
.b-file .meta{font-size:11px; color:#8a98a0;}
.typing{align-self:flex-start; background:#fff; padding:12px 15px; border-radius:16px 16px 16px 4px; box-shadow:0 1px 2px rgba(24,48,64,.07); display:flex; gap:5px;}
.typing i{width:7px; height:7px; border-radius:50%; background:var(--teal); animation:typedot 1.2s infinite;}
.typing i:nth-child(2){animation-delay:.2s;} .typing i:nth-child(3){animation-delay:.4s;}
.b-analyze{align-self:flex-start; max-width:88%; background:#fff; padding:13px 14px; border-radius:16px 16px 16px 4px; box-shadow:0 1px 3px rgba(24,48,64,.08);}
.b-analyze .t{font-size:13px; font-weight:600; color:var(--ink); margin-bottom:10px; display:flex; align-items:center; gap:7px;}
.b-analyze .t svg{color:var(--teal);}
.b-analyze .bar{position:relative; height:7px; border-radius:99px; background:#EAF0F2; overflow:hidden;}
.b-analyze .bar i{position:absolute; top:0; width:40%; height:100%; border-radius:99px; background:linear-gradient(90deg,#30C8C0,#00D1C2); animation:scan 1.3s ease-in-out infinite;}
.b-analyze .li{margin-top:9px; display:flex; flex-direction:column; gap:5px; font-size:11.5px; color:var(--muted); font-weight:500;}
.b-result{align-self:flex-start; max-width:90%; background:#fff; padding:14px; border-radius:16px 16px 16px 4px; box-shadow:0 4px 14px rgba(24,48,64,.12);}
.b-result .lead{font-size:13px; color:var(--gray); line-height:1.45; margin-bottom:10px; font-weight:500;}
.b-result .amt{display:flex; align-items:baseline; gap:8px; padding:11px 14px; background:rgba(32,192,88,.08); border-radius:12px;}
.b-result .amt .v{font-family:'Poppins',sans-serif; font-weight:700; font-size:26px; color:var(--green); line-height:1;}
.b-result .amt .u{font-size:13px; color:var(--gray); font-weight:600;}
.b-cta{align-self:stretch; margin-top:4px; display:flex; align-items:center; justify-content:center; gap:8px; background:var(--teal); color:var(--dark); font-family:'Poppins',sans-serif; font-weight:600; font-size:14.5px; text-decoration:none; padding:13px; border-radius:14px; box-shadow:0 6px 16px -6px rgba(48,200,192,.6);}
.probador__note{margin-top:8px; font-size:11.5px; color:var(--muted); font-weight:500; text-align:center; max-width:330px;}
.probador__steplabel{margin-top:clamp(8px,1.6vh,16px); font-size:13.5px; color:var(--muted); font-weight:600; min-height:20px; text-align:center; position:relative; z-index:2;}

/* MIA working side */
.mia-side{position:relative; width:clamp(208px,18.5vw,276px); flex:none; align-self:center; justify-self:start;}
.mia-side__halo{position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); width:150%; aspect-ratio:1; background:radial-gradient(circle,rgba(48,200,192,.34),rgba(0,209,194,.06) 52%,transparent 67%); z-index:0; animation:blob 12s ease-in-out infinite;}
.mia-side__card{position:relative; z-index:1; width:100%; padding:9px; border-radius:30px; background:linear-gradient(160deg,#fff,#eaf4f5); animation:float 7s ease-in-out infinite;
  box-shadow:0 30px 60px -28px rgba(15,35,48,.5),0 2px 10px -4px rgba(15,35,48,.25),inset 0 0 0 1px rgba(255,255,255,.7);}
/* aspect-ratio = el del vídeo re-derivado de la fuente HD (600×744), sin barras negras */
.mia-side__vidwrap{position:relative; width:100%; aspect-ratio:600/744; overflow:hidden; border-radius:22px; -webkit-mask-image:radial-gradient(150% 140% at 50% 49%,#000 72%,rgba(0,0,0,0) 100%); mask-image:radial-gradient(150% 140% at 50% 49%,#000 72%,rgba(0,0,0,0) 100%);}
/* scale(1.04) hace que el vídeo rebose ~2% el marco → elimina de raíz cualquier seam/línea de 1px en los bordes */
.mia-side__vidwrap video{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transform:scale(1.04);}
.mia-side__bubble{position:absolute; z-index:3; bottom:11%; right:-22%; background:#fff; border-radius:16px 16px 4px 16px; padding:10px 14px; box-shadow:0 16px 32px -16px rgba(24,48,64,.32); font-size:13px; font-weight:600; color:var(--ink); max-width:158px; line-height:1.35; text-align:right;}

@media (max-width:900px){
  /* El chat sigue ligado al scroll TAMBIÉN en móvil (sticky): solo ocultamos los laterales
     y encogemos el teléfono para que quepa con el título arriba y la etiqueta de paso abajo */
  .stepper, .mia-side{display:none;}
  .probador__stage{display:flex; justify-content:center; column-gap:0;}
  .probador{height:240vh;}
  .probador__sticky{padding:18px 16px;}
  .probador__head{margin-bottom:8px;}
  /* altura EXPLÍCITA (no via aspect-ratio): así el height:100% del .phone__scr resuelve
     en iOS y el contenido blanco no se sale del marco redondeado */
  .phone{width:min(236px,64vw); height:min(472px,56vh); max-height:none; aspect-ratio:auto;}
  .phone__scr{-webkit-transform:translateZ(0); transform:translateZ(0);}  /* iOS: fuerza el recorte de las esquinas redondeadas */
  .chat__icons{display:none;}  /* teléfono estrecho: liberamos ancho para que "MIA · MejorIA" no se parta */
  .probador__note{max-width:320px;}
}

/* Sin JS el chat no puede animarse por scroll: colapsamos el tramo de 380vh,
   mostramos la conversación completa y ocultamos los indicadores "escribiendo…". */
.no-js .probador{height:auto;}
.no-js .probador__sticky{position:static; height:auto; min-height:0; padding:48px 18px;}
.no-js .stepper, .no-js .mia-side{display:none;}
.no-js .bubble[data-typing]{display:none;}

/* ====== CÓMO FUNCIONA ====== */
.steps{display:flex; flex-wrap:wrap; gap:clamp(18px,2.5vw,28px);}
.step-card{flex:1 1 260px; min-width:240px; background:#fff; border:1px solid var(--line); border-radius:24px; padding:clamp(24px,3vw,34px); box-shadow:var(--shadow-card); transition:transform .3s, box-shadow .3s, background .35s, border-color .35s;}
.step-card:hover, .step-card:focus-within{transform:translateY(-6px); box-shadow:var(--shadow-lift); background:linear-gradient(165deg,#eafaf8,#fff); border-color:rgba(48,200,192,.45);}
.step-card .ic{width:48px; height:48px; border-radius:14px; display:flex; align-items:center; justify-content:center; margin-bottom:18px; background:var(--bg); color:var(--teal); transition:background .35s, color .35s, transform .35s;}
.step-card:hover .ic{background:var(--teal); color:#fff; transform:scale(1.08) rotate(-4deg);}
.step-card .num{font-family:'Poppins',sans-serif; font-weight:700; font-size:14px; margin-bottom:8px; color:var(--teal);}
.step-card h3{font-weight:600; font-size:21px; margin:0 0 10px; color:var(--ink);}
.step-card p{font-size:16px; line-height:1.55; color:var(--gray); margin:0; font-weight:500;}

/* ====== GARANTÍAS ====== */
.guarantees{display:flex; flex-wrap:wrap; gap:clamp(14px,2vw,22px);}
.guar{flex:1 1 220px; min-width:200px; background:var(--bg); border-radius:20px; padding:26px 24px; border:1px solid rgba(24,48,64,.05); cursor:pointer; position:relative; transition:transform .3s, box-shadow .3s, background .35s, border-color .35s;}
.guar:hover, .guar:focus-visible{transform:translateY(-5px); box-shadow:var(--shadow-lift); background:#fff; border-color:rgba(48,200,192,.4);}
.guar .ic{width:42px; height:42px; border-radius:12px; background:#fff; color:var(--teal); display:flex; align-items:center; justify-content:center; margin-bottom:16px; box-shadow:0 6px 16px -10px rgba(24,48,64,.3); transition:background .35s, color .35s, transform .35s;}
.guar:hover .ic{background:var(--teal); color:#fff; transform:scale(1.08);}
.guar .t{font-family:'Poppins',sans-serif; font-weight:600; font-size:17px; color:var(--ink); margin-bottom:6px;}
.guar .s{font-size:14px; color:var(--muted); font-weight:500; line-height:1.5;}
.guar__more{display:inline-block; margin-top:12px; font-size:13px; font-weight:700; color:var(--deep); opacity:.6; transition:opacity .25s, transform .25s;}
.guar:hover .guar__more, .guar:focus-visible .guar__more{opacity:1; transform:translateX(3px);}

/* ====== PARTICULAR/EMPRESA ====== */
.toggle{display:inline-flex; padding:5px; background:var(--bg); border-radius:999px; border:1px solid rgba(24,48,64,.07);}
.toggle button{border:none; cursor:pointer; font-family:'Poppins',sans-serif; font-weight:600; font-size:15px; padding:11px 26px; border-radius:999px; transition:all .3s; background:transparent; color:var(--muted);}
.toggle button.on{background:var(--teal); color:var(--dark); box-shadow:0 6px 16px -8px rgba(48,200,192,.7);}
.plan{max-width:1080px; margin:0 auto; background:#fff; border:1px solid var(--line); border-radius:28px; padding:clamp(28px,4vw,48px); box-shadow:0 30px 60px -36px rgba(24,48,64,.28); display:flex; flex-wrap:wrap; gap:clamp(24px,4vw,48px); align-items:center;}
.plan__main{flex:1 1 280px; min-width:260px;}
.plan__tag{display:inline-flex; align-items:center; gap:8px; padding:6px 13px; border-radius:999px; background:rgba(48,200,192,.12); color:var(--deep); font-size:13px; font-weight:700; margin-bottom:18px;}
.plan__main h3{font-weight:700; font-size:clamp(22px,3vw,30px); line-height:1.15; margin:0 0 14px; color:var(--ink);}
.plan__main p{font-size:16.5px; line-height:1.6; color:var(--gray); margin:0; font-weight:500;}
.plan__points{flex:1 1 240px; min-width:230px; display:flex; flex-direction:column; gap:14px;}
.plan__points .pt{display:flex; align-items:flex-start; gap:12px;}
.plan__points .pt .tk{width:24px; height:24px; border-radius:50%; background:rgba(32,192,88,.14); color:var(--green); display:inline-flex; align-items:center; justify-content:center; flex:none; margin-top:1px;}
.plan__points .pt span{font-size:16px; color:var(--ink); font-weight:600; line-height:1.4;}

/* ====== STATS (prueba social) ====== */
.stats-card{max-width:600px; margin:0 auto;}
.stats-card .inner{background:var(--dark); color:#fff; border-radius:32px; padding:clamp(36px,5vw,56px) clamp(28px,4vw,48px); box-shadow:0 40px 80px -36px rgba(15,35,48,.55); display:flex; flex-direction:column; gap:clamp(22px,3vw,32px); text-align:center;}
.stats-card .big{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(46px,7vw,74px); line-height:1; letter-spacing:-.03em; color:#fff;}
.stats-card .big.teal{color:var(--teal);}
.stats-card .sub{font-size:16px; color:#9fb3bd; margin-top:10px; font-weight:500;}
.stats-card .div{height:1px; width:64%; margin:0 auto; background:rgba(255,255,255,.12);}

/* ====== MANIFIESTO ====== */
.manifesto{max-width:900px; margin:0 auto; text-align:center;}
.manifesto h2{font-weight:700; font-size:clamp(27px,4.6vw,50px); line-height:1.14; letter-spacing:-.025em; margin:0 0 22px; color:var(--ink); text-wrap:balance;}
.manifesto p{font-size:clamp(16.5px,2.2vw,21px); line-height:1.6; color:var(--gray); max-width:620px; margin:0 auto; font-weight:500;}
.manifesto p strong{color:var(--ink); font-weight:700;}

/* ====== MARQUEE ====== */
.marquee-sec{padding:clamp(44px,6vw,68px) 0; border-top:1px solid rgba(24,48,64,.05); border-bottom:1px solid rgba(24,48,64,.05); overflow:hidden;}
.marquee-sec .lead{text-align:center; font-size:15px; font-weight:600; color:var(--muted); margin-bottom:34px; padding:0 20px;}
.marquee-sec .lead strong{color:var(--ink); font-weight:700;}
.marquee{position:relative; width:100%; -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);}
/* Loop continuo sin huecos: el espaciado va en margin-right de CADA item (no en gap del track).
   Así el ancho total = 2× el ancho de un grupo exacto y translateX(-50%) cuadra sin saltos. */
.marquee__track{display:flex; width:max-content; align-items:center; animation:marquee 42s linear infinite;}
.marquee__item{display:flex; align-items:center; flex:none; margin-right:46px;}
/* grayscale unifica las marcas; brightness baja el trazo para que las claras (Endesa, TotalEnergies, Plenitude) no desaparezcan sobre fondo blanco */
.marquee__item img{height:30px; width:auto; max-width:180px; object-fit:contain; filter:grayscale(1) brightness(.55); opacity:.78; display:block; vertical-align:middle; transition:filter .25s,opacity .25s;}
.marquee:hover .marquee__item img{filter:grayscale(0) brightness(1); opacity:1;}
.marquee__item .name{font-family:'Poppins',sans-serif; font-weight:700; font-size:19px; color:#9aa8b0; letter-spacing:-.01em;}
.marquee-note{text-align:center; font-size:11px; color:#aab6bd; margin-top:28px; font-weight:500; padding:0 20px;}
.marquee:hover .marquee__track{animation-play-state:paused;}

/* ====== MIA SIGUE / vigilancia ====== */
.followup{display:flex; flex-wrap:wrap; align-items:center; gap:clamp(36px,5vw,72px);}
.followup__l{flex:1 1 320px; min-width:280px;}
.followup__l h2{font-weight:700; font-size:clamp(27px,4.4vw,44px); line-height:1.1; letter-spacing:-.025em; margin:0 0 16px; color:var(--ink);}
.followup__l p{font-size:clamp(16px,2vw,18.5px); line-height:1.6; color:var(--gray); margin:0 0 18px; font-weight:500;}
.followup__price{font-size:14px; color:var(--gray); font-weight:600; margin:0 0 22px;}
.followup__price b{color:var(--ink);}
.followup__btns{display:flex; flex-wrap:wrap; gap:12px; align-items:stretch;}
/* Ambos botones del MISMO tamaño (igual base y crecimiento), sea cual sea su clase base */
.followup__btns .btn{flex:1 1 235px; justify-content:center; padding:16px 22px; font-size:16.5px;}
.followup__r{flex:1 1 300px; min-width:280px; display:flex; flex-direction:column; gap:14px;}
.fcard{background:#fff; border-radius:18px; padding:18px 20px; box-shadow:0 14px 34px -22px rgba(24,48,64,.3); display:flex; align-items:center; gap:14px; cursor:pointer; position:relative; transition:transform .3s, box-shadow .3s, background .35s;}
.fcard:hover, .fcard:focus-visible{transform:translateY(-4px); box-shadow:var(--shadow-lift); background:linear-gradient(165deg,#eafaf8,#fff);}
.fcard .ic{width:42px; height:42px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex:none; background:rgba(48,200,192,.12); color:var(--teal); transition:transform .35s;}
.fcard:hover .ic{transform:scale(1.1);}
.fcard .ic.green{background:rgba(32,192,88,.14); color:var(--green);}
.fcard .t{font-weight:700; font-size:15px; color:var(--ink);}
.fcard .s{font-size:13.5px; color:var(--muted); font-weight:500;}
.fcard__more{margin-left:auto; width:28px; height:28px; flex:none; border-radius:50%; background:var(--bg); color:var(--deep); display:flex; align-items:center; justify-content:center; font-size:19px; font-weight:400; line-height:1; transition:background .25s, color .25s, transform .25s;}
.fcard:hover .fcard__more, .fcard:focus-visible .fcard__more{background:var(--teal); color:#fff; transform:rotate(90deg);}

/* ====== MIA STORY ====== */
.story{display:flex; flex-wrap:wrap; align-items:center; gap:clamp(30px,5vw,64px);}
.story__img{flex:1 1 300px; min-width:260px; display:flex; justify-content:center;}
.story__img img{width:min(440px,92%); height:auto; border-radius:24px; background:linear-gradient(160deg,#fff,#eaf4f5); padding:10px; box-shadow:0 30px 60px -30px rgba(15,35,48,.4);}
.story__txt{flex:1 1 380px; min-width:300px;}
.story__txt h2{font-weight:700; font-size:clamp(26px,4.2vw,42px); line-height:1.12; letter-spacing:-.02em; margin:0 0 16px; color:var(--ink);}
.story__txt p{font-size:clamp(15.5px,1.9vw,17.5px); line-height:1.65; color:var(--gray); margin:0 0 12px; font-weight:500;}
.story__txt p strong{color:var(--ink); font-weight:700;}

/* ====== QUIÉN DETRÁS ====== */
.behind{text-align:center;}
.behind__cards{display:flex; flex-wrap:wrap; gap:clamp(14px,2vw,22px); justify-content:center;}
.behind__card{flex:1 1 240px; max-width:340px; background:#fff; border-radius:20px; padding:30px 26px; box-shadow:0 18px 40px -28px rgba(24,48,64,.26);}
.behind__card .n{font-family:'Poppins',sans-serif; font-weight:700; font-size:32px; color:var(--ink);}
.behind__card .n.teal{color:var(--teal);}
.behind__card .l{font-size:15px; color:var(--muted); font-weight:500; margin-top:6px;}


/* ====== FAQ ====== */
.faq{max-width:780px; margin:0 auto;}
.faq__item{background:#fff; border:1px solid rgba(24,48,64,.09); border-radius:18px; overflow:hidden; margin-bottom:12px;}
.faq__q{width:100%; display:flex; align-items:center; justify-content:space-between; gap:16px; padding:20px 22px; background:none; border:none; cursor:pointer; text-align:left; font-family:'Montserrat',sans-serif;}
.faq__q span{font-size:17px; font-weight:600; color:var(--ink);}
.faq__q .ico{width:28px; height:28px; flex:none; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; font-size:20px; font-weight:400; transition:transform .3s, background .3s, color .3s; background:var(--bg); color:var(--teal);}
.faq__item.open .faq__q .ico{transform:rotate(45deg); background:var(--teal); color:var(--dark);}
.faq__a{overflow:hidden; max-height:0; opacity:0; transition:max-height .4s cubic-bezier(.22,.61,.36,1), opacity .35s;}
.faq__item.open .faq__a{max-height:320px; opacity:1;}
.faq__a p{margin:0; padding:0 22px 22px; font-size:15.5px; line-height:1.6; color:var(--gray); font-weight:500;}

/* ====== CTA FINAL + FOOTER ====== */
.final{text-align:center; max-width:720px; margin:0 auto;}
.final h2{font-weight:700; font-size:clamp(28px,4.6vw,48px); line-height:1.06; letter-spacing:-.03em; margin:0 0 16px; color:#fff; text-wrap:balance;}
.final p{font-size:clamp(16.5px,2.2vw,20px); line-height:1.55; color:#9fb3bd; max-width:480px; margin:0 auto 30px; font-weight:500;}
.foot{border-top:1px solid rgba(255,255,255,.1); margin-top:clamp(36px,5vw,56px);}
/* Footer oficial autónomo (páginas legales, sin sección CTA encima) */
.foot--standalone{background:var(--dark); color:#fff; margin-top:0; padding:clamp(40px,5vw,60px) 0 clamp(28px,4vw,40px);}
.foot .grid{display:flex; flex-wrap:wrap; gap:28px; justify-content:space-between; align-items:flex-start; margin-bottom:32px;}
.foot__brand{flex:1 1 280px; max-width:380px;}
.foot__logo{display:inline-block; background:#fff; padding:10px 16px; border-radius:12px; margin-bottom:16px;}
.foot__logo img{height:30px; width:auto;}
.foot__brand p{font-size:14px; line-height:1.6; color:#7e909a; margin:0; font-weight:500;}
.foot__cols{display:flex; flex-wrap:wrap; gap:48px;}
.foot__col{display:flex; flex-direction:column; gap:11px;}
.foot__col .h{font-size:12px; font-weight:700; letter-spacing:.1em; text-transform:uppercase; color:#5e7079; margin-bottom:2px;}
.foot__col a{color:#cfdbe1; text-decoration:none; font-size:14.5px; font-weight:500;}
.foot__col a:hover{color:#fff;}
.foot__legal{padding-top:24px; border-top:1px solid rgba(255,255,255,.08); display:flex; flex-wrap:wrap; gap:14px; justify-content:space-between; align-items:center;}
.foot__legal .c{font-size:12.5px; color:#5e7079; font-weight:500;}
.foot__legal .d{font-size:11.5px; color:#5e7079; font-weight:500; max-width:520px; line-height:1.5; text-align:right;}

/* ====== MODAL ====== */
.modal{position:fixed; inset:0; z-index:300; background:rgba(15,35,48,.55); backdrop-filter:blur(5px); display:flex; align-items:center; justify-content:center; padding:20px;}
.modal[hidden]{display:none;}
.modal__box{background:#fff; border-radius:28px; max-width:480px; width:100%; padding:clamp(28px,4vw,40px); box-shadow:0 50px 100px -30px rgba(15,35,48,.6); position:relative; animation:bubble .35s ease both; max-height:90vh; overflow:auto;}
.modal__close{position:absolute; top:16px; right:16px; width:36px; height:36px; border-radius:50%; border:none; background:var(--bg); color:var(--gray); cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:22px; line-height:1;}
.modal__iconwrap{width:56px; height:56px; border-radius:16px; display:flex; align-items:center; justify-content:center; margin-bottom:20px; background:rgba(48,200,192,.12); color:var(--teal);}
.modal__tag{display:inline-flex; align-items:center; padding:5px 12px; border-radius:999px; background:var(--bg); font-size:12px; font-weight:700; letter-spacing:.04em; text-transform:uppercase; color:var(--deep); margin-bottom:14px;}
.modal__box h3{font-weight:700; font-size:clamp(22px,3vw,28px); line-height:1.15; letter-spacing:-.02em; margin:0 0 12px; color:var(--ink);}
.modal__box>p{font-size:16px; line-height:1.6; color:var(--gray); margin:0 0 22px; font-weight:500;}
.modal__rows{display:flex; flex-direction:column; gap:14px; margin-bottom:26px;}
.modal__rows .r{display:flex; align-items:flex-start; gap:12px;}
.modal__rows .r .tk{width:26px; height:26px; flex:none; border-radius:50%; background:rgba(48,200,192,.14); color:var(--teal); display:inline-flex; align-items:center; justify-content:center; margin-top:1px;}
.modal__rows .r span{font-size:15.5px; line-height:1.5; color:var(--ink); font-weight:500;}
.modal__price{font-size:14px; color:var(--gray); font-weight:600; margin:0 0 18px; padding:12px 14px; background:var(--bg); border-radius:12px;}
.modal__price b{color:var(--ink);}
.modal__cta{display:flex; align-items:center; justify-content:center; gap:9px; background:var(--teal); color:var(--dark); font-family:'Poppins',sans-serif; font-weight:600; font-size:16px; text-decoration:none; padding:15px; border-radius:999px; box-shadow:0 14px 30px -12px rgba(48,200,192,.6);}

/* ====== LEGAL PAGES ====== */
.legal{max-width:820px; margin:0 auto; padding:clamp(40px,6vw,80px) clamp(18px,4vw,40px);}
.legal h1{font-weight:700; font-size:clamp(28px,4.6vw,44px); line-height:1.08; letter-spacing:-.02em; margin:0 0 8px; color:var(--ink);}
.legal .updated{font-size:13px; color:var(--muted); font-weight:600; margin-bottom:28px;}
.legal h2{font-weight:700; font-size:clamp(18px,2.6vw,22px); color:var(--deep2); margin:28px 0 8px;}
.legal h3{font-weight:600; font-size:16px; color:var(--ink); margin:18px 0 6px;}
.legal p, .legal li{font-size:15.5px; line-height:1.7; color:#3f5360; font-weight:500;}
.legal ul{padding-left:20px;} .legal li{margin:5px 0;}
.legal strong{color:var(--ink);}
.legal a{color:var(--deep); text-decoration:underline;}
.legal table{border-collapse:collapse; width:100%; margin:12px 0; font-size:13.5px;}
.legal th,.legal td{border:1px solid var(--line); padding:8px 10px; text-align:left; vertical-align:top;}
.legal th{background:var(--bg); color:var(--ink); font-family:'Poppins';}
.legal .back{display:inline-block; margin-top:32px; font-weight:600; color:var(--deep); text-decoration:none;}
.legalnav{border-bottom:1px solid var(--line);}
.legalnav .wrap{display:flex; align-items:center; justify-content:space-between; padding:14px clamp(18px,4vw,40px);}
.legalnav img{height:36px;}
.legalnav a.home{font-size:13px; font-weight:600; color:var(--gray); text-decoration:none;}

/* ====== CTA historia + botón flotante WhatsApp ====== */
.story-cta{display:inline-flex; align-items:center; gap:8px; margin-top:20px; font-family:'Poppins',sans-serif; font-weight:600; font-size:16px; color:var(--deep); text-decoration:none; transition:gap .2s;}
.story-cta:hover{gap:12px; text-decoration:underline;}
.wa-float{position:fixed; right:18px; bottom:18px; z-index:200; width:58px; height:58px; border-radius:50%; background:#25D366; color:#fff; display:flex; align-items:center; justify-content:center; box-shadow:0 14px 30px -8px rgba(0,0,0,.35); transition:transform .25s ease, box-shadow .25s ease;}
.wa-float:hover{transform:translateY(-3px) scale(1.06); box-shadow:0 18px 38px -10px rgba(0,0,0,.4);}
@media (max-width:760px){ .wa-float{width:54px; height:54px; right:14px; bottom:14px;} }
@media print{ .wa-float{display:none;} }

/* ====== skip link ====== */
.skip{position:absolute; left:8px; top:-60px; z-index:400; background:var(--ink); color:#fff; padding:10px 16px; border-radius:8px; font-weight:600; text-decoration:none; transition:top .2s;}
.skip:focus-visible{top:8px;}

/* ====== nav móvil / hamburguesa ====== */
.nav__burger{display:none; width:42px; height:42px; border:none; background:none; cursor:pointer; flex-direction:column; justify-content:center; gap:5px; padding:0;}
.nav__burger span{display:block; width:24px; height:2px; background:var(--ink); margin:0 auto; border-radius:2px; transition:.25s;}
.nav__burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav__burger[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav__burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}
.nav__mobile{flex-direction:column; gap:2px; padding:8px clamp(18px,4vw,40px) 18px; background:rgba(255,255,255,.98); border-bottom:1px solid var(--line);}
.nav__mobile:not([hidden]){display:flex;}
.nav__mobile a{padding:13px 6px; text-decoration:none; color:var(--ink); font-weight:600; font-size:16px; border-bottom:1px solid var(--line);}
.nav__mobile a.btn-primary{border-bottom:none; margin-top:10px; justify-content:center; color:var(--dark);}
@media (max-width:860px){ .nav__burger{display:flex;} .nav .wrap > a.btn-primary{display:none;} }
@media (min-width:861px){ .nav__mobile{display:none!important;} }

/* ====== lead magnet ====== */
.leadmagnet{display:flex; flex-wrap:wrap; align-items:center; gap:clamp(24px,4vw,48px); background:linear-gradient(135deg,#eafaf8,#ffffff); border:1px solid var(--line); border-radius:28px; padding:clamp(28px,4vw,48px); box-shadow:var(--shadow-card);}
.leadmagnet__txt{flex:1 1 320px; min-width:280px;}
.leadmagnet__txt h2, .leadmagnet__txt h3{font-weight:700; font-size:clamp(24px,3.4vw,36px); line-height:1.12; letter-spacing:-.02em; margin:6px 0 12px; color:var(--ink);}
.leadmagnet__txt p{font-size:16.5px; line-height:1.6; color:var(--gray); margin:0; font-weight:500;}
.leadmagnet__form{flex:1 1 300px; min-width:280px; display:flex; flex-direction:column; gap:14px;}
.leadmagnet__form input[type=email]{width:100%; padding:15px 18px; border:1.5px solid var(--line); border-radius:14px; font-family:'Montserrat',sans-serif; font-size:16px; color:var(--ink); background:#fff;}
.leadmagnet__form input[type=email]:focus{outline:none; border-color:var(--teal); box-shadow:0 0 0 4px rgba(48,200,192,.15);}
.leadmagnet__consent{display:flex; align-items:flex-start; gap:10px; font-size:13.5px; line-height:1.5; color:var(--gray); font-weight:500; cursor:pointer;}
.leadmagnet__consent input{margin-top:3px; width:18px; height:18px; flex:none; accent-color:var(--teal);}
.leadmagnet__consent a{color:var(--deep); text-decoration:underline;}
.leadmagnet__form button{justify-content:center;}
.leadmagnet__msg{font-size:14px; font-weight:600; margin:2px 0 0; min-height:18px;}
.leadmagnet__msg.ok{color:var(--green);}
.leadmagnet__msg.err{color:#d23f3f;}

/* ====== Selector de compañía (guía por WhatsApp) ====== */
.company-pick{margin-top:6px;}
.company-pick__q{font-family:'Poppins',sans-serif; font-weight:700; font-size:15px; color:var(--ink); margin-bottom:12px;}
.company-pick__grid{display:grid; grid-template-columns:repeat(2,1fr); gap:10px;}
.company-pick__grid--single{grid-template-columns:1fr;}
.company-chip--cta{background:var(--grad); color:#fff; border-color:transparent; font-size:16.5px; padding:17px 18px; box-shadow:0 14px 30px -12px rgba(48,200,192,.55);}
.company-chip--cta:hover{color:#fff; transform:translateY(-2px); box-shadow:0 18px 36px -12px rgba(48,200,192,.6);}
.company-chip{display:flex; align-items:center; justify-content:center; gap:8px; padding:14px 12px; background:#fff; border:1.5px solid var(--line); border-radius:14px; font-family:'Poppins',sans-serif; font-weight:600; font-size:15px; color:var(--ink); text-decoration:none; cursor:pointer; transition:transform .2s, box-shadow .2s, border-color .2s, background .2s;}
.company-chip:hover, .company-chip:focus-visible{transform:translateY(-2px); border-color:var(--teal); box-shadow:0 12px 26px -14px rgba(48,200,192,.6); background:linear-gradient(160deg,#eafaf8,#fff);}
.company-chip--other{grid-column:1 / -1; color:var(--deep);}
.consent-note{font-size:11.5px; line-height:1.5; color:var(--muted); font-weight:500; margin:14px 0 0;}
.consent-note a{color:var(--deep); text-decoration:underline;}
.company-pick__proof{display:flex; align-items:center; justify-content:center; gap:8px; margin:12px 0 0; font-size:12px; font-weight:700; color:var(--deep); letter-spacing:.01em;}
.company-pick--pop .company-pick__proof{font-size:11px; margin-top:9px;}

/* ====== Guía: hero con imagen (página /guia) ====== */
.guidehero{display:grid; grid-template-columns:minmax(0,400px) 1fr; gap:clamp(24px,4vw,54px); align-items:center; max-width:1000px; margin:0 auto;}
.guidehero__img{display:flex; justify-content:center;}
.guidehero__img img{width:100%; max-width:380px; height:auto; border-radius:24px; box-shadow:0 34px 70px -30px rgba(15,35,48,.5); background:linear-gradient(160deg,#fff,#eaf4f5);}
.guidehero__txt h2{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(25px,3.6vw,38px); line-height:1.12; letter-spacing:-.02em; margin:6px 0 14px; color:var(--ink);}
.guidehero__txt>p{font-size:16.5px; line-height:1.6; color:var(--gray); font-weight:500; margin:0 0 16px;}
.guidehero__list{margin:0 0 22px; padding-left:20px; color:var(--gray); font-weight:500; line-height:1.7; font-size:15.5px;}
.guidehero__list strong{color:var(--ink);}
@media (max-width:760px){ .guidehero{grid-template-columns:1fr;} .guidehero__img{order:-1;} .guidehero__img img{max-width:280px;} }

/* ====== POP-UP GUÍA (toast NO intrusivo, arriba-derecha) ====== */
.guiapop{position:fixed; top:84px; right:20px; z-index:320; width:min(470px, calc(100vw - 32px));}
.guiapop[hidden]{display:none;}
.guiapop__box{position:relative; background:#fff; border-radius:20px; overflow:hidden; border:1px solid rgba(24,48,64,.08); box-shadow:0 30px 70px -18px rgba(15,35,48,.5); animation:guiapop-in .5s cubic-bezier(.2,.8,.25,1) both, guiapop-glow 3s ease-in-out 1.1s infinite;}
/* Barrido de brillo cada 3s (gancho elegante, sincronizado con el latido) */
.guiapop__box::after{content:""; position:absolute; top:0; left:-60%; width:45%; height:100%; background:linear-gradient(115deg, transparent, rgba(255,255,255,.55), transparent); transform:skewX(-18deg); pointer-events:none; z-index:3; animation:guiapop-shine 3s ease-in-out 1.1s infinite;}
.guiapop__close{position:absolute; top:10px; right:10px; z-index:4; width:30px; height:30px; border-radius:50%; border:none; background:rgba(15,35,48,.55); color:#fff; cursor:pointer; display:flex; align-items:center; justify-content:center; font-size:19px; line-height:1; backdrop-filter:blur(4px);}
.guiapop__grid{display:grid; grid-template-columns:216px 1fr;}
.guiapop__art{position:relative; overflow:hidden; background:linear-gradient(160deg,#eafaf8,#cfeeec);}
.guiapop__art img{width:100%; height:100%; object-fit:cover; object-position:50% 14%; transform-origin:50% 30%; animation:guiapop-breath 3s ease-in-out 1.1s infinite;}
.guiapop__txt{padding:18px 18px 16px;}
.guiapop__txt .eyebrow{margin-bottom:7px; font-size:11px;}
.guiapop__txt h3{font-family:'Poppins',sans-serif; font-weight:700; font-size:18px; line-height:1.15; letter-spacing:-.01em; margin:0 0 6px; color:var(--ink);}
.guiapop__txt>p{font-size:13px; line-height:1.45; color:var(--gray); font-weight:500; margin:0 0 12px;}
.company-pick--pop .company-pick__grid{gap:7px;}
.company-pick--pop .company-chip{padding:10px 8px; font-size:13.5px; border-radius:11px;}
.company-pick--pop .consent-note{font-size:10.5px; margin-top:10px;}
@media (max-width:560px){
  .guiapop{top:auto; bottom:14px; right:12px; left:12px; width:auto;}
  .guiapop__grid{grid-template-columns:168px 1fr;}
}
@keyframes guiapop-in{0%{opacity:0; transform:translateX(40px) scale(.94);} 72%{opacity:1; transform:translateX(-5px) scale(1.006);} 100%{opacity:1; transform:none;}}
/* Latido cada 3s: halo teal en la caja, brillo que barre y MIA que "respira". Inactivo el ~70% del ciclo → elegante, no molesto. */
@keyframes guiapop-glow{0%,70%,100%{box-shadow:0 30px 70px -18px rgba(15,35,48,.5);} 84%{box-shadow:0 30px 70px -18px rgba(15,35,48,.5), 0 0 0 3px rgba(48,200,192,.32);}}
@keyframes guiapop-shine{0%,70%{left:-60%;} 88%,100%{left:130%;}}
@keyframes guiapop-breath{0%,68%,100%{transform:scale(1);} 82%{transform:scale(1.05);} 92%{transform:scale(1.02);}}

/* CTA del probador en móvil */
.probador__cta-mobile{display:none; margin-top:16px;}
@media (max-width:900px){ .probador__cta-mobile{display:inline-flex;} }

/* ====== "Funciono para todos": fondo dinámico según estado ====== */
.para-todos{position:relative; overflow:hidden; transition:background .6s ease;}
.para-todos>.wrap{position:relative; z-index:1;}
.para-todos::before{content:""; position:absolute; width:560px; height:560px; border-radius:50%; right:-150px; top:-170px; pointer-events:none; z-index:0; transition:background .6s ease; background:radial-gradient(circle, rgba(48,200,192,.16), transparent 68%);}
.para-todos.is-particular{background:linear-gradient(160deg,#ecfbf8 0%,#F5F8FA 58%,#ffffff 100%);}
.para-todos.is-empresa{background:linear-gradient(160deg,#e9f1fc 0%,#eef4f8 58%,#ffffff 100%);}
.para-todos.is-empresa::before{background:radial-gradient(circle, rgba(59,130,246,.18), transparent 68%);}

/* ====== Imágenes (lote ALTA prioridad 2026-06-21): fotovoltaica + contextos + equipo ====== */
/* Hero fotovoltaica: la foto del tejado es el FONDO; el texto se lee sobre ella,
   con la imagen fundiéndose de derecha (nítida, paneles) a izquierda (se disuelve en el fondo claro). */
.solhero{position:relative; overflow:hidden; background:var(--bg);}
.solhero__bg{position:absolute; inset:0; z-index:0; background-image:url('../img/solar-hero.jpg'); background-size:cover; background-position:right center; background-repeat:no-repeat;}
.solhero__bg::after{content:""; position:absolute; inset:0; background:linear-gradient(90deg, var(--bg) 3%, rgba(245,248,250,.95) 28%, rgba(245,248,250,.5) 52%, rgba(245,248,250,0) 74%);}
.solhero__inner{position:relative; z-index:1; padding-top:clamp(60px,9vw,108px); padding-bottom:clamp(60px,9vw,108px); min-height:clamp(360px,42vw,520px); display:flex; align-items:center;}
.solhero__txt{max-width:540px;}
@media (max-width:820px){
  .solhero__bg{background-position:right 28%;}
  .solhero__bg::after{background:linear-gradient(180deg, rgba(245,248,250,.97) 0%, rgba(245,248,250,.9) 40%, rgba(245,248,250,.5) 72%, rgba(245,248,250,.12) 100%);}
  .solhero__inner{min-height:0; align-items:flex-start; padding-bottom:clamp(190px,52vw,320px); text-align:center;}
  .solhero__txt{max-width:640px; margin:0 auto;}
  .solhero__txt p{margin-left:auto; margin-right:auto;}
}

/* Tira de 3 fotos del proceso solar */
.solgrid{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(18px,2.4vw,26px);}
.solgrid figure{margin:0; background:#fff; border:1px solid var(--line); border-radius:20px; overflow:hidden; box-shadow:var(--shadow-card);}
.solgrid img{width:100%; height:auto; aspect-ratio:4/3; object-fit:cover; display:block;}
.solgrid figcaption{padding:18px 20px 22px; flex:1 1 auto;}
.solgrid figcaption .t{font-family:'Poppins',sans-serif; font-weight:700; font-size:17px; color:var(--ink); margin-bottom:5px;}
.solgrid figcaption .s{font-size:14.5px; line-height:1.5; color:var(--gray); font-weight:500;}
@media (max-width:760px){ .solgrid{grid-template-columns:1fr; max-width:440px; margin:0 auto;} }
/* Badge numerado del proceso solar (1-2-3 sobre cada foto) */
.solgrid figure{position:relative; display:flex; flex-direction:column;}
.solnum{position:absolute; top:14px; left:14px; z-index:2; width:44px; height:44px; border-radius:50%; background:var(--teal); color:var(--dark); font-family:'Poppins',sans-serif; font-weight:700; font-size:18px; display:flex; align-items:center; justify-content:center; box-shadow:0 10px 22px -8px rgba(15,35,48,.55); border:2px solid rgba(255,255,255,.85);}

/* Panel destacado de beneficios solares (lado derecho del bloque leadmagnet) */
.solstat{flex:1 1 300px; min-width:280px; background:var(--dark); color:#fff; border-radius:22px; padding:clamp(28px,3.4vw,38px) clamp(24px,3vw,32px); text-align:center; box-shadow:0 26px 56px -26px rgba(15,35,48,.55);}
.solstat__ico{font-size:42px; line-height:1; margin-bottom:14px;}
.solstat__big{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(22px,3vw,28px); line-height:1.14; letter-spacing:-.02em; margin-bottom:12px;}
.solstat__big::after{content:""; display:block; width:54px; height:3px; border-radius:3px; background:var(--teal); margin:14px auto 0;}
.solstat__sub{font-size:14.5px; line-height:1.55; color:rgba(255,255,255,.78); font-weight:500;}

/* "Funciono para todos": la tarjeta lleva la foto de contexto como panel lateral
   (no una tira recortada); la foto cambia con el toggle particular/empresa. */
.plan--media{display:grid; grid-template-columns:minmax(320px,48%) 1fr; padding:0; gap:0; overflow:hidden; align-items:stretch;}
.plan--media .plan__photo{position:relative; min-height:430px;}
.plan--media .plan__photo::after{content:""; position:absolute; inset:0; box-shadow:inset -28px 0 40px -28px rgba(15,35,48,.25); pointer-events:none;}
.plan--media .plan__photo img{position:absolute; inset:0; width:100%; height:100%; object-fit:cover; display:block;}
.plan--media .plan__body{padding:clamp(28px,4vw,46px); display:flex; flex-direction:column; gap:clamp(20px,3vw,28px); justify-content:center;}
.plan--media .plan__main,.plan--media .plan__points{flex:0 1 auto; min-width:0;}
/* Animación al cambiar Particular/Empresa: crossfade + micro-deslizamiento */
.plan--media .plan__body{transition:opacity .3s ease, transform .3s ease;}
.plan--media .plan__photo img{transition:opacity .34s ease, transform .34s ease;}
.plan--media.is-swapping .plan__body{opacity:0; transform:translateY(10px);}
.plan--media.is-swapping .plan__photo img{opacity:0; transform:scale(1.04);}
@media (max-width:760px){
  .plan--media{grid-template-columns:1fr;}
  .plan--media .plan__photo{min-height:0; aspect-ratio:16/10;}
  .plan--media .plan__photo::after{box-shadow:inset 0 -28px 40px -28px rgba(15,35,48,.25);}
}

/* Foto del equipo en "Quién está detrás" */
.behind__photo{max-width:720px; margin:6px auto 32px; border-radius:24px; overflow:hidden; box-shadow:0 30px 60px -34px rgba(24,48,64,.34);}
.behind__photo img{width:100%; height:auto; display:block;}

/* ====== Recortes 3D de MIA (lote 2): figura con halo radial + flotación. Cada sección, una escena. ====== */
@keyframes mia-float{0%,100%{transform:translateY(0)} 50%{transform:translateY(-9px)}}

/* Tres pasos: MIA protagoniza cada tarjeta */
.step-card--mia{position:relative; padding-top:18px; overflow:hidden;}
.step-card__art{position:relative; height:206px; margin:0 -8px 12px; display:flex; align-items:flex-end; justify-content:center;}
.step-card__art::before{content:""; position:absolute; bottom:4px; left:50%; transform:translateX(-50%); width:210px; height:210px; border-radius:50%; background:radial-gradient(circle, rgba(48,200,192,.20), transparent 66%); z-index:0;}
.step-card__art img{position:relative; z-index:1; height:100%; width:auto; max-width:94%; object-fit:contain; filter:drop-shadow(0 14px 22px rgba(15,35,48,.20)); animation:mia-float 6s ease-in-out infinite;}
.step-card--mia:nth-of-type(2) .step-card__art img{animation-delay:-2s;}
.step-card--mia:nth-of-type(3) .step-card__art img{animation-delay:-4s;}

/* Escena lateral de MIA (manifiesto · sigue contigo · bono) */
.mia-scene{position:relative; display:flex; align-items:flex-end; justify-content:center; min-height:300px;}
.mia-scene::before{content:""; position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:min(88%,380px); aspect-ratio:1; border-radius:50%; background:radial-gradient(circle, rgba(48,200,192,.22), transparent 65%); z-index:0;}
.mia-scene img{position:relative; z-index:1; width:auto; max-width:100%; max-height:430px; object-fit:contain; filter:drop-shadow(0 22px 32px rgba(15,35,48,.22)); animation:mia-float 7s ease-in-out infinite;}

/* Manifiesto en 2 columnas (MIA + texto) */
.manifesto-row{display:grid; grid-template-columns:0.82fr 1fr; gap:clamp(20px,4vw,56px); align-items:center;}
.manifesto-row .manifesto{text-align:left; max-width:none; margin:0;}
.manifesto-row .manifesto p{margin-left:0; margin-right:0;}
@media (max-width:820px){ .manifesto-row{grid-template-columns:1fr; text-align:center;} .manifesto-row .manifesto{text-align:center;} .manifesto-row .manifesto p{margin-left:auto; margin-right:auto;} .manifesto-row .mia-scene{min-height:0; order:-1;} }

/* MIA sigue contigo: MIA a la izquierda; texto + tarjetas apilados a la derecha */
.followup--mia{display:grid; grid-template-columns:0.78fr 1fr; gap:clamp(28px,4vw,60px); align-items:center;}
.followup--mia .followup__content{display:flex; flex-direction:column; gap:clamp(24px,3vw,32px);}
.followup--mia .followup__l,.followup--mia .followup__r{flex:0 1 auto; min-width:0; width:100%;}
@media (max-width:880px){ .followup--mia{grid-template-columns:1fr;} .followup--mia .mia-scene{min-height:0; order:-1;} }


/* ====== Modal PREMIUM (lujo) ====== */
.modal__box.is-premium{background:linear-gradient(158deg,#0f2330 0%,#15384a 55%,#0c1f2b 100%); color:#fff; box-shadow:0 50px 120px -22px rgba(246,177,78,.32), 0 0 0 1px rgba(246,177,78,.3); animation:lux-in .5s cubic-bezier(.2,.7,.2,1) both;}
.modal__box.is-premium::before{content:""; position:absolute; top:0; left:-70%; width:55%; height:100%; background:linear-gradient(115deg,transparent,rgba(255,255,255,.16),transparent); transform:skewX(-18deg); animation:lux-shine 1.9s ease-in-out .35s 1; pointer-events:none; z-index:2;}
.is-premium .modal__close{background:rgba(255,255,255,.14); color:#fff;}
.is-premium .modal__tag{background:linear-gradient(90deg,#f7d97a,#fda085); color:#3a2810; box-shadow:0 6px 18px -6px rgba(246,177,78,.6);}
.is-premium h3{color:#fff;}
.is-premium>p{color:#bcd0da;}
.is-premium .modal__iconwrap{background:linear-gradient(135deg,#f7d97a,#f6b14e); color:#3a2810; box-shadow:0 12px 34px -8px rgba(246,177,78,.65); animation:lux-pulse 2.4s ease-in-out infinite;}
.is-premium .modal__rows .r span{color:#dceaf0;}
.is-premium .modal__rows .r .tk{background:linear-gradient(135deg,#f7d97a,#f6b14e); color:#3a2810;}
.is-premium .modal__price{background:rgba(255,255,255,.08); color:#dceaf0;}
.is-premium .modal__price b{color:#fff;}
.is-premium .modal__cta{background:linear-gradient(90deg,#f7d97a,#fda085); color:#3a2810; box-shadow:0 16px 40px -10px rgba(246,177,78,.6);}

/* ====== keyframes ====== */
@keyframes lux-in{from{opacity:0; transform:translateY(16px) scale(.94)} to{opacity:1; transform:none}}
@keyframes lux-shine{from{left:-70%} to{left:140%}}
@keyframes lux-pulse{0%,100%{transform:scale(1)} 50%{transform:scale(1.07)}}
@keyframes marquee{from{transform:translateX(0)} to{transform:translateX(-50%)}}
@keyframes typedot{0%,60%,100%{transform:translateY(0); opacity:.35} 30%{transform:translateY(-5px); opacity:1}}
@keyframes float{0%,100%{transform:translateY(0)} 50%{transform:translateY(-14px)}}
@keyframes bubble{from{opacity:0; transform:translateY(12px) scale(.97)} to{opacity:1; transform:none}}
@keyframes scan{0%{left:-35%} 100%{left:135%}}
@keyframes blob{0%,100%{border-radius:46% 54% 57% 43%/47% 45% 55% 53%} 50%{border-radius:55% 45% 43% 57%/52% 57% 43% 48%}}

/* ===== Página Eventos — "El Mes de MIA" (hero carta sellada + timeline + manifiesto) ===== */
.ev-hero{background:linear-gradient(165deg,#eafbf8 0%,#F5F8FA 60%,#ffffff 100%); position:relative; overflow:hidden;}
.ev-hero::before{content:""; position:absolute; width:560px; height:560px; right:-160px; top:-180px; border-radius:50%; background:radial-gradient(circle, rgba(48,200,192,.18), transparent 68%); pointer-events:none;}
.ev-grid{position:relative; z-index:1; display:grid; grid-template-columns:1fr 0.82fr; gap:clamp(24px,4vw,56px); align-items:center;}
.ev-mia{position:relative; display:flex; align-items:flex-end; justify-content:center; min-height:340px;}
.ev-mia::before{content:""; position:absolute; bottom:0; left:50%; transform:translateX(-50%); width:min(86%,380px); aspect-ratio:1; border-radius:50%; background:radial-gradient(circle, rgba(48,200,192,.24), transparent 66%); z-index:0;}
.ev-mia img{position:relative; z-index:1; width:auto; max-width:100%; max-height:480px; object-fit:contain; filter:drop-shadow(0 22px 32px rgba(15,35,48,.22)); animation:mia-float 7s ease-in-out infinite;}
.ev-badge{display:inline-block; background:var(--teal); color:var(--dark); font-family:'Poppins',sans-serif; font-weight:700; font-size:12.5px; letter-spacing:.08em; text-transform:uppercase; padding:7px 16px; border-radius:999px; margin-bottom:16px;}
.ev-intro h1{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(30px,4.8vw,50px); line-height:1.08; letter-spacing:-.025em; color:var(--ink); margin:0 0 14px;}
.ev-intro>p{font-size:clamp(16px,2.1vw,19px); line-height:1.6; color:var(--gray); font-weight:500; margin:0 0 24px; max-width:540px;}

/* Sello interactivo "rompe el sello" */
.seal{position:relative; max-width:520px; perspective:1300px;}
.seal__content{position:relative; z-index:1; border-radius:22px; padding:26px 26px 24px; box-sizing:border-box; text-align:left;
  background:linear-gradient(180deg,#ffffff,#f1fbfa); border:1px solid rgba(48,200,192,.3);
  box-shadow:0 22px 48px -26px rgba(15,35,48,.4);}
.seal.is-open .seal__content{animation:ev-pop .55s cubic-bezier(.2,.7,.3,1.35) both;}
.seal__content:focus{outline:none;}
.seal__tag{display:inline-block; background:rgba(48,200,192,.16); color:var(--deep); font-family:'Poppins',sans-serif; font-weight:700; font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; padding:5px 12px; border-radius:999px; margin-bottom:12px;}
.seal__content h2{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(21px,3vw,26px); color:var(--ink); margin:0 0 10px; line-height:1.15;}
.seal__content p{font-size:15.5px; line-height:1.6; color:var(--gray); font-weight:500; margin:0 0 10px;}
.seal__soon{color:var(--deep)!important; font-weight:600; font-size:14px!important; margin-bottom:0!important;}
/* tapa: papel + lacre */
.seal__cover{position:absolute; inset:0; z-index:3; width:100%; height:100%; margin:0; padding:0; border:0; background:transparent; cursor:pointer; font:inherit; text-align:center; -webkit-tap-highlight-color:transparent;}
.no-js .seal__cover{display:none;}
.seal.is-open .seal__cover{pointer-events:none;}
.seal__paper{position:absolute; inset:0; box-sizing:border-box; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:12px; padding:30px 24px;
  background:linear-gradient(180deg,#fffdf6,#faf2e2); border:1px solid #efe2c6; border-radius:22px;
  box-shadow:0 22px 48px -26px rgba(15,35,48,.45);
  transform-origin:top center; backface-visibility:hidden;
  transition:transform .6s cubic-bezier(.5,0,.25,1), opacity .5s ease, box-shadow .3s ease;}
.seal__paper::after{content:""; position:absolute; inset:0; border-radius:22px; background:repeating-linear-gradient(135deg, rgba(0,0,0,.014) 0 6px, transparent 6px 12px); pointer-events:none;}
.seal:not(.is-open) .seal__cover:hover .seal__paper{transform:translateY(-3px); box-shadow:0 30px 54px -24px rgba(15,35,48,.5);}
.seal:not(.is-open) .seal__cover:active .seal__paper{transform:scale(.986);}
.seal__cover:focus-visible .seal__paper{outline:3px solid var(--teal); outline-offset:3px;}
.seal__wax{position:relative; width:74px; height:74px; display:flex; align-items:center; justify-content:center; animation:seal-breathe 3.2s ease-in-out infinite;}
.seal__half{position:absolute; top:0; width:50%; height:100%; background:radial-gradient(circle at 38% 30%, #5fdcd3, #30C8C0 44%, #127f7a 100%); box-shadow:inset 0 2px 6px rgba(255,255,255,.45), 0 6px 14px -4px rgba(18,127,122,.6); transition:transform .5s cubic-bezier(.4,0,.2,1), opacity .5s ease;}
.seal__half--l{left:0; border-radius:50% 0 0 50%;}
.seal__half--r{right:0; border-radius:0 50% 50% 0;}
.seal__m{position:relative; z-index:2; font-family:'Poppins',sans-serif; font-weight:800; font-size:30px; color:#fff; text-shadow:0 2px 4px rgba(12,110,102,.5);}
.seal__cta{font-family:'Poppins',sans-serif; font-weight:700; font-size:17px; color:var(--ink);}
.seal__finger{display:inline-block; animation:seal-tap 1.8s ease-in-out infinite;}
.seal__sub{font-size:13.5px; color:var(--gray); font-weight:600;}
/* estado abierto */
.seal.is-open .seal__half--l{transform:translateX(-24px) translateY(12px) rotate(-46deg); opacity:0;}
.seal.is-open .seal__half--r{transform:translateX(24px) translateY(12px) rotate(46deg); opacity:0;}
.seal.is-open .seal__wax{animation:none;}
.seal.is-open .seal__paper{transform:rotateX(-116deg); opacity:0;}
/* confeti */
.seal__confetti{position:absolute; left:0; right:0; top:46%; height:0; pointer-events:none; z-index:5;}
.seal__confetti i{position:absolute; left:50%; top:0; width:9px; height:9px; border-radius:2px; opacity:0; animation:seal-confetti .95s ease-out forwards;}

/* Timeline "lo que viene" */
.ev-next{background:var(--bg);}
.ev-next__head{text-align:center; max-width:640px; margin:0 auto clamp(28px,4vw,44px);}
.ev-next__head h2{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(24px,3.6vw,36px); letter-spacing:-.02em; color:var(--ink); margin:0 0 10px;}
.ev-next__head p{font-size:17px; line-height:1.55; color:var(--gray); font-weight:500; margin:0;}
.ev-line{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,24px);}
.ev-card{position:relative; background:#fff; border:1px solid var(--line); border-radius:20px; padding:26px 24px 24px; box-shadow:0 18px 40px -28px rgba(24,48,64,.4); display:flex; flex-direction:column; gap:7px; transition:transform .3s ease, box-shadow .3s ease;}
.ev-card__when{font-family:'Poppins',sans-serif; font-weight:700; font-size:11.5px; letter-spacing:.08em; text-transform:uppercase; color:var(--gray);}
.ev-card__ico{font-size:30px; line-height:1; margin:2px 0 2px;}
.ev-card h3{font-family:'Poppins',sans-serif; font-weight:700; font-size:19px; color:var(--ink); margin:0;}
.ev-card p{font-size:14.5px; line-height:1.55; color:var(--gray); font-weight:500; margin:0; flex:1 1 auto;}
.ev-card__state{align-self:flex-start; margin-top:12px; font-size:12.5px; font-weight:700; padding:5px 12px; border-radius:999px; background:var(--bg); color:var(--gray); border:1px solid var(--line);}
.ev-card__state--live{background:rgba(32,192,88,.12); color:#138a3c; border-color:rgba(32,192,88,.32);}
.ev-card--live{border-color:rgba(48,200,192,.45); box-shadow:0 22px 46px -26px rgba(18,127,122,.5);}
.ev-card--live::before{content:""; position:absolute; inset:0; border-radius:20px; background:linear-gradient(180deg, rgba(48,200,192,.06), transparent 60%); pointer-events:none;}
.ev-card--lock{background:#fbfcfd;}
.ev-card--lock .ev-card__ico{opacity:.9;}
.ev-card--lock:hover{transform:translateY(-2px);}
.ev-card--lock:hover .ev-card__ico{animation:seal-shake .5s ease;}

/* Manifiesto */
.ev-manif{background:linear-gradient(180deg,#ffffff,#eef9f8);}
.ev-manif__in{text-align:center; max-width:880px; margin:0 auto;}
.ev-manif__in>h2{font-family:'Poppins',sans-serif; font-weight:700; font-size:clamp(26px,4vw,42px); line-height:1.1; letter-spacing:-.025em; color:var(--ink); margin:0 0 14px;}
.ev-manif__in>h2 em{font-style:normal; color:var(--deep);}
.ev-manif__in>p{font-size:clamp(16px,2vw,18.5px); line-height:1.6; color:var(--gray); font-weight:500; margin:0 auto 34px; max-width:620px;}
.ev-pillars{display:grid; grid-template-columns:repeat(3,1fr); gap:clamp(16px,2vw,26px); text-align:left;}
.ev-pillar{background:#fff; border:1px solid var(--line); border-radius:18px; padding:24px 22px;}
.ev-pillar__ico{font-size:26px; margin-bottom:8px;}
.ev-pillar h3{font-family:'Poppins',sans-serif; font-weight:700; font-size:18px; color:var(--ink); margin:0 0 6px;}
.ev-pillar p{font-size:14.5px; line-height:1.55; color:var(--gray); font-weight:500; margin:0;}

@keyframes ev-pop{0%{transform:scale(.95); opacity:0} 60%{transform:scale(1.03); opacity:1} 100%{transform:scale(1); opacity:1}}
@keyframes seal-breathe{0%,100%{transform:scale(1)} 50%{transform:scale(1.06)}}
@keyframes seal-tap{0%,100%{transform:translateY(0)} 50%{transform:translateY(-4px)}}
@keyframes seal-shake{0%,100%{transform:translateX(0) rotate(0)} 25%{transform:translateX(-3px) rotate(-6deg)} 75%{transform:translateX(3px) rotate(6deg)}}
@keyframes seal-confetti{0%{opacity:1; transform:translate(-50%,-50%) scale(1) rotate(0)} 100%{opacity:0; transform:translate(calc(-50% + var(--dx)),calc(-50% + var(--dy))) scale(.4) rotate(220deg)}}

@media (max-width:820px){
  .ev-grid{grid-template-columns:1fr; text-align:center;}
  .ev-mia{order:-1; min-height:0;}
  .ev-intro>p{margin-left:auto; margin-right:auto;}
  .seal{margin-left:auto; margin-right:auto;}
  .seal__content{text-align:center;}
  .ev-line{grid-template-columns:1fr;}
  .ev-pillars{grid-template-columns:1fr; text-align:center;}
}
@media (prefers-reduced-motion: reduce){
  .seal__wax,.seal__finger,.ev-mia img{animation:none!important;}
  .seal__paper{transition:opacity .25s ease!important; transform:none!important;}
  .seal.is-open .seal__paper{opacity:0!important; transform:none!important;}
  .seal.is-open .seal__half--l,.seal.is-open .seal__half--r{transform:none!important;}
}

/* ===== Eventos — CTA "colaborar" (en hero, bajo el sello) + formulario modal ===== */
.ev-ask{display:flex; align-items:center; flex-wrap:wrap; gap:12px 16px; margin-top:22px; padding-top:22px; border-top:1px solid var(--line); max-width:520px;}
.ev-ask__txt{font-size:15px; font-weight:600; color:var(--gray); line-height:1.4;}
.ev-ask__btn{flex:none; white-space:nowrap;}
@media (max-width:820px){ .ev-ask{justify-content:center; text-align:center; margin-left:auto; margin-right:auto;} }

/* Modal form (reusa .modal / .modal__box) */
.modal__box--form{max-width:520px;}
.collab-form{display:flex; flex-direction:column; gap:14px;}
.collab-form__row{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
.collab-form__field{display:flex; flex-direction:column; gap:6px;}
.collab-form__field>span{font-family:'Poppins',sans-serif; font-weight:600; font-size:13px; color:var(--ink);}
.collab-form input, .collab-form textarea{width:100%; box-sizing:border-box; font-family:'Montserrat',sans-serif; font-size:15px; color:var(--ink); background:var(--bg); border:1px solid var(--line); border-radius:12px; padding:12px 14px; transition:border-color .2s ease, box-shadow .2s ease;}
.collab-form textarea{resize:vertical; min-height:96px;}
.collab-form input::placeholder, .collab-form textarea::placeholder{color:#9aa9b2;}
.collab-form input:focus, .collab-form textarea:focus{outline:none; border-color:var(--teal); box-shadow:0 0 0 3px rgba(48,200,192,.22);}
.collab-form input:invalid:not(:placeholder-shown), .collab-form textarea:invalid:not(:placeholder-shown){border-color:#e6736f;}
.collab-form__check{display:flex; align-items:flex-start; gap:10px; font-size:13.5px; line-height:1.45; color:var(--gray); font-weight:500;}
.collab-form__check input{flex:none; width:18px; height:18px; margin-top:1px; accent-color:var(--teal);}
.collab-form__check a{color:var(--deep); text-decoration:underline;}
.collab-form__submit{width:100%; justify-content:center; margin-top:4px;}
.collab-form__note{font-size:12.5px; line-height:1.45; color:var(--gray); margin:2px 0 0; text-align:center;}
.collab-done{text-align:center; padding:8px 4px 4px;}
.collab-done__ico{width:58px; height:58px; border-radius:50%; margin:0 auto 16px; display:flex; align-items:center; justify-content:center; background:rgba(32,192,88,.14); color:#138a3c;}
.collab-done h3{font-family:'Poppins',sans-serif; font-weight:700; font-size:22px; color:var(--ink); margin:0 0 8px;}
.collab-done p{font-size:15px; line-height:1.55; color:var(--gray); font-weight:500; margin:0 0 20px;}
.collab-done p a{color:var(--deep); text-decoration:underline;}
@media (max-width:680px){
  .collab-form__row{grid-template-columns:1fr;}
}
