/* ═══════════════════════════════════════════════════════
   VITALA — style.css  v6
   ═══════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,700;0,800;1,700&family=DM+Sans:opsz,wght@9..40,300;9..40,400;9..40,500&display=swap');

:root {
  --verde:       #064E3B;
  --verde-mid:   #0a6b52;
  --verde-light: #d1fae5;
  --verde-pale:  #f0fdf4;
  --verde-dark:  #022c22;
  --blanco:      #FFFFFF;
  --gris-bg:     #F9FAFB;
  --gris-texto:  #374151;
  --gris-suave:  #E5E7EB;
  --gris-linea:  #D1D5DB;
  --gris-claro:  #6B7280;
  --wa-green:    #25D366;
  --wa-dark:     #128C7E;
  --font-title:  'Playfair Display', Georgia, serif;
  --font-body:   'DM Sans', sans-serif;
  --r-sm:  8px; --r-md: 14px; --r-lg: 20px; --r-full: 9999px;
  --shadow-xs: 0 1px 3px rgba(0,0,0,.06);
  --shadow-sm: 0 2px 12px rgba(6,78,59,.07), 0 1px 3px rgba(0,0,0,.05);
  --shadow-md: 0 8px 32px rgba(6,78,59,.12), 0 2px 8px rgba(0,0,0,.06);
  --shadow-lg: 0 16px 48px rgba(6,78,59,.16), 0 4px 12px rgba(0,0,0,.08);
  --trans: .28s cubic-bezier(.4,0,.2,1);
  --nav-h: 76px;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0 }
html { scroll-behavior:smooth }
body { font-family:var(--font-body); background:var(--blanco); color:var(--gris-texto); line-height:1.65; -webkit-font-smoothing:antialiased; overflow-x:hidden }
img  { display:block; max-width:100%; height:auto }
a    { color:inherit; text-decoration:none }
svg  { fill:none; stroke:currentColor; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; flex-shrink:0 }
.container { max-width:1180px; margin:0 auto; padding:0 28px }
h1,h2,h3   { font-family:var(--font-title); font-weight:800 }
h1 em,h2 em,h3 em { font-style:italic; font-weight:700 }

/* ── BUTTONS ─────────────────────────────────────────── */
.btn-primary,.btn-whatsapp { display:inline-flex; align-items:center; gap:9px; font-family:var(--font-body); font-weight:500; font-size:.82rem; letter-spacing:.08em; text-transform:uppercase; padding:13px 28px; border-radius:var(--r-sm); transition:background var(--trans),box-shadow var(--trans),transform var(--trans); cursor:pointer; white-space:nowrap }
.btn-primary  { background:var(--verde);    color:var(--blanco); box-shadow:0 4px 14px rgba(6,78,59,.28) }
.btn-primary:hover  { background:var(--verde-mid); box-shadow:0 8px 24px rgba(6,78,59,.36); transform:translateY(-1px) }
.btn-whatsapp { background:var(--wa-green); color:var(--blanco); box-shadow:0 4px 14px rgba(37,211,102,.35) }
.btn-whatsapp:hover { background:var(--wa-dark); box-shadow:0 8px 24px rgba(37,211,102,.4); transform:translateY(-1px) }
.btn-sm { padding:10px 22px; font-size:.76rem }
.btn-lg { padding:15px 34px; font-size:.86rem }
.btn-primary svg,.btn-whatsapp svg { width:16px; height:16px }

/* ── EYEBROW ─────────────────────────────────────────── */
.eyebrow { display:inline-flex; align-items:center; gap:10px; font-size:.7rem; letter-spacing:.2em; text-transform:uppercase; color:var(--verde); font-weight:500; margin-bottom:14px; font-family:var(--font-body) }
.eyebrow::before,.eyebrow::after { content:''; display:block; width:28px; height:1px; background:var(--verde); opacity:.45 }
.eyebrow--light { color:rgba(255,255,255,.75) }
.eyebrow--light::before,.eyebrow--light::after { background:rgba(255,255,255,.4) }

/* ── SECTION HEADER ──────────────────────────────────── */
.section-header { text-align:center; max-width:640px; margin:0 auto 56px }
.section-header h2 { font-size:clamp(1.8rem,3.5vw,2.8rem); color:var(--verde); line-height:1.2; margin-bottom:14px }
.section-header p  { font-size:.92rem; color:var(--gris-claro); font-weight:300 }
.section-header--light h2 { color:var(--blanco) }

/* ═══════════════════════════════════════════════════════
   TOP BAR
   ═══════════════════════════════════════════════════════ */
.topbar { background:var(--verde-dark); color:rgba(255,255,255,.72); font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; text-align:center; padding:9px 20px; display:flex; justify-content:center; flex-wrap:wrap; gap:4px 0 }
.topbar .sep { margin:0 12px; opacity:.35 }
.topbar a { color:rgba(255,255,255,.85); transition:color var(--trans) }
.topbar a:hover { color:var(--blanco) }

/* ═══════════════════════════════════════════════════════
   NAV — logo cuadrado centrado en círculo verde
   ═══════════════════════════════════════════════════════ */
#navbar { background:var(--blanco); border-bottom:1px solid var(--gris-linea); position:sticky; top:0; z-index:200; box-shadow:var(--shadow-xs) }
.nav-inner { max-width:1180px; margin:0 auto; padding:0 28px; height:var(--nav-h); display:flex; align-items:center; justify-content:space-between; gap:20px }
.nav-logo { display:flex; align-items:center; gap:12px; flex-shrink:0 }

/* Círculo nav: borde verde, imagen centrada */
.logo-circle {
  width:56px; height:56px; border-radius:50%;
  overflow:hidden; flex-shrink:0;
  border:2.5px solid var(--verde);
  background:var(--blanco);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 2px 10px rgba(6,78,59,.18);
}
.logo-circle img {
  width:100%; height:100%;
  object-fit:cover;        /* llena el círculo */
  object-position:center;  /* centrado perfecto */
  display:block;
}
.logo-wordmark { font-family:var(--font-title); font-size:1.55rem; font-weight:800; color:var(--verde); letter-spacing:.03em; line-height:1 }

.nav-links { list-style:none; display:flex; align-items:center; gap:28px }
.nav-links a { font-size:.8rem; letter-spacing:.07em; text-transform:uppercase; font-weight:500; color:var(--gris-texto); padding-bottom:3px; border-bottom:1.5px solid transparent; transition:color var(--trans),border-color var(--trans) }
.nav-links a:hover { color:var(--verde); border-bottom-color:var(--verde) }
.btn-agenda { background:var(--verde)!important; color:var(--blanco)!important; padding:9px 20px!important; border-radius:7px!important; border-bottom:none!important }
.btn-agenda:hover { background:var(--verde-mid)!important }
.nav-toggle { display:none }
.hamburger  { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px }
.hamburger span { display:block; width:24px; height:2px; background:var(--verde); border-radius:2px }

/* ═══════════════════════════════════════════════════════
   HERO — logo grande centrado, cuadrado dentro de círculo
   ═══════════════════════════════════════════════════════ */
.hero { position:relative; min-height:100svh; display:flex; align-items:center; justify-content:center; overflow:hidden }
.slides { position:absolute; inset:0 }
.slide  { position:absolute; inset:0; opacity:0; animation:slideShow 18s infinite }
.slide img { width:100%; height:100%; object-fit:cover }
.s1{animation-delay:0s} .s2{animation-delay:6s} .s3{animation-delay:12s}
@keyframes slideShow {
  0%  { opacity:0; transform:scale(1.04) }
  5%  { opacity:1; transform:scale(1.04) }
  28% { opacity:1; transform:scale(1) }
  33% { opacity:0; transform:scale(1) }
  100%{ opacity:0 }
}
.hero-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(2,28,18,.75) 0%,rgba(6,78,59,.58) 50%,rgba(2,28,18,.8) 100%); z-index:1 }
.hero-content { position:relative; z-index:2; text-align:center; padding:40px 28px; max-width:820px; width:100%; animation:fadeUp 1s both .2s }

.hero-logo-wrap { display:flex; justify-content:center; margin-bottom:28px }
/* Círculo hero: grande, borde blanco, sombra profunda */
.hero-logo-circle {
  width:190px; height:190px; border-radius:50%;
  overflow:hidden;
  border:5px solid rgba(255,255,255,.95);
  background:var(--blanco);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 40px rgba(0,0,0,.35), 0 0 0 8px rgba(255,255,255,.12);
}
.hero-logo-circle img {
  width:100%; height:100%;
  object-fit:cover;       /* llena todo el círculo */
  object-position:center; /* centrado */
  display:block;
}

.hero-sub { font-family:var(--font-title); font-size:clamp(1.4rem,4vw,2.5rem); font-weight:700; color:var(--blanco); line-height:1.25; margin-bottom:24px }
.hero-sub em { font-style:italic; color:#a7f3d0 }
.hero-pillars { display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:6px; margin-bottom:40px; font-size:.75rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(255,255,255,.75); font-weight:400; font-family:var(--font-body) }
.hero-pillars .dot { opacity:.35 }
.hero-btns { display:flex; flex-wrap:wrap; gap:14px; justify-content:center }

/* ═══════════════════════════════════════════════════════
   INTRO — terapeuta joven
   ═══════════════════════════════════════════════════════ */
.intro { padding:100px 0; background:var(--blanco) }
.intro-grid { display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center }
.intro-img-wrap { position:relative }
.intro-img {
  width:100%; height:560px;
  object-fit:cover;
  object-position:center top;
  border-radius:var(--r-lg);
  box-shadow:var(--shadow-lg);
}
.intro-badge { position:absolute; bottom:-20px; right:-20px; background:var(--verde); color:var(--blanco); border-radius:var(--r-md); padding:16px 22px; text-align:center; box-shadow:var(--shadow-md) }
.badge-num   { display:block; font-family:var(--font-title); font-size:2rem; font-weight:800; line-height:1 }
.badge-stars { display:block; color:#fbbf24; font-size:.85rem; margin:4px 0 2px }
.badge-label { display:block; font-size:.65rem; letter-spacing:.12em; text-transform:uppercase; opacity:.75; font-family:var(--font-body) }
.intro-text h2 { font-size:clamp(1.8rem,3vw,2.6rem); color:var(--verde); line-height:1.22; margin-bottom:18px }
.intro-text p  { font-size:.95rem; color:var(--gris-claro); font-weight:300; margin-bottom:26px; line-height:1.75 }
.check-list { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:32px }
.check-list li { display:flex; align-items:center; gap:10px; font-size:.9rem; color:var(--gris-texto) }
.check-list li::before { content:''; display:block; width:18px; height:18px; background:var(--verde-light); border-radius:50%; flex-shrink:0; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 16 16' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M3 8l3.5 3.5L13 5' stroke='%23064E3B' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E"); background-size:14px; background-repeat:no-repeat; background-position:center }

/* ═══════════════════════════════════════════════════════
   SERVICIOS — FLIP CARDS
   ═══════════════════════════════════════════════════════ */
.servicios { padding:100px 0; background:var(--gris-bg) }
.services-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; margin-bottom:48px }
.flip-card { position:relative; height:420px; perspective:1200px }
.flip-card--featured .flip-front { border:2px solid var(--verde) }
.badge-card { position:absolute; top:12px; right:12px; z-index:10; background:var(--blanco); color:var(--verde); border:1.5px solid var(--verde); font-size:.6rem; letter-spacing:.16em; text-transform:uppercase; font-weight:600; padding:4px 10px; border-radius:var(--r-full); font-family:var(--font-body) }
.flip-inner { position:relative; width:100%; height:100%; transform-style:preserve-3d; transition:transform .65s cubic-bezier(.4,0,.2,1) }
.flip-card:hover .flip-inner { transform:rotateY(180deg) }
.flip-front { position:absolute; inset:0; background:var(--blanco); border-radius:var(--r-md); box-shadow:var(--shadow-sm); border:1px solid rgba(6,78,59,.07); overflow:hidden; display:flex; flex-direction:column; backface-visibility:hidden; -webkit-backface-visibility:hidden }
.card-head { background:var(--verde); padding:20px 22px 18px; display:flex; align-items:center; gap:13px; flex-shrink:0 }
.card-icon { width:38px; height:38px; background:rgba(255,255,255,.15); border-radius:9px; display:flex; align-items:center; justify-content:center; flex-shrink:0 }
.card-icon svg { width:18px; height:18px; stroke:rgba(255,255,255,.9); fill:none; stroke-width:1.5 }
.card-head h3 { font-size:1rem; font-weight:800; color:var(--blanco); line-height:1.25 }
.flip-front ul { list-style:none; padding:18px 20px 10px; display:flex; flex-direction:column; gap:8px; flex:1; overflow:hidden }
.flip-front ul li { display:flex; align-items:flex-start; gap:9px; font-size:.845rem; color:var(--gris-texto); font-weight:300; line-height:1.4 }
.flip-front ul li::before { content:''; display:block; width:6px; height:6px; background:var(--verde); border-radius:1.5px; flex-shrink:0; margin-top:5px; opacity:.65 }
.flip-hint { display:flex; align-items:center; justify-content:center; gap:6px; padding:12px; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500; color:var(--verde); border-top:1px solid var(--gris-suave); background:var(--verde-pale); font-family:var(--font-body); flex-shrink:0 }
.flip-hint svg { stroke:var(--verde) }
.flip-back { position:absolute; inset:0; border-radius:var(--r-md); background-size:cover; background-position:center; backface-visibility:hidden; -webkit-backface-visibility:hidden; transform:rotateY(180deg); overflow:hidden }
.flip-back-overlay { position:absolute; inset:0; background:linear-gradient(160deg,rgba(2,28,18,.88) 0%,rgba(6,78,59,.82) 100%); display:flex; flex-direction:column; align-items:flex-start; justify-content:flex-end; padding:32px 28px; gap:14px }
.flip-back-overlay h3 { font-size:1.3rem; font-weight:800; color:var(--blanco); line-height:1.2 }
.flip-back-overlay p  { font-size:.875rem; color:rgba(255,255,255,.85); font-weight:300; line-height:1.7; font-family:var(--font-body) }
.services-cta { text-align:center }

/* ═══════════════════════════════════════════════════════
   GALERÍA
   ═══════════════════════════════════════════════════════ */
.galeria { padding:100px 0; background:var(--verde-dark) }
.galeria .section-header { margin-bottom:48px }
.gallery-grid { display:grid; grid-template-columns:repeat(3,1fr); grid-auto-rows:280px; gap:14px; max-width:1180px; margin:0 auto; padding:0 28px }
.gal-item { position:relative; overflow:hidden; border-radius:var(--r-md); cursor:pointer }
.gal-item img { width:100%; height:100%; object-fit:cover; object-position:center; transition:transform .5s ease }
.gal-item:hover img { transform:scale(1.07) }
.gal-label { position:absolute; bottom:0; left:0; right:0; background:linear-gradient(transparent,rgba(2,28,18,.85)); color:var(--blanco); font-size:.8rem; letter-spacing:.1em; text-transform:uppercase; font-weight:500; padding:28px 18px 14px; transform:translateY(100%); transition:transform .35s ease; font-family:var(--font-body) }
.gal-item:hover .gal-label { transform:translateY(0) }

/* ═══════════════════════════════════════════════════════
   CTA BANNER
   ═══════════════════════════════════════════════════════ */
.cta-banner { background:var(--verde-pale); border-top:1px solid var(--verde-light); border-bottom:1px solid var(--verde-light); padding:80px 0 }
.cta-inner  { display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:36px }
.cta-text h2 { font-size:clamp(1.6rem,3vw,2.4rem); color:var(--verde); margin-bottom:10px }
.cta-text p  { font-size:.92rem; color:var(--gris-claro); font-weight:300; max-width:420px }
.cta-btns    { display:flex; flex-wrap:wrap; gap:14px; flex-shrink:0 }

/* ═══════════════════════════════════════════════════════
   CONTACTO — logo circular sobre fondo oscuro
   ═══════════════════════════════════════════════════════ */
.contacto { padding:100px 0; background:var(--blanco) }
.contact-grid { display:grid; grid-template-columns:1fr 1.1fr; gap:56px; align-items:stretch }
.contact-info { background:var(--verde-dark); border-radius:var(--r-lg); padding:44px 40px; display:flex; flex-direction:column; gap:28px }
.contact-logo-wrap { display:flex; align-items:center; gap:16px }
.contact-logo-circle {
  width:80px; height:80px; border-radius:50%;
  overflow:hidden; flex-shrink:0;
  border:3px solid rgba(255,255,255,.35);
  background:var(--blanco);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 16px rgba(0,0,0,.25);
}
.contact-logo-circle img {
  width:100%; height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}
.contact-brand  { display:block; font-family:var(--font-title); font-size:2rem; font-weight:800; color:var(--blanco); letter-spacing:.04em; line-height:1 }
.contact-slogan { display:block; font-size:.65rem; letter-spacing:.2em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-top:4px; font-family:var(--font-body) }
.rating-strip { display:flex; align-items:center; gap:8px; padding:12px 0; border-top:1px solid rgba(255,255,255,.1); border-bottom:1px solid rgba(255,255,255,.1) }
.r-stars { color:#fbbf24; letter-spacing:2px }
.r-score { font-family:var(--font-title); font-size:1.4rem; color:var(--blanco); font-weight:800 }
.r-label { font-size:.72rem; color:rgba(255,255,255,.5); font-weight:300; font-family:var(--font-body) }
.contact-items { display:flex; flex-direction:column; gap:18px }
.c-item { display:flex; align-items:flex-start; gap:14px }
.c-icon { width:38px; height:38px; background:rgba(255,255,255,.1); border-radius:9px; display:flex; align-items:center; justify-content:center; flex-shrink:0 }
.c-icon svg { width:18px; height:18px; stroke:rgba(255,255,255,.8); fill:none; stroke-width:1.4 }
.c-item strong { display:block; font-size:.72rem; letter-spacing:.1em; text-transform:uppercase; color:rgba(255,255,255,.5); margin-bottom:3px; font-weight:500; font-family:var(--font-body) }
.c-item span   { font-size:.88rem; color:rgba(255,255,255,.85); font-weight:300; line-height:1.6 }
.contact-actions { display:flex; flex-direction:column; gap:12px; margin-top:auto }
.contact-actions .btn-primary,.contact-actions .btn-whatsapp { justify-content:center }
.map-wrap { border-radius:var(--r-lg); overflow:hidden; min-height:480px; box-shadow:var(--shadow-md) }
.map-wrap iframe { width:100%; height:100%; border:0; display:block }

/* ═══════════════════════════════════════════════════════
   REDES SOCIALES
   ═══════════════════════════════════════════════════════ */
.redes { padding:90px 0; background:var(--gris-bg); border-top:1px solid var(--gris-suave) }
.redes-inner { display:grid; grid-template-columns:1fr 2fr; gap:64px; align-items:center }
.redes-text h2 { font-size:clamp(1.8rem,3vw,2.6rem); color:var(--verde); line-height:1.2; margin-bottom:16px }
.redes-text p  { font-size:.92rem; color:var(--gris-claro); font-weight:300; line-height:1.75 }
.redes-text strong { color:var(--verde); font-weight:600 }
.redes-cards { display:grid; grid-template-columns:repeat(2,1fr); gap:16px }
.red-card { display:flex; align-items:center; gap:16px; padding:20px 22px; border-radius:var(--r-md); border:1px solid var(--gris-suave); background:var(--blanco); box-shadow:var(--shadow-xs); transition:transform var(--trans),box-shadow var(--trans); cursor:pointer }
.red-card:hover { transform:translateY(-3px); box-shadow:var(--shadow-md) }
.red-icon { width:46px; height:46px; border-radius:12px; display:flex; align-items:center; justify-content:center; flex-shrink:0 }
.red-icon svg { width:22px; height:22px }
.red-ig .red-icon { background:linear-gradient(135deg,#f09433,#e6683c,#dc2743,#cc2366,#bc2a8d) }
.red-ig .red-icon svg { stroke:white }
.red-fb .red-icon { background:#1877F2 }
.red-fb .red-icon svg { stroke:white }
.red-tk .red-icon { background:#010101 }
.red-tk .red-icon svg { stroke:white }
.red-wa .red-icon { background:var(--wa-green) }
.red-wa .red-icon svg { stroke:white }
.red-info { display:flex; flex-direction:column; gap:2px }
.red-info strong { font-size:.9rem; color:var(--gris-texto); font-weight:600; font-family:var(--font-body) }
.red-info span   { font-size:.8rem; color:var(--gris-claro); font-weight:400 }
.red-info em     { font-size:.72rem; letter-spacing:.06em; color:var(--verde); font-style:normal; font-weight:500; margin-top:2px }

/* ═══════════════════════════════════════════════════════
   FOOTER — logo circular pequeño
   ═══════════════════════════════════════════════════════ */
#footer { background:#021a12; padding:72px 0 0 }
.footer-top { display:grid; grid-template-columns:1.6fr 1fr 1fr .9fr; gap:48px; padding-bottom:56px }
.footer-logo-wrap { display:flex; align-items:center; gap:12px; margin-bottom:16px }
.footer-logo-circle {
  width:52px; height:52px; border-radius:50%;
  overflow:hidden; flex-shrink:0;
  border:2px solid rgba(255,255,255,.25);
  background:var(--blanco);
  display:flex; align-items:center; justify-content:center;
}
.footer-logo-circle img {
  width:100%; height:100%;
  object-fit:cover;
  object-position:center;
  display:block;
}
.footer-brand-name { font-family:var(--font-title); font-size:1.55rem; font-weight:800; color:rgba(255,255,255,.9); letter-spacing:.04em }
.footer-brand p { font-size:.85rem; color:rgba(255,255,255,.45); font-weight:300; line-height:1.75; max-width:280px; margin-bottom:20px }
.footer-social { display:flex; gap:12px }
.footer-social a { width:36px; height:36px; background:rgba(255,255,255,.08); border-radius:8px; display:flex; align-items:center; justify-content:center; transition:background var(--trans) }
.footer-social a:hover { background:rgba(255,255,255,.16) }
.footer-social svg { width:16px; height:16px; stroke:rgba(255,255,255,.7) }
.footer-col h5 { font-size:.68rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(255,255,255,.35); font-weight:500; margin-bottom:18px; font-family:var(--font-body) }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:10px }
.footer-col ul li { font-size:.83rem; color:rgba(255,255,255,.55); font-weight:300; transition:color var(--trans) }
.footer-col ul li a { color:rgba(255,255,255,.55) }
.footer-col ul li:hover,.footer-col ul li a:hover { color:rgba(255,255,255,.85) }
.footer-btn { display:flex; justify-content:center; margin-bottom:10px; width:100% }
.footer-btn svg { width:14px; height:14px }
.footer-bottom { border-top:1px solid rgba(255,255,255,.07); padding:22px 0; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px }
.footer-bottom p { font-size:.72rem; color:rgba(255,255,255,.28) }

/* ═══════════════════════════════════════════════════════
   WHATSAPP FLOTANTE
   ═══════════════════════════════════════════════════════ */
.wa-float { position:fixed; bottom:28px; right:28px; z-index:999; width:58px; height:58px; background:var(--wa-green); border-radius:50%; display:flex; align-items:center; justify-content:center; box-shadow:0 6px 24px rgba(37,211,102,.45); transition:transform var(--trans),box-shadow var(--trans); animation:waPulse 2.5s infinite 3s }
.wa-float:hover { transform:scale(1.1); box-shadow:0 10px 32px rgba(37,211,102,.55); animation:none }
.wa-float svg { width:28px; height:28px; stroke:none; fill:var(--blanco) }
@keyframes waPulse {
  0%  { box-shadow:0 6px 24px rgba(37,211,102,.45),0 0 0 0   rgba(37,211,102,.4) }
  70% { box-shadow:0 6px 24px rgba(37,211,102,.45),0 0 0 14px rgba(37,211,102,0) }
  100%{ box-shadow:0 6px 24px rgba(37,211,102,.45),0 0 0 0   rgba(37,211,102,0) }
}
@keyframes fadeUp { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }

/* ═══════════════════════════════════════════════════════
   RESPONSIVE ≤1024px
   ═══════════════════════════════════════════════════════ */
@media(max-width:1024px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .footer-top{grid-template-columns:1fr 1fr}
  .intro-grid{gap:40px}
  .contact-grid{grid-template-columns:1fr}
  .map-wrap{min-height:360px}
  .redes-inner{grid-template-columns:1fr;gap:40px}
  .redes-cards{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:860px){
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .cta-inner{flex-direction:column;text-align:center}
  .cta-btns{justify-content:center}
  .cta-text p{margin:0 auto}
  .intro-grid{grid-template-columns:1fr}
  .intro-img{height:420px}
  .intro-badge{right:10px;bottom:-14px}
}
@media(max-width:640px){
  .topbar .sep{margin:0 6px}
  .hamburger{display:flex}
  .nav-links{display:none;position:fixed;top:var(--nav-h);left:0;right:0;background:var(--blanco);border-top:1px solid var(--gris-linea);flex-direction:column;gap:0;padding:12px 0 20px;box-shadow:var(--shadow-md);z-index:199}
  .nav-toggle:checked~.nav-links{display:flex}
  .nav-links li{width:100%}
  .nav-links a{display:block;padding:13px 28px;border-bottom:none;font-size:.88rem}
  .btn-agenda{margin:8px 28px 0!important;display:block!important;text-align:center!important}
  .logo-circle{width:46px;height:46px}
  .logo-wordmark{font-size:1.25rem}
  .hero-logo-circle{width:150px;height:150px}
  .services-grid{grid-template-columns:1fr}
  .flip-card{height:auto;min-height:400px}
  .gallery-grid{grid-template-columns:1fr;padding:0 20px}
  .footer-top{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;text-align:center}
  .contact-info{padding:32px 24px}
  .contact-actions{flex-direction:column}
  .redes-cards{grid-template-columns:1fr}
  .wa-float{bottom:20px;right:20px;width:52px;height:52px}
  .wa-float svg{width:24px;height:24px}
  .cta-btns{flex-direction:column}
}
@media(max-width:400px){
  .container{padding:0 16px}
  .hero-content{padding:30px 16px}
}
