/* ═══════════════════════════════════════════════════
   SOMA — Ultimate Landing CSS
   White + Cyan · Outfit · Maximum Impact
   ═══════════════════════════════════════════════════ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --c:#00b9e6;--cd:#0091b8;--cl:#e8f9fe;
  --t:#0c1222;--t2:#556275;--t3:#8896a8;
  --bg:#fff;--sf:#f5f8fb;--bd:#dfe6ed;
  --r:18px;--rl:26px;
  --s1:0 2px 8px rgba(12,18,34,.04);
  --s2:0 8px 30px rgba(12,18,34,.07);
  --s3:0 20px 60px rgba(12,18,34,.10);
  --sc:0 8px 36px rgba(0,185,230,.20);
  --mx:1140px;--hh:56px;
  --f:'Outfit',system-ui,sans-serif;
}
html{scroll-behavior:smooth;scroll-padding-top:calc(var(--hh)+20px)}
body{font-family:var(--f);color:var(--t);background:var(--bg);line-height:1.6;overflow-x:hidden;-webkit-font-smoothing:antialiased;padding-bottom:72px}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block;height:auto}ul{list-style:none}
.w{max-width:var(--mx);margin:0 auto;padding:0 28px}

/* ═══ HEADER ═══ */
.hdr{position:sticky;top:0;z-index:100;background:rgba(255,255,255,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--bd);height:var(--hh)}
.hdr .w{display:flex;align-items:center;justify-content:space-between;height:100%}
.hdr-logo img{height:26px}
.hdr-nav{display:flex;gap:4px;align-items:center}
.hdr-nav a{padding:6px 14px;border-radius:999px;font-size:13.5px;font-weight:600;color:var(--t2);transition:.2s}
.hdr-nav a:hover{color:var(--t);background:var(--sf)}
.nav-cta,.nav-cta:hover,.nav-cta:visited{background:var(--c);color:#fff!important;box-shadow:var(--sc)}
.nav-cta:hover{background:var(--cd)}
.mob-m{display:none;position:relative}
.mob-m>summary{list-style:none;cursor:pointer;padding:6px 14px;border-radius:999px;border:1px solid var(--bd);font-weight:700;font-size:14px;color:var(--c);background:#fff}
.mob-m>summary::-webkit-details-marker{display:none}
.mob-p{position:absolute;top:calc(100%+6px);right:0;background:#fff;border:1px solid var(--bd);border-radius:var(--r);padding:6px;box-shadow:var(--s3);width:280px;z-index:120}
.mob-p a{display:block;padding:10px 14px;border-radius:12px;font-weight:600;font-size:15px}
.mob-p a:hover{background:var(--sf)}
@media(max-width:860px){.hdr-nav{display:none}.mob-m{display:block}}

/* ═══ BUTTONS ═══ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:14px 26px;border-radius:14px;font-weight:700;font-size:15px;font-family:var(--f);border:none;cursor:pointer;transition:.3s cubic-bezier(.2,.8,.3,1)}
.bp{background:var(--c);color:#fff;box-shadow:var(--sc);position:relative;overflow:hidden}
.bp::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.15);border-radius:50%;transform:translate(-50%,-50%);transition:width .5s,height .5s}
.bp:hover::after{width:300px;height:300px}
.bp:hover{background:var(--cd);transform:translateY(-3px);box-shadow:0 14px 44px rgba(0,185,230,.28)}
.bs{background:#fff;color:var(--t);border:1.5px solid var(--bd);box-shadow:var(--s1)}
.bs:hover{border-color:var(--c);transform:translateY(-3px);box-shadow:var(--s2)}

/* ═══ KEYFRAMES ═══ */
@keyframes rise{from{opacity:0;transform:translateY(50px) scale(.97)}to{opacity:1;transform:none}}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(0,185,230,.4)}70%{box-shadow:0 0 0 14px rgba(0,185,230,0)}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes glow{0%,100%{filter:drop-shadow(0 0 20px rgba(0,185,230,0))}50%{filter:drop-shadow(0 0 40px rgba(0,185,230,.15))}}
@keyframes tiltIn{from{opacity:0;transform:perspective(1200px) rotateX(8deg) translateY(40px)}to{opacity:1;transform:perspective(1200px) rotateX(0) translateY(0)}}
@keyframes slideUp{from{opacity:0;transform:translateY(60px)}to{opacity:1;transform:none}}
@keyframes scaleIn{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}
@keyframes borderDraw{from{clip-path:inset(0 100% 0 0)}to{clip-path:inset(0 0 0 0)}}
@keyframes countUp{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes blurIn{from{opacity:0;filter:blur(10px)}to{opacity:1;filter:blur(0)}}
@keyframes marquee{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* Scroll reveals with stagger */
.rv{opacity:0;transform:translateY(30px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.rv.v{opacity:1;transform:none}
.rv-d1{transition-delay:.12s}.rv-d2{transition-delay:.24s}.rv-d3{transition-delay:.36s}

/* Tilt-in reveal for special sections */
.rv-tilt{opacity:0;transform:perspective(1200px) rotateX(6deg) translateY(40px);transition:opacity .9s cubic-bezier(.16,1,.3,1),transform .9s cubic-bezier(.16,1,.3,1)}
.rv-tilt.v{opacity:1;transform:perspective(1200px) rotateX(0) translateY(0)}

/* Scale reveal */
.rv-scale{opacity:0;transform:scale(.92);transition:opacity .8s ease,transform .8s cubic-bezier(.16,1,.3,1)}
.rv-scale.v{opacity:1;transform:scale(1)}

/* Blur reveal */
.rv-blur{opacity:0;filter:blur(8px);transition:opacity .7s ease,filter .7s ease}
.rv-blur.v{opacity:1;filter:blur(0)}

/* ═══════════════════════════════════════════════════
   HERO — Wide image, centered, immersive
   ═══════════════════════════════════════════════════ */
.hero{position:relative;padding:60px 0 40px;overflow:hidden}
.hero::before{content:'';position:absolute;top:-30%;right:-15%;width:800px;height:800px;background:radial-gradient(circle,rgba(0,185,230,.06) 0%,transparent 70%);border-radius:50%;pointer-events:none;animation:float 15s ease-in-out infinite}
.hero::after{content:'';position:absolute;bottom:-20%;left:-10%;width:600px;height:600px;background:radial-gradient(circle,rgba(0,185,230,.04) 0%,transparent 70%);border-radius:50%;pointer-events:none;animation:float 18s ease-in-out infinite reverse}
.hero .w{display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;z-index:1}
.hero-tag{display:inline-flex;align-items:center;gap:8px;padding:6px 16px 6px 10px;background:var(--cl);border:1px solid rgba(0,185,230,.2);border-radius:999px;font-size:12px;font-weight:700;color:var(--cd);text-transform:uppercase;letter-spacing:.06em;margin-bottom:24px;animation:rise .6s ease both}
.hero-tag span{width:8px;height:8px;background:var(--c);border-radius:50%;animation:pulse 2s ease-in-out infinite}
.hero h1{font-size:clamp(36px,5.5vw,62px);font-weight:800;line-height:1.05;letter-spacing:-.04em;max-width:780px;margin-bottom:20px;animation:rise .6s ease .1s both}
.hero h1 em{font-style:normal;background:linear-gradient(90deg,var(--c),#38ddf7,var(--c));background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 4s linear infinite}

/* IA gradient text — red/orange shimmer */
.ia-grad{font-style:normal;font-weight:800;background:linear-gradient(90deg,#ff6b35,#e63946,#ff6b35);background-size:200% auto;-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;animation:shimmer 3.5s linear infinite}

/* Hero IA callout badge */
.hero-ia{animation:rise .6s ease .14s both;margin-bottom:20px}
.hero-ia-badge{display:inline-flex;align-items:center;gap:10px;padding:10px 20px;background:rgba(255,107,53,.05);border:1.5px solid rgba(230,57,70,.12);border-radius:14px;font-size:14px;color:var(--t2);line-height:1.45;max-width:560px}
.hero-ia-badge svg{flex-shrink:0}

.hero-sub{font-size:18px;color:var(--t2);max-width:580px;margin-bottom:32px;line-height:1.6;animation:rise .6s ease .2s both}
.hero-btns{display:flex;gap:12px;flex-wrap:wrap;justify-content:center;margin-bottom:16px;animation:rise .6s ease .28s both}
.hero-note{font-size:13.5px;color:var(--t3);animation:rise .6s ease .34s both}.hero-note b{color:var(--t)}

/* Hero wide image — BIGGER */
.hero-img{width:100%;max-width:1060px;margin-top:48px;animation:tiltIn 1s cubic-bezier(.16,1,.3,1) .4s both;position:relative}
.hero-img::after{content:'';position:absolute;bottom:-20px;left:10%;right:10%;height:40px;background:radial-gradient(ellipse,rgba(12,18,34,.08),transparent 70%);filter:blur(10px);z-index:-1}
.hero-img img{width:100%;border-radius:16px;filter:drop-shadow(0 32px 64px rgba(12,18,34,.18));animation:glow 5s ease-in-out 2s infinite}

@media(max-width:860px){.hero{padding:40px 0 32px}.hero-img{max-width:100%;margin-top:32px}.hero-ia-badge{font-size:13.5px;padding:12px 18px;text-align:center;flex-direction:column;gap:4px;justify-content:center}.hero-ia-badge svg{margin:0 auto}}
@media(max-width:768px){.hero-img img{border-radius:20px}.hero-btns .btn{min-width:150px;padding:12px 24px;font-size:15px}}
@media(max-width:480px){.hero-btns{gap:10px;width:100%}.hero-btns .btn{flex:1;padding:14px 12px;font-size:14.5px;min-height:0}}

/* ═══ SOCIAL PROOF ═══ */
.proof{padding:28px 0;border-bottom:1px solid var(--bd)}
.proof .w{display:flex;align-items:center;justify-content:center;gap:40px;flex-wrap:wrap}
.proof-i{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:600;color:var(--t2)}
.proof-ic{width:36px;height:36px;background:var(--cl);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;transition:.3s}
.proof-i:hover .proof-ic{transform:scale(1.15) rotate(-5deg);box-shadow:var(--sc)}
@media(max-width:600px){.proof .w{gap:20px}.proof-i{font-size:13px}}

/* ═══ SECTION UTILS ═══ */
.sec{padding:96px 0}
.sec-alt{background:var(--sf)}
.sh{text-align:center;margin-bottom:52px}
.sh h2{font-size:clamp(26px,3.5vw,38px);font-weight:800;letter-spacing:-.03em;line-height:1.1;margin-bottom:12px}
.sh p{font-size:16px;color:var(--t2);max-width:580px;margin:0 auto;line-height:1.6}
.sh-label{display:inline-block;font-size:11.5px;font-weight:700;color:var(--c);text-transform:uppercase;letter-spacing:.08em;margin-bottom:10px}

/* ═══ ECOSYSTEM ═══ */
.eco-g{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.eco-c{background:var(--bg);border:1.5px solid var(--bd);border-radius:var(--rl);padding:36px 28px;text-align:center;transition:.4s cubic-bezier(.2,.8,.3,1);position:relative;overflow:hidden}
.eco-c::before{content:'';position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--c),#38ddf7);transform:scaleX(0);transition:transform .4s cubic-bezier(.2,.8,.3,1);transform-origin:left}
.eco-c::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 50% 0%,rgba(0,185,230,.04),transparent 60%);opacity:0;transition:opacity .4s}
.eco-c:hover{transform:translateY(-8px);box-shadow:var(--s2);border-color:rgba(0,185,230,.25)}
.eco-c:hover::before{transform:scaleX(1)}
.eco-c:hover::after{opacity:1}
.eco-ic{width:56px;height:56px;margin:0 auto 20px;background:linear-gradient(135deg,var(--cl),rgba(0,185,230,.08));border-radius:16px;display:flex;align-items:center;justify-content:center;font-size:24px;transition:.4s}
.eco-c:hover .eco-ic{transform:scale(1.1) rotate(-5deg);box-shadow:0 8px 24px rgba(0,185,230,.15)}
.eco-c h3{font-size:18px;font-weight:700;margin-bottom:4px}
.eco-c .tag{font-size:11.5px;color:var(--c);font-weight:700;margin-bottom:14px}
.eco-c p{font-size:14.5px;color:var(--t2);line-height:1.6}
@media(max-width:768px){.eco-g{grid-template-columns:1fr;max-width:460px;margin:0 auto}}

/* ═══ SHOW SECTION ═══ */
.show{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.show.flip .show-img{order:-1}
.show-txt h2{font-size:clamp(24px,3vw,34px);font-weight:800;letter-spacing:-.02em;margin-bottom:16px;line-height:1.12}
.show-txt>p{color:var(--t2);font-size:15.5px;margin-bottom:24px;line-height:1.65}
.show-img{display:flex;justify-content:center;align-items:center}
.show-img img{max-height:520px;filter:drop-shadow(0 24px 56px rgba(12,18,34,.14));transition:.5s cubic-bezier(.2,.8,.3,1)}
.show-img:hover img{transform:scale(1.03) translateY(-6px);filter:drop-shadow(0 32px 72px rgba(12,18,34,.18))}
.fl{display:flex;flex-direction:column;gap:14px}
.fl li{display:flex;align-items:flex-start;gap:12px;font-size:14.5px;font-weight:500;line-height:1.5}
.fl li .dot{width:8px;height:8px;border-radius:50%;background:var(--c);flex-shrink:0;margin-top:7px;transition:.3s}
.fl li:hover .dot{transform:scale(1.5);box-shadow:0 0 0 4px rgba(0,185,230,.15)}
@media(max-width:860px){.show{grid-template-columns:1fr;text-align:center;gap:32px}.show.flip .show-img,.show-img{order:-1}.show-img img{max-height:380px}.fl{align-items:center}}

/* ═══ CAROUSEL ═══ */
.carousel{padding:80px 0}
.slider{border-radius:var(--rl);overflow:hidden;box-shadow:var(--s2);background:#fff;border:1px solid var(--bd);transition:.4s}
.slider:hover{box-shadow:var(--s3)}
.s-track{display:flex;transition:transform .55s cubic-bezier(.22,.61,.36,1);will-change:transform}
.s-slide{min-width:100%;display:flex;align-items:center;justify-content:center;padding:12px}
.s-slide img{max-width:100%;max-height:70vh;object-fit:contain;border-radius:12px}
.s-nav{display:flex;gap:10px;justify-content:center;padding:14px 0 8px}
.s-dot{width:10px;height:10px;border-radius:50%;background:var(--bd);cursor:pointer;transition:.35s cubic-bezier(.2,.8,.3,1)}
.s-dot.on{background:var(--c);transform:scale(1.4);box-shadow:0 0 0 4px rgba(0,185,230,.15)}

/* ═══ PRO CARDS ═══ */
.pro-g{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.pro-c{background:#fff;border:1.5px solid var(--bd);border-radius:var(--rl);overflow:hidden;transition:.4s cubic-bezier(.2,.8,.3,1)}
.pro-c:hover{transform:translateY(-6px);box-shadow:var(--s2)}
.pro-c-img{padding:24px 20px;display:flex;justify-content:center;align-items:center;min-height:300px;background:linear-gradient(180deg,var(--sf),#fff)}
.pro-c-img img{max-width:100%;max-height:420px;object-fit:contain;transition:.5s cubic-bezier(.2,.8,.3,1)}
.pro-c:hover .pro-c-img img{transform:scale(1.03)}
.pro-c-txt{padding:20px 24px}
.pro-c-txt h3{font-size:17px;font-weight:700;margin-bottom:6px}
.pro-c-txt p{color:var(--t2);font-size:14.5px;line-height:1.55}

/* --- Span card (agenda) BIGGER --- */
.pro-span{grid-column:1/-1}
.pro-span .pro-c-img{min-height:420px;padding:32px 24px}
.pro-span .pro-c-img img{max-height:520px;max-width:85%}

@media(max-width:768px){.pro-g{grid-template-columns:1fr}.pro-span{grid-column:auto}.pro-c-img{min-height:220px}.pro-c-img img{max-height:320px}}

/* ═══ VIDEO ═══ */
.vid-frame{border-radius:var(--rl);overflow:hidden;box-shadow:var(--s3);border:1px solid var(--bd);transition:.4s}
.vid-frame:hover{box-shadow:0 24px 72px rgba(12,18,34,.14);transform:translateY(-4px)}
.vid-r{position:relative;padding-top:56.25%}
.vid-r iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ═══ CATEGORIES ═══ */
.cats-img{border-radius:var(--rl);overflow:hidden;box-shadow:var(--s2);border:1px solid var(--bd);transition:.4s}
.cats-img:hover{box-shadow:var(--s3);transform:translateY(-4px)}
.cats-img img{width:100%}

/* ═══ MAP ═══ */
.map-img{max-width:880px;margin:0 auto;border-radius:var(--rl);overflow:hidden;box-shadow:var(--s3);transition:.4s}
.map-img:hover{transform:scale(1.02)}
.map-img img{width:100%}

/* ═══ TESTIMONIALS ═══ */
.te-g{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.te-c{background:#fff;border:1.5px solid var(--bd);border-radius:var(--rl);padding:32px;display:flex;flex-direction:column;justify-content:space-between;transition:.4s cubic-bezier(.2,.8,.3,1)}
.te-c:hover{transform:translateY(-6px);box-shadow:var(--s2);border-color:rgba(0,185,230,.2)}
.te-c blockquote{font-size:15.5px;line-height:1.65;margin-bottom:20px;color:var(--t);font-style:italic;padding-left:20px;border-left:3px solid var(--c)}
.te-foot{display:flex;align-items:center;justify-content:space-between}
.te-foot cite{font-style:normal;font-size:13.5px;font-weight:600;color:var(--t2)}
.te-stars{color:#f59e0b;font-size:14px;letter-spacing:1px}
@media(max-width:768px){.te-g{grid-template-columns:1fr}}

/* ═══ PRICING ═══ */
.pr-g{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.pr-c{background:#fff;border:1.5px solid var(--bd);border-radius:var(--rl);padding:32px;transition:.4s cubic-bezier(.2,.8,.3,1)}
.pr-c:hover{box-shadow:var(--s2);border-color:rgba(0,185,230,.2);transform:translateY(-4px)}
.pr-c h3{font-size:20px;font-weight:800;margin-bottom:6px}
.pr-badge{display:inline-block;font-size:11px;font-weight:700;color:var(--cd);background:var(--cl);border:1px solid rgba(0,185,230,.2);padding:4px 12px;border-radius:999px;margin-bottom:14px}
.pr-hint{color:var(--t3);font-size:13px;margin-bottom:20px}
.plans{display:flex;flex-direction:column;gap:10px}
.plan{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:#fff;border:1.5px solid var(--bd);border-radius:14px;font-weight:600;font-size:14.5px;transition:.3s cubic-bezier(.2,.8,.3,1);color:var(--t);position:relative;overflow:hidden}
.plan::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--c);transform:scaleY(0);transition:transform .3s;transform-origin:bottom}
.plan:hover{border-color:var(--c);box-shadow:var(--s1);transform:translateX(6px)}
.plan:hover::before{transform:scaleY(1)}
.plan b{font-weight:800;font-size:15px}
.pr-banner{margin-top:28px;padding:18px 24px;background:var(--cl);border:1px solid rgba(0,185,230,.15);border-radius:16px;text-align:center;font-size:14.5px}
.pr-banner strong{color:var(--cd)}
@media(max-width:768px){.pr-g{grid-template-columns:1fr}}

/* ═══ POST-SUBSCRIBE ═══ */
.ps-card{background:#fff;border:1.5px solid var(--bd);border-radius:var(--rl);padding:36px;box-shadow:var(--s1);transition:.3s}
.ps-card:hover{box-shadow:var(--s2)}
.ps-card h3{font-size:20px;font-weight:800;margin-bottom:8px}
.ps-card>p{color:var(--t2);font-size:15px;margin-bottom:20px}
.ps-chips{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.ps-chips span{padding:8px 16px;border:1.5px solid var(--bd);border-radius:999px;font-size:13px;font-weight:600;background:var(--sf);transition:.25s}
.ps-chips span:hover{border-color:var(--c);color:var(--c);transform:translateY(-2px)}
.ps-note{margin-top:12px;font-size:12.5px;color:var(--t3)}

/* ═══ FAQ — Full width ═══ */
.faq{padding:80px 0}
.faq .w{max-width:var(--mx)}
.faq-list{display:flex;flex-direction:column;gap:10px}
.faq-i{background:#fff;border:1.5px solid var(--bd);border-radius:14px;overflow:hidden;transition:.3s cubic-bezier(.2,.8,.3,1)}
.faq-i:hover{border-color:rgba(0,185,230,.25);box-shadow:var(--s1)}
.faq-i summary{cursor:pointer;list-style:none;padding:18px 22px;font-weight:600;font-size:15px;display:flex;justify-content:space-between;align-items:center;transition:.2s}
.faq-i summary:hover{background:var(--sf)}
.faq-i summary::-webkit-details-marker{display:none}
.faq-i summary::after{content:'+';font-size:22px;font-weight:300;color:var(--c);transition:transform .35s cubic-bezier(.2,.8,.3,1);width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--cl);flex-shrink:0}
.faq-i[open] summary::after{transform:rotate(45deg);background:var(--c);color:#fff}
.faq-i[open] summary{border-bottom:1px solid var(--bd)}
.faq-a{padding:18px 22px;color:var(--t2);font-size:14.5px;line-height:1.7;animation:slideUp .3s ease both}

/* ═══ CTA FINAL ═══ */
.fcta{padding:48px 0}
.fcta-box{background:linear-gradient(135deg,var(--cl),#fff);border:1.5px solid rgba(0,185,230,.15);border-radius:var(--rl);padding:48px 32px;text-align:center;position:relative;overflow:hidden}
.fcta-box::before{content:'';position:absolute;top:-50%;right:-20%;width:400px;height:400px;background:radial-gradient(circle,rgba(0,185,230,.06),transparent 70%);border-radius:50%;pointer-events:none}
.fcta-box h3{font-size:24px;font-weight:800;margin-bottom:10px;position:relative}
.fcta-box>p{color:var(--t2);font-size:16px;margin-bottom:22px;position:relative}
.btn-wa{display:inline-flex;align-items:center;gap:8px;background:var(--c);color:#fff;padding:14px 26px;border-radius:14px;font-weight:700;font-size:15px;font-family:var(--f);transition:.3s cubic-bezier(.2,.8,.3,1);box-shadow:var(--sc);position:relative;overflow:hidden}
.btn-wa::after{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,.15);border-radius:50%;transform:translate(-50%,-50%);transition:width .5s,height .5s}
.btn-wa:hover::after{width:300px;height:300px}
.btn-wa:hover{background:var(--cd);transform:translateY(-3px)}
.fcta-sm{margin-top:12px;font-size:13px;color:var(--t3);position:relative}

/* ═══ FOOTER ═══ */
.ftr{padding:24px 0;border-top:1px solid var(--bd);color:var(--t3);font-size:13px}
.ftr .w{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.ftr-links{display:flex;gap:10px}
.ftr-links a{padding:6px 14px;border-radius:999px;border:1px solid var(--bd);font-weight:600;font-size:12.5px;transition:.25s}
.ftr-links a:hover{border-color:var(--c);color:var(--c);transform:translateY(-2px)}

/* ═══ STICKY ═══ */
.sticky{position:fixed;left:0;right:0;bottom:0;z-index:90;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border-top:1px solid var(--bd);padding:10px 16px;display:none;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px))}
.sticky.v{display:block;animation:slideUp .3s ease both}
.sticky .w{display:flex;gap:12px;align-items:center;justify-content:center}


/* ═══════════════════════════════════════════════════
   ZOE IA CHAT WIDGET
   Arquitectura:
   - Desktop: panel flotante 380x580 en esquina inferior derecha
   - Mobile: fullscreen usando position:fixed + top/bottom:0
     El teclado virtual se maneja con padding-bottom dinámico (ver zoe-chat.js).
   - No usa 100dvh ni altura forzada por JS. Solo padding-bottom = kbHeight.
   - Cuando se abre en mobile, bloqueamos scroll del body (body.zoe-lock).
   ═══════════════════════════════════════════════════ */

/* Container */
.zoe-chat{position:fixed;bottom:24px;right:24px;z-index:200;font-family:var(--f)}

/* ── Bubble trigger ── */
.zoe-trigger-wrap{display:flex;align-items:center;gap:14px}
.zoe-teaser{
  min-height:60px;max-width:292px;
  display:flex;align-items:center;gap:12px;
  padding:10px 16px 10px 12px;
  background:linear-gradient(180deg,#fff 0%,#f8fdff 100%);
  border:1px solid rgba(0,185,230,.20);
  border-radius:22px;
  box-shadow:0 14px 36px rgba(12,18,34,.10);
  color:var(--t);
  position:relative;
  transition:.3s cubic-bezier(.2,.8,.3,1);
}
.zoe-teaser::before{
  content:'';position:absolute;inset:0;border-radius:22px;
  background:linear-gradient(135deg,rgba(0,185,230,.06),rgba(0,185,230,0) 58%);
  pointer-events:none;
}
.zoe-teaser::after{
  content:'';position:absolute;top:50%;right:-8px;width:16px;height:16px;
  background:linear-gradient(180deg,#fff 0%,#f8fdff 100%);
  border-top:1px solid rgba(0,185,230,.20);
  border-right:1px solid rgba(0,185,230,.20);
  transform:translateY(-50%) rotate(45deg);
}
.zoe-teaser:hover{transform:translateX(-2px) translateY(-1px);box-shadow:0 18px 44px rgba(12,18,34,.13)}
.zoe-teaser-badge{
  position:relative;z-index:1;
  flex:0 0 auto;
  min-width:72px;height:36px;
  display:inline-flex;align-items:center;justify-content:center;
  padding:0 12px;
  border-radius:14px;
  background:var(--cl);
  border:1px solid rgba(0,185,230,.18);
  color:var(--cd);
  font-size:12px;font-weight:800;letter-spacing:.01em;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.9);
}
.zoe-teaser-copy{
  position:relative;z-index:1;
  display:block;
  font-size:14px;line-height:1.22;font-weight:600;letter-spacing:-.01em;
  color:var(--t2);
}
.zoe-teaser-copy strong{display:block;color:var(--t);font-weight:800}
.zoe-chat.open .zoe-teaser{opacity:0;transform:translateX(12px) scale(.96);pointer-events:none}
.zoe-bubble{width:60px;height:60px;border-radius:50%;background:var(--c);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(0,185,230,.35);transition:.3s cubic-bezier(.2,.8,.3,1);position:relative;z-index:201}
.zoe-bubble:hover{transform:scale(1.08);box-shadow:0 8px 32px rgba(0,185,230,.45)}
.zoe-bubble-icon,.zoe-bubble-x{position:absolute;transition:.3s}
.zoe-bubble-x{opacity:0;transform:rotate(-90deg) scale(.5)}
.zoe-chat.open .zoe-bubble-icon{opacity:0;transform:rotate(90deg) scale(.5)}
.zoe-chat.open .zoe-bubble-x{opacity:1;transform:rotate(0) scale(1)}
.zoe-pulse{position:absolute;inset:0;border-radius:50%;background:var(--c);animation:zoePulse 2.5s ease-in-out infinite;z-index:-1}
@keyframes zoePulse{0%,100%{transform:scale(1);opacity:.4}50%{transform:scale(1.35);opacity:0}}

/* ── Panel (desktop default) ── */
.zoe-panel{
  position:absolute;bottom:72px;right:0;
  width:380px;height:580px;max-height:calc(100vh - 120px);
  background:#fff;border-radius:20px;
  box-shadow:0 16px 64px rgba(12,18,34,.15);
  border:1px solid var(--bd);
  display:flex;flex-direction:column;overflow:hidden;
  opacity:0;transform:translateY(16px) scale(.95);pointer-events:none;
  transition:opacity .3s cubic-bezier(.2,.8,.3,1),transform .3s cubic-bezier(.2,.8,.3,1);
}
.zoe-chat.open .zoe-panel{opacity:1;transform:translateY(0) scale(1);pointer-events:auto}

/* ── Header ── */
.zoe-hdr{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;background:linear-gradient(135deg,var(--c),#38ddf7);color:#fff;flex-shrink:0}
.zoe-hdr-info{display:flex;align-items:center;gap:12px}
.zoe-avatar{width:38px;height:38px;border-radius:12px;background:rgba(255,255,255,.2);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:17px}
.zoe-name{font-weight:700;font-size:15px;line-height:1.2}
.zoe-status{font-size:11.5px;opacity:.85;display:flex;align-items:center;gap:5px}
.zoe-dot-on{width:6px;height:6px;border-radius:50%;background:#4ade80}
.zoe-close{background:none;border:none;color:#fff;cursor:pointer;padding:6px;border-radius:8px;transition:.2s;display:flex;align-items:center;justify-content:center}
.zoe-close:hover{background:rgba(255,255,255,.2)}

/* ── Body (mensajes) ── */
.zoe-body{flex:1 1 0;min-height:0;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:12px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}
.zoe-body::-webkit-scrollbar{width:4px}
.zoe-body::-webkit-scrollbar-thumb{background:var(--bd);border-radius:4px}

.zoe-msg{max-width:85%;animation:zoeMsg .3s cubic-bezier(.16,1,.3,1) both}
@keyframes zoeMsg{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.zoe-msg p{font-size:14.5px;line-height:1.6;margin:0}
.zoe-msg-ai{align-self:flex-start}
.zoe-msg-ai p{background:var(--sf);border:1px solid var(--bd);border-radius:4px 16px 16px 16px;padding:14px 18px;color:var(--t)}
.zoe-msg-user{align-self:flex-end}
.zoe-msg-user p{background:var(--c);color:#fff;border-radius:16px 4px 16px 16px;padding:14px 18px}

/* ── Preguntas rápidas (chips verticales dentro del body) ── */
.zoe-quick{display:flex;flex-direction:column;gap:8px;margin-top:2px;animation:zoeMsg .4s cubic-bezier(.16,1,.3,1) .15s both}
.zoe-quick.hidden{display:none}
.zoe-quick-lbl{font-size:10.5px;font-weight:700;color:var(--t3);text-transform:uppercase;letter-spacing:.08em;margin:2px 0 2px 4px}
.zoe-quick button{text-align:left;padding:12px 14px;border:1.5px solid var(--bd);border-radius:12px;background:#fff;font-family:var(--f);font-size:14px;font-weight:600;color:var(--t);cursor:pointer;transition:.2s;display:flex;align-items:center;gap:10px;line-height:1.3}
.zoe-quick button::before{content:'';flex-shrink:0;width:20px;height:20px;border-radius:50%;background:var(--cl);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2300b9e6' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 18 15 12 9 6'/></svg>");background-repeat:no-repeat;background-position:center;transition:.2s}
.zoe-quick button:hover{border-color:var(--c);background:var(--cl);color:var(--cd);transform:translateX(2px)}
.zoe-quick button:hover::before{background-color:var(--c);background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='9 18 15 12 9 6'/></svg>")}
.zoe-quick button:active{transform:scale(.98)}

/* ── Typing dots ── */
.zoe-typing{display:flex;gap:5px;padding:14px 18px;align-self:flex-start;background:var(--sf);border:1px solid var(--bd);border-radius:4px 16px 16px 16px}
.zoe-typing span{width:8px;height:8px;border-radius:50%;background:var(--t3);animation:zoeDot 1.4s ease-in-out infinite}
.zoe-typing span:nth-child(2){animation-delay:.15s}
.zoe-typing span:nth-child(3){animation-delay:.3s}
@keyframes zoeDot{0%,60%,100%{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}

/* ── Input bar ── */
.zoe-input-wrap{display:flex;gap:10px;padding:12px 14px;border-top:1px solid var(--bd);flex-shrink:0;background:#fff}
.zoe-input{flex:1;min-width:0;border:1.5px solid var(--bd);border-radius:14px;padding:12px 16px;font-family:var(--f);font-size:16px;outline:none;transition:.2s;background:var(--sf)}
.zoe-input:focus{border-color:var(--c);background:#fff;box-shadow:0 0 0 3px rgba(0,185,230,.1)}
.zoe-input::placeholder{color:var(--t3)}
.zoe-send{width:44px;height:44px;border-radius:14px;background:var(--c);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.2s;flex-shrink:0}
.zoe-send:hover{background:var(--cd)}
.zoe-send:active{transform:scale(.95)}
.zoe-send:disabled{opacity:.5;cursor:default}

/* ═══════════════════════════════════════════════════
   MOBILE (<=600px) — Fullscreen
   La altura del panel = viewport completo (top:0;bottom:0).
   El teclado se compensa con padding-bottom en el panel (seteado por JS).
   En navegadores que achican el layout viewport (Chrome Android con
   interactive-widget=resizes-content), no se necesita padding — el panel
   ya se achica solo. En iOS y en in-app browsers, el JS lo compensa.
   ═══════════════════════════════════════════════════ */
@media(max-width:600px){
  .zoe-chat{bottom:80px;right:14px}
  .zoe-trigger-wrap{gap:10px}
  .zoe-teaser{min-height:56px;max-width:240px;padding:9px 15px 9px 11px;border-radius:18px;gap:10px}
  .zoe-teaser::before{border-radius:18px}
  .zoe-teaser::after{width:12px;height:12px;right:-6px}
  .zoe-teaser-badge{min-width:62px;height:32px;padding:0 10px;font-size:11px;border-radius:12px}
  .zoe-teaser-copy{font-size:12.5px;line-height:1.15}
  .zoe-bubble{width:56px;height:56px}
  .zoe-chat.open .zoe-trigger-wrap{display:none}
  .zoe-chat.open .zoe-bubble{opacity:0;pointer-events:none;transform:scale(.5)}

  .zoe-panel{
    position:fixed;
    top:0;
    left:0;
    right:0;
    bottom:0;
    width:100%;
    height:auto;     /* top+bottom definen la altura */
    max-height:none;
    border-radius:0;
    box-shadow:none;
    border:none;
    z-index:9999;
    transition:opacity .3s cubic-bezier(.2,.8,.3,1),transform .3s cubic-bezier(.2,.8,.3,1);
  }

  .zoe-hdr{
    padding:14px 18px;
    padding-top:calc(14px + env(safe-area-inset-top, 0px));
  }
  .zoe-avatar{width:38px;height:38px;font-size:17px}
  .zoe-name{font-size:15.5px}
  .zoe-close{padding:8px}
  .zoe-close svg{width:20px;height:20px}

  .zoe-body{padding:18px 16px;gap:14px}
  .zoe-msg p{font-size:15px;line-height:1.6}
  .zoe-msg-ai p{padding:14px 18px}
  .zoe-msg-user p{padding:14px 18px}

  .zoe-quick button{padding:13px 15px;font-size:14.5px}

  .zoe-input-wrap{
    padding:10px 14px;
    padding-bottom:calc(10px + env(safe-area-inset-bottom, 0px));
    gap:8px;
  }
  .zoe-input{padding:12px 16px;font-size:16px;border-radius:14px}
  .zoe-send{width:46px;height:46px;border-radius:14px}
}

/* ═══════════════════════════════════════════════════
   Body scroll lock — cuando el chat está abierto en mobile
   evitamos que la landing scrollee detrás del overlay.
   ═══════════════════════════════════════════════════ */
body.zoe-lock{
  position:fixed;
  top:var(--zoe-lock-top, 0);
  left:0;
  right:0;
  width:100%;
  overflow:hidden;
}

/* ═══════════════════════════════════════════════════
   ✦ APPENDED — Modales de Login/Registro + Plan Cards
   (fusión con flujo automatizado de Soma Pro)
   ═══════════════════════════════════════════════════ */

/* ─── HEADER: botón Acceder secundario ─── */
.nav-secondary {
  padding: 6px 14px;
  border-radius: 999px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--t);
  background: var(--sf);
  border: 1px solid var(--bd);
  margin-right: 6px;
  cursor: pointer;
  font-family: var(--f);
  transition: .2s;
}
.nav-secondary:hover { background: #fff; border-color: var(--c); color: var(--c); }
@media (max-width: 860px) { .nav-secondary { display: none; } }

/* ─── PLAN CARDS (3 cards: Basic / Pro / Unlimited) ─── */
.plans-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 980px;
  margin: 0 auto;
}
@media (max-width: 768px) {
  .plans-grid { grid-template-columns: 1fr; gap: 18px; }
}

.plan-card {
  background: #fff;
  border: 2px solid var(--bd);
  border-radius: 18px;
  padding: 30px 24px;
  text-align: center;
  position: relative;
  transition: all .25s;
  display: flex;
  flex-direction: column;
}
.plan-card:hover {
  border-color: var(--c);
  box-shadow: 0 12px 36px rgba(0, 185, 230, 0.14);
  transform: translateY(-4px);
}
.plan-card.popular {
  border-color: var(--c);
  box-shadow: 0 8px 30px rgba(0, 185, 230, 0.12);
  transform: translateY(-2px);
}
.plan-badge-popular {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: linear-gradient(135deg, var(--c), var(--cd));
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  padding: 5px 18px;
  border-radius: 20px;
  white-space: nowrap;
  letter-spacing: 0.3px;
  box-shadow: var(--sc);
}
.plan-card h3 {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--t);
  margin-bottom: 4px;
  letter-spacing: -0.01em;
}
.plan-limit {
  font-size: 0.88rem;
  color: var(--t3);
  margin-bottom: 18px;
}
.plan-price {
  display: flex;
  align-items: baseline;
  justify-content: center;
  gap: 3px;
  margin-bottom: 2px;
}
.plan-amount {
  font-size: 2rem;
  font-weight: 800;
  color: var(--t);
}
.plan-period {
  font-size: 0.92rem;
  color: var(--t3);
}
.plan-usd {
  font-size: 0.78rem;
  color: var(--t3);
  margin-bottom: 18px;
}
.btn-plan {
  width: 100%;
  padding: 12px;
  border: none;
  background: linear-gradient(135deg, var(--c), var(--cd));
  color: #fff;
  border-radius: 12px;
  font-size: 0.95rem;
  font-weight: 700;
  font-family: var(--f);
  cursor: pointer;
  transition: all .22s;
  margin-bottom: 18px;
  box-shadow: 0 4px 14px rgba(0, 185, 230, 0.22);
}
.btn-plan:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 22px rgba(0, 185, 230, 0.34);
}
.plan-features {
  list-style: none;
  text-align: left;
  margin: 0;
  padding: 0;
}
.plan-features li {
  font-size: 0.86rem;
  color: var(--t2);
  padding: 6px 0 6px 22px;
  position: relative;
  line-height: 1.45;
}
.plan-features li::before {
  content: '';
  position: absolute;
  left: 0;
  top: 11px;
  width: 14px;
  height: 14px;
  background: var(--cl);
  border-radius: 50%;
}
.plan-features li::after {
  content: '✓';
  position: absolute;
  left: 3px;
  top: 6px;
  color: var(--c);
  font-weight: 700;
  font-size: 11px;
}

.plans-note {
  text-align: center;
  font-size: 0.88rem;
  color: var(--t2);
  background: var(--cl);
  padding: 14px 22px;
  border-radius: 14px;
  max-width: 620px;
  margin: 22px auto 0;
}
.plans-note strong { color: var(--cd); }

/* ─── MODALES (Login + Registro) ─── */
.login-modal {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 10000;
  align-items: center;
  justify-content: center;
  padding: 16px;
}
.login-modal.active { display: flex; }

.login-overlay {
  position: absolute;
  inset: 0;
  background: rgba(12, 18, 34, 0.55);
  -webkit-backdrop-filter: saturate(120%) blur(12px);
  backdrop-filter: saturate(120%) blur(12px);
  animation: lmFadeIn 0.22s ease;
}
@keyframes lmFadeIn { from { opacity: 0; } to { opacity: 1; } }

.login-card {
  position: relative;
  z-index: 1;
  background: #fff;
  border-radius: 22px;
  padding: 38px 30px 30px;
  width: 92%;
  max-width: 420px;
  max-height: 92vh;
  overflow-y: auto;
  overscroll-behavior: contain;
  box-shadow: 0 28px 90px rgba(12, 18, 34, 0.18);
  animation: lmModalIn 0.32s cubic-bezier(.16, 1, .3, 1);
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 0, 0, 0.12) transparent;
}
.login-card::-webkit-scrollbar { width: 5px; }
.login-card::-webkit-scrollbar-track { background: transparent; }
.login-card::-webkit-scrollbar-thumb { background: rgba(0, 0, 0, 0.12); border-radius: 10px; }
@keyframes lmModalIn {
  from { opacity: 0; transform: scale(0.96) translateY(10px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

.reg-row { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.reg-row > * { min-width: 0; }
.login-card-wide { max-width: 480px; }

.login-close {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  background: var(--sf);
  border: 1px solid var(--bd);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all .2s;
}
.login-close svg { width: 16px; height: 16px; color: var(--t3); }
.login-close:hover { background: #fef2f2; border-color: #fecaca; }
.login-close:hover svg { color: #ef4444; }

.login-header { text-align: center; margin-bottom: 1.6rem; }
.login-logo { width: 42px; height: 42px; margin-bottom: 14px; }
.login-header h2 {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  margin-bottom: 4px;
  color: var(--t);
}
.login-header p { color: var(--t2); font-size: 0.92rem; }

.login-form { display: flex; flex-direction: column; gap: 0.95rem; }
.login-field { display: flex; flex-direction: column; gap: 0.32rem; }
.login-field label {
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--t2);
}
.login-field input,
.login-field select {
  width: 100%;
  box-sizing: border-box;
  padding: 11px 14px;
  border: 1.5px solid var(--bd);
  border-radius: 11px;
  font-size: 0.94rem;
  font-family: var(--f);
  color: var(--t);
  background: #fff;
  transition: all 0.18s;
}
.login-field input:focus,
.login-field select:focus {
  outline: none;
  border-color: var(--c);
  box-shadow: 0 0 0 3px rgba(0, 185, 230, 0.15);
}

.error-message {
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #dc2626;
  padding: 0.65rem 1rem;
  border-radius: 10px;
  font-size: 0.85rem;
  text-align: center;
}

.btn-login-submit {
  width: 100%;
  padding: 13px;
  background: linear-gradient(135deg, var(--c), var(--cd));
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 0.97rem;
  font-weight: 700;
  cursor: pointer;
  font-family: var(--f);
  transition: all 0.25s ease;
  box-shadow: 0 4px 14px rgba(0, 185, 230, 0.25);
  margin-top: 0.4rem;
}
.btn-login-submit:hover {
  transform: translateY(-1px);
  box-shadow: 0 8px 22px rgba(0, 185, 230, 0.35);
}
.btn-login-submit:disabled { opacity: 0.55; cursor: not-allowed; transform: none; }

.login-footer {
  margin-top: 1.4rem;
  text-align: center;
}
.login-footer a {
  color: var(--c);
  text-decoration: none;
  font-size: 0.86rem;
  font-weight: 600;
}
.login-footer a:hover { text-decoration: underline; }

/* Avatar upload area */
.reg-avatar-area {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1.5px dashed var(--bd);
  border-radius: 11px;
  cursor: pointer;
  transition: all .18s;
}
.reg-avatar-area:hover { border-color: var(--c); background: var(--cl); }
.reg-avatar-preview {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: var(--sf);
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  flex-shrink: 0;
}
.reg-avatar-text { font-size: 13px; color: var(--t3); }

/* Pay method radios */
.pay-methods {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  margin-top: 6px;
}
.pay-method-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 12px;
  border: 2px solid var(--bd);
  border-radius: 11px;
  cursor: pointer;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--t);
  transition: all .15s;
  text-align: center;
}
.pay-method-card.selected { border-color: var(--c); background: var(--cl); }
.pay-method-card .pay-currency {
  font-size: 11px;
  color: var(--t3);
  font-weight: 400;
}
