/* ============================================================
   QUIROTERAPIA · Dr. Roy Ramírez — editorial wellness cálido
   Paleta entintada · Fraunces + Hanken Grotesk · motion "respiración"
   ============================================================ */
:root{
  /* IDENTIDAD DEL CLIENTE: blanco + azul (primary #011A5A del sitio original).
     Nota: se conservan los nombres de variable; sus VALORES son azules. Acento cálido (dorado) mínimo. */
  --terra:#1E5AC8; --terra-deep:#123F94; --clay:#2E6FDB; --sage:#5B7BB5;   /* "acento primario" = azul médico */
  --sage-deep:#3A5688; --cream:#F3F7FC; --cream-lo:#FBFDFF; --paper:#E7EEF8; /* base blanca / azul muy claro */
  --ink:#0C1B33; --ink-70:rgba(12,27,51,.72); --ink-45:rgba(12,27,51,.46);   /* tinta = navy oscuro */
  --line:rgba(12,27,51,.12); --gold:#D8A24B;
  --navy:#011A5A; --navy-2:#0A2E6E; --blue:#2E6FDB; /* navy de identidad */
  --shadow:0 22px 60px -30px rgba(36,28,23,.5);
  --r:18px; --maxw:1200px;
  --ff-d:"Fraunces",Georgia,serif; --ff-t:"Hanken Grotesk",system-ui,sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0; background:var(--cream); color:var(--ink);
  font-family:var(--ff-t); font-size:clamp(16px,1.05vw,18px); line-height:1.65;
  -webkit-font-smoothing:antialiased; overflow-x:hidden;
}
h1,h2,h3{font-family:var(--ff-d); font-weight:500; line-height:1.02; letter-spacing:-.02em; margin:0}
p{margin:0 0 1em}
a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}
.wrap{width:min(92%,var(--maxw)); margin-inline:auto}
.eyebrow{font-family:var(--ff-t); font-weight:700; font-size:.72rem; letter-spacing:.22em; text-transform:uppercase; color:var(--terra)}

/* ---------- duotono cálido: unifica fotos dispares en una sola voz ---------- */
.duo{position:relative; overflow:hidden; background:var(--paper)}
.duo img{width:100%; height:100%; object-fit:cover;
  filter:saturate(1.02) contrast(1.04) brightness(1.0); transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.duo::after{content:""; position:absolute; inset:0; mix-blend-mode:multiply;
  background:linear-gradient(135deg,rgba(1,26,90,.24),rgba(46,111,219,.10) 55%,rgba(12,27,51,.06)); pointer-events:none}
.duo:hover img{transform:scale(1.045)}

/* ---------- nav ---------- */
.nav{position:fixed; inset:0 0 auto; z-index:60; display:flex; align-items:center; justify-content:space-between;
  padding:18px clamp(16px,4vw,48px); transition:background .4s,box-shadow .4s,padding .4s}
.nav.scrolled{background:rgba(244,236,223,.86); backdrop-filter:blur(12px); box-shadow:0 1px 0 var(--line); padding-block:12px}
.brand{display:flex; align-items:center; gap:10px; font-family:var(--ff-d); font-weight:600; font-size:1.18rem; letter-spacing:-.01em}
.brand .mark{width:30px;height:30px;flex:0 0 auto}
.nav-links{display:flex; gap:30px; align-items:center}
.nav-links a{font-size:.9rem; color:var(--ink-70); font-weight:500}
.nav-links a:hover{color:var(--terra)}
.nav-cta{display:inline-flex; align-items:center; gap:8px; background:var(--terra); color:var(--cream-lo);
  padding:10px 18px; border-radius:999px; font-weight:700; font-size:.86rem; transition:transform .2s,background .2s}
.nav-cta:hover{background:var(--terra-deep); transform:translateY(-2px)}
.nav-burger{display:none; background:none; border:0; color:var(--ink); cursor:pointer}
@media(max-width:860px){
  .nav-links{position:fixed; inset:0 0 0 auto; width:min(78%,320px); flex-direction:column; justify-content:center;
    gap:26px; background:var(--cream-lo); transform:translateX(100%); transition:transform .4s; box-shadow:var(--shadow); padding:40px}
  .nav-links.open{transform:none}
  .nav-burger{display:block}
}

/* ---------- botones ---------- */
.btn{display:inline-flex; align-items:center; gap:9px; font-weight:700; font-size:.95rem; padding:14px 24px;
  border-radius:999px; cursor:pointer; border:0; transition:transform .2s,background .2s,color .2s}
.btn-primary{background:var(--terra); color:var(--cream-lo)}
.btn-primary:hover{background:var(--terra-deep); transform:translateY(-2px)}
.btn-ghost{background:transparent; color:var(--ink); box-shadow:inset 0 0 0 1.5px var(--ink)}
.btn-ghost:hover{background:var(--ink); color:var(--cream-lo); transform:translateY(-2px)}
.wa-ic{width:18px;height:18px;flex:0 0 auto}

/* ---------- HERO ---------- */
.hero{position:relative; min-height:100svh; display:grid; grid-template-columns:1.05fr .95fr; align-items:center;
  gap:40px; padding:120px clamp(16px,4vw,48px) 60px}
.hero-copy{max-width:620px}
.hero h1{font-size:clamp(2.9rem,7vw,5.4rem); margin:.28em 0 .35em}
.hero h1 .it{font-style:italic; color:var(--terra)}
.hero .lede{font-size:clamp(1.05rem,1.6vw,1.28rem); color:var(--ink-70); max-width:44ch; margin-bottom:1.7em}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap}
.hero-media{position:relative; align-self:stretch; min-height:60svh; border-radius:26px; overflow:hidden; box-shadow:var(--shadow)}
.hero-media .duo,.hero-media img{position:absolute; inset:0; height:100%}
.hero-badge{position:absolute; left:20px; bottom:20px; z-index:3; display:flex; align-items:center; gap:12px;
  background:rgba(244,236,223,.94); backdrop-filter:blur(6px); border-radius:16px; padding:12px 16px; box-shadow:var(--shadow)}
.hero-badge .stars{color:var(--gold); font-size:1rem; letter-spacing:2px}
.hero-badge b{font-family:var(--ff-d)}
.hero-badge small{display:block; color:var(--ink-45); font-size:.72rem}
/* columna vértebras firma */
.spine{position:absolute; top:0; bottom:0; left:calc(50% - 1px); width:2px; z-index:1; pointer-events:none; opacity:.5}
.spine i{position:absolute; left:50%; width:26px; height:9px; margin-left:-13px; border-radius:6px;
  background:var(--navy); opacity:.85; transform:translateX(var(--dx,14px)) rotate(var(--rot,6deg)); transition:transform .9s cubic-bezier(.2,.7,.2,1)}
.is-anim .spine.aligned i{transform:translateX(0) rotate(0)}
@media(max-width:860px){.hero{grid-template-columns:1fr; min-height:auto; padding-top:104px} .hero-media{min-height:52svh} .spine{display:none}}

/* ---------- hero dinámico ---------- */
.hero{position:relative; overflow:hidden}
.hero-aurora{position:absolute; inset:0; z-index:0; pointer-events:none}
.hero-aurora span{position:absolute; border-radius:50%; filter:blur(70px)}
.hero-aurora span:nth-child(1){width:46vw; height:46vw; left:-8vw; top:-12vw; background:radial-gradient(circle,rgba(46,111,219,.42),transparent 70%); animation:aur1 18s ease-in-out infinite alternate}
.hero-aurora span:nth-child(2){width:40vw; height:40vw; right:-6vw; top:6vw; background:radial-gradient(circle,rgba(1,26,90,.30),transparent 70%); animation:aur2 23s ease-in-out infinite alternate}
.hero-aurora span:nth-child(3){width:34vw; height:34vw; left:26vw; bottom:-18vw; background:radial-gradient(circle,rgba(120,180,255,.34),transparent 70%); animation:aur1 27s ease-in-out infinite alternate-reverse}
@keyframes aur1{to{transform:translate(6vw,4vw) scale(1.15)}}
@keyframes aur2{to{transform:translate(-5vw,6vw) scale(1.1)}}
.hero-copy,.hero-media{position:relative; z-index:2}
.rot{display:inline-block; position:relative}
.rot-word{display:inline-block; color:var(--terra); font-style:italic; transition:opacity .35s,transform .35s}
.rot-word.out{opacity:0; transform:translateY(-10px)}
.rot::after{content:""; position:absolute; left:0; right:0; bottom:.04em; height:.13em; background:var(--terra); opacity:.26; border-radius:4px}
.hero-img{will-change:transform; transition:transform .3s cubic-bezier(.2,.7,.2,1)}
.hero-chip{position:absolute; z-index:4; background:rgba(255,255,255,.84); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.7); border-radius:16px; padding:12px 16px; box-shadow:var(--shadow); display:flex; align-items:center; gap:10px}
.hero-chip b{font-family:var(--ff-d); font-size:1.7rem; color:var(--navy); line-height:1}
.hero-chip span{font-size:.72rem; color:var(--ink-70); line-height:1.15; text-align:left}
.chip-years{right:-14px; top:22px; animation:floaty 5s ease-in-out infinite}
.hero-badge{animation:floaty 6s ease-in-out infinite .6s}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-9px)}}
@media (prefers-reduced-motion:reduce){.hero-aurora span,.chip-years,.hero-badge,.hero-img{animation:none!important; transition:none} .rot-word{transition:none}}
@media(max-width:860px){.chip-years{right:8px; top:10px; padding:8px 12px} .chip-years b{font-size:1.3rem}}

/* ---------- secciones base ---------- */
section{padding:clamp(64px,9vw,120px) 0}
.sec-head{max-width:60ch; margin-bottom:48px}
.sec-head h2{font-size:clamp(2rem,4.4vw,3.3rem); margin:.25em 0 .3em}
.sec-head p{color:var(--ink-70); font-size:1.08rem}
.underline{position:relative; white-space:nowrap}
.underline::after{content:""; position:absolute; left:0; right:0; bottom:.08em; height:.42em; z-index:-1;
  background:rgba(46,111,219,.24); transform:scaleX(0); transform-origin:left; transition:transform .7s cubic-bezier(.2,.7,.2,1) .15s}
.in .underline::after,.underline.on::after{transform:scaleX(1)}

/* ---------- BODY MAP interactivo ---------- */
.map{background:var(--cream-lo)}
.map-grid{display:grid; grid-template-columns:.9fr 1.1fr; gap:clamp(28px,5vw,64px); align-items:center}
.body-wrap{position:relative; display:flex; justify-content:center}
.body-fig{position:relative; width:100%; max-width:300px; margin-inline:auto}
.body-fig img{width:100%; height:auto; display:block; filter:drop-shadow(0 22px 44px rgba(1,26,90,.20))}
.hot{position:absolute; width:26px; height:26px; transform:translate(-50%,-50%); border-radius:50%; border:2px solid #fff; background:var(--navy); opacity:.72; cursor:pointer; padding:0; box-shadow:0 3px 10px rgba(1,26,90,.35); transition:transform .2s,opacity .2s,background .2s}
.hot::after{content:""; position:absolute; inset:-7px; border-radius:50%; border:2px solid var(--navy); opacity:.4; animation:hotpulse 2.6s ease-out infinite}
.hot:hover{opacity:1; transform:translate(-50%,-50%) scale(1.18); background:var(--blue)}
.hot.active{background:var(--gold); opacity:1; border-color:#fff}
.hot.active::after{border-color:var(--gold); animation:none}
@keyframes hotpulse{0%{transform:scale(1);opacity:.45}70%,100%{transform:scale(1.7);opacity:0}}
@media (prefers-reduced-motion:reduce){.hot::after{animation:none}}
@media(max-width:820px){.body-fig{max-width:220px}.hot{width:22px;height:22px}}
.map-panel{background:var(--cream); border:1px solid var(--line); border-radius:var(--r); padding:clamp(22px,3vw,34px); min-height:340px; box-shadow:var(--shadow)}
.map-panel .zone-name{font-family:var(--ff-d); font-size:1.7rem; color:var(--terra); margin-bottom:4px}
.map-panel .zone-hint{color:var(--ink-45); font-size:.9rem; margin-bottom:20px}
.cond-list{display:flex; flex-direction:column; gap:12px}
.cond{display:grid; grid-template-columns:1fr auto; gap:4px 14px; padding:14px 16px; border-radius:12px; background:var(--cream-lo); border:1px solid var(--line)}
.cond h4{font-family:var(--ff-d); font-weight:500; font-size:1.08rem; margin:0}
.cond .sess{font-size:.78rem; font-weight:700; color:var(--sage-deep); align-self:center; white-space:nowrap}
.cond p{grid-column:1/-1; margin:0; font-size:.9rem; color:var(--ink-70)}
.cond a{grid-column:1/-1; font-size:.8rem; font-weight:700; color:var(--terra)}
.map-chips{display:flex; flex-wrap:wrap; gap:8px; margin-top:22px}
.chip{border:1px solid var(--line); background:none; border-radius:999px; padding:7px 14px; font-size:.82rem; font-weight:600; cursor:pointer; color:var(--ink-70); transition:all .2s}
.chip:hover,.chip.active{background:var(--terra); color:var(--cream-lo); border-color:var(--terra)}
@media(max-width:820px){.map-grid{grid-template-columns:1fr} .body-svg{max-width:240px}}

/* ---------- MÉTODO ---------- */
.method-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:22px}
.mcard{background:var(--cream-lo); border-radius:var(--r); overflow:hidden; border:1px solid var(--line); display:flex; flex-direction:column}
.mcard .duo{aspect-ratio:16/10}
.mcard-body{padding:22px 22px 26px}
.mcard h3{font-size:1.35rem; margin-bottom:.35em}
.mcard p{color:var(--ink-70); font-size:.95rem; margin:0}
.mcard .n{font-family:var(--ff-d); font-style:italic; color:var(--clay); font-size:.95rem}

/* ---------- ROY ---------- */
.roy{background:var(--paper)}
.roy-grid{display:grid; grid-template-columns:.8fr 1.2fr; gap:clamp(30px,5vw,60px); align-items:center}
.roy-media{position:relative}
.roy-portrait{aspect-ratio:4/5; border-radius:22px; overflow:hidden; box-shadow:var(--shadow); background:var(--sage);
  display:flex; align-items:flex-end; justify-content:center}
.roy-initial{font-family:var(--ff-d); font-size:13rem; color:var(--cream-lo); opacity:.9; line-height:.8; padding-bottom:10px}
.roy-tag{position:absolute; right:-14px; bottom:24px; background:var(--terra); color:var(--cream-lo); font-family:var(--ff-d);
  font-style:italic; padding:10px 18px; border-radius:14px; font-size:1.05rem; box-shadow:var(--shadow)}
.roy h2{font-size:clamp(1.9rem,4vw,3rem); margin-bottom:.4em}
.roy .role{font-weight:700; color:var(--terra); font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; margin-bottom:1em}
.roy blockquote{font-family:var(--ff-d); font-style:italic; font-size:1.3rem; border-left:3px solid var(--terra); padding-left:18px; margin:1.4em 0 0; color:var(--ink)}
@media(max-width:820px){.roy-grid{grid-template-columns:1fr} .roy-initial{font-size:9rem}}

/* ---------- RESEÑAS ---------- */
.revs{background:var(--navy); color:var(--cream)}
.revs .sec-head h2{color:var(--cream-lo)}
.revs .sec-head p{color:rgba(244,236,223,.65)}
.rev-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr)); gap:20px}
.rev{background:rgba(244,236,223,.06); border:1px solid rgba(244,236,223,.14); border-radius:var(--r); padding:26px}
.rev .stars{color:var(--gold); letter-spacing:2px; margin-bottom:12px}
.rev blockquote{font-family:var(--ff-d); font-size:1.12rem; line-height:1.4; margin:0 0 16px}
.rev .by{font-size:.85rem; color:rgba(244,236,223,.7); font-weight:600}
.rev-foot{margin-top:30px; display:flex; align-items:center; gap:12px; color:rgba(244,236,223,.7); font-size:.88rem}

/* ---------- SEDES ---------- */
.sedes-tabs{display:flex; gap:10px; margin-bottom:28px}
.stab{border:1px solid var(--line); background:none; border-radius:999px; padding:11px 22px; font-weight:700; font-size:.92rem; cursor:pointer; color:var(--ink-70); transition:all .2s}
.stab.active{background:var(--ink); color:var(--cream-lo); border-color:var(--ink)}
.sede{display:none; grid-template-columns:1fr 1fr; gap:30px; align-items:stretch}
.sede.show{display:grid}
.sede-info h3{font-size:1.9rem; margin-bottom:.5em}
.sede-info .row{display:flex; gap:12px; padding:12px 0; border-bottom:1px solid var(--line); font-size:.98rem}
.sede-info .row b{min-width:96px; color:var(--ink-45); font-weight:700; font-size:.8rem; letter-spacing:.08em; text-transform:uppercase; padding-top:2px}
.sede-info .cta{margin-top:22px; display:flex; gap:12px; flex-wrap:wrap}
.sede-map{border-radius:var(--r); overflow:hidden; min-height:320px; border:1px solid var(--line)}
.sede-map iframe{width:100%; height:100%; min-height:320px; border:0; filter:sepia(.15) saturate(1.05)}
@media(max-width:760px){.sede.show{grid-template-columns:1fr}}

/* ---------- FAQ ---------- */
.faq{background:var(--cream-lo)}
.faq-list{max-width:820px; margin-inline:auto}
.faq-item{border-bottom:1px solid var(--line)}
.faq-item summary{cursor:pointer; list-style:none; padding:22px 0; font-family:var(--ff-d); font-size:1.2rem; display:flex; justify-content:space-between; gap:20px; align-items:center}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+"; color:var(--terra); font-size:1.5rem; transition:transform .3s; flex:0 0 auto}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item p{color:var(--ink-70); padding:0 0 22px; margin:0; max-width:70ch}

/* ---------- CTA / CONTACTO ---------- */
.cta-final{background:linear-gradient(150deg,var(--terra),var(--terra-deep)); color:var(--cream-lo); text-align:center}
.cta-final h2{font-size:clamp(2.1rem,5vw,3.6rem); margin-bottom:.35em; color:var(--cream-lo)}
.cta-final p{color:rgba(251,246,236,.85); max-width:52ch; margin:0 auto 1.8em}
.cta-final .btn-primary{background:var(--cream-lo); color:var(--terra-deep)}
.cta-final .btn-primary:hover{background:#fff}
.cta-final .btn-ghost{box-shadow:inset 0 0 0 1.5px var(--cream-lo); color:var(--cream-lo)}
.cta-final .btn-ghost:hover{background:var(--cream-lo); color:var(--terra-deep)}

/* ---------- footer ---------- */
.foot{background:var(--navy); color:rgba(244,236,223,.7); padding:60px 0 30px}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr; gap:30px; margin-bottom:36px}
.foot h4{color:var(--cream-lo); font-family:var(--ff-d); font-weight:500; margin-bottom:14px; font-size:1.1rem}
.foot a{color:rgba(244,236,223,.7); font-size:.92rem; display:block; padding:3px 0}
.foot a:hover{color:var(--terra)}
.foot .socials{display:flex; gap:14px; margin-top:8px}
.foot .socials a{display:inline-flex}
.foot-bottom{border-top:1px solid rgba(244,236,223,.14); padding-top:22px; font-size:.8rem; color:rgba(244,236,223,.5); display:flex; justify-content:space-between; flex-wrap:wrap; gap:8px}
@media(max-width:760px){.foot-grid{grid-template-columns:1fr 1fr} .foot-grid>div:first-child{grid-column:1/-1}}

/* ---------- FAB WhatsApp ---------- */
.fab{position:fixed; right:20px; bottom:20px; z-index:55; width:56px; height:56px; border-radius:50%; background:#25D366;
  display:flex; align-items:center; justify-content:center; box-shadow:0 12px 30px -8px rgba(37,211,102,.6); transition:transform .25s}
.fab:hover{transform:scale(1.08)}
.fab svg{width:30px; height:30px}

/* ---------- reveal robusto ---------- */
.is-anim [data-r]{opacity:0; transform:translateY(26px); transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.is-anim [data-r].in{opacity:1; transform:none}
@media (prefers-reduced-motion:reduce){
  .is-anim [data-r]{opacity:1!important; transform:none!important}
  .duo img,.spine i{transition:none!important}
}

/* ---------- páginas de condición ---------- */
.cond-hero{padding:140px clamp(16px,4vw,48px) 60px; display:grid; grid-template-columns:1.1fr .9fr; gap:40px; align-items:center; background:var(--cream-lo)}
.cond-hero h1{font-size:clamp(2.4rem,5.5vw,4rem); margin:.2em 0 .4em}
.cond-hero .crumb{font-size:.85rem; color:var(--ink-45)}
.cond-hero .crumb a{color:var(--terra); font-weight:600}
.cond-hero-media{aspect-ratio:4/3; border-radius:22px; overflow:hidden; box-shadow:var(--shadow)}
.prose{max-width:760px; margin-inline:auto}
.prose h2{font-size:clamp(1.6rem,3.4vw,2.4rem); margin:1.4em 0 .5em}
.prose ul{padding-left:1.1em} .prose li{margin:.4em 0}
.sess-box{background:var(--paper); border-radius:var(--r); padding:24px 28px; margin:28px 0; border-left:4px solid var(--terra)}
.sess-box b{font-family:var(--ff-d); font-size:1.3rem; color:var(--terra)}
@media(max-width:820px){.cond-hero{grid-template-columns:1fr; padding-top:110px}}

/* ---------- MODAL WhatsApp (QR + directo) ---------- */
.wa-modal{position:fixed; inset:0; z-index:100; display:flex; align-items:center; justify-content:center; padding:20px}
.wa-modal[hidden]{display:none!important}
.wa-overlay{position:absolute; inset:0; background:rgba(1,26,90,.55); backdrop-filter:blur(4px)}
.wa-card{position:relative; background:var(--cream-lo); border-radius:24px; padding:30px 28px 26px; max-width:392px; width:100%; text-align:center; box-shadow:var(--shadow); animation:waPop .3s cubic-bezier(.2,.7,.2,1)}
@keyframes waPop{from{opacity:0; transform:translateY(16px) scale(.98)} to{opacity:1; transform:none}}
.wa-x{position:absolute; top:12px; right:14px; width:34px; height:34px; border:0; background:none; font-size:1.7rem; line-height:1; cursor:pointer; color:var(--ink-45); border-radius:50%}
.wa-x:hover{background:var(--paper); color:var(--ink)}
.wa-card .eyebrow{color:var(--navy)}
.wa-card h3{font-size:1.7rem; margin:.2em 0 0}
.wa-sedes{display:flex; gap:8px; justify-content:center; margin:18px 0 16px}
.wa-sede{border:1px solid var(--line); background:none; border-radius:999px; padding:9px 18px; font-weight:700; font-size:.86rem; cursor:pointer; color:var(--ink-70); transition:all .2s}
.wa-sede.active{background:var(--navy); color:var(--cream-lo); border-color:var(--navy)}
.wa-qr{width:206px; height:206px; margin:0 auto 14px; background:#fff; border-radius:16px; padding:12px; box-shadow:inset 0 0 0 1px var(--line)}
.wa-qr img{width:100%; height:100%; display:block; image-rendering:pixelated}
.wa-hint{font-size:.88rem; color:var(--ink-70); margin:0 0 8px; display:flex; align-items:center; gap:8px; justify-content:center}
.wa-addr{font-size:.78rem; color:var(--ink-45); margin:0 0 16px}
.wa-card .btn-primary{width:100%; justify-content:center; background:#25D366; color:#fff}
.wa-card .btn-primary:hover{background:#1eb457}
.wa-num{font-size:.8rem; color:var(--ink-45); margin:12px 0 0}
@media (prefers-reduced-motion:reduce){.wa-card{animation:none}}
@media(max-width:420px){.wa-qr{width:180px; height:180px}}

/* ---------- Chat asistente (feature flag) ---------- */
.chat-launch{position:fixed; left:20px; bottom:20px; z-index:90; display:flex; align-items:center; gap:9px; background:var(--navy); color:var(--cream-lo); border:0; border-radius:999px; padding:12px 18px 12px 14px; cursor:pointer; box-shadow:0 12px 30px -8px rgba(1,26,90,.55); font-family:var(--ff-t); font-weight:700; font-size:.9rem; transition:transform .2s}
.chat-launch:hover{transform:translateY(-2px)}
.chat-launch svg{width:22px; height:22px}
.chat-launch .dot{position:absolute; top:7px; right:12px; width:9px; height:9px; background:var(--gold); border-radius:50%; animation:cpulse 2s infinite}
@keyframes cpulse{0%{box-shadow:0 0 0 0 rgba(216,162,75,.6)}70%{box-shadow:0 0 0 8px rgba(216,162,75,0)}100%{box-shadow:0 0 0 0 rgba(216,162,75,0)}}
.chat-panel{position:fixed; left:20px; bottom:20px; z-index:95; width:min(380px,calc(100vw - 40px)); height:min(560px,calc(100vh - 40px)); background:var(--cream-lo); border-radius:22px; box-shadow:0 30px 70px -20px rgba(1,26,90,.5); display:flex; flex-direction:column; overflow:hidden; opacity:0; transform:translateY(20px) scale(.98); pointer-events:none; transition:opacity .3s,transform .3s}
.chat-panel.open{opacity:1; transform:none; pointer-events:auto}
.chat-head{background:var(--navy); color:var(--cream-lo); padding:15px 16px; display:flex; align-items:center; gap:11px}
.chat-head .av{width:38px; height:38px; border-radius:50%; background:var(--blue); display:flex; align-items:center; justify-content:center; flex:0 0 auto}
.chat-head h4{font-family:var(--ff-d); font-size:1.08rem; margin:0; color:#fff; font-weight:500}
.chat-head small{font-size:.72rem; color:rgba(255,255,255,.72); display:flex; align-items:center; gap:5px}
.chat-head small::before{content:""; width:7px; height:7px; border-radius:50%; background:#4ade80}
.chat-close{margin-left:auto; background:none; border:0; color:rgba(255,255,255,.85); cursor:pointer; font-size:1.6rem; line-height:1}
.chat-body{flex:1; overflow-y:auto; padding:18px; display:flex; flex-direction:column; gap:11px; background:var(--cream)}
.msg{max-width:84%; padding:11px 14px; border-radius:16px; font-size:.92rem; line-height:1.45; white-space:pre-wrap; overflow-wrap:anywhere; word-break:break-word}
.msg.bot{align-self:flex-start; background:#fff; color:var(--ink); border-bottom-left-radius:5px; box-shadow:0 2px 8px rgba(1,26,90,.06)}
.msg.user{align-self:flex-end; background:var(--navy); color:var(--cream-lo); border-bottom-right-radius:5px}
.chat-quick{display:flex; flex-wrap:wrap; gap:8px; padding:0 16px 10px; background:var(--cream)}
.chat-quick button{border:1px solid var(--line); background:#fff; border-radius:999px; padding:8px 13px; font-size:.8rem; font-weight:600; color:var(--navy); cursor:pointer; transition:all .2s}
.chat-quick button:hover{background:var(--navy); color:#fff; border-color:var(--navy)}
.chat-typing{align-self:flex-start; display:flex; gap:4px; padding:13px 14px; background:#fff; border-radius:16px; border-bottom-left-radius:5px}
.chat-typing i{width:7px; height:7px; border-radius:50%; background:var(--ink-45); animation:ctype 1.2s infinite}
.chat-typing i:nth-child(2){animation-delay:.2s} .chat-typing i:nth-child(3){animation-delay:.4s}
@keyframes ctype{0%,60%,100%{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-4px)}}
.chat-input{display:flex; gap:8px; padding:12px; border-top:1px solid var(--line); background:var(--cream-lo)}
.chat-input input{flex:1; border:1px solid var(--line); border-radius:999px; padding:11px 16px; font-family:var(--ff-t); font-size:.92rem; outline:none; background:#fff; color:var(--ink)}
.chat-input input:focus{border-color:var(--blue)}
.chat-input button{width:44px; height:44px; border-radius:50%; border:0; background:var(--navy); color:#fff; cursor:pointer; flex:0 0 auto; display:flex; align-items:center; justify-content:center}
.chat-input button:disabled{opacity:.5}
.chat-disc{font-size:.68rem; color:var(--ink-45); text-align:center; padding:0 12px 10px; background:var(--cream-lo)}
@media (prefers-reduced-motion:reduce){.chat-panel{transition:none} .chat-launch .dot{animation:none}}
@media(max-width:520px){.chat-launch span{display:none} .chat-launch{padding:13px}}
