/* ============================ TOKENS DE MARCA ============================ */
:root{
  --verde-900:#0d2b22;   /* verde empresarial profundo */
  --verde-800:#123c2f;
  --verde-700:#1a4d3c;
  --verde-600:#236b53;
  --verde-glow:rgba(35,107,83,.35);
  --dorado:#c9a35b;       /* dorado elegante */
  --dorado-claro:#e6cf9b;
  --dorado-deep:#a8843f;
  --crema:#f7f1e6;        /* crema suave */
  --crema-2:#efe6d4;
  --blanco:#ffffff;
  --tinta:#16241f;        /* texto sobre claro */
  --tinta-suave:#4a5a52;
  --linea:rgba(201,163,91,.28);

  --display:'Fraunces', Georgia, 'Times New Roman', serif;
  --texto:'Outfit', -apple-system, BlinkMacSystemFont, sans-serif;

  --sombra-soft:0 12px 40px rgba(13,43,34,.10);
  --sombra-card:0 20px 60px rgba(13,43,34,.14);
  --sombra-glow:0 24px 80px rgba(13,43,34,.35);
  --radio:22px;
  --radio-sm:14px;
  --max:1180px;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--texto);
  color:var(--tinta);
  background:var(--crema);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}

.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.eyebrow{
  font-family:var(--texto);font-weight:600;letter-spacing:.22em;
  text-transform:uppercase;font-size:.74rem;color:var(--dorado-deep);
}
.serif{font-family:var(--display)}

/* Botones --------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--texto);font-weight:600;font-size:1rem;
  padding:1rem 2rem;border-radius:100px;cursor:pointer;border:0;
  transition:transform .35s cubic-bezier(.2,.9,.25,1), box-shadow .35s, background .35s;
  text-align:center;line-height:1.2;
}
.btn-oro{
  background:linear-gradient(135deg,var(--dorado-claro),var(--dorado) 55%,var(--dorado-deep));
  color:#23170a;box-shadow:0 14px 34px rgba(168,132,63,.42);
}
.btn-oro:hover{transform:translateY(-3px);box-shadow:0 22px 48px rgba(168,132,63,.55)}
.btn-line{
  background:transparent;color:var(--crema);
  border:1.5px solid rgba(230,207,155,.5);
}
.btn-line:hover{border-color:var(--dorado-claro);background:rgba(230,207,155,.08);transform:translateY(-3px)}
.btn-verde{
  background:linear-gradient(135deg,var(--verde-600),var(--verde-800));
  color:var(--crema);box-shadow:var(--sombra-card);
}
.btn-verde:hover{transform:translateY(-3px);box-shadow:var(--sombra-glow)}
.btn-block{width:100%}

/* Reveal on scroll ------------------------------------------------------ */
.reveal{opacity:0;transform:translateY(34px);transition:opacity .9s ease, transform .9s cubic-bezier(.2,.9,.25,1)}
.reveal.in{opacity:1;transform:none}

/* ============================ HERO ============================ */
.hero{
  position:relative;min-height:100vh;display:flex;align-items:center;
  background:
    radial-gradient(1200px 600px at 80% -5%, rgba(201,163,91,.18), transparent 60%),
    radial-gradient(900px 500px at -10% 110%, rgba(35,107,83,.5), transparent 60%),
    linear-gradient(160deg,var(--verde-900),var(--verde-800) 55%,#0a221b);
  color:var(--crema);overflow:hidden;
}
.hero::before{ /* textura sutil de grano */
  content:"";position:absolute;inset:0;opacity:.05;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.hero-grid{
  position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;
  gap:48px;align-items:center;width:100%;padding:120px 0 90px;
}
.hero h1{
  font-family:var(--display);font-weight:600;line-height:1.05;
  font-size:clamp(2.3rem,5vw,4rem);letter-spacing:-.01em;margin:1.1rem 0;
}
.hero h1 em{font-style:italic;color:var(--dorado-claro)}
.hero .sub{font-size:1.18rem;color:rgba(247,241,230,.82);max-width:46ch;margin-bottom:2rem;font-weight:300}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-note{margin-top:1.6rem;font-size:.86rem;color:rgba(230,207,155,.85);display:flex;align-items:center;gap:.5rem}
.hero-note::before{content:"✦";color:var(--dorado)}

/* Avatar empresarial */
.hero-figure{position:relative;display:flex;justify-content:center}
.avatar-frame{
  position:relative;width:clamp(260px,32vw,400px);aspect-ratio:3/4;
  border-radius:30px;overflow:hidden;
  box-shadow:0 30px 90px rgba(0,0,0,.45);
  border:1px solid rgba(230,207,155,.35);
}
.avatar-frame svg{width:100%;height:100%;display:block}
.avatar-badge{
  position:absolute;bottom:-22px;left:50%;transform:translateX(-50%);
  background:linear-gradient(135deg,var(--dorado-claro),var(--dorado-deep));
  color:#23170a;padding:.7rem 1.4rem;border-radius:100px;font-weight:600;
  font-size:.85rem;white-space:nowrap;box-shadow:0 12px 30px rgba(0,0,0,.35);
}
.ring{position:absolute;border:1px solid rgba(230,207,155,.25);border-radius:50%}
.ring.r1{width:120%;height:120%;top:-10%;left:-10%;animation:spin 40s linear infinite}
.ring.r2{width:145%;height:145%;top:-22%;left:-22%;border-style:dashed;animation:spin 60s linear infinite reverse}
@keyframes spin{to{transform:rotate(360deg)}}

/* ============================ VIDEO ============================ */
.video-sec{background:linear-gradient(180deg,#0a221b,var(--verde-900));color:var(--crema);padding:96px 0}
.sec-head{text-align:center;max-width:60ch;margin:0 auto 56px}
.sec-head h2{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.6vw,3rem);line-height:1.1;margin:.6rem 0 1rem;letter-spacing:-.01em}
.video-stage{
  position:relative;max-width:430px;margin:0 auto;
  border-radius:28px;overflow:hidden;
  box-shadow:0 40px 120px rgba(0,0,0,.55), 0 0 0 1px rgba(230,207,155,.22);
  background:#000;
}
.video-stage::after{ /* halo dorado */
  content:"";position:absolute;inset:-40px;z-index:-1;
  background:radial-gradient(circle,var(--dorado-glow,rgba(201,163,91,.4)),transparent 70%);
  filter:blur(30px);
}
.video-stage video,
.video-stage iframe{width:100%;display:block;border-radius:28px}
/* El iframe vertical (Short 9:16) usa aspect-ratio para mantener la proporción exacta */
.video-stage iframe{aspect-ratio:9/16;border:0}
.video-cap{text-align:center;color:rgba(230,207,155,.8);font-size:.92rem;margin-top:22px}

/* ============================ SECCIONES CLARAS ============================ */
.light{background:var(--crema);color:var(--tinta);padding:100px 0}
.light .eyebrow{color:var(--dorado-deep)}
.light h2{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.6vw,3rem);line-height:1.1;margin:.6rem 0 1rem;letter-spacing:-.01em;color:var(--verde-900)}
.light .lead{color:var(--tinta-suave);font-size:1.1rem;max-width:62ch;margin:0 auto;font-weight:300}

/* Problema cards */
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:54px}
.card{
  background:var(--blanco);border:1px solid var(--linea);border-radius:var(--radio);
  padding:34px 28px;box-shadow:var(--sombra-soft);
  transition:transform .4s cubic-bezier(.2,.9,.25,1), box-shadow .4s;
}
.card:hover{transform:translateY(-8px);box-shadow:var(--sombra-card)}
.card .ic{
  width:54px;height:54px;border-radius:14px;display:flex;align-items:center;justify-content:center;
  background:linear-gradient(135deg,var(--verde-700),var(--verde-600));margin-bottom:18px;
  box-shadow:0 10px 24px var(--verde-glow);
}
.card .ic svg{width:26px;height:26px;stroke:var(--dorado-claro);fill:none;stroke-width:1.8}
.card h3{font-family:var(--display);font-weight:600;font-size:1.22rem;color:var(--verde-900);margin-bottom:.5rem}
.card p{color:var(--tinta-suave);font-size:.97rem}

/* ============================ TOMOS ============================ */
.tomos-sec{background:linear-gradient(180deg,var(--crema),var(--crema-2));padding:100px 0}
.tomos{display:grid;grid-template-columns:repeat(2,1fr);gap:26px;margin-top:54px}
.tomo{
  display:flex;gap:22px;background:var(--blanco);border-radius:var(--radio);
  border:1px solid var(--linea);padding:26px;box-shadow:var(--sombra-soft);
  transition:transform .4s cubic-bezier(.2,.9,.25,1), box-shadow .4s;position:relative;overflow:hidden;
}
.tomo::before{content:"";position:absolute;left:0;top:0;bottom:0;width:5px;background:linear-gradient(180deg,var(--dorado-claro),var(--dorado-deep))}
.tomo:hover{transform:translateY(-6px);box-shadow:var(--sombra-card)}
.tomo-spine{
  flex:0 0 90px;height:130px;border-radius:10px;
  background:linear-gradient(150deg,var(--verde-700),var(--verde-900));
  display:flex;flex-direction:column;align-items:center;justify-content:space-between;
  padding:14px 8px;box-shadow:inset 0 0 0 1px rgba(230,207,155,.25), 0 12px 26px var(--verde-glow);
}
.tomo-spine .num{font-family:var(--display);font-weight:700;font-size:1.9rem;color:var(--dorado-claro);line-height:1}
.tomo-spine .seal{width:30px;height:30px;border-radius:50%;border:1.5px solid var(--dorado);display:flex;align-items:center;justify-content:center;color:var(--dorado-claro);font-size:.7rem}
.tomo-body{flex:1;display:flex;flex-direction:column}
.tomo-body h3{font-family:var(--display);font-weight:600;font-size:1.16rem;color:var(--verde-900);line-height:1.2;margin-bottom:.4rem}
.tomo-body p{color:var(--tinta-suave);font-size:.92rem;margin-bottom:auto}
.tomo-foot{display:flex;align-items:center;justify-content:space-between;margin-top:16px;gap:12px;flex-wrap:wrap}
.precio{font-family:var(--display);font-weight:600;color:var(--verde-800);font-size:1.3rem}
.precio small{font-size:.78rem;color:var(--tinta-suave);font-family:var(--texto);font-weight:400}
.btn-mini{
  background:linear-gradient(135deg,var(--verde-600),var(--verde-800));color:var(--crema);
  padding:.6rem 1.25rem;border-radius:100px;font-size:.88rem;font-weight:600;
  transition:transform .3s, box-shadow .3s;
}
.btn-mini:hover{transform:translateY(-2px);box-shadow:0 12px 26px var(--verde-glow)}

/* ============================ OFERTA ============================ */
.oferta{
  position:relative;color:var(--crema);padding:110px 0;text-align:center;overflow:hidden;
  background:
    radial-gradient(900px 500px at 50% -10%, rgba(201,163,91,.25), transparent 60%),
    linear-gradient(155deg,#0a221b,var(--verde-800));
}
.oferta::before{
  content:"";position:absolute;inset:0;opacity:.06;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.oferta-card{
  position:relative;z-index:2;max-width:760px;margin:0 auto;
  background:linear-gradient(160deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
  border:1px solid rgba(230,207,155,.3);border-radius:30px;
  padding:60px 44px;backdrop-filter:blur(8px);box-shadow:0 40px 110px rgba(0,0,0,.5);
}
.oferta-card h2{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4vw,3.2rem);line-height:1.05;margin:1rem 0}
.oferta-card .desc{color:rgba(247,241,230,.82);max-width:50ch;margin:0 auto 2rem;font-weight:300}
.precios{display:flex;align-items:baseline;justify-content:center;gap:20px;margin:1.4rem 0 .4rem;flex-wrap:wrap}
.precio-tach{font-size:1.6rem;color:rgba(247,241,230,.55);text-decoration:line-through;font-family:var(--display)}
.precio-oferta{font-family:var(--display);font-weight:700;font-size:clamp(3rem,7vw,4.6rem);color:var(--dorado-claro);line-height:1}
.ahorro{display:inline-block;background:rgba(201,163,91,.18);border:1px solid var(--dorado);color:var(--dorado-claro);padding:.4rem 1.1rem;border-radius:100px;font-size:.85rem;font-weight:600;margin-bottom:2rem}
.incluye{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;text-align:left;max-width:540px;margin:0 auto 2.2rem}
.incluye li{list-style:none;display:flex;gap:.6rem;font-size:.95rem;color:rgba(247,241,230,.9)}
.incluye li::before{content:"✓";color:var(--dorado-claro);font-weight:700}

/* ============================ GPT IA ============================ */
.gpt{
  background:
    radial-gradient(700px 400px at 85% 20%, rgba(35,107,83,.4), transparent 60%),
    linear-gradient(160deg,#061812,#0c2b21);
  color:var(--crema);padding:104px 0;position:relative;overflow:hidden;
}
.gpt-grid{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}
.gpt h2{font-family:var(--display);font-weight:600;font-size:clamp(2rem,3.6vw,3rem);line-height:1.1;margin:.6rem 0 1.2rem}
.gpt ul{margin:1.4rem 0 2rem;display:grid;gap:.7rem}
.gpt ul li{list-style:none;display:flex;gap:.7rem;color:rgba(247,241,230,.86)}
.gpt ul li::before{content:"◆";color:var(--dorado);font-size:.8rem;margin-top:.35rem}
/* mock chat */
.chat{
  background:rgba(255,255,255,.04);border:1px solid rgba(230,207,155,.25);
  border-radius:26px;padding:24px;box-shadow:0 30px 80px rgba(0,0,0,.5);backdrop-filter:blur(8px);
}
.chat-top{display:flex;align-items:center;gap:.7rem;padding-bottom:16px;border-bottom:1px solid rgba(230,207,155,.18);margin-bottom:18px}
.chat-dot{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--dorado-claro),var(--dorado-deep));display:flex;align-items:center;justify-content:center;color:#23170a;font-weight:700}
.chat-top b{font-family:var(--display);font-weight:600}
.chat-top span{font-size:.78rem;color:#7fd6af}
.bubble{padding:.85rem 1.1rem;border-radius:16px;margin-bottom:12px;font-size:.94rem;max-width:88%}
.bubble.user{background:rgba(230,207,155,.14);margin-left:auto;border-bottom-right-radius:4px}
.bubble.ai{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-bottom-left-radius:4px;color:rgba(247,241,230,.92)}

/* ============================ COMUNIDAD ============================ */
.comunidad{background:linear-gradient(180deg,var(--crema-2),var(--crema));padding:100px 0}
.membresia{
  max-width:680px;margin:48px auto 0;background:var(--blanco);
  border:1px solid var(--linea);border-radius:28px;overflow:hidden;
  box-shadow:var(--sombra-card);
}
.membresia-top{background:linear-gradient(135deg,var(--verde-700),var(--verde-900));color:var(--crema);padding:38px;text-align:center}
.membresia-top h3{font-family:var(--display);font-weight:600;font-size:1.7rem}
.membresia-top .price{font-family:var(--display);font-weight:700;font-size:3rem;color:var(--dorado-claro);margin-top:.4rem}
.membresia-top .price small{font-size:1rem;color:rgba(247,241,230,.7);font-family:var(--texto);font-weight:400}
.membresia-body{padding:38px}
.membresia-body ul{display:grid;gap:.85rem;margin-bottom:28px}
.membresia-body li{list-style:none;display:flex;gap:.7rem;color:var(--tinta-suave)}
.membresia-body li::before{content:"✦";color:var(--dorado-deep)}

/* ============================ TESTIMONIOS ============================ */
.testi{background:var(--verde-900);color:var(--crema);padding:100px 0}
.testi .sec-head h2{color:var(--crema)}
.testi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px}
.quote{
  background:linear-gradient(160deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid rgba(230,207,155,.2);border-radius:var(--radio);padding:32px;
  position:relative;
}
.quote::before{content:"\201C";font-family:var(--display);font-size:4rem;color:var(--dorado);position:absolute;top:6px;left:18px;opacity:.4;line-height:1}
.quote p{position:relative;z-index:2;color:rgba(247,241,230,.9);font-size:.98rem;margin-bottom:20px;font-style:italic}
.quote .who{display:flex;align-items:center;gap:.8rem}
.quote .av{width:46px;height:46px;border-radius:50%;background:linear-gradient(135deg,var(--dorado-claro),var(--dorado-deep));display:flex;align-items:center;justify-content:center;color:#23170a;font-weight:700;font-family:var(--display)}
.quote .who b{display:block;font-size:.95rem}
.quote .who span{font-size:.8rem;color:rgba(230,207,155,.75)}

/* ============================ FAQ ============================ */
.faq{background:var(--crema);padding:100px 0}
.faq-list{max-width:780px;margin:48px auto 0;display:grid;gap:14px}
.faq-item{background:var(--blanco);border:1px solid var(--linea);border-radius:var(--radio-sm);overflow:hidden;box-shadow:var(--sombra-soft)}
.faq-item summary{cursor:pointer;padding:22px 26px;font-family:var(--display);font-weight:600;color:var(--verde-900);font-size:1.08rem;list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:"+";color:var(--dorado-deep);font-size:1.5rem;transition:transform .3s;font-family:var(--texto)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item .ans{padding:0 26px 24px;color:var(--tinta-suave);font-size:.97rem}

/* ============================ CTA FINAL ============================ */
.final{
  position:relative;text-align:center;color:var(--crema);padding:120px 0;overflow:hidden;
  background:
    radial-gradient(900px 500px at 50% 120%, rgba(201,163,91,.22), transparent 60%),
    linear-gradient(160deg,var(--verde-900),#0a221b);
}
.final h2{font-family:var(--display);font-weight:600;font-size:clamp(2rem,4.4vw,3.4rem);line-height:1.12;max-width:20ch;margin:0 auto 1.6rem}
.final p{color:rgba(247,241,230,.82);max-width:52ch;margin:0 auto 2.4rem;font-size:1.12rem;font-weight:300}
.final .btn{font-size:1.1rem;padding:1.2rem 2.6rem}

/* ============================ FOOTER ============================ */
footer{background:#06140f;color:rgba(247,241,230,.6);padding:50px 0;text-align:center;font-size:.85rem}
footer .legal{max-width:70ch;margin:0 auto 1rem;line-height:1.7}
footer b{color:var(--dorado-claro);font-family:var(--display);font-weight:600;font-size:1.05rem}

/* ============================ RESPONSIVE ============================ */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr;text-align:center;gap:60px;padding:110px 0 70px}
  .hero .sub{margin-left:auto;margin-right:auto}
  .hero-cta,.hero-note{justify-content:center}
  .cards{grid-template-columns:1fr 1fr}
  .gpt-grid{grid-template-columns:1fr;gap:40px}
  .testi-grid{grid-template-columns:1fr}
}
@media (max-width:680px){
  .wrap{padding:0 18px}
  .cards,.tomos,.incluye{grid-template-columns:1fr}
  .tomo{flex-direction:column}
  .tomo-spine{flex:0 0 auto;width:100%;height:64px;flex-direction:row;justify-content:space-between;padding:0 16px}
  .tomo-spine .num{font-size:1.5rem}
  .oferta-card{padding:42px 24px}
  .light,.video-sec,.gpt,.comunidad,.testi,.faq,.tomos-sec,.oferta{padding:72px 0}
  .btn{width:100%}
  .hero-cta .btn{width:100%}
}
/* ============================ CHAT FLOTANTE GLOBAL DPB ============================ */
#dpb-launcher{
  position:fixed;bottom:24px;right:24px;z-index:9998;
  width:64px;height:64px;border-radius:50%;border:0;cursor:pointer;
  background:linear-gradient(135deg,var(--dorado-claro),var(--dorado) 55%,var(--dorado-deep));
  box-shadow:0 14px 34px rgba(168,132,63,.5);
  display:flex;align-items:center;justify-content:center;
  transition:transform .35s cubic-bezier(.2,.9,.25,1), box-shadow .35s;
}
#dpb-launcher:hover{transform:translateY(-3px) scale(1.05);box-shadow:0 20px 44px rgba(168,132,63,.6)}
#dpb-launcher svg{width:30px;height:30px;stroke:#23170a;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
#dpb-launcher .pulse{position:absolute;inset:0;border-radius:50%;background:var(--dorado);opacity:.5;animation:dpbpulse 2.4s ease-out infinite;z-index:-1}
@keyframes dpbpulse{0%{transform:scale(1);opacity:.5}100%{transform:scale(1.8);opacity:0}}

#dpb-panel{
  position:fixed;bottom:100px;right:24px;z-index:9999;
  width:380px;max-width:calc(100vw - 32px);
  height:600px;max-height:calc(100vh - 130px);
  border-radius:24px;overflow:hidden;background:var(--verde-900);
  box-shadow:0 30px 90px rgba(0,0,0,.5), 0 0 0 1px rgba(230,207,155,.25);
  display:flex;flex-direction:column;
  opacity:0;transform:translateY(20px) scale(.98);pointer-events:none;
  transition:opacity .35s ease, transform .35s cubic-bezier(.2,.9,.25,1);
}
#dpb-panel.open{opacity:1;transform:none;pointer-events:auto}
.dpb-header{background:linear-gradient(135deg,var(--verde-700),var(--verde-900));padding:18px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid rgba(230,207,155,.2);flex-shrink:0}
.dpb-emblema{width:42px;height:42px;border-radius:11px;flex-shrink:0;background:linear-gradient(135deg,var(--dorado-claro),var(--dorado-deep));display:flex;align-items:center;justify-content:center;font-family:var(--display);font-weight:700;color:#23170a;font-size:.95rem;overflow:hidden}
.dpb-header .info{flex:1;line-height:1.25}
.dpb-header .info b{font-family:var(--display);font-weight:600;font-size:1.02rem;color:var(--crema);display:block}
.dpb-header .info span{font-size:.76rem;color:#7fd6af}
.dpb-header .info span::before{content:"● ";color:#41c98a}
.dpb-close{background:transparent;border:0;color:rgba(247,241,230,.7);cursor:pointer;font-size:1.5rem;line-height:1;padding:4px;transition:color .2s}
.dpb-close:hover{color:var(--crema)}
.dpb-legal{padding:10px 16px;font-size:.68rem;line-height:1.45;color:rgba(230,207,155,.6);text-align:center;background:#0a221b;border-top:1px solid rgba(230,207,155,.12);flex-shrink:0}

/* Cuerpo del chat: ocupa todo el alto disponible entre cabecera y aviso legal */
.dpb-body{flex:1 1 auto;position:relative;padding:0;overflow:hidden;background:var(--verde-900);min-height:0}
#dpb-chatkit{width:100%;height:100%;display:block}
.dpb-fallback{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;padding:30px;text-align:center}
.dpb-fallback.hidden{display:none}
.dpb-saludo{font-family:var(--display);font-size:1.05rem;color:var(--crema);line-height:1.4}
.dpb-spinner{width:30px;height:30px;border:3px solid rgba(230,207,155,.25);border-top-color:var(--dorado);border-radius:50%;animation:dpbspin 1s linear infinite}
@keyframes dpbspin{to{transform:rotate(360deg)}}
.dpb-errmsg{font-size:.85rem;color:#f0b8a8;max-width:30ch}

/* Móvil / Android: pantalla completa, con doble unidad de altura por compatibilidad */
@media (max-width:480px){
  #dpb-panel{
    bottom:0;right:0;left:0;top:auto;
    width:100vw;max-width:100vw;
    height:100vh;height:100dvh;max-height:100vh;max-height:100dvh;
    border-radius:0;
  }
  #dpb-launcher{bottom:18px;right:18px}
}
