/* InRecint — inrecint.com */

:root{
  --noche:#0F1419;
  --noche2:#101720;
  --papel:#FAFBFC;
  --tinta:#15202B;
  --gris:#5F6B76;
  --linea:rgba(21,32,43,.10);
  --acc:#FF6B6B; --acc2:#FF8E53; --acc-strong:#D85A30; --acc-deep:#993C1D; --acc-ink:#4A1B0C; --acc-soft:#FAECE7;
  --r-sm:12px; --r-md:18px; --r-lg:28px;
  --font:"DM Sans",system-ui,sans-serif;
  --mono:"DM Mono",ui-monospace,monospace;
}
html[data-world="hotel"]{
  --acc:#1E3A5F; --acc2:#2E5A8F; --acc-strong:#185FA5; --acc-deep:#0C447C; --acc-ink:#042C53; --acc-soft:#E6F1FB;
}
html[data-world="operator"]{
  --acc:#1D9E75; --acc2:#5DCAA5; --acc-strong:#0F6E56; --acc-deep:#085041; --acc-ink:#04342C; --acc-soft:#E1F5EE;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:#0F1419;overscroll-behavior-y:none}
html[data-world="traveler"],html[data-world="operator"]{background:#FAFBFC}
html[data-world="hotel"]{background:#101720}
body{overscroll-behavior-y:none}
body{font-family:var(--font);background:var(--papel);color:var(--tinta);line-height:1.6;-webkit-font-smoothing:antialiased}
.mono{font-family:var(--mono);letter-spacing:.04em}
img,svg{display:block}
button{font:inherit;background:none;border:none;cursor:pointer;color:inherit}
a{color:inherit;text-decoration:none}
h1,h2,h3{line-height:1.12;letter-spacing:-.02em;font-weight:800}
h1{font-size:clamp(2.3rem,5.6vw,4rem)}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem);margin-bottom:.6em}
h3{font-size:1.12rem;font-weight:700;letter-spacing:-.01em}
.wrap{max-width:1120px;margin:0 auto;padding:0 24px}
.narrow{max-width:680px}
.body{color:var(--gris);font-size:1.06rem;max-width:56ch}
.eyebrow{font-size:.8rem;text-transform:uppercase;color:var(--acc-strong);margin-bottom:14px;font-weight:500}
.hp{position:absolute;left:-9999px;opacity:0}

/* ---------- top bar ---------- */
.topbar{position:fixed;inset:0 0 auto 0;z-index:50;display:flex;align-items:center;gap:18px;padding:calc(14px + env(safe-area-inset-top,0px)) 22px 14px;transition:background .3s,box-shadow .3s}
.topbar.solid{background:rgba(250,251,252,.86);backdrop-filter:blur(14px);box-shadow:0 1px 0 var(--linea)}
.brand{display:flex;align-items:center;gap:10px;position:relative}
.brand-name{font-weight:800;font-size:1.15rem;letter-spacing:-.02em}
.topbar .brand-name{color:#fff;transition:color .3s}
.topbar.solid .brand-name{color:var(--tinta)}
.topnav{display:none;gap:6px;margin-left:8px}
.topbar.in-world .topnav{display:flex}
.wpill{font-size:.86rem;font-weight:500;padding:7px 14px;border-radius:999px;color:var(--gris);transition:.2s}
.wpill:hover{background:var(--acc-soft);color:var(--acc-deep)}
.wpill.active{background:var(--acc);color:#fff}
.topbar:not(.solid) .wpill{color:rgba(255,255,255,.75)}
.topbar:not(.solid) .wpill.active{background:rgba(255,255,255,.16);color:#fff}
/* affordance "volver al inicio": flecha junto al logo (sólo in-world) + tooltip + pestaña Inicio */
.brand-back{display:none;align-items:center;justify-content:center;width:30px;height:30px;border-radius:10px;flex:none;transition:background .2s,transform .2s}
.topbar.in-world .brand-back{display:inline-flex}
.brand-back svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.topbar .brand-back{color:#fff;background:rgba(255,255,255,.14)}
.topbar.solid .brand-back{color:var(--acc-strong);background:var(--acc-soft)}
.topbar:not(.solid) .brand:hover .brand-back,.topbar:not(.solid) .brand:focus-visible .brand-back{background:rgba(255,255,255,.26)}
.topbar.solid .brand:hover .brand-back,.topbar.solid .brand:focus-visible .brand-back{background:var(--acc);color:#fff}
.brand:hover .brand-back,.brand:focus-visible .brand-back{transform:translateX(-2px)}
.brand-tip{position:absolute;left:0;top:calc(100% + 9px);background:#0F1419;color:#fff;font-size:.76rem;font-weight:500;padding:6px 11px;border-radius:10px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s;box-shadow:0 8px 20px -8px rgba(0,0,0,.55)}
.topbar.in-world .brand:hover .brand-tip,.topbar.in-world .brand:focus-visible .brand-tip{opacity:1}
@media (pointer:coarse){.brand-tip{display:none}}
.wpill-home{display:inline-flex;align-items:center;gap:6px}
.wpill-home svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.top-right{margin-left:auto;display:flex;align-items:center;gap:10px}
.lang-select{font-family:var(--mono);font-size:.8rem;padding:7px 10px;border-radius:10px;border:1px solid rgba(255,255,255,.25);background:transparent;color:#fff;cursor:pointer;appearance:auto}
.topbar.solid .lang-select{border-color:var(--linea);color:var(--tinta)}
.lang-select option{color:var(--tinta)}

/* ---------- puerta ---------- */
.door{min-height:100svh;background:var(--noche);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:calc(96px + env(safe-area-inset-top,0px)) 24px calc(48px + env(safe-area-inset-bottom,0px));text-align:center}
/* header centrado y estable entre idiomas: contenedor con max-width + margin auto (sin posiciones absolutas) */
.door-head{max-width:min(94vw,620px);margin:0 auto;display:flex;flex-direction:column;align-items:center;text-align:center}
.door-kicker{color:rgba(255,255,255,.45);font-size:clamp(.72rem,1.8vw,.8rem);line-height:1.4;margin-bottom:16px;min-height:1.4em}
.door-title{color:#fff;margin-bottom:12px;min-height:1.12em;text-wrap:balance}
/* min-height reserva 2 líneas → el título no salta de posición al cambiar de idioma */
.door-sub{color:rgba(255,255,255,.55);font-size:clamp(.98rem,2.6vw,1.08rem);line-height:1.5;margin-bottom:40px;max-width:36ch;min-height:3em;text-wrap:balance}
.door-panels{display:flex;gap:14px;width:min(1060px,100%);height:min(58vh,520px)}
.panel{flex:1;min-width:0;border-radius:var(--r-lg);padding:30px 26px;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;text-align:left;color:#fff;position:relative;overflow:hidden;transition:flex .45s cubic-bezier(.2,.8,.2,1),transform .45s;will-change:flex}
.panel:hover,.panel:focus-visible{flex:2.1}
.panel:focus-visible{outline:3px solid #fff;outline-offset:3px}
.panel-t{background:linear-gradient(160deg,#FF6B6B,#FF8E53)}
.panel-h{background:linear-gradient(160deg,#27496E,#101A2B)}
.panel-o{background:linear-gradient(160deg,#1D9E75,#0A5742)}
/* ---- escenas animadas (íconos vivos) ---- */
/* AJUSTÁ TAMAÑOS AQUÍ: globo y pin pesan menos que la puerta → van más grandes */
.panel-icon{position:absolute;top:22px;left:22px;width:116px;height:116px;opacity:1;z-index:1}
.panel-h .panel-icon{width:104px;height:104px}            /* puerta: más alta y angosta */
.panel-icon svg{width:100%;height:100%;overflow:visible}
.panel-fx{position:absolute;inset:0;z-index:0;pointer-events:none;overflow:hidden;border-radius:inherit}
.panel-fx svg{position:absolute;display:block}
.panel-text,.panel-enter{position:relative;z-index:2}     /* el texto SIEMPRE por encima de la escena */
/* Viajero */
.fx-sky{inset:0;width:100%;height:100%}
.fx-plane{position:absolute;inset:0;width:100%;height:100%}   /* avión en SVG propio: NO se deforma al crecer/en mobile */
.cloud{opacity:.16}
/* Hotel */
.fx-glow{position:absolute;inset:0;opacity:.5;background:radial-gradient(circle at 58px 64px,rgba(255,180,90,.22),transparent 46%)} /* color/posición del brillo cálido */
/* Operador */
.fx-bike{position:absolute;left:0;bottom:20px;width:72px;height:46px}  /* bici tamaño fijo (ruedas 1:1); altura sobre el pasto = bottom */
.fx-bike-2{width:68px;height:40px;bottom:14px;opacity:0}              /* bici extra (solo gesto al click) */
.fx-grass{left:0;bottom:0;width:100%;height:64px}          /* AJUSTÁ alto del pasto aquí */
/* will-change con criterio: el JS agrega .scenes-live SOLO cuando las escenas animan
   (no en reduced ni sin GSAP) → no se promueven capas GPU al pedo en mobile */
.scenes-live .plane,.scenes-live .globe,.scenes-live .fx-bike,.scenes-live .pin,.scenes-live .disco,.scenes-live .leaf,.scenes-live .grass,.scenes-live .trail-dot{will-change:transform}
.scenes-live .fx-glow,.scenes-live .party-l,.scenes-live .trail-dot{will-change:opacity}
/* clamp para que el título más largo (alemán "Veranstalter") no desborde ni tape la animación */
.panel-title{display:block;font-size:clamp(1.35rem,1.9vw,1.9rem);font-weight:800;letter-spacing:-.02em;line-height:1.1;margin-bottom:8px;overflow-wrap:break-word}
/* min-height = 2 líneas: ancla título y "Entrar →" a la misma altura en las 3 cards sin importar el largo de la bajada */
.panel-tag{display:block;font-size:clamp(.85rem,.95vw,.96rem);line-height:1.4;opacity:0;max-width:32ch;min-height:2.8em;transform:translateY(8px);transition:.35s .08s}
.panel:hover .panel-tag,.panel:focus-visible .panel-tag{opacity:.92;transform:none}
.panel-enter{margin-top:16px;font-size:.8rem;opacity:.85}
.panel::after{content:"";position:absolute;inset:0;background:radial-gradient(220px circle at var(--mx,50%) var(--my,50%),rgba(255,255,255,.16),transparent 70%);opacity:0;transition:opacity .3s;pointer-events:none}
.panel:hover::after{opacity:1}

/* barra de progreso */
.progress{position:fixed;top:0;left:0;height:3px;width:100%;z-index:60;background:linear-gradient(90deg,var(--acc),var(--acc2));transform:scaleX(0);transform-origin:left;pointer-events:none}
html:not([data-world]) .progress{display:none}

/* color wipe */
.wipe{position:fixed;inset:0;z-index:80;pointer-events:none;transform:scaleY(0);transform-origin:bottom;background:var(--acc)}

/* ---------- mundos ---------- */
.world[hidden],main[hidden],.door[hidden]{display:none}
.hero{padding:calc(140px + env(safe-area-inset-top,0px)) 0 90px;background:
  radial-gradient(900px 480px at 85% -10%,var(--acc-soft),transparent 70%),var(--papel)}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center}
.hero-copy h1{margin:18px 0 16px}
.lede{color:var(--gris);font-size:1.15rem;max-width:46ch;margin-bottom:30px}
.badge{display:inline-block;background:var(--acc-soft);color:var(--acc-deep);font-size:.82rem;font-weight:500;padding:6px 14px;border-radius:999px}
.cta-row{display:flex;gap:12px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:700;font-size:.96rem;padding:14px 26px;border-radius:16px;transition:transform .15s,box-shadow .2s,background .2s}
.btn:active{transform:scale(.97)}
.btn-primary{color:#fff;background:linear-gradient(135deg,var(--acc),var(--acc2));box-shadow:0 8px 24px -8px var(--acc)}
.btn-primary:hover{box-shadow:0 12px 30px -8px var(--acc)}
.btn-ghost{border:1.5px solid var(--linea);color:var(--tinta)}
.btn-ghost:hover{background:#fff;border-color:rgba(21,32,43,.22)}

/* hotel hero oscuro */
.hero-dark{background:radial-gradient(900px 520px at 85% -10%,#23456b,transparent 70%),var(--noche2)}
.hero-dark h1,.hero-dark .lede{color:#fff}
.hero-dark .lede{color:rgba(255,255,255,.7)}
.hero-dark .badge{background:rgba(230,241,251,.12);color:#B5D4F4}
.hero-dark .btn-ghost{border-color:rgba(255,255,255,.25);color:#fff}

/* ---------- teléfono ---------- */
.hero-visual{display:flex;justify-content:center;perspective:1000px}
.phone{width:min(300px,100%);background:#fff;border:1px solid var(--linea);border-radius:34px;padding:20px 16px 22px;box-shadow:0 30px 60px -28px rgba(15,20,25,.35)}
.phone-dark{background:#16222E;border-color:rgba(255,255,255,.08)}
.phone-dark .ph-eyebrow{color:rgba(255,255,255,.5)}
.phone-dark .ph-card{background:#1D2B3A;border-color:rgba(255,255,255,.07)}
.phone-dark .ph-t{color:#fff}
.phone-dark .ph-m{color:rgba(255,255,255,.55)}
.ph-eyebrow{font-size:.68rem;color:var(--gris);margin-bottom:2px}
.ph-hotel{font-weight:700;font-size:.95rem;margin-bottom:14px}
.ph-card{background:var(--papel);border:1px solid var(--linea);border-radius:16px;padding:12px 13px;margin-bottom:10px}
.ph-t{font-weight:700;font-size:.9rem;display:flex;align-items:center;gap:6px}
.ph-m{font-size:.76rem;color:var(--gris);margin:3px 0 8px}
.ph-teal-t{color:#0F6E56}
.ph-price{font-weight:700;font-size:.84rem;margin:2px 0 8px}
.ph-btn{display:inline-block;font-size:.74rem;font-weight:700;padding:5px 12px;border-radius:10px}
.ph-coral{background:#FAECE7;color:#993C1D}
.ph-teal{background:#E1F5EE;color:#0F6E56}
.ph-tealsolid{background:#1D9E75;color:#fff}
.ph-blue{background:#E6F1FB;color:#185FA5}
.ph-dark{background:var(--noche);color:#fff}
.ph-photo{height:84px;border-radius:12px;background:linear-gradient(135deg,#5DCAA5,#1D9E75);margin-bottom:10px;display:grid;place-items:center;overflow:hidden}
.ph-photo svg{width:34px;height:34px;stroke:#fff;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;opacity:.95}
.ph-service .ph-t{margin-top:2px}
.seal{width:15px;height:15px;color:#D85A30;flex:none}
.seal-teal{color:#0F6E56}

/* ---------- secciones ---------- */
.sec{padding:96px 0}
.sec-tint{background:linear-gradient(180deg,var(--acc-soft) 0%,var(--papel) 100%)}
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:34px}
.step{background:#fff;border:1px solid var(--linea);border-radius:var(--r-md);padding:26px 24px;transition:transform .25s,box-shadow .25s,border-color .25s}
.step-n{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:12px;color:var(--acc-strong);font-family:var(--mono);font-size:.84rem;font-weight:500;margin-bottom:16px;
  background:linear-gradient(145deg,#fff,var(--acc-soft));
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 9px 20px -12px var(--acc-strong),inset 0 1px 0 rgba(255,255,255,.95)}   /* mismo chip que los iconos de feature → coherente */
.step h3{margin-bottom:8px}
.step p{color:var(--gris);font-size:.95rem}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}
.card{background:#fff;border:1px solid var(--linea);border-radius:var(--r-md);padding:26px 22px;transition:transform .25s,box-shadow .25s,border-color .25s}
.card:hover{transform:translateY(-5px);box-shadow:0 18px 36px -22px rgba(15,20,25,.3)}
.card-art{width:54px;height:54px;border-radius:16px;color:var(--acc-strong);display:flex;align-items:center;justify-content:center;margin-bottom:18px;
  background:linear-gradient(145deg,#fff,var(--acc-soft));
  border:1px solid rgba(255,255,255,.8);
  box-shadow:0 9px 20px -12px var(--acc-strong),inset 0 1px 0 rgba(255,255,255,.95)}   /* chip glass premium, teñido por mundo */
.card-art svg{width:25px;height:25px;stroke-width:1.7}   /* trazo más fino y parejo */
.card h3{margin-bottom:8px;font-size:1.02rem}
.card p{color:var(--gris);font-size:.92rem}
.split{display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center}

/* compartir gastos */
.share-widget{background:#fff;border:1px solid var(--linea);border-radius:var(--r-lg);padding:30px 28px;max-width:380px;margin:0 auto;text-align:center;box-shadow:0 24px 48px -28px rgba(15,20,25,.25)}
.sw-label{font-size:.74rem;color:var(--gris);text-transform:uppercase}
.sw-total{font-weight:800;font-size:1.3rem;margin:2px 0 12px;color:var(--gris);text-decoration:none}
.sw-each{font-size:2.4rem;font-weight:800;letter-spacing:-.03em;color:#0F6E56}
.sw-each-l{display:block;font-size:.85rem;font-weight:500;color:var(--gris);letter-spacing:0}
.sw-people{display:flex;justify-content:center;gap:6px;margin:18px 0 6px;min-height:34px;flex-wrap:wrap}
.sw-av{width:32px;height:32px;border-radius:11px;background:#E1F5EE;color:#0F6E56;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.78rem}
.sw-count{font-size:.78rem;color:var(--gris);margin-bottom:16px}
.sw-controls{display:flex;gap:10px;justify-content:center}
.btn-mini{border:1.5px solid var(--linea);border-radius:12px;padding:10px 16px;font-weight:700;font-size:.88rem}
.btn-mini:hover{background:var(--papel)}
.btn-mini-add{background:#1D9E75;color:#fff;border-color:#1D9E75}
.btn-mini-add:hover{background:#0F6E56}
.sw-note{font-size:.78rem;color:var(--gris);margin-top:14px}

/* flujo estrella */
.flow{position:relative;display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:44px}
.flow-line{position:absolute;top:9px;left:6%;width:88%;height:8px}
.flow-line path{stroke:var(--acc);stroke-width:3;fill:none;stroke-dasharray:1;stroke-dashoffset:1}
.flow-step{position:relative;padding-top:34px}
.flow-dot{position:absolute;top:0;left:0;width:20px;height:20px;border-radius:50%;background:var(--acc);box-shadow:0 0 0 6px var(--acc-soft)}
.flow-step h3{margin-bottom:6px}
.flow-step p{color:var(--gris);font-size:.95rem}

/* banda CTA + waitlist */
.cta-band{background:var(--noche2);color:#fff;text-align:center}
.cta-band h2{color:#fff}
.cta-band .body{color:rgba(255,255,255,.65);margin:0 auto 28px}
.wl-form{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;position:relative}
.wl-form input[type=email]{flex:1;min-width:240px;max-width:340px;padding:14px 18px;border-radius:16px;border:1.5px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);color:#fff;font:inherit;font-size:.96rem}
.wl-form input[type=email]::placeholder{color:rgba(255,255,255,.4)}
.wl-form input[type=email]:focus{outline:2px solid var(--acc2);border-color:transparent}
.wl-msg{width:100%;margin-top:14px;font-size:.9rem;color:#9FE1CB;min-height:1.2em}
.wl-msg.err{color:#F09595}
.store-row{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/* footer */
.footer{background:var(--noche);color:#fff;padding:64px 0 calc(28px + env(safe-area-inset-bottom,0px))}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding-bottom:40px}
.f-tag{color:rgba(255,255,255,.55);font-size:.92rem;margin-top:8px}
.f-h{font-size:.74rem;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:12px}
.f-link{display:block;color:rgba(255,255,255,.78);font-size:.95rem;margin-bottom:9px;text-align:left}
.f-link:hover{color:#fff}
.f-rights{text-align:center;font-size:.74rem;color:rgba(255,255,255,.35);border-top:1px solid rgba(255,255,255,.08);padding-top:24px;margin:0 24px}

/* whatsapp flotante */
.wa{position:fixed;right:18px;bottom:calc(18px + env(safe-area-inset-bottom,0px));z-index:70;width:58px;height:58px;border-radius:19px;background:linear-gradient(135deg,#2BE07A,#1FAF54);color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:0 10px 28px -8px rgba(31,175,84,.65);transition:transform .2s,box-shadow .2s}
.wa svg{width:30px;height:30px}
.wa:hover{transform:scale(1.07);box-shadow:0 14px 34px -8px rgba(31,175,84,.75)}
.wa:active{transform:scale(.96)}
.wa::after{content:attr(data-tip);position:absolute;right:70px;top:50%;transform:translateY(-50%);background:#0F1419;color:#fff;font-size:.82rem;font-weight:500;padding:8px 14px;border-radius:12px;white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s}
.wa:hover::after{opacity:1}
@media (pointer:coarse){.wa::after{display:none}}
@media (max-width:920px){.wa{right:14px;bottom:calc(14px + env(safe-area-inset-bottom,0px));width:54px;height:54px}}

/* launch mode */
html.launch .only-wait{display:none!important}
html:not(.launch) .only-launch{display:none!important}

/* reveals (estado inicial lo maneja JS para no esconder sin GSAP) */
.reveal{will-change:transform,opacity}

/* ============================================================
   MUNDO VIAJERO · vivo  (Capa 1 cielo + glass + mini-escenas)
   Todo scopeado a #world-traveler → Hotel/Operador intactos.
   AJUSTÁ colores/intensidad/opacidades en este bloque.
   ============================================================ */
#world-traveler{position:relative;z-index:0;background:transparent}
#world-traveler > section{position:relative;z-index:1}            /* contenido SIEMPRE sobre el cielo */

/* --- Capa 1: cielo del mundo (usa --acc/--acc2 → replicable a hotel/operador) --- */
.world-bg{position:absolute;inset:0;z-index:0;pointer-events:none;
  background:linear-gradient(168deg,var(--acc) 0%,var(--acc2) 44%,#FFD9C2 100%)}   /* AJUSTÁ el cielo */
.world-bg::before{content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 620px at 84% -8%,rgba(255,255,255,.34),transparent 60%),
    radial-gradient(720px 540px at 10% 16%,rgba(255,108,80,.30),transparent 60%),
    radial-gradient(820px 600px at 50% 112%,rgba(255,255,255,.30),transparent 62%)}   /* halos / atmósfera */
.world-bg-stage{position:sticky;top:0;height:100vh;overflow:hidden}    /* el cielo animado queda fijo mientras scrolleás */
.world-sky{position:absolute;inset:0;width:100%;height:100%}
.wb-cloud{opacity:.16}                                            /* AJUSTÁ opacidad de nubes */
.wb-plane path{filter:drop-shadow(0 2px 7px rgba(120,40,10,.22))} /* leve sombra: el avión lee sobre el cielo */
.scenes-live .wb-cloud,.scenes-live .wb-plane,.scenes-live .wb-plane-layer{will-change:transform}
.scenes-live .wb-dot{will-change:transform,opacity}

/* --- legibilidad: lo que va sobre el cielo, en claro --- */
#world-traveler .hero{background:transparent}
#world-traveler .hero-copy h1{color:#fff}
#world-traveler .lede{color:rgba(255,255,255,.92)}
#world-traveler .badge{background:rgba(255,255,255,.2);color:#fff}
#world-traveler .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
#world-traveler .btn-ghost:hover{background:rgba(255,255,255,.14);border-color:rgba(255,255,255,.75)}
#world-traveler .hero .btn-primary{background:#fff;color:var(--acc-strong);box-shadow:0 12px 30px -10px rgba(120,40,10,.5)}  /* CTA blanco resalta sobre el naranja */
#world-traveler .hero .btn-primary:hover{box-shadow:0 18px 40px -10px rgba(120,40,10,.6)}
#world-traveler .eyebrow{color:#fff;opacity:.92}
#world-traveler .sec h2{color:#fff}
#world-traveler .body{color:rgba(255,255,255,.88)}
#world-traveler .sec-tint{background:transparent}                 /* la sección de gastos deja ver el cielo */

/* --- glass: tarjetas translúcidas sobre el cielo --- */
#world-traveler .card,
#world-traveler .live-step,
#world-traveler .share-widget{
  background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 16px 42px -20px rgba(120,45,10,.5),inset 0 1px 0 rgba(255,255,255,.75)}
#world-traveler .card:hover,
#world-traveler .live-step:hover,
#world-traveler .social-card:hover{
  transform:translateY(-6px);
  border-color:rgba(255,255,255,.92);                                                      /* borde de luz al hover */
  box-shadow:0 28px 56px -20px rgba(214,90,48,.55),inset 0 1px 0 rgba(255,255,255,.85)}   /* hover: se eleva con glow naranja */
#world-traveler .card h3,#world-traveler .live-step h3{color:var(--tinta)}
#world-traveler .card p{color:#5a4a42}

/* --- Capa 2: mini-escenas "app viva" --- */
.live-step{border-radius:var(--r-md);padding:22px 22px 24px;text-align:left;transition:transform .28s,box-shadow .28s,border-color .28s}
.ls-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.ls-ico{width:46px;height:46px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--acc-soft);color:var(--acc-strong)}
.ls-ico svg{width:24px;height:24px}
.ls-num{font-family:var(--mono);font-size:.74rem;color:var(--acc-strong);opacity:.65;letter-spacing:.12em}
.live-step h3{margin-bottom:14px;font-size:1.06rem}
.ls-screen{background:#fff;border:1px solid var(--linea);border-radius:14px;padding:12px;min-height:78px;display:flex;align-items:center;overflow:hidden;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.ls-notif{display:flex;align-items:center;gap:10px;width:100%}
.ls-notif-ico{flex:none;width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;background:var(--acc);color:#fff}
.ls-notif-ico svg{width:18px;height:18px}
.ls-notif-tx{display:flex;flex-direction:column;line-height:1.3}
.ls-notif-tx b{font-size:.9rem;color:var(--tinta)}
.ls-notif-tx i{font-style:normal;font-size:.78rem;color:var(--gris)}
.ls-plan{width:100%}
.ls-plan-t{font-weight:700;font-size:.92rem;color:var(--tinta)}
.ls-plan-m{font-size:.8rem;color:var(--gris);margin-top:3px}
.ls-plan-join{display:flex;align-items:center;justify-content:space-between;gap:10px}
.ls-count{font-weight:800;color:var(--acc-strong);display:inline-block}
.ls-join{position:relative;flex:none;display:inline-grid;place-items:center;min-width:86px;min-height:32px}
.ls-join>span{grid-area:1/1;display:inline-flex;align-items:center;gap:5px;font-size:.78rem;font-weight:700;padding:7px 13px;border-radius:11px;white-space:nowrap}
.ls-join-a{background:var(--acc);color:#fff}
.ls-join-b{background:#E1F5EE;color:#0F6E56;opacity:0}
.ls-join-b svg{width:14px;height:14px}

/* --- prueba social: tarjeta glass premium, ESTABLE e IDÉNTICA en los 3 mundos --- */
.social-sec{position:relative}
/* base común (los 3 mundos): forma, padding, entrada y transición.
   Antes la forma/padding venían solo de #world-traveler → Hotel/Operador salían cuadrados. */
.social-card{border-radius:var(--r-lg);padding:46px 40px 42px;text-align:center;
  animation:socialIn .55s ease;transition:transform .28s,box-shadow .28s,border-color .28s}
@keyframes socialIn{from{opacity:0}to{opacity:1}}   /* entrada por CSS: re-corre al cambiar de mundo, sin depender del scroll/JS → estable */
/* glass cálido del mundo Viajero (Hotel/Operador tienen su propia regla glass más abajo) */
#world-traveler .social-card{
  background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 16px 42px -20px rgba(120,45,10,.5),inset 0 1px 0 rgba(255,255,255,.75)}
/* eyebrow en el color del mundo (var de tema → gana al .eyebrow blanco con su ID) */
#world-traveler .social-card .social-eb,#world-hotel .social-card .social-eb,#world-operator .social-card .social-eb{color:var(--acc-strong);opacity:.92;margin-bottom:18px;letter-spacing:.14em}
/* icono superior: chip teñido por el mundo */
.social-ico{width:58px;height:58px;border-radius:18px;display:grid;place-items:center;margin:0 auto 18px;background:var(--acc-soft);color:var(--acc-strong)}
.social-ico svg{width:28px;height:28px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}
/* MENSAJE (default) vs CONTADOR (.has-count): toggle por CLASE = determinista, sin pelea de [hidden]/display */
.social-count{display:none;flex-direction:column;align-items:center;gap:2px;margin-bottom:2px}
.social-card.has-count .social-count{display:flex}
.social-card.has-count .social-empty{display:none}
.social-n{font-size:clamp(3rem,9vw,4.2rem);font-weight:700;color:var(--acc-strong);letter-spacing:-.03em;line-height:1}
.social-l{font-size:1rem;color:#5a4a42;font-weight:500}
.social-empty{font-size:clamp(1.5rem,4.4vw,2.05rem);font-weight:800;color:var(--tinta);letter-spacing:-.015em;line-height:1.16;margin:0 auto;max-width:16ch}
.social-sub{color:#6a6f76;font-size:.95rem;margin:14px auto 0;max-width:34ch;line-height:1.5}
.social-cta{margin-top:26px}

/* ============================================================
   FASE 4 · mockups de la app (marco de teléfono + pantallas)
   Todo vector/CSS → nítido en retina. Scopeado a .appshow/.appframe.
   ============================================================ */
.appshow .split{align-items:center}
.app-hint{color:#fff;opacity:.82;font-size:.8rem;margin-top:18px;letter-spacing:.03em}

/* --- marco del teléfono --- */
.appframe{position:relative;width:100%;max-width:300px;margin:0 auto;aspect-ratio:300/612;
  background:#0e1116;border-radius:42px;padding:14px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 44px 90px -34px rgba(80,30,10,.75),inset 0 0 0 2px rgba(255,255,255,.05),inset 0 2px 0 rgba(255,255,255,.12)}
@supports not (aspect-ratio:1){.appframe{height:612px}}
.appframe-cam{position:absolute;top:20px;left:50%;transform:translateX(-50%);width:9px;height:9px;border-radius:50%;background:#23262d;box-shadow:0 0 0 3px #0e1116;z-index:4}
.appstatus{position:absolute;top:21px;left:32px;right:32px;display:flex;align-items:center;justify-content:space-between;font-size:.66rem;color:var(--tinta);z-index:3;pointer-events:none}
.appstatus .mono{font-weight:700}
.appstatus-i{display:flex;align-items:center;gap:5px}
.appstatus-bars{display:flex;align-items:flex-end;gap:1.6px;height:9px}
.appstatus-bars i{width:2.5px;background:var(--tinta);border-radius:1px}
.appstatus-bars i:nth-child(1){height:4px}
.appstatus-bars i:nth-child(2){height:6.5px}
.appstatus-bars i:nth-child(3){height:9px}
.appstatus-i svg{width:18px;height:11px;stroke:var(--tinta);fill:none;stroke-width:1.3}

/* --- pantalla: vistas apiladas, solo .is-active visible --- */
.appscreen{position:absolute;inset:14px;border-radius:30px;overflow:hidden;background:linear-gradient(180deg,#fff,#fbf4ef)}
.appview{position:absolute;inset:0;display:flex;flex-direction:column;padding:48px 0 64px;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .35s ease,transform .35s ease,visibility .35s}
.appview.is-active{opacity:1;visibility:visible;transform:none}
.av-bar{padding:2px 16px 10px;display:flex;flex-direction:column;gap:3px}
.av-bar-t{font-weight:800;font-size:1.16rem;color:var(--tinta);letter-spacing:-.01em}
.av-bar-loc{display:flex;align-items:center;gap:5px;font-size:.72rem;color:var(--acc-strong)}
.av-bar-loc svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
/* zona scrolleable, recortada a la pantalla (sin barra) */
.av-feed,.av-list,.av-agenda,.av-prof{flex:1;overflow-y:auto;padding:4px 16px 10px;scrollbar-width:none}
.av-feed::-webkit-scrollbar,.av-list::-webkit-scrollbar,.av-agenda::-webkit-scrollbar,.av-prof::-webkit-scrollbar{display:none}

/* EXPLORAR */
.av-card{background:#fff;border:1px solid var(--linea);border-radius:18px;overflow:hidden;margin-bottom:13px;box-shadow:0 9px 22px -16px rgba(40,20,10,.55)}
.av-photo{position:relative;height:104px;overflow:hidden;border-radius:18px 18px 0 0}
.av-img{display:block;width:100%;height:104px;object-fit:cover;border-radius:18px 18px 0 0}
.av-photo::after{content:"";position:absolute;inset:0;pointer-events:none;background:linear-gradient(180deg,rgba(10,14,20,.45),rgba(10,14,20,0) 40%,rgba(10,14,20,0) 68%,rgba(10,14,20,.30))}
.av-photo .av-chip{z-index:2}
.av-chip{position:absolute;top:8px;left:8px;font-size:.62rem;font-weight:700;padding:4px 9px;border-radius:999px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}
.av-chip-off{background:rgba(15,20,25,.82);color:#fff}
.av-chip-guest{background:rgba(255,255,255,.9);color:var(--tinta)}
.av-card-b{position:relative;padding:11px 13px 14px;min-height:44px}
.av-card-t{font-weight:700;font-size:.9rem;color:var(--tinta);padding-right:70px}
.av-card-m{font-size:.74rem;color:var(--gris);margin-top:2px;padding-right:70px}
.av-go{position:absolute;right:13px;bottom:12px;font-size:.72rem;font-weight:700;padding:6px 12px;border-radius:10px}
.av-go-coral{background:var(--acc);color:#fff}
.av-go-dark{background:var(--tinta);color:#fff}

/* CHATS */
.av-chat{display:flex;align-items:center;gap:11px;padding:11px 3px;border-bottom:1px solid var(--linea)}
.av-chat:last-child{border-bottom:0}
.av-ava{flex:none;width:42px;height:42px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:.8rem;color:#fff;letter-spacing:.02em}
.av-ava-coral{background:linear-gradient(135deg,#FF6B6B,#FF8E53)}
.av-ava-teal{background:linear-gradient(135deg,#2BBF9E,#1F9E8E)}
.av-ava-amber{background:linear-gradient(135deg,#F2A33C,#E5732B)}
.av-chat-b{flex:1;min-width:0}
.av-chat-t{font-weight:700;font-size:.85rem;color:var(--tinta);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.av-chat-m{font-size:.76rem;color:var(--gris);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-top:1px}
.av-chat-r{flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.av-chat-time{font-size:.64rem;color:var(--gris)}
.av-dot{width:8px;height:8px;border-radius:50%;background:var(--acc)}

/* ACTIVIDADES */
.av-day{font-size:.66rem;text-transform:uppercase;letter-spacing:.14em;color:var(--acc-strong);margin:8px 0 7px}
.av-item{display:flex;align-items:center;gap:11px;background:#fff;border:1px solid var(--linea);border-radius:14px;padding:11px 12px;margin-bottom:10px}
.av-time{flex:none;width:42px;font-size:.78rem;font-weight:700;color:var(--acc-strong)}
.av-item-b{flex:1;min-width:0}
.av-item-t{font-weight:700;font-size:.84rem;color:var(--tinta)}
.av-item-m{font-size:.72rem;color:var(--gris);margin-top:1px}
.av-going{flex:none;font-size:.66rem;font-weight:700;color:#0F6E56;background:#E1F5EE;padding:5px 10px;border-radius:9px}

/* PERFIL */
.av-prof{text-align:center;display:flex;flex-direction:column;align-items:center;padding-top:6px}
.av-prof-ava{width:74px;height:74px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-weight:700;font-size:1.5rem;color:#fff;background:linear-gradient(135deg,#FF6B6B,#FF8E53);box-shadow:0 12px 26px -12px rgba(214,90,48,.7)}
.av-prof-name{font-weight:800;font-size:1.08rem;color:var(--tinta);margin-top:12px}
.av-prof-loc{display:flex;align-items:center;gap:5px;font-size:.74rem;color:var(--gris);margin-top:4px}
.av-prof-loc svg{width:13px;height:13px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.av-prof-stats{display:flex;gap:8px;width:100%;margin:18px 0 14px}
.av-prof-stats div{flex:1;background:#fff;border:1px solid var(--linea);border-radius:13px;padding:11px 4px;display:flex;flex-direction:column;gap:2px}
.av-prof-stats b{font-size:1.12rem;color:var(--acc-strong);font-weight:800}
.av-prof-stats span{font-size:.64rem;color:var(--gris)}
.av-prof-badges{display:flex;flex-direction:column;gap:8px;width:100%}
.av-badge{display:flex;align-items:center;justify-content:center;gap:7px;font-size:.74rem;font-weight:600;color:var(--tinta);background:#fff;border:1px solid var(--linea);border-radius:11px;padding:9px}
.av-badge svg{width:15px;height:15px;stroke:#0F6E56;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.av-prof-edit{margin-top:14px;font-size:.78rem;font-weight:700;color:var(--acc-strong);border:1.5px solid var(--acc);border-radius:11px;padding:9px 18px}

/* --- barra de tabs inferior --- */
.apptabs{position:absolute;left:14px;right:14px;bottom:14px;height:54px;z-index:2;
  display:grid;grid-auto-flow:column;grid-auto-columns:1fr;          /* se adapta a 3 o 4 pestañas */
  background:rgba(255,255,255,.93);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-top:1px solid var(--linea);border-radius:0 0 30px 30px}
/* chip "en revisión" (ámbar) para tours sin avalar */
.av-chip-wait{background:rgba(255,244,229,.95);color:#9a5a12}
/* placeholder premium de los mockups: gradiente + icono (CERO fotos con gente) */
.av-ph{position:relative;height:104px;display:grid;place-items:center;overflow:hidden}
.av-ph svg{width:42px;height:42px;stroke:#fff;fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round;opacity:.95}
.av-ph-1{background:linear-gradient(135deg,#FF8E53,#FF5D7E)}
.av-ph-2{background:linear-gradient(135deg,#5DA8FF,#3060C0)}
.av-ph-3{background:linear-gradient(135deg,#9B7BFF,#6C49D8)}
.av-ph-4{background:linear-gradient(135deg,#2BC6A4,#129E86)}
.av-ph-5{background:linear-gradient(135deg,#F5A93C,#E36A22)}
/* stack de avatares "quién va" (iniciales) — toque de app real */
.av-stack{display:inline-flex;margin-top:10px;vertical-align:middle}
.av-stack i{width:21px;height:21px;border-radius:50%;display:grid;place-items:center;font-family:var(--mono);font-size:.55rem;font-weight:700;font-style:normal;color:#fff;border:1.5px solid #fff;margin-left:-7px}
.av-stack i:first-child{margin-left:0}
/* línea de reseñas (estrella) para listados del operador */
.av-rev{display:flex;align-items:center;gap:5px;font-size:.74rem;color:var(--gris);margin-top:4px}
.av-rev svg{width:13px;height:13px;fill:#F5A93C;stroke:none}
/* tarjetas de feed sin boton (vista hotel/operador): no reservar el hueco del CTA */
.av-card.no-cta .av-card-t,.av-card.no-cta .av-card-m{padding-right:0}
/* pantalla "Proponer" del operador (formulario mock) */
.av-compose{padding:4px 2px}
.av-field{margin-bottom:12px}
.av-field label{display:block;font-size:.7rem;font-weight:600;color:var(--gris);margin-bottom:5px}
.av-input{background:#fff;border:1px solid var(--linea);border-radius:11px;padding:11px 12px;font-size:.85rem;color:var(--tinta);font-weight:600}
.av-compose-cta{display:block;text-align:center;margin-top:4px;font-size:.8rem;font-weight:700;padding:12px;border-radius:11px;background:var(--acc);color:#fff}
.apptab{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:#9aa3ad;font-size:.58rem;font-weight:600;padding:0 2px;transition:color .2s}
.apptab svg{width:21px;height:21px;stroke-width:1.8;transition:transform .2s}
.apptab span{max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apptab.is-active{color:var(--acc-strong)}
.apptab.is-active svg{transform:translateY(-1px) scale(1.05)}

/* ============================================================
   FASE 5 · mundos vivos Hotel (azul noche) y Operador (verde)
   Mismo patrón que Viajero: cielo + parallax + glass + legibilidad.
   Lo compartido va agrupado; el cielo y los acentos, por mundo.
   ============================================================ */
#world-hotel,#world-operator{position:relative;z-index:0;background:transparent}
#world-hotel > section,#world-operator > section{position:relative;z-index:1}

/* cielos por mundo: bien presentes y distintos (texto blanco lee: el tope queda oscuro) */
/* HOTEL · azul noche de fiesta */
#world-hotel .world-bg{background:linear-gradient(168deg,#0a1c3e 0%,#1b4a8f 44%,#2f2a68 100%)}
#world-hotel .world-bg::before{background:
  radial-gradient(860px 580px at 82% -6%,rgba(255,176,90,.40),transparent 60%),
  radial-gradient(760px 540px at 12% 18%,rgba(255,93,143,.38),transparent 60%),
  radial-gradient(940px 640px at 50% 114%,rgba(93,184,255,.40),transparent 62%)}
/* OPERADOR · verde aire libre */
#world-operator .world-bg{background:linear-gradient(168deg,#0e5a37 0%,#1d8a53 46%,#34ab68 100%)}
#world-operator .world-bg::before{background:
  radial-gradient(900px 620px at 84% -8%,rgba(255,255,255,.40),transparent 60%),
  radial-gradient(700px 540px at 10% 16%,rgba(206,245,222,.42),transparent 60%),
  radial-gradient(860px 620px at 50% 112%,rgba(255,255,255,.30),transparent 62%)}
#world-operator .wb-cloud{opacity:.34}        /* nubes blancas más visibles → cielo aireado */
#world-operator .wb-bike{opacity:.42}
#world-operator .wb-grass{opacity:.82}

/* legibilidad: texto claro sobre el cielo */
#world-hotel .hero,#world-operator .hero{background:transparent}
#world-hotel .hero-copy h1,#world-operator .hero-copy h1,
#world-hotel .sec h2,#world-operator .sec h2{color:#fff}
#world-hotel .lede,#world-operator .lede{color:rgba(255,255,255,.9)}
#world-hotel .body,#world-operator .body{color:rgba(255,255,255,.88)}
#world-hotel .eyebrow,#world-operator .eyebrow{color:#fff;opacity:.92}
#world-hotel .flow-step h3,#world-operator .flow-step h3{color:#fff}
#world-hotel .flow-step p,#world-operator .flow-step p{color:rgba(255,255,255,.85)}
#world-hotel .sec-tint,#world-operator .sec-tint{background:transparent}
#world-operator .btn-ghost{border-color:rgba(255,255,255,.5);color:#fff}
#world-operator .badge{background:rgba(255,255,255,.2);color:#fff}
#world-hotel .hero .btn-primary,#world-operator .hero .btn-primary{background:#fff;box-shadow:0 12px 30px -10px rgba(0,0,0,.45)}
#world-hotel .hero .btn-primary{color:#15315a}
#world-operator .hero .btn-primary{color:#15663f}

/* glass: tarjetas translúcidas sobre el cielo (card, step, live-step, social) */
#world-hotel .card,#world-hotel .step,#world-hotel .live-step,#world-hotel .social-card,
#world-operator .card,#world-operator .step,#world-operator .live-step,#world-operator .social-card{
  background:rgba(255,255,255,.72);
  -webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.6);
  box-shadow:0 16px 42px -20px rgba(8,18,38,.62),inset 0 1px 0 rgba(255,255,255,.7)}
#world-hotel .card:hover,#world-hotel .step:hover,#world-hotel .live-step:hover,#world-hotel .social-card:hover,
#world-operator .card:hover,#world-operator .step:hover,#world-operator .live-step:hover,#world-operator .social-card:hover{
  transform:translateY(-6px);border-color:rgba(255,255,255,.92);
  box-shadow:0 28px 56px -20px rgba(8,28,58,.62),inset 0 1px 0 rgba(255,255,255,.85)}
#world-hotel .card h3,#world-hotel .step h3,#world-hotel .live-step h3,
#world-operator .card h3,#world-operator .step h3,#world-operator .live-step h3{color:var(--tinta)}
#world-hotel .card p,#world-hotel .step p,#world-operator .card p,#world-operator .step p{color:#46505c}
/* los acentos de las mini-escenas .ls-* (icono/nro/contador/boton) ya se tiñen por mundo
   via las variables de tema --acc-* (data-world): azul en Hotel, verde en Operador. */

/* ---------- responsive ---------- */
@media (max-width:920px){
  .hero-grid,.split{grid-template-columns:1fr;gap:40px}
  .grid4{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:1fr}
  .wb-cloud:nth-of-type(n+3){display:none}        /* menos nubes en mobile */
  #world-traveler .live-step{padding:20px 18px}
  .appframe{max-width:290px}
  /* mobile: sin blur (caro sobre fondo animado), glass más opaco → 60fps */
  #world-traveler .card,#world-traveler .live-step,#world-traveler .share-widget,#world-traveler .social-card{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(255,255,255,.92)}
  #world-hotel .card,#world-hotel .step,#world-hotel .live-step,#world-hotel .social-card,#world-operator .card,#world-operator .step,#world-operator .live-step,#world-operator .social-card{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(255,255,255,.92)}
  .flow{grid-template-columns:1fr;gap:30px}
  .flow-line{display:none}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .door-panels{flex-direction:column;height:auto}
  .panel{min-height:150px;justify-content:center;padding:22px 24px}
  .panel-icon{position:static;margin-bottom:10px;top:auto;left:auto;width:84px;height:84px}
  .panel-h .panel-icon{width:78px;height:78px}
  .fx-grass{height:52px}
  .fx-plane{transform:scale(1.6);transform-origin:50% 50%}   /* el avión (meet) achica en cards anchas-bajas; agrandalo aquí (1.5–1.8) */
  .panel-tag{opacity:.9;transform:none;min-height:0;max-width:38ch}   /* mobile: bajada visible y compacta (cards apiladas, sin reserva) */
  .panel:hover{flex:1}
  .hero{padding:calc(120px + env(safe-area-inset-top,0px)) 0 70px}
  .sec{padding:70px 0}
  .topnav{display:none!important}
}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .panel,.panel-tag,.btn,.card{transition:none}
  .panel::after{display:none}
  .appview{transition:opacity .2s ease;transform:none}   /* mockup: sin deslizamiento, solo fade corto */
  .apptab svg{transition:none}
  .social-card{animation:none}
}
