/* ==========================================================================
   Patitags — Premium Glass + Nav estable
   ✅ Sin duplicados de footer/glass/shine/reveal
   ✅ Dock eliminado
   ✅ Footer tipo “perfil perritos”
   ✅ Botón WhatsApp flotante halo + ondas (all devices)
   ✅ Mini avatar FIX (estable 30x30 + img cover)
   ========================================================================== */

:root{
  --font:"Poppins",system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;

  --pink:#e4717a;
  --violet:#764ba2;
  --fuchsia:#f093fb;

  --blue:#2f86ff;
  --blue2:#6fe1ff;

  --r-lg:26px;
  --r-xl:34px;
  --ease:cubic-bezier(.2,.8,.2,1);

  --max:1080px;
  --p4:22px;
  --p5:28px;
}

/* ✅ Evita “saltos” por scrollbar al abrir modal */
html{ scrollbar-gutter: stable; }

*{ box-sizing:border-box }
html,body{ height:100% }
body{
  margin:0;
  font-family:var(--font);
  overflow-x:hidden;
}
img{ max-width:100%; display:block }
a{ color:inherit; text-decoration:none }
button{ font-family:inherit }
.muted{ color:var(--muted) }
#top{ height:1px; width:1px }

/* =========================
   THEME: DARK
   ========================= */
body[data-theme="dark"]{
  --bg:#0b0b10;
  --text: rgba(255,255,255,.92);
  --text2: rgba(255,255,255,.82);
  --muted: rgba(255,255,255,.70);

  --glass-border: rgba(255,255,255,.18);
  --glass-1: rgba(255,255,255,.11);
  --glass-2: rgba(255,255,255,.05);
  --glass-lite: rgba(255,255,255,.06);
  --glass-lite-border: rgba(255,255,255,.14);

  --shadow:0 18px 60px rgba(0,0,0,.45);
  --shadow-soft:0 10px 30px rgba(0,0,0,.30);

  --title-a1: var(--pink);
  --title-a2: var(--violet);

  --rot-b1: var(--blue2);
  --rot-b2: var(--fuchsia);

  --mock-accent: var(--blue2);

  background:var(--bg);
  color:var(--text);
}

/* =========================
   THEME: LIGHT
   ========================= */
body[data-theme="light"]{
  --bg:#f6f9ff;

  --text: rgba(10,40,90,.92);
  --text2: rgba(10,40,90,.78);
  --muted: rgba(10,40,90,.62);

  --glass-border: rgba(10,40,90,.10);
  --glass-1: rgba(255,255,255,.82);
  --glass-2: rgba(255,255,255,.52);
  --glass-lite: rgba(255,255,255,.72);
  --glass-lite-border: rgba(10,40,90,.10);

  --shadow:0 16px 48px rgba(10,30,60,.12);
  --shadow-soft:0 10px 24px rgba(10,30,60,.08);

  --title-a1: var(--blue);
  --title-a2: var(--blue2);

  --rot-b1: var(--pink);
  --rot-b2: var(--violet);

  --mock-accent: var(--blue);

  background:var(--bg);
  color:var(--text);
}

/* =========================
   TYPO
   ========================= */
.titleXL{margin:0;font-weight:900;letter-spacing:-.03em;line-height:1.06;font-size:28px;}
.titleLG{margin:0;font-weight:900;letter-spacing:-.02em;line-height:1.10;font-size:22px;}
.titleMD{margin:0;font-weight:900;letter-spacing:-.01em;line-height:1.15;font-size:16px;}
.textBody{margin:10px 0 0;color:var(--text2);font-size:13.5px;line-height:1.55;}
.textSmall{margin:12px 0 0;color:var(--muted);font-size:12px;line-height:1.45;}
@media (min-width:760px){
  .titleXL{font-size:42px}
  .titleLG{font-size:26px}
}

/* Gradientes */
.gradTitleA{
  background: linear-gradient(90deg, var(--title-a1), var(--title-a2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.gradRotatorB{
  background: linear-gradient(90deg, var(--rot-b1), var(--rot-b2));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.titleHero{
  display:flex;
  flex-wrap:wrap;
  align-items:baseline;
  gap:8px;
}

/* =========================
   BACKGROUND
   ========================= */
.bg{position:fixed;inset:0;z-index:-2;overflow:hidden}
.blob{position:absolute;width:520px;height:520px;filter:blur(46px);opacity:.55;border-radius:50%;}
body[data-theme="dark"] .blob--1{background:radial-gradient(circle at 30% 30%, var(--pink), transparent 60%);top:-160px;left:-180px}
body[data-theme="dark"] .blob--2{background:radial-gradient(circle at 30% 30%, var(--violet), transparent 60%);bottom:-220px;right:-180px}
body[data-theme="dark"] .blob--3{background:radial-gradient(circle at 30% 30%, var(--blue2), transparent 60%);top:45%;left:60%;width:380px;height:380px;opacity:.35}
body[data-theme="light"] .blob--1{background:radial-gradient(circle at 30% 30%, var(--blue2), transparent 60%);top:-160px;left:-180px}
body[data-theme="light"] .blob--2{background:radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--blue) 55%, white), transparent 60%);bottom:-220px;right:-180px}
body[data-theme="light"] .blob--3{background:radial-gradient(circle at 30% 30%, color-mix(in srgb, var(--pink) 35%, white), transparent 60%);top:45%;left:60%;width:380px;height:380px;opacity:.28}
.noise{
  position:absolute;inset:0;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)' opacity='.18'/%3E%3C/svg%3E");
  opacity:.10;mix-blend-mode:overlay;
}

/* =========================
   GLASS
   ========================= */
.glass,.glassLite{position:relative;overflow:hidden}
.glass::before,.glassLite::before{
  content:"";position:absolute;inset:-1px;
  background:linear-gradient(180deg, rgba(255,255,255,.18), rgba(255,255,255,0));
  opacity:.35;pointer-events:none;
}
.glass{
  background:linear-gradient(180deg,var(--glass-1),var(--glass-2));
  border:1px solid var(--glass-border);
  box-shadow:var(--shadow);
  border-radius:var(--r-xl);
}
.glassLite{
  background:var(--glass-lite);
  border:1px solid var(--glass-lite-border);
  box-shadow:var(--shadow-soft);
  border-radius:var(--r-lg);
}
@supports ((-webkit-backdrop-filter: blur(12px)) or (backdrop-filter: blur(12px))){
  .glass{backdrop-filter:blur(18px) saturate(1.2);-webkit-backdrop-filter:blur(18px) saturate(1.2)}
  .glassLite{backdrop-filter:blur(14px) saturate(1.15);-webkit-backdrop-filter:blur(14px) saturate(1.15)}
}

/* =========================
   APPLE SHINE (solo hover en elementos con .shine)
   ========================= */
.shine{position:relative}
.shine::after{
  content:"";
  position:absolute;
  inset:-60%;
  background:linear-gradient(115deg,
      rgba(255,255,255,0) 40%,
      rgba(255,255,255,.20) 50%,
      rgba(255,255,255,0) 60%);
  transform: translateX(-60%) rotate(10deg);
  opacity:0;
  pointer-events:none;
}
@media (hover:hover){
  .shine:hover::after{
    opacity:.9;
    animation: shineSweep 900ms var(--ease) forwards;
  }
}
@keyframes shineSweep{
  from{ transform: translateX(-60%) rotate(10deg); }
  to{ transform: translateX(60%) rotate(10deg); }
}

/* =========================
   LAYOUT
   ========================= */
.main{
  width:min(100% - 24px,var(--max));
  margin:0 auto;
  padding:92px 0 calc(64px + env(safe-area-inset-bottom));
}

/* =========================
   NAV ESTABLE
   ========================= */
.nav{
  position:fixed;
  top:14px;
  left:12px;
  right:12px;
  margin:0 auto;
  max-width:var(--max);

  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:10px 12px;
  border-radius:999px;

  z-index:50;
}

/* Brand */
.brand{display:flex;align-items:center;gap:10px}
.brand__logo{width:40px;height:40px;border-radius:14px;object-fit:cover;box-shadow:0 12px 25px rgba(0,0,0,.20)}
.brand__name{font-weight:900;letter-spacing:-.02em}
.brand__badge{
  font-size:12px;padding:6px 10px;border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid var(--glass-border);
}

.nav__links{display:none;gap:14px}
.nav__link{
  font-size:14px;color:var(--muted);
  padding:8px 10px;border-radius:999px;
  transition:background .2s var(--ease), color .2s var(--ease);
}
.nav__link:hover{background:rgba(255,255,255,.10);color:var(--text)}
.nav__actions{display:flex;align-items:center;gap:10px}

/* Theme */
.themeBtn{
  height:44px;padding:0 12px;border-radius:999px;
  border:1px solid var(--glass-border);
  background:rgba(255,255,255,.08);
  display:flex;align-items:center;gap:10px;
  cursor:pointer;
}
.themeBtn__dot{
  width:10px;height:10px;border-radius:99px;
  background:linear-gradient(135deg, var(--title-a1), var(--title-a2));
  box-shadow:0 0 0 6px rgba(255,255,255,.10);
}
.themeBtn__text{font-weight:900;font-size:13px;color:var(--text)}

/* Menu btn */
.nav__menu{
  width:44px;height:44px;border:0;border-radius:14px;
  background:rgba(255,255,255,.10);
  border:1px solid var(--glass-border);
  display:grid;place-items:center;gap:5px;
  cursor:pointer;
}
.nav__menu span{
  width:18px;height:2px;
  background:color-mix(in srgb, var(--text) 85%, transparent);
  display:block;border-radius:99px
}

/* Drawer */
.drawer{
  position:fixed;
  top:82px;
  left:12px;
  right:12px;
  margin:0 auto;
  max-width:520px;

  padding:14px;
  display:none;
  z-index:60;
}
.drawer.is-open{display:grid;gap:10px}
.drawer__link{
  padding:14px;border-radius:16px;text-align:left;
  background:rgba(255,255,255,.08);
  border:1px solid var(--glass-border);
  color:var(--text);
  cursor:pointer;
}
.drawer__link--ghost{background:transparent}

/* =========================
   HERO
   ========================= */
.hero{display:grid;gap:16px;margin-top:10px}
.hero__card{padding:var(--p5);overflow:hidden;position:relative}
.hero__topline{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}
.pill{
  font-size:12px;padding:7px 10px;border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid var(--glass-border);
}
.pill--soft{opacity:.9;color:var(--muted)}
.rotator{
  display:inline-flex;align-items:center;
  padding:4px 10px;border-radius:999px;
  background:rgba(255,255,255,.08);
  border:1px solid var(--glass-border);
  box-shadow:0 10px 25px rgba(0,0,0,.12);
}
.rotator__word{font-weight:900;transition:opacity .16s var(--ease);}

.hero__cta{display:grid;grid-template-columns:1fr;gap:10px;margin-top:16px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  border-radius:18px;padding:14px 16px;font-weight:900;
  border:1px solid transparent;
  transition:transform .18s var(--ease), filter .18s var(--ease);
  user-select:none;
}
.btn:active{transform:scale(.98)}
.btn--primary{
  background: linear-gradient(135deg,
    color-mix(in srgb, var(--title-a1) 92%, white 0%),
    color-mix(in srgb, var(--title-a2) 82%, white 0%)
  );
  color: rgba(255,255,255,.96);
  box-shadow: 0 18px 45px rgba(0,0,0,.18);
}
body[data-theme="light"] .btn--primary{
  background: linear-gradient(135deg, var(--blue), var(--blue2));
  box-shadow: 0 18px 45px rgba(47,134,255,.22);
}
.btn--secondary{
  background:rgba(255,255,255,.08);
  border-color:var(--glass-border);
  color:var(--text);
}
.btn--full{width:100%}
.btn--mini{
  padding:10px 12px;border-radius:14px;
  background:rgba(255,255,255,.10);
  border:1px solid var(--glass-border);
  color:var(--text);
}

.hero__stats{margin-top:16px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.stat{padding:12px;text-align:center}
.stat__big{display:block;font-weight:900}
.stat__small{display:block;font-size:12px;color:var(--muted);margin-top:4px}

/* Mascotas */
.mascot{
  position:absolute;width:130px;height:auto;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,.18));
  pointer-events:none;user-select:none;opacity:.92;
}
.mascot--cat{top:-6px; right:-22px; rotate:6deg;}
.mascot--dog{bottom:-18px; left:-26px; rotate:-5deg;}
@media (max-width:420px){
  .mascot{width:112px}
  .mascot--cat{top:-14px; right:-34px}
  .mascot--dog{bottom:-26px; left:-40px}
}

/* Mock */
.mock{padding:var(--p4)}
.mock__header{display:flex;align-items:center;gap:12px}
.mock__meta{flex:1}
.mock__name{margin:0;font-weight:900;font-size:14px}
.mock__hint{margin:2px 0 0;font-size:12px;color:var(--muted)}
.mock__body{margin-top:14px}
.mock__row{display:flex;gap:8px;flex-wrap:wrap}
.mock__card{margin-top:12px;padding:14px}
.mock__buttons{display:flex;gap:10px;flex-wrap:wrap}
.mock__copy{margin:0 0 10px;line-height:1.45;font-size:13px;color:var(--mock-accent);font-weight:700;}

.avatar{
  width:44px;height:44px;border-radius:16px;
  overflow:hidden;border:1px solid var(--glass-border);
  background:rgba(255,255,255,.08);
  display:grid;place-items:center;
  box-shadow:0 12px 25px rgba(0,0,0,.12);
}
.avatar__img{width:100%;height:100%;object-fit:cover}
.chip{
  font-size:12px;padding:8px 10px;border-radius:999px;
  border:1px solid var(--glass-border);background:rgba(255,255,255,.08);
}
.chip--ok{background:rgba(62,230,159,.12);border-color:rgba(62,230,159,.22)}
.chip--soft{background:rgba(255,255,255,.06);color:var(--muted)}

/* Sections */
.section{margin-top:18px;padding-top:18px}
.section__head{padding:0 6px;margin-bottom:12px}
.product{display:grid;gap:12px}
.productCard{padding:var(--p4)}
.productCard__icon{
  font-size:22px;width:44px;height:44px;display:grid;place-items:center;
  border-radius:16px;background:rgba(255,255,255,.08);
  border:1px solid var(--glass-border);
}

/* Demos */
.demoGrid{display:grid;gap:12px}
.demoCard{padding:var(--p4);display:block;text-align:left}
.demoCard--button{cursor:pointer}
.demoCard__top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.demoBadge{
  font-size:12px;padding:7px 10px;border-radius:999px;
  background:rgba(255,255,255,.10);
  border:1px solid var(--glass-border);
}
.demoBadge--soft{opacity:.9;color:var(--muted)}
.demoIcon{font-size:20px}
.demoCard__cta{display:inline-block;margin-top:10px;font-weight:800}

/* =========================
   FOOTER
   ========================= */
.footer.footer--full{
  margin-top:14px;
  padding:22px 18px 16px;
  border-radius:22px;
}
.footer-content{
  display:grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap:16px;
  margin:0 auto 12px;
}
.footer-title{
  margin:0 0 10px;
  font-weight:900;
  letter-spacing:-.01em;
}
.footer-sub{
  margin:0;
  color:var(--muted);
  font-size:12px;
  line-height:1.5;
  max-width:46ch;
}
.footer-section ul{ list-style:none; padding:0; margin:0; display:grid; gap:8px; }
.footer-section a{
  color:color-mix(in srgb, var(--text) 88%, transparent);
  font-weight:800;
  font-size:13px;
  line-height:1.2;
  opacity:.92;
  transition: opacity .2s var(--ease), transform .2s var(--ease);
}
.footer-section a:hover{ opacity:1; transform: translateY(-1px); }

.footer-linkBtn{
  width:100%;
  text-align:left;
  border:0;
  padding:0;
  background:transparent;
  color:color-mix(in srgb, var(--text) 88%, transparent);
  font-weight:800;
  font-size:13px;
  cursor:pointer;
  opacity:.92;
  transition: opacity .2s var(--ease), transform .2s var(--ease);
}
.footer-linkBtn:hover{ opacity:1; transform: translateY(-1px); }

.footer-cta{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 12px;
  border-radius:12px;
  font-weight:900;
  color: rgba(255,255,255,.96) !important;
  background: linear-gradient(135deg, rgba(37,211,102,.85), rgba(37,211,102,.62));
  border: 1px solid rgba(255,255,255,.18);
  box-shadow: 0 14px 30px rgba(0,0,0,.20);
  opacity:1 !important;
}
.footer-cta:hover{ filter: brightness(1.02); transform:none; }

.social-links{
  display:flex;
  gap:10px;
  align-items:center;
  margin-top:12px;
}
.social{
  width:40px;
  height:40px;
  display:grid;
  place-items:center;
  border-radius:999px;
  background: rgba(255,255,255,.08);
  border:1px solid var(--glass-border);
  box-shadow: 0 14px 34px rgba(0,0,0,.16);
  font-size:18px;
  transition: transform .2s var(--ease), background .2s var(--ease), opacity .2s var(--ease);
}
.social:hover{ transform: translateY(-2px) scale(1.03); background: rgba(255,255,255,.12); }

.footer-bottom{
  border-top: 1px solid var(--glass-border);
  padding-top:12px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.2px;
  color:var(--muted);
}

/* Focus */
.footer a:focus-visible,
.footer-linkBtn:focus-visible{
  outline: 2px solid color-mix(in srgb, var(--blue2) 55%, transparent);
  outline-offset: 4px;
  border-radius: 10px;
}

/* Modal */
.modal{position:fixed;inset:0;z-index:120;display:none}
.modal.is-open{display:block}
.modal__overlay{
  position:absolute;inset:0;
  background:rgba(0,0,0,.42);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}
.modal__panel{
  position:relative;
  width:min(100% - 26px, 560px);
  margin:96px auto 0;
  padding:18px;border-radius:26px;
  box-shadow:0 28px 90px rgba(0,0,0,.35);
}
.modal__top{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}
.modal__close{
  width:44px;height:44px;border-radius:14px;
  border:1px solid var(--glass-border);
  background:rgba(255,255,255,.08);
  color:var(--text);
  font-size:24px;line-height:1;
  cursor:pointer;
}
.modal__body{margin-top:14px;display:grid;gap:14px}
.modalList{display:grid;gap:10px}
.modalLink{
  padding:12px;border-radius:22px;
  display:flex;align-items:center;gap:12px;
}
.modalLink__icon{font-size:20px}
.modalLink__text{flex:1;font-size:13px;line-height:1.2}
.modalLink__arrow{font-weight:900;opacity:.9}

/* Reveal (UNICO) */
.reveal{
  opacity:0;
  transform:translateY(14px) scale(.985);
  filter:blur(6px);
  transition:opacity .55s var(--ease), transform .55s var(--ease), filter .55s var(--ease);
}
.reveal.is-in{opacity:1;transform:translateY(0) scale(1);filter:blur(0);}

/* Responsive */
@media (min-width:760px){
  .nav__links{display:flex}
  .hero{grid-template-columns:1.25fr .9fr;gap:14px;align-items:stretch}
  .hero__cta{grid-template-columns:1fr 1fr}
  .product{grid-template-columns:repeat(3,1fr)}
  .demoGrid{grid-template-columns:repeat(3,1fr)}
  .mascot{width:170px}
}

/* =========================
   WHATSAPP FLOAT (halo + ondas)
   ========================= */
.wa-float{
  position:fixed;
  right: 16px;
  bottom: calc(14px + env(safe-area-inset-bottom));
  width:62px;
  height:62px;
  border-radius:50%;
  border: 1px solid rgba(255,255,255,.22);
  cursor:pointer;
  display:grid;
  place-items:center;
  z-index:130;
  isolation:isolate;

  background: linear-gradient(135deg, rgba(37,211,102,.22), rgba(255,255,255,.08));

  box-shadow:
    0 16px 44px rgba(0,0,0,.22),
    0 0 0 6px rgba(37,211,102,.14),
    0 0 22px rgba(37,211,102,.22),
    inset 0 1px 0 rgba(255,255,255,.35),
    inset 0 -1px 0 rgba(255,255,255,.08);

  transition: transform .2s var(--ease), filter .2s var(--ease);
}
@supports ((-webkit-backdrop-filter: blur(10px)) or (backdrop-filter: blur(10px))){
  .wa-float{
    backdrop-filter: blur(18px) saturate(1.35);
    -webkit-backdrop-filter: blur(18px) saturate(1.35);
  }
}
.wa-icon{
  width:30px;
  height:30px;
  fill: rgba(255,255,255,.98);
  position:relative;
  z-index:2;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.22));
}

/* Glow constante detrás */
.wa-float::after{
  content:"";
  position:absolute;
  inset:-18px;
  border-radius:50%;
  z-index:0;
  background:
    radial-gradient(circle at 50% 50%, rgba(37,211,102,.32), transparent 62%),
    radial-gradient(circle at 35% 30%, rgba(255,255,255,.16), transparent 60%);
  filter: blur(14px);
  opacity: .95;
  pointer-events:none;
}

/* Ondas vivas */
.wa-float::before{
  content:"";
  position:absolute;
  inset:-10px;
  border-radius:50%;
  z-index:1;
  pointer-events:none;
  border: 2px solid rgba(37,211,102,.38);
  box-shadow:
    0 0 0 0 rgba(37,211,102,.26),
    0 0 26px rgba(37,211,102,.18);
  animation: waPulseRing 1.8s ease-in-out infinite;
}

@keyframes waPulseRing{
  0%{
    transform: scale(1);
    opacity: .95;
    box-shadow:
      0 0 0 0 rgba(37,211,102,.26),
      0 0 18px rgba(37,211,102,.20);
  }
  60%{
    transform: scale(1.18);
    opacity: .55;
    box-shadow:
      0 0 0 14px rgba(37,211,102,.10),
      0 0 34px rgba(37,211,102,.18);
  }
  100%{
    transform: scale(1);
    opacity: .95;
    box-shadow:
      0 0 0 0 rgba(37,211,102,.26),
      0 0 18px rgba(37,211,102,.20);
  }
}

@media (hover:hover){
  .wa-float:hover{ transform: scale(1.06); filter: brightness(1.02); }
}

/* Panel mini (toggle) */
.wa-box{
  width: 330px;
  position:fixed;
  right: 16px;
  bottom: calc(90px + env(safe-area-inset-bottom));
  border-radius:16px;
  overflow:hidden;
  display:none;
  z-index:129;
  animation: waFadeUp .22s var(--ease);

  background: linear-gradient(180deg,var(--glass-1),var(--glass-2));
  border: 1px solid var(--glass-border);
  box-shadow: 0 22px 70px rgba(0,0,0,.18);
}
@supports ((-webkit-backdrop-filter: blur(10px)) or (backdrop-filter: blur(10px))){
  .wa-box{ backdrop-filter: blur(18px) saturate(1.25); -webkit-backdrop-filter: blur(18px) saturate(1.25); }
}
.wa-box.is-open{ display:block; }
@keyframes waFadeUp{ from{ opacity:0; transform: translateY(10px); } to{ opacity:1; transform: translateY(0); } }

.wa-header{
  background: rgba(31,122,53,.92);
  color:#fff;
  padding: 14px 16px;
  display:flex;
  align-items:center;
  gap: 12px;
}

/* Avatar header */
.wa-avatar-wrap{ width:46px; height:46px; position:relative; flex: 0 0 46px; }
.wa-avatar{
  width:46px;
  height:46px;
  border-radius:50%;
  overflow:hidden;
  display:grid;
  place-items:center;
  background: rgba(255,255,255,.16);
  border: 1px solid rgba(255,255,255,.22);
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
  line-height:0;
}
.wa-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.wa-online{
  position:absolute;
  left:-2px; bottom:-2px;
  width:12px; height:12px;
  border-radius:50%;
  background: #25d366;
  border: 2px solid #fff;
}

.wa-info h3{ margin:0; font-size: 16px; font-weight: 900; line-height:1.1; }
.wa-info span{ font-size: 12px; opacity:.95; display:block; margin-top:2px; }
.wa-close{
  margin-left:auto;
  background:transparent;
  border:none;
  color:#fff;
  font-size:24px;
  cursor:pointer;
  opacity:.9;
}
.wa-close:hover{ opacity:1; }

.wa-body{ padding: 14px 16px 16px; }
.wa-time{ display:block; text-align:center; color:var(--muted); font-size: 12px; margin: 2px 0 10px; }
.wa-chatrow{ display:flex; gap:10px; align-items:flex-start; margin-bottom: 12px; }

/* ✅ MINI AVATAR (chat) — estable */
.wa-mini-avatar{
  width:30px;
  height:30px;
  border-radius:50%;
  overflow:hidden;
  flex:0 0 30px;
  display:grid;
  place-items:center;
  background: rgba(255,255,255,.10);
  border: 1px solid var(--glass-border);
  box-shadow: 0 10px 20px rgba(0,0,0,.10);
  line-height:0;
  margin:0; /* clave: NO margin-left aquí */
}
.wa-mini-avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}

.wa-msg{
  background: rgba(219,231,255,.18);
  border: 1px solid rgba(255,255,255,.10);
  color: var(--text);
  padding: 12px 14px;
  border-radius: 14px;
  max-width: 230px;
  font-size: 13px;
  line-height: 1.35;
}
.wa-start{ text-align:center; font-weight: 900; margin: 8px 0 10px; color: var(--text); font-size: 13px; }
.wa-button{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  width:100%;
  background: linear-gradient(135deg, rgba(37,211,102,.92), rgba(37,211,102,.70));
  color:#fff;
  padding: 14px;
  border-radius: 12px;
  text-decoration:none;
  font-weight: 900;
  font-size: 16px;
  border: 1px solid rgba(255,255,255,.18);
}
.wa-button:hover{ filter: brightness(.98); }

/* Dark: más profundo */
body[data-theme="dark"] .wa-float{
  background: linear-gradient(135deg, rgba(18,18,20,.72), rgba(37,211,102,.22));
  border: 1px solid rgba(255,255,255,.16);
  box-shadow:
    0 22px 70px rgba(0,0,0,.55),
    0 0 0 6px rgba(37,211,102,.12),
    0 0 26px rgba(37,211,102,.22),
    inset 0 1px 0 rgba(255,255,255,.16),
    inset 0 -1px 0 rgba(0,0,0,.32);
}
body[data-theme="dark"] .wa-float::after{
  opacity: .98;
  filter: blur(16px);
  background:
    radial-gradient(circle at 50% 50%, rgba(37,211,102,.38), transparent 62%),
    radial-gradient(circle at 35% 30%, rgba(255,255,255,.10), transparent 60%);
}
body[data-theme="dark"] .wa-msg{ background: rgba(219,231,255,.12); }

/* Mobile tweaks */
@media (max-width: 420px){
  .wa-box{ width: calc(100vw - 24px); right: 12px; bottom: calc(88px + env(safe-area-inset-bottom)); }
  .wa-float{ right: 12px; }
}

/* Reduce motion */
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;filter:none;transition:none}
  .shine::after{display:none}
  .wa-float::before{ animation:none !important; }
}
