:root {
    --peach:#FBE7D5; --peach-soft:#FDEFE2; --cream:#FFF7EF;
    --teal:#1F6E6B; --teal-dark:#155350;
    --coral:#F08268; --coral-dark:#E16A50; --orange:#E07B3C;
    --ink:#2B2B2B; --muted:#6c6760;
    --radius:999px;
    --shadow-soft:0 18px 40px -20px rgba(31,110,107,.35);
    --shadow-card:0 24px 60px -28px rgba(31,110,107,.28);
    --max:1180px;
  }
  * { box-sizing:border-box; margin:0; padding:0; }
  html { scroll-behavior:auto; }
  body {
    font-family:'Nunito',system-ui,sans-serif; color:var(--ink);
    background:var(--peach); line-height:1.65; overflow-x:hidden; -webkit-font-smoothing:antialiased;
  }
  h1,h2,h3,h4,.title,.hero h1 { font-family:'Fredoka','Nunito',sans-serif; }
  .wrap { max-width:var(--max); margin:0 auto; padding:0 24px; }
  a { text-decoration:none; color:inherit; }
  img { max-width:100%; display:block; }

  /* ---------- barra de progreso ---------- */
  #progress { position:fixed; top:0; left:0; height:4px; width:0%;
    background:linear-gradient(90deg,var(--coral),var(--teal)); z-index:100; box-shadow:0 0 12px rgba(240,130,104,.6); }

  /* ---------- cursor personalizado ---------- */
  @media (hover:hover) and (pointer:fine) {
    body { cursor:none; }
    a, .btn, .burger, .acard, label { cursor:none; }
    input, textarea { cursor:auto; }
    #cursor, #cursor-ring { position:fixed; top:0; left:0; pointer-events:none; z-index:9999; border-radius:50%; mix-blend-mode:difference; }
    #cursor { width:9px; height:9px; background:#fff; }
    #cursor-ring { width:42px; height:42px; border:1.6px solid #fff; }
  }
  @media (hover:none) { #cursor, #cursor-ring { display:none; } }

  /* ---------- fondo ---------- */
  .bg-blobs { position:fixed; inset:0; z-index:-2; overflow:hidden; }
  .bg-blobs span { position:absolute; border-radius:50%; filter:blur(70px); opacity:.5; }
  .bg-blobs .b1 { width:480px; height:480px; background:#f7c9ac; top:-120px; right:-120px; }
  .bg-blobs .b2 { width:420px; height:420px; background:#bfe0dd; bottom:-140px; left:-120px; }
  .bg-blobs .b3 { width:360px; height:360px; background:#f3a98f; top:40%; left:60%; opacity:.25; }

  /* ---------- loader ---------- */
  #loader { position:fixed; inset:0; z-index:999; background:var(--peach); display:grid; place-items:center; color:var(--teal); }
  #loader .loader-inner { text-align:center; }
  #loader .load-word { opacity:0; transform:translateY(20px); }
  #loader .load-word .lw1 { display:block; font-family:'Fredoka','Nunito',sans-serif; font-weight:700; color:var(--teal); font-size:clamp(2.6rem,9vw,5rem); line-height:.95; letter-spacing:-.01em; }
  #loader .load-word .lw2 { display:block; font-family:'Pacifico',cursive; color:var(--coral); font-size:clamp(2.8rem,10vw,5.6rem); line-height:1; margin-top:-.06em; }
  #loader #count { font-size:clamp(2.2rem,8vw,4.4rem); font-weight:800; letter-spacing:-.03em; margin-top:16px; color:var(--teal); }
  #loader #count::after { content:'%'; font-size:.4em; vertical-align:super; opacity:.6; margin-left:4px; }

  /* ---------- navbar ---------- */
  header { position:sticky; top:0; z-index:50; background:rgba(251,231,213,.78); backdrop-filter:blur(12px); border-bottom:1px solid rgba(31,110,107,.08); }
  .nav { display:flex; align-items:center; justify-content:space-between; padding:10px 24px; max-width:var(--max); margin:0 auto; }
  .brand img { height:170px; width:auto; }
  nav.menu { display:flex; gap:34px; align-items:center; }
  nav.menu a { font-weight:700; color:var(--teal); font-size:.82rem; text-transform:uppercase; letter-spacing:.09em; position:relative; transition:color .25s ease; }
  nav.menu a.active { color:var(--orange); }
  nav.menu a::after { content:''; position:absolute; left:0; bottom:-6px; width:0; height:2px; background:var(--coral); transition:width .3s ease; }
  nav.menu a:hover { color:var(--coral); }
  nav.menu a:hover::after { width:100%; }
  .burger { display:none; background:none; border:0; cursor:pointer; }
  .burger span { display:block; width:26px; height:2.5px; background:var(--teal); margin:5px 0; border-radius:2px; transition:.3s; }

  /* ---------- hero ---------- */
  .hero { position:relative; overflow:hidden; min-height:100vh; display:flex; flex-direction:column;
    align-items:center; justify-content:center; padding:40px 0 150px; text-align:center; }
  @media (max-width:640px){ .hero { padding:10px 0 210px; } }
  .hero .wrap { position:relative; z-index:2; }
  .hero-heads { width:min(300px,70vw); margin:0 auto 14px; aspect-ratio:1024/300; object-fit:cover; object-position:top center; }
  .hero h1 { font-weight:800; color:var(--teal); font-size:clamp(3rem,9vw,6rem); line-height:.95; letter-spacing:-.02em; }
  .hero h1 .ht-word { display:block; }
  .hero h1 .char { display:inline-block; will-change:transform; }
  .hero .script { font-family:'Pacifico',cursive; color:var(--coral); font-size:clamp(3.2rem,11vw,7.5rem); line-height:1; margin-top:-.1em; transform:rotate(-3deg); display:inline-block; }
  .hero .tagline { font-size:clamp(1.05rem,2.4vw,1.5rem); margin:24px 0 6px; }
  .hero .micro { color:var(--muted); font-size:.95rem; letter-spacing:.04em; margin-bottom:32px; }
  .scroll-cue { margin-top:50px; color:var(--teal); font-size:1.6rem; }

  .btn { display:inline-block; background:var(--coral); color:#fff; font-weight:700; padding:15px 40px; border-radius:var(--radius); box-shadow:var(--shadow-soft); transition:background .25s ease, box-shadow .25s ease; border:0; cursor:pointer; font-size:1rem; will-change:transform; }
  .btn span { text-decoration:underline; text-underline-offset:4px; }
  .btn:hover { background:var(--coral-dark); box-shadow:0 26px 48px -18px rgba(225,106,80,.55); }
  .btn.ghost { background:transparent; color:var(--teal); border:2px solid var(--teal); box-shadow:none; }
  .btn.ghost span { text-decoration:none; }
  .btn.ghost:hover { background:var(--teal); color:#fff; }

  /* ---------- secciones ---------- */
  .section-pad { padding:100px 0; position:relative; }
  .eyebrow { text-transform:uppercase; letter-spacing:.28em; font-size:.75rem; font-weight:700; color:var(--coral); margin-bottom:14px; }
  h2.title { color:var(--teal); font-weight:800; font-size:clamp(1.9rem,4.5vw,3rem); line-height:1.1; letter-spacing:-.01em; margin-bottom:8px; }
  h2.title .accent { font-family:'Pacifico',cursive; color:var(--coral); font-weight:400; }

  /* máscara para revelado de texto palabra a palabra */
  .word { display:inline-block; overflow:hidden; vertical-align:top; }
  .word > i { display:inline-block; font-style:inherit; will-change:transform; }

  /* HISTORIA */
  .historia { background:var(--peach-soft); }
  .historia .grid { display:grid; grid-template-columns:1fr 1.15fr; gap:60px; align-items:start; }
  .historia .sticky { position:sticky; top:110px; }
  .historia h2.title { font-size:clamp(2rem,4.5vw,3.2rem); }
  .historia p { color:#4a4640; margin-bottom:18px; font-size:1.02rem; }
  .historia .pull { font-family:'Pacifico',cursive; color:var(--teal); font-size:1.5rem; line-height:1.4; margin:26px 0; padding-left:22px; border-left:4px solid var(--coral); }
  .historia strong { color:var(--teal-dark); }

  /* ÁREAS — scroll horizontal */
  .areas { background:var(--peach); overflow:hidden; }
  .areas .intro { text-align:center; padding:90px 24px 10px; }
  #hpin { height:100vh; display:flex; align-items:center; }
  .htrack { display:flex; gap:30px; padding:0 8vw; will-change:transform; perspective:1000px; }
  .acard { flex:0 0 340px; background:var(--cream); border-radius:26px; padding:40px 32px; box-shadow:var(--shadow-card); border:1px solid rgba(31,110,107,.06); min-height:360px; display:flex; flex-direction:column; transform-style:preserve-3d; will-change:transform; }
  .acard .ico { width:64px; height:64px; border-radius:50%; background:var(--peach-soft); display:grid; place-items:center; font-size:1.9rem; color:var(--teal); margin-bottom:22px; transform:translateZ(40px); }
  .acard h3 { color:var(--teal); font-size:1.35rem; margin-bottom:12px; transform:translateZ(28px); }
  .acard p { color:var(--muted); font-size:.96rem; transform:translateZ(18px); }
  .areas .hint { text-align:center; color:var(--muted); font-size:.82rem; letter-spacing:.18em; text-transform:uppercase; padding-bottom:70px; }

  /* MARQUEE */
  .marquee { background:var(--teal); color:#fff; overflow:hidden; padding:26px 0; white-space:nowrap; }
  .marquee-inner { display:inline-flex; will-change:transform; }
  .marquee-inner .grp { display:inline-flex; align-items:center; }
  .marquee-inner b { font-size:clamp(1.5rem,4vw,2.8rem); font-weight:800; text-transform:uppercase; letter-spacing:.01em; padding:0 28px; }
  .marquee-inner .dot { color:var(--coral); font-size:1.4rem; }

  /* CITA — ventana que se abre */
  .quote { background:var(--coral); color:#fff; text-align:center; overflow:hidden; clip-path:inset(0 0 0 0); }
  .quote p { font-family:'Pacifico',cursive; font-size:clamp(1.5rem,4.2vw,2.7rem); line-height:1.4; max-width:900px; margin:0 auto; }

  /* MISIÓN */
  .mision { background:var(--teal); color:#fff; text-align:center; }
  .mision .eyebrow { color:#ffd9cb; }
  .mision h2.title { color:#fff; max-width:880px; margin:0 auto 14px; }
  .mision h2.title .accent { color:#ffc4b3; }
  .mision p { color:rgba(255,255,255,.85); max-width:620px; margin:0 auto 30px; }
  .mision .btn.ghost { color:#fff; border-color:#fff; }
  .mision .btn.ghost:hover { background:#fff; color:var(--teal); }

  /* EQUIPO */
  .equipo { background:var(--peach); text-align:center; }
  .team-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr)); gap:28px; margin-top:50px; }
  .member { position:relative; background:var(--cream); border-radius:24px; overflow:hidden; box-shadow:var(--shadow-card); cursor:pointer; text-align:left; transition:transform .35s ease, box-shadow .35s ease; }
  .member:hover { transform:translateY(-10px); box-shadow:0 34px 70px -30px rgba(31,110,107,.45); }
  .member .ph { position:relative; aspect-ratio:4/5; overflow:hidden; background:linear-gradient(135deg,var(--teal),var(--coral)); }
  .member .ph img { width:100%; height:100%; object-fit:cover; object-position:top center; transition:transform .6s ease; }
  .member:hover .ph img { transform:scale(1.06); }
  .member .fallback { position:absolute; inset:0; display:none; place-items:center; color:#fff; font-size:3.4rem; font-weight:800; letter-spacing:.05em; }
  .member .meta { padding:22px 24px 26px; }
  .member .meta h3 { color:var(--teal); font-size:1.2rem; line-height:1.2; }
  .member .meta .role { color:var(--coral); font-weight:600; font-size:.86rem; margin-top:6px; }
  .member .meta .more { display:inline-flex; align-items:center; gap:6px; margin-top:14px; color:var(--teal); font-weight:600; font-size:.85rem; }
  .member .meta .more::after { content:'→'; transition:transform .3s ease; }
  .member:hover .meta .more::after { transform:translateX(5px); }
  .member-bio { display:none; }

  /* MODAL */
  #modal { position:fixed; inset:0; z-index:200; display:none; }
  #modal.open { display:grid; place-items:center; }
  #modal .modal-bg { position:absolute; inset:0; background:rgba(21,83,80,.55); backdrop-filter:blur(8px); opacity:0; }
  .modal-card { position:relative; background:var(--cream); width:min(720px,92%); max-height:88vh; border-radius:28px; overflow:hidden; box-shadow:0 40px 90px -30px rgba(0,0,0,.5); display:grid; grid-template-columns:250px 1fr; opacity:0; }
  .modal-card .m-photo { position:relative; background:linear-gradient(135deg,var(--teal),var(--coral)); min-height:100%; }
  .modal-card .m-photo img { width:100%; height:100%; object-fit:cover; object-position:top center; }
  .modal-card .m-photo .fallback { position:absolute; inset:0; display:none; place-items:center; color:#fff; font-size:4rem; font-weight:800; }
  .modal-card .m-info { padding:34px 34px 38px; overflow-y:auto; max-height:88vh; }
  .modal-card .m-info h3 { color:var(--teal); font-size:1.5rem; line-height:1.15; }
  .modal-card .m-info .role { color:var(--coral); font-weight:700; font-size:.9rem; text-transform:uppercase; letter-spacing:.08em; margin:8px 0 18px; }
  .modal-card .m-info p { color:#4a4640; font-size:.96rem; margin-bottom:14px; }
  .modal-close { position:absolute; top:14px; right:16px; z-index:3; width:40px; height:40px; border-radius:50%; border:0; background:rgba(255,255,255,.85); color:var(--teal); font-size:1.3rem; cursor:pointer; display:grid; place-items:center; box-shadow:0 6px 18px -6px rgba(0,0,0,.3); transition:transform .25s ease, background .25s ease; }
  .modal-close:hover { transform:rotate(90deg); background:#fff; }
  @media (max-width:680px) {
    .team-grid { grid-template-columns:1fr; }
    .modal-card { grid-template-columns:1fr; }
    .modal-card .m-photo { aspect-ratio:4/3; min-height:auto; }
  }

  /* CONTACTO */
  .contacto { background:var(--peach-soft); }
  .contacto .grid { display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; }
  .contacto p { color:#4a4640; margin-bottom:22px; }
  .form { background:var(--cream); padding:34px; border-radius:26px; box-shadow:var(--shadow-card); }
  .form label { display:block; font-weight:600; color:var(--teal); margin:14px 0 6px; font-size:.9rem; }
  .form input, .form textarea { width:100%; padding:13px 16px; border-radius:14px; border:1.5px solid rgba(31,110,107,.18); background:#fff; font-family:inherit; font-size:.95rem; color:var(--ink); transition:border .2s ease; }
  .form input:focus, .form textarea:focus { outline:none; border-color:var(--coral); }
  .form .btn { width:100%; margin-top:22px; }
  .form .btn span { text-decoration:none; }
  .form .req { color:var(--coral); }
  .form .field-label { display:block; font-weight:600; color:var(--teal); margin:18px 0 10px; font-size:.9rem; }
  /* chips temáticos (áreas) */
  .chips { display:flex; flex-wrap:wrap; gap:9px; }
  .chip { border:1.5px solid rgba(31,110,107,.22); background:var(--peach-soft); color:var(--teal);
    padding:9px 15px; border-radius:40px; font-family:inherit; font-weight:600; font-size:.85rem; cursor:pointer;
    display:inline-flex; align-items:center; gap:7px; transition:background .2s ease, color .2s ease, border-color .2s ease, transform .2s ease; }
  .chip .e { font-size:1rem; }
  .chip:hover { border-color:var(--coral); color:var(--coral); transform:translateY(-1px); }
  .chip.on { background:var(--coral); border-color:var(--coral); color:#fff; box-shadow:0 10px 20px -10px rgba(225,106,80,.6); }
  /* botón enviar por whatsapp */
  .btn.wa-submit { background:#25D366; display:flex; align-items:center; justify-content:center; gap:9px; }
  .btn.wa-submit:hover { background:#1EBE59; box-shadow:0 26px 48px -18px rgba(37,211,102,.55); }
  .btn.wa-submit span::before { content:'💬 '; }

  /* Botón flotante de WhatsApp */
  .wa-float { position:fixed; right:22px; bottom:22px; z-index:200; width:60px; height:60px; border-radius:50%;
    background:#25D366; display:grid; place-items:center;
    box-shadow:0 14px 30px -8px rgba(37,211,102,.6), 0 6px 16px -6px rgba(0,0,0,.3); transition:transform .25s ease; }
  .wa-float:hover { transform:scale(1.08) translateY(-2px); }
  .wa-float svg { width:32px; height:32px; fill:#fff; position:relative; z-index:2; }
  .wa-float::after { content:''; position:absolute; inset:0; border-radius:50%; box-shadow:0 0 0 0 rgba(37,211,102,.5);
    animation:waPulse 2.4s ease-out infinite; }
  @keyframes waPulse { 0%{ box-shadow:0 0 0 0 rgba(37,211,102,.5); } 70%{ box-shadow:0 0 0 18px rgba(37,211,102,0); } 100%{ box-shadow:0 0 0 0 rgba(37,211,102,0); } }
  @media (max-width:600px){ .wa-float{ width:54px; height:54px; right:16px; bottom:16px; } .wa-float svg{ width:28px; height:28px; } }
  .contact-list { list-style:none; display:grid; gap:14px; }
  .contact-list li { display:flex; gap:12px; align-items:center; color:#4a4640; }
  .contact-list .ci { width:42px; height:42px; border-radius:50%; background:var(--peach); display:grid; place-items:center; color:var(--coral); font-size:1.1rem; flex:0 0 auto; }

  /* FOOTER */
  footer { background:var(--teal-dark); color:rgba(255,255,255,.85); padding:56px 0 28px; }
  footer .grid { display:flex; justify-content:space-between; gap:40px; flex-wrap:wrap; }
  footer img { height:56px; margin-bottom:14px; filter:brightness(0) invert(1); opacity:.92; }
  footer h4 { color:#fff; margin-bottom:14px; font-size:1rem; }
  footer a { color:rgba(255,255,255,.8); display:block; margin-bottom:8px; font-size:.92rem; }
  footer a:hover { color:var(--coral); }
  footer .copy { text-align:center; margin-top:40px; padding-top:22px; border-top:1px solid rgba(255,255,255,.12); font-size:.82rem; color:rgba(255,255,255,.5); }

  @media (max-width:900px) {
    .historia .grid, .contacto .grid { grid-template-columns:1fr; gap:36px; }
    .historia .sticky { position:static; }
    nav.menu { display:none; }
    .burger { display:block; }
    nav.menu.open { display:flex; flex-direction:column; gap:18px; position:absolute; top:100%; left:0; right:0; background:var(--peach); padding:24px; border-bottom:1px solid rgba(0,0,0,.06); }
    #hpin { height:auto; display:block; }
    .htrack { flex-wrap:wrap; justify-content:center; padding:20px 16px 0; }
    .acard { flex:1 1 280px; min-height:auto; }
    .areas .hint { display:none; }
  }

.device-reveal{ padding:90px 24px 40px; }
  .device-reveal .dr-head{ text-align:center; max-width:680px; margin:0 auto 10px; }
  .dr-stage{ perspective:1400px; min-height:100vh; display:flex; flex-direction:column;
    align-items:center; justify-content:center; gap:30px; }

  /* ===== iPhone (vertical -> horizontal al scrollear) ===== */
  .iphone{ position:relative; width:min(300px,44vw); aspect-ratio:9/19.5;
    transform-origin:50% 50%; will-change:transform; }

  /* Cuerpo / chasis del móvil (titanio) */
  .pbody{ position:relative; width:100%; height:100%; border-radius:15% / 7.2%;
    padding:10px;
    background:linear-gradient(150deg,#5a5c62 0%,#2a2b2f 17%,#3d3f44 38%,#191a1d 58%,#35373c 80%,#131416 100%);
    box-shadow:
      inset 0 0 0 1.5px rgba(255,255,255,.16),
      inset 0 2px 1px rgba(255,255,255,.28),
      inset 0 -3px 4px rgba(0,0,0,.72),
      0 34px 60px -24px rgba(0,0,0,.62), 0 8px 18px -8px rgba(0,0,0,.45); }
  /* botones laterales */
  .pbody::before{ content:''; position:absolute; left:-2px; top:23%; width:3px; height:6%;
    background:linear-gradient(#3a3c41,#25272b); border-radius:3px 0 0 3px;
    box-shadow:0 26px 0 -1px #2b2d31, 0 44px 0 -1px #2b2d31; }
  .pbody::after{ content:''; position:absolute; right:-2px; top:31%; width:3px; height:12%;
    background:linear-gradient(#3a3c41,#25272b); border-radius:0 3px 3px 0; }

  .pscreen{ position:relative; width:100%; height:100%; border-radius:12% / 6%;
    overflow:hidden; background:#000; container-type:size;
    box-shadow:0 0 0 4px #060607, inset 0 0 0 1px rgba(255,255,255,.05); }

  /* vídeo contrarrotado: queda recto cuando el móvil está en horizontal */
  .video-wrap{ position:absolute; top:50%; left:50%; width:100cqh; height:100cqw;
    transform:translate(-50%,-50%) rotate(-90deg); }
  .video-wrap video{ width:100%; height:100%; object-fit:cover; display:block; }

  /* isla dinámica */
  .island{ position:absolute; z-index:5; top:14px; left:50%; transform:translateX(-50%);
    width:34%; height:19px; background:#000; border-radius:14px; box-shadow:inset 0 0 0 1px #16181c; }
  .island::after{ content:''; position:absolute; top:50%; right:20%; transform:translateY(-50%);
    width:6px; height:6px; border-radius:50%; background:#0e1a24; box-shadow:inset 0 0 2px #22405a; }

  /* Capa del logo (negro + glow blanco), tapa el vídeo hasta el giro */
  .logo-layer{ position:absolute; inset:0; z-index:3; display:grid; place-items:center; pointer-events:none;
    background:radial-gradient(70% 60% at 50% 42%, #16181c 0%, #000 70%); }
  .logo-layer img{ width:66%; filter:brightness(0) invert(1)
      drop-shadow(0 0 14px rgba(255,255,255,.5)) drop-shadow(0 0 34px rgba(255,255,255,.28));
    animation:logoGlow 2.8s ease-in-out infinite; }
  @keyframes logoGlow{
    0%,100%{ filter:brightness(0) invert(1) drop-shadow(0 0 10px rgba(255,255,255,.35)) drop-shadow(0 0 26px rgba(255,255,255,.18)); }
    50%{ filter:brightness(0) invert(1) drop-shadow(0 0 20px rgba(255,255,255,.75)) drop-shadow(0 0 46px rgba(255,255,255,.42)); }
  }

  /* reflejo de cristal */
  .pscreen::after{ content:''; position:absolute; inset:0; z-index:4; pointer-events:none;
    background:linear-gradient(125deg, rgba(255,255,255,.10) 0%, rgba(255,255,255,0) 20%,
      rgba(255,255,255,0) 82%, rgba(255,255,255,.05) 100%); }

  /* controles del vídeo (bajo el móvil) */
  .device-controls{ display:flex; flex-wrap:wrap; align-items:center; justify-content:center; gap:10px; }
  .soundbtn, .fullscreenbtn{ display:inline-flex; align-items:center; justify-content:center; gap:8px; border:0; cursor:pointer;
    padding:11px 22px; border-radius:40px; font-family:inherit; font-weight:700; font-size:.92rem;
    box-shadow:0 14px 28px -14px rgba(0,0,0,.55); opacity:0; transform:translateY(10px); pointer-events:none;
    transition:opacity .5s ease, transform .5s ease, background .25s ease, color .25s ease, border-color .25s ease; }
  .soundbtn{ color:#fff; background:var(--teal); }
  .fullscreenbtn{ color:var(--teal); background:rgba(255,247,239,.92); border:1.5px solid rgba(31,110,107,.28); }
  .soundbtn.show, .fullscreenbtn.show{ opacity:1; transform:none; pointer-events:auto; }
  .soundbtn:hover{ background:var(--teal-dark); }
  .fullscreenbtn:hover{ color:#fff; background:var(--teal); border-color:var(--teal); }

  /* Modal de vídeo a tamaño completo */
  .video-modal{ position:fixed; inset:0; z-index:260; display:none; place-items:center; padding:28px; }
  .video-modal.open{ display:grid; }
  .video-modal-bg{ position:absolute; inset:0; background:rgba(12,29,28,.82); backdrop-filter:blur(10px); opacity:0; transition:opacity .28s ease; }
  .video-modal.open .video-modal-bg{ opacity:1; }
  .video-modal-card{ position:relative; z-index:1; width:min(1180px,100%); max-height:calc(100vh - 56px); aspect-ratio:16/9; background:#000; border-radius:22px; overflow:hidden; box-shadow:0 36px 100px -28px rgba(0,0,0,.78); opacity:0; transform:translateY(18px) scale(.97); transition:opacity .28s ease, transform .28s ease; }
  .video-modal.open .video-modal-card{ opacity:1; transform:none; }
  .video-modal-card video{ display:block; width:100%; height:100%; object-fit:contain; background:#000; }
  .video-modal-close{ position:absolute; z-index:2; top:14px; right:14px; width:42px; height:42px; border:0; border-radius:50%; cursor:pointer; display:grid; place-items:center; font-size:1.5rem; line-height:1; color:var(--teal); background:rgba(255,255,255,.94); box-shadow:0 8px 22px -8px rgba(0,0,0,.5); transition:transform .2s ease, background .2s ease; }
  .video-modal-close:hover{ transform:rotate(90deg); background:#fff; }
  @media (max-width:680px){
    .device-controls{ width:100%; }
    .soundbtn, .fullscreenbtn{ flex:1 1 auto; padding:11px 16px; font-size:.86rem; }
    .video-modal{ padding:16px; }
    .video-modal-card{ max-height:calc(100vh - 32px); border-radius:16px; }
    .video-modal-close{ top:9px; right:9px; width:38px; height:38px; }
  }

/* WordPress integration and non-animation fallback */
html { margin-top:0 !important; }
body.admin-bar header { top:32px; }
@media screen and (max-width:782px) { body.admin-bar header { top:46px; } }
body.bmc-no-gsap { cursor:auto; }
body.bmc-no-gsap a, body.bmc-no-gsap .btn, body.bmc-no-gsap .burger, body.bmc-no-gsap .acard, body.bmc-no-gsap label { cursor:pointer; }
body.bmc-no-gsap #cursor, body.bmc-no-gsap #cursor-ring { display:none; }
body.bmc-no-gsap .soundbtn, body.bmc-no-gsap .fullscreenbtn { opacity:1; transform:none; pointer-events:auto; }
#loader.bmc-loader-off { display:none !important; }

/* Cabecera móvil: logo centrado y elevado sin interferir con el menú */
@media (max-width:900px) {
  header { top:0; }
  .nav {
    position:relative;
    min-height:100px;
    padding:0 20px;
    justify-content:center;
  }
  .brand {
    position:absolute;
    left:50%;
    top:2px;
    z-index:2;
    display:block;
    line-height:0;
    transform:translateX(-50%);
  }
  .brand img {
    display:block;
    height:98px;
    width:auto;
    max-width:calc(100vw - 132px);
    object-fit:contain;
    object-position:center;
  }
  .burger {
    position:absolute;
    right:20px;
    top:50%;
    z-index:3;
    padding:10px 0 10px 10px;
    transform:translateY(-50%);
  }
  nav.menu.open { top:100%; }
}

@media (max-width:420px) {
  .nav { min-height:90px; }
  .brand img { height:88px; }
  .burger { right:16px; }
}

/* Ajuste definitivo de cabecera móvil: el logo permanece centrado respecto a la pantalla,
   independientemente del ancho del menú o del botón. */
@media (max-width:900px) {
  .bmc-header {
    position:sticky !important;
    top:0 !important;
    z-index:999 !important;
    height:76px !important;
  }
  .bmc-header .nav {
    position:relative !important;
    display:block !important;
    width:100% !important;
    height:76px !important;
    min-height:76px !important;
    margin:0 auto !important;
    padding:0 16px !important;
  }
  .bmc-header .brand {
    position:absolute !important;
    top:50% !important;
    left:50% !important;
    z-index:5 !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    width:max-content !important;
    max-width:calc(100vw - 120px) !important;
    line-height:0 !important;
    transform:translate(-50%, -57%) !important;
  }
  .bmc-header .brand img {
    display:block !important;
    width:auto !important;
    height:66px !important;
    max-width:100% !important;
    max-height:66px !important;
    object-fit:contain !important;
    object-position:center center !important;
  }
  .bmc-header .burger {
    position:absolute !important;
    top:50% !important;
    right:16px !important;
    z-index:10 !important;
    margin:0 !important;
    padding:9px 0 9px 10px !important;
    transform:translateY(-50%) !important;
  }
  .bmc-header nav.menu.open {
    top:76px !important;
  }
  body.admin-bar .bmc-header {
    top:46px !important;
  }
}

@media (max-width:420px) {
  .bmc-header,
  .bmc-header .nav {
    height:70px !important;
    min-height:70px !important;
  }
  .bmc-header .brand img {
    height:60px !important;
    max-height:60px !important;
  }
  .bmc-header nav.menu.open {
    top:70px !important;
  }
}

/* Cabecera móvil: se usa una versión del logo recortada para eliminar el espacio transparente
   del archivo original. El símbolo queda más grande y más alto sin afectar al escritorio. */
@media (max-width:900px) {
  .bmc-header,
  .bmc-header .nav {
    height:88px !important;
    min-height:88px !important;
  }
  .bmc-header .brand {
    top:1px !important;
    height:84px !important;
    transform:translateX(-50%) !important;
  }
  .bmc-header .brand picture {
    display:block;
    height:100%;
    line-height:0;
  }
  .bmc-header .brand img {
    display:block !important;
    width:114px !important;
    height:auto !important;
    max-height:none !important;
    object-fit:contain !important;
  }
  .bmc-header nav.menu.open {
    top:88px !important;
  }
}
@media (max-width:420px) {
  .bmc-header,
  .bmc-header .nav {
    height:84px !important;
    min-height:84px !important;
  }
  .bmc-header .brand {
    top:1px !important;
    height:80px !important;
  }
  .bmc-header .brand img {
    width:108px !important;
  }
  .bmc-header nav.menu.open {
    top:84px !important;
  }
}

/* Ajuste final de cabecera móvil: elimina la franja superior y coloca el logo en el borde superior.
   Se deja el logo ligeramente solapado sobre el contenido para mantenerlo grande sin crear una cabecera alta. */
@media (max-width:900px) {
  .bmc-header,
  .bmc-header .nav {
    height:64px !important;
    min-height:64px !important;
  }
  .bmc-header .nav {
    overflow:visible !important;
  }
  .bmc-header .brand {
    top:-12px !important;
    height:84px !important;
    max-width:calc(100vw - 118px) !important;
    overflow:visible !important;
  }
  .bmc-header .brand picture {
    height:84px !important;
    overflow:visible !important;
  }
  .bmc-header .brand img {
    width:116px !important;
    height:auto !important;
    max-width:none !important;
  }
  .bmc-header .burger {
    top:32px !important;
  }
  .bmc-header nav.menu.open {
    top:64px !important;
  }
}
@media (max-width:420px) {
  .bmc-header,
  .bmc-header .nav {
    height:60px !important;
    min-height:60px !important;
  }
  .bmc-header .brand {
    top:-13px !important;
    height:82px !important;
  }
  .bmc-header .brand picture {
    height:82px !important;
  }
  .bmc-header .brand img {
    width:112px !important;
  }
  .bmc-header .burger {
    top:30px !important;
  }
  .bmc-header nav.menu.open {
    top:60px !important;
  }
}

/* Cabecera móvil fija arriba: no modifica el hero.
   Se fuerza fuera del flujo de scroll para evitar que arranque desplazada hacia abajo. */
@media (max-width:900px) {
  .bmc-header {
    position:fixed !important;
    top:0 !important;
    right:0 !important;
    left:0 !important;
    width:100% !important;
    margin:0 !important;
    transform:none !important;
    z-index:9999 !important;
  }
  .bmc-header,
  .bmc-header .nav {
    height:64px !important;
    min-height:64px !important;
  }
  .bmc-header .brand {
    top:-10px !important;
    height:82px !important;
    transform:translateX(-50%) !important;
  }
  .bmc-header .brand picture {
    height:82px !important;
  }
  .bmc-header .brand img {
    width:118px !important;
    height:auto !important;
    max-width:none !important;
  }
  .bmc-header .burger {
    top:32px !important;
  }
  .bmc-header nav.menu.open {
    top:64px !important;
  }
  body.admin-bar .bmc-header {
    top:46px !important;
  }
}
@media (max-width:420px) {
  .bmc-header,
  .bmc-header .nav {
    height:60px !important;
    min-height:60px !important;
  }
  .bmc-header .brand {
    top:-12px !important;
    height:80px !important;
  }
  .bmc-header .brand picture {
    height:80px !important;
  }
  .bmc-header .brand img {
    width:114px !important;
  }
  .bmc-header .burger {
    top:30px !important;
  }
  .bmc-header nav.menu.open {
    top:60px !important;
  }
}


/* Ajuste móvil solicitado: subir más el hero y recolocar el botón CTA debajo de la flecha de scroll.
   Solo afecta a móvil. */
@media (max-width:900px) {
  .hero {
    min-height:auto !important;
    justify-content:flex-start !important;
    padding:84px 0 135px !important;
  }
  .hero .wrap {
    display:flex !important;
    flex-direction:column !important;
    align-items:center !important;
  }
  .hero .wrap > h1 { order:1; }
  .hero .wrap > .tagline { order:2; }
  .hero .wrap > .micro { order:3; }
  .hero .wrap > .scroll-cue {
    order:4;
    margin-top:30px !important;
    margin-bottom:18px !important;
  }
  .hero .wrap > .btn {
    order:5;
    padding:18px 54px !important;
    font-size:1.1rem !important;
    line-height:1.15 !important;
    border-radius:999px !important;
  }
}

@media (max-width:420px) {
  .hero {
    padding:76px 0 120px !important;
  }
  .hero .wrap > .scroll-cue {
    margin-top:24px !important;
    margin-bottom:16px !important;
  }
  .hero .wrap > .btn {
    padding:19px 58px !important;
    font-size:1.14rem !important;
  }
}


/* Ajuste móvil: el CTA queda antes de la flecha y la flecha baja, con una presencia mayor. */
@media (max-width:900px) {
  .hero .wrap > .btn {
    order:4 !important;
  }
  .hero .wrap > .scroll-cue {
    order:5 !important;
    margin-top:52px !important;
    margin-bottom:0 !important;
    font-size:2.7rem !important;
    line-height:1 !important;
  }
}

@media (max-width:420px) {
  .hero .wrap > .scroll-cue {
    margin-top:46px !important;
    font-size:2.55rem !important;
  }
}


/* Popup de perfiles: scroll táctil real en móvil.
   El desplazamiento se realiza en todo el panel, evitando que la foto y el texto queden bloqueados. */
@media (max-width:680px) {
  #modal.open {
    display:block !important;
    overflow-y:auto !important;
    overscroll-behavior:contain !important;
    -webkit-overflow-scrolling:touch;
    touch-action:pan-y !important;
    padding:16px 14px calc(16px + env(safe-area-inset-bottom)) !important;
  }
  #modal .modal-bg {
    position:fixed !important;
  }
  #modal .modal-card {
    position:relative !important;
    z-index:1 !important;
    display:block !important;
    width:100% !important;
    max-height:none !important;
    min-height:0 !important;
    margin:0 auto !important;
    overflow:visible !important;
    touch-action:pan-y !important;
  }
  #modal .modal-card .m-photo {
    aspect-ratio:4 / 3 !important;
    min-height:0 !important;
  }
  #modal .modal-card .m-info {
    max-height:none !important;
    overflow:visible !important;
    padding:28px 24px 32px !important;
    touch-action:pan-y !important;
  }
  #modal .modal-close {
    position:sticky !important;
    top:10px !important;
    float:right;
    margin:10px 10px -50px 0;
  }
}


/* Posición final del CTA y la flecha en móvil: ambos bajan sin cambiar escritorio. */
@media (max-width:900px) {
  .hero .wrap > .btn {
    margin-top:30px !important;
  }
  .hero .wrap > .scroll-cue {
    margin-top:72px !important;
  }
}

@media (max-width:420px) {
  .hero .wrap > .btn {
    margin-top:28px !important;
  }
  .hero .wrap > .scroll-cue {
    margin-top:66px !important;
  }
}


/* Header móvil sin sticky: se desplaza con la página igual que el resto del contenido. */
@media (max-width:900px) {
  header.bmc-header,
  .bmc-header {
    position:relative !important;
    top:auto !important;
    right:auto !important;
    bottom:auto !important;
    left:auto !important;
    width:100% !important;
    inset:auto !important;
  }
  body.admin-bar header.bmc-header,
  body.admin-bar .bmc-header {
    top:auto !important;
  }
}


/* Pop-ups de equipo en móvil: se desplazan un poco hacia abajo para que la X nunca quede pegada
   al borde superior o a la interfaz del navegador. Mantiene el scroll táctil dentro del popup. */
@media (max-width:680px) {
  #modal.open {
    padding-top:calc(72px + env(safe-area-inset-top)) !important;
    padding-bottom:calc(24px + env(safe-area-inset-bottom)) !important;
  }
  #modal .modal-card {
    margin:0 auto 28px !important;
  }
  #modal .modal-close {
    top:14px !important;
    margin:12px 12px -52px 0 !important;
    z-index:12 !important;
    touch-action:manipulation !important;
  }
}

/* El efecto del iPhone utiliza su propio tramo de scroll en móvil. */
@media (max-width:900px) {
  .device-reveal .dr-stage {
    min-height:100svh;
    min-height:100dvh;
  }
}


/* Bloqueo controlado del scroll durante el giro del iPhone en móvil.
   No se aplica en escritorio y se libera automáticamente al terminar el efecto. */
@media (max-width:900px) {
  html:has(body.bmc-device-scroll-lock),
  body.bmc-device-scroll-lock {
    overflow:hidden !important;
    overscroll-behavior:none !important;
    touch-action:none !important;
  }
  body.bmc-device-scroll-lock .device-reveal,
  body.bmc-device-scroll-lock .dr-stage {
    touch-action:none !important;
  }
}


/* Ajuste de composición en escritorio: eleva ligeramente el bloque principal del hero.
   No afecta a la versión móvil ni a la animación de zoom. */
@media (min-width:901px) {
  .hero {
    padding-top:40px !important;
    padding-bottom:230px !important;
  }
}


/* Cita individual desde el perfil de cada profesional */
.member-whatsapp {
  display:flex !important;
  width:100%;
  justify-content:center;
  align-items:center;
  margin-top:24px;
  padding:15px 22px !important;
  text-align:center;
  line-height:1.25;
}
.member-whatsapp span { text-decoration:none !important; }
.member-whatsapp::before { content:'◔'; margin-right:9px; font-size:1.12em; line-height:1; }
@media (max-width:680px) {
  #modal .member-whatsapp {
    margin-top:26px;
    margin-bottom:8px;
    min-height:54px;
  }
}


/* Corrección definitiva del scroll de los pop-ups de profesionales en móvil.
   El popup queda fijo y el contenido del perfil se desplaza dentro de su propio panel,
   sin transferir el gesto al documento ni a las animaciones de ScrollTrigger. */
@media (max-width:680px) {
  html.bmc-member-modal-open,
  body.bmc-member-modal-open {
    height:100% !important;
    overflow:hidden !important;
    overscroll-behavior:none !important;
  }

  #modal.open {
    display:flex !important;
    position:fixed !important;
    inset:0 !important;
    align-items:flex-start !important;
    justify-content:center !important;
    overflow:hidden !important;
    padding:calc(64px + env(safe-area-inset-top)) 14px calc(22px + env(safe-area-inset-bottom)) !important;
    touch-action:pan-y !important;
  }

  #modal .modal-card {
    position:relative !important;
    z-index:2 !important;
    display:flex !important;
    flex-direction:column !important;
    width:min(100%, 540px) !important;
    height:calc(100svh - 104px) !important;
    max-height:calc(100svh - 104px) !important;
    min-height:0 !important;
    margin:0 !important;
    overflow:hidden !important;
    border-radius:22px !important;
    touch-action:pan-y !important;
  }

  @supports (height: 100dvh) {
    #modal .modal-card {
      height:calc(100dvh - 104px) !important;
      max-height:calc(100dvh - 104px) !important;
    }
  }

  #modal .modal-card .m-photo {
    flex:0 0 auto !important;
    height:clamp(150px, 27svh, 210px) !important;
    min-height:0 !important;
    aspect-ratio:auto !important;
    overflow:hidden !important;
  }

  #modal .modal-card .m-photo img {
    height:100% !important;
  }

  #modal .modal-card .m-info {
    display:block !important;
    flex:1 1 auto !important;
    min-height:0 !important;
    height:auto !important;
    max-height:none !important;
    overflow-x:hidden !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch !important;
    overscroll-behavior:contain !important;
    touch-action:pan-y !important;
    padding:28px 24px 34px !important;
  }

  #modal .modal-close {
    position:absolute !important;
    top:12px !important;
    right:12px !important;
    z-index:30 !important;
    float:none !important;
    margin:0 !important;
    touch-action:manipulation !important;
  }

  #modal .member-whatsapp {
    margin-bottom:10px !important;
  }
}


/* Hero de escritorio: se eleva el bloque completo de título, textos, botón y flecha
   sin alterar la escala ni el pin de la animación. */
@media (min-width:901px) {
  .hero .wrap {
    top:-68px !important;
  }
}
