/* ===========================================================
   Decretando Disney — hoja de estilos
   Paleta de marca: azul #005DA8 · magenta #E42083
   =========================================================== */

@import url('https://fonts.googleapis.com/css2?family=Baloo+2:wght@500;600;700;800&family=Nunito:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&display=swap');

:root{
  --azul:#005DA8;
  --azul-deep:#0a1f5c;
  --azul-night:#050a2e;
  --magenta:#E42083;
  --magenta-soft:#ff5bb0;
  --aurora-1:#37e6c0;   /* verde-aqua */
  --aurora-2:#5b8cff;   /* azul */
  --aurora-3:#e44ea8;   /* magenta */
  --aurora-4:#a880ff;   /* violeta */
  --ink:#0a2a6e;
  --ink-soft:#2c448f;
  --glass:linear-gradient(165deg, rgba(255,224,243,.93), rgba(255,199,231,.86));
  --glass-line:rgba(255,255,255,.65);
  --font-display:'Baloo 2', system-ui, sans-serif;
  --font-body:'Nunito', system-ui, sans-serif;
  --aurora-intensity:1;
  --anim:1;
  --radius:22px;
  --shadow-soft:0 18px 50px -18px rgba(5,16,60,.55);
  --shadow-card:0 22px 60px -24px rgba(5,16,60,.45);
}

*{box-sizing:border-box;}
html,body{margin:0;padding:0;height:100%;}
body{
  font-family:var(--font-body);
  color:var(--ink);
  background:var(--azul-night);
  -webkit-font-smoothing:antialiased;
  overflow:hidden;
}
#root{height:100vh;width:100vw;position:relative;}

/* ---------- Fondo aurora (fijo, detrás de todo) ---------- */
.dd-sky{position:fixed;inset:0;z-index:0;overflow:hidden;background:
  radial-gradient(120% 90% at 50% -10%, #112a7a 0%, #0a1f5c 38%, #050a2e 78%);}
.dd-sky__glow{position:absolute;left:50%;bottom:-30%;width:130%;height:70%;transform:translateX(-50%);
  background:radial-gradient(60% 70% at 50% 100%, rgba(91,140,255,.35), transparent 70%);
  filter:blur(20px);}
.dd-aurora{position:absolute;inset:-15% -10% auto -10%;height:85%;
  filter:blur(48px);mix-blend-mode:screen;opacity:calc(.85*var(--aurora-intensity));
  pointer-events:none;}
.dd-aurora b{position:absolute;display:block;border-radius:50%;}
.dd-aurora .a1{left:2%;top:6%;width:46%;height:62%;
  background:radial-gradient(closest-side, var(--aurora-1), transparent 72%);
  animation:auroraDrift 16s ease-in-out infinite;}
.dd-aurora .a2{left:30%;top:-4%;width:52%;height:74%;
  background:radial-gradient(closest-side, var(--aurora-2), transparent 70%);
  animation:auroraDrift 22s ease-in-out infinite reverse;}
.dd-aurora .a3{right:4%;top:2%;width:44%;height:66%;
  background:radial-gradient(closest-side, var(--aurora-3), transparent 72%);
  animation:auroraDrift2 19s ease-in-out infinite;}
.dd-aurora .a4{left:18%;top:14%;width:40%;height:56%;
  background:radial-gradient(closest-side, var(--aurora-4), transparent 74%);
  animation:auroraDrift2 25s ease-in-out infinite reverse;}
.dd-aurora .curtain{left:8%;top:-8%;width:84%;height:96%;border-radius:0;
  background:repeating-linear-gradient(100deg,
     transparent 0 5%, rgba(55,230,192,.16) 6% 9%, transparent 10% 15%,
     rgba(168,128,255,.14) 16% 19%, transparent 20% 26%,
     rgba(228,78,168,.13) 27% 30%, transparent 31% 38%);
  -webkit-mask:linear-gradient(#000, transparent 78%);mask:linear-gradient(#000, transparent 78%);
  animation:curtainSway 14s ease-in-out infinite;}

@keyframes auroraDrift{
  0%,100%{transform:translate(0,0) scale(1);}
  33%{transform:translate(7%, -5%) scale(1.12);}
  66%{transform:translate(-6%, 4%) scale(.95);}
}
@keyframes auroraDrift2{
  0%,100%{transform:translate(0,0) scale(1.05);}
  50%{transform:translate(5%, 6%) scale(.9);}
}
@keyframes curtainSway{
  0%,100%{transform:translateX(0) skewX(0deg);opacity:.8;}
  50%{transform:translateX(-5%) skewX(-4deg);opacity:1;}
}

/* estrellas */
.dd-stars{position:absolute;inset:0;}
.dd-star{position:absolute;border-radius:50%;background:#fff;
  animation:twinkle var(--tw,4s) ease-in-out infinite;will-change:opacity,transform;}
@keyframes twinkle{0%,100%{opacity:.25;transform:scale(.8);}50%{opacity:1;transform:scale(1.2);}}
/* destellos brillantes (pixie dust) */
.dd-spark{position:absolute;color:#fff;pointer-events:none;
  filter:drop-shadow(0 0 6px rgba(255,255,255,.9));
  animation:floatUp var(--fl,12s) linear infinite;opacity:0;}
@keyframes floatUp{
  0%{transform:translateY(20px) scale(.4) rotate(0deg);opacity:0;}
  12%{opacity:.9;}
  88%{opacity:.7;}
  100%{transform:translateY(-90vh) scale(1) rotate(220deg);opacity:0;}
}
/* estrella fugaz */
.dd-shoot{position:absolute;width:2px;height:2px;background:#fff;border-radius:50%;
  box-shadow:0 0 0 1px rgba(255,255,255,.6);opacity:0;}
.dd-shoot::after{content:"";position:absolute;right:0;top:50%;width:140px;height:1.5px;
  transform:translateY(-50%);background:linear-gradient(90deg,transparent,#fff);}
@keyframes shoot{0%{opacity:0;transform:translate(0,0) rotate(18deg);}
  6%{opacity:1;}40%{opacity:1;}100%{opacity:0;transform:translate(420px,140px) rotate(18deg);}}

/* marca de agua del logo */
.dd-watermark{position:absolute;left:50%;top:80%;transform:translate(-50%,-50%);
  width:min(94vw,1040px);opacity:.06;pointer-events:none;
  filter:drop-shadow(0 0 30px rgba(91,140,255,.4));}

.dd-dim{position:absolute;inset:0;background:rgba(5,10,46,.42);opacity:0;transition:opacity .5s;}
.dd-dim.on{opacity:1;}

/* reduce animaciones */
.no-anim .dd-aurora b,.no-anim .dd-star,.no-anim .dd-spark,.no-anim .dd-shoot,.no-anim .curtain{animation:none !important;}
@media (prefers-reduced-motion: reduce){
  .dd-aurora b,.dd-star,.dd-spark,.dd-shoot{animation-duration:0.001ms !important;animation-iteration-count:1 !important;}
}

/* =================== Header =================== */
.dd-header{position:fixed;top:0;left:0;right:0;z-index:40;display:flex;align-items:center;
  justify-content:space-between;gap:16px;padding:16px clamp(16px,4vw,40px);
  background:linear-gradient(180deg, rgba(5,12,46,.55), rgba(5,12,46,0));
  backdrop-filter:blur(2px);}
.dd-navleft{display:flex;align-items:center;gap:10px;}
.dd-navbtn{font-family:var(--font-display);font-weight:600;font-size:clamp(15px,1.5vw,18px);
  color:#fff;background:rgba(255,255,255,.12);border:1.5px solid rgba(255,255,255,.28);
  padding:10px 20px;border-radius:999px;cursor:pointer;letter-spacing:.2px;
  transition:transform .18s, background .18s, border-color .18s, box-shadow .18s;
  display:inline-flex;align-items:center;gap:9px;backdrop-filter:blur(6px);}
.dd-navbtn:hover{background:rgba(255,255,255,.22);transform:translateY(-2px);
  box-shadow:0 10px 24px -10px rgba(0,0,0,.5);}
.dd-navbtn.menu{background:linear-gradient(120deg,var(--magenta),var(--magenta-soft));
  border-color:transparent;box-shadow:0 10px 26px -10px rgba(228,32,131,.8);}
.dd-navbtn.menu:hover{filter:brightness(1.06);}
.dd-brandmini{display:flex;align-items:center;gap:10px;cursor:pointer;}
.dd-brandmini img{height:38px;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.4));}
.dd-home{width:50px;height:50px;border-radius:16px;display:grid;place-items:center;cursor:pointer;
  background:rgba(255,255,255,.14);border:1.5px solid rgba(255,255,255,.3);
  transition:transform .18s, background .18s;backdrop-filter:blur(6px);}
.dd-home:hover{background:#fff;transform:translateY(-2px) scale(1.04);}
.dd-home:hover svg{stroke:var(--azul);}
.dd-home svg{stroke:#fff;}

/* =================== Menú lateral =================== */
.dd-scrim{position:fixed;inset:0;z-index:50;background:rgba(5,10,40,.5);
  opacity:0;pointer-events:none;transition:opacity .35s;backdrop-filter:blur(1px);}
.dd-scrim.open{opacity:1;pointer-events:auto;}
.dd-drawer{position:fixed;top:0;left:0;bottom:0;z-index:60;width:min(86vw,380px);
  background:linear-gradient(170deg, #0b2470, #0a1746 70%);
  border-right:1px solid rgba(255,255,255,.12);
  box-shadow:30px 0 80px -30px rgba(0,0,0,.7);
  transform:translateX(-104%);transition:transform .42s cubic-bezier(.22,1,.36,1);
  display:flex;flex-direction:column;overflow:hidden;}
.dd-drawer.open{transform:translateX(0);}
.dd-drawer__head{padding:24px 24px 14px;display:flex;align-items:center;justify-content:space-between;}
.dd-drawer__head h3{font-family:var(--font-display);color:#fff;margin:0;font-size:22px;font-weight:700;}
.dd-drawer__head .sub{color:#9db4e8;font-size:13px;margin-top:2px;font-weight:600;letter-spacing:.3px;}
.dd-x{width:38px;height:38px;border-radius:50%;border:none;cursor:pointer;color:#fff;
  background:rgba(255,255,255,.12);font-size:20px;display:grid;place-items:center;transition:background .2s;}
.dd-x:hover{background:rgba(255,255,255,.24);}
.dd-cats{padding:8px 14px 24px;overflow-y:auto;display:flex;flex-direction:column;gap:8px;}
.dd-cat{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 16px;border-radius:16px;cursor:pointer;border:1px solid transparent;
  background:rgba(255,255,255,.04);transition:background .2s, transform .2s, border-color .2s;}
.dd-cat:hover{background:rgba(255,255,255,.12);transform:translateX(4px);border-color:rgba(255,255,255,.18);}
.dd-cat__txt .n{font-family:var(--font-display);color:#fff;font-weight:600;font-size:18px;line-height:1.15;}
.dd-cat__txt .num{color:var(--magenta-soft);font-weight:700;font-size:12px;letter-spacing:1px;}
.dd-cat__icon{width:52px;height:52px;flex:0 0 auto;display:grid;place-items:center;
  background:rgba(255,255,255,.08);border-radius:14px;}
.dd-cat:hover .dd-cat__icon{background:rgba(255,255,255,.16);}

/* =================== Capa de pantallas =================== */
.dd-screen{position:absolute;inset:0;z-index:10;overflow-y:auto;overflow-x:hidden;
  padding:96px clamp(16px,5vw,64px) 64px;animation:screenIn .5s cubic-bezier(.22,1,.36,1);}
@keyframes screenIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:none;}}
.dd-wrap{max-width:1120px;margin:0 auto;}

/* ----- Inicio ----- */
.dd-hero{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;
  text-align:center;padding:120px 24px 80px;position:relative;z-index:10;}
.dd-hero::before{content:"";position:absolute;left:50%;top:46%;transform:translate(-50%,-50%);
  width:min(96vw,940px);height:min(86vh,760px);z-index:0;pointer-events:none;
  background:radial-gradient(ellipse 60% 50% at 50% 50%, rgba(5,11,42,.72), rgba(5,11,42,.45) 42%, transparent 72%);
  filter:blur(8px);}
.dd-hero > *{position:relative;z-index:1;}
.dd-hero img.logo{width:min(74vw,500px);filter:drop-shadow(0 10px 34px rgba(0,0,0,.55)) drop-shadow(0 0 18px rgba(255,255,255,.25));
  animation:floaty 6s ease-in-out infinite;}
@keyframes floaty{0%,100%{transform:translateY(0);}50%{transform:translateY(-10px);}}
.dd-hero .kicker{margin-top:30px;color:#bcd0ff;font-weight:700;letter-spacing:3px;
  text-transform:uppercase;font-size:clamp(12px,1.4vw,15px);}
.dd-hero h1{font-family:var(--font-display);color:#fff;font-weight:800;
  font-size:clamp(34px,6vw,72px);line-height:1.02;margin:14px 0 0;max-width:14ch;
  text-shadow:0 6px 30px rgba(0,0,0,.35);}
.dd-hero h1 em{font-style:normal;color:var(--magenta-soft);
  text-shadow:0 0 28px rgba(255,91,176,.55);}
.dd-hero p.lead{color:#dce6ff;font-size:clamp(16px,2vw,21px);max-width:46ch;margin:22px auto 0;
  line-height:1.55;font-weight:500;}
.dd-cta{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap;justify-content:center;}
.btn{font-family:var(--font-display);font-weight:700;font-size:clamp(16px,1.7vw,19px);
  border:none;cursor:pointer;border-radius:999px;padding:16px 34px;transition:transform .18s, box-shadow .18s, filter .18s;
  display:inline-flex;align-items:center;gap:10px;}
.btn-primary{background:linear-gradient(120deg,var(--magenta),var(--magenta-soft));color:#fff;
  box-shadow:0 16px 40px -14px rgba(228,32,131,.85);}
.btn-primary:hover{transform:translateY(-3px);filter:brightness(1.05);box-shadow:0 22px 48px -16px rgba(228,32,131,.95);}
.btn-ghost{background:rgba(255,255,255,.14);color:#fff;border:1.5px solid rgba(255,255,255,.35);backdrop-filter:blur(6px);}
.btn-ghost:hover{background:rgba(255,255,255,.24);transform:translateY(-3px);}
.btn-blue{background:linear-gradient(120deg,var(--azul),#2a86d8);color:#fff;box-shadow:0 16px 40px -14px rgba(0,93,168,.8);}
.btn-blue:hover{transform:translateY(-3px);filter:brightness(1.07);}
.dd-scrollhint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:#9db4e8;
  font-size:13px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;
  display:flex;flex-direction:column;align-items:center;gap:6px;animation:bob 2.2s ease-in-out infinite;}
@keyframes bob{0%,100%{transform:translate(-50%,0);}50%{transform:translate(-50%,8px);}}

/* mini-categorías en home */
.dd-homecats{margin-top:8px;width:100%;}
.dd-homecats h2{font-family:var(--font-display);color:#fff;text-align:center;font-size:clamp(24px,3.4vw,38px);
  font-weight:700;margin:0 0 6px;}
.dd-homecats .sub{text-align:center;color:#cdd9ff;font-size:16px;margin:0 0 30px;font-weight:500;}
.dd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:18px;}
.dd-chip{position:relative;cursor:pointer;border-radius:20px;overflow:hidden;padding:22px 20px;min-height:150px;
  display:flex;flex-direction:column;justify-content:flex-end;gap:6px;
  background:linear-gradient(160deg, rgba(255,255,255,.16), rgba(255,255,255,.05));
  border:1px solid rgba(255,255,255,.2);transition:transform .2s, box-shadow .2s, background .2s;}
.dd-chip:hover{transform:translateY(-5px);background:linear-gradient(160deg, rgba(255,255,255,.26), rgba(255,255,255,.08));
  box-shadow:var(--shadow-soft);}
.dd-chip .ic{position:absolute;right:12px;top:12px;opacity:.85;}
.dd-chip .nm{font-family:var(--font-display);color:#fff;font-weight:700;font-size:20px;line-height:1.1;z-index:1;
  text-shadow:0 0 12px rgba(255,91,176,.55);}
.dd-chip .tg{color:#d7e2ff;font-size:13px;font-weight:600;z-index:1;}

/* =================== Tarjetas frosted (pantallas internas) =================== */
.dd-card{background:var(--glass);border:1px solid var(--glass-line);border-radius:var(--radius);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  box-shadow:0 22px 60px -24px rgba(228,32,131,.45), inset 0 0 30px rgba(255,255,255,.25);}
.dd-eyebrow{display:inline-flex;align-items:center;gap:9px;color:#fff;font-weight:800;
  letter-spacing:2px;text-transform:uppercase;font-size:13px;
  background:rgba(228,32,131,.9);padding:7px 16px;border-radius:999px;box-shadow:0 8px 22px -10px rgba(228,32,131,.9);}
.dd-pagetitle{font-family:var(--font-display);color:#fff;font-weight:800;
  font-size:clamp(30px,5vw,56px);line-height:1.04;margin:18px 0 0;text-shadow:0 6px 26px rgba(0,0,0,.35);}
.dd-pagelead{color:#dce6ff;font-size:clamp(16px,1.9vw,20px);max-width:52ch;margin:14px 0 0;line-height:1.55;font-weight:500;}

/* Nosotros */
.dd-about{margin-top:34px;display:grid;grid-template-columns:1.3fr 1fr;gap:24px;align-items:start;}
.dd-about__text{padding:34px clamp(24px,3vw,40px);}
.dd-about__text p{color:var(--ink-soft);font-size:17px;line-height:1.7;margin:0 0 16px;}
.dd-about__text p:last-child{margin-bottom:0;font-family:var(--font-display);font-weight:700;
  color:var(--azul);font-size:19px;line-height:1.5;}
/* foto del equipo */
.dd-photocard{overflow:hidden;padding:0;position:relative;}
.dd-photocard img{width:100%;display:block;}
.dd-photocard .tag{position:absolute;left:14px;bottom:14px;font-family:var(--font-display);font-weight:700;
  color:#fff;font-size:15px;background:linear-gradient(120deg,var(--magenta),var(--magenta-soft));
  padding:7px 16px;border-radius:999px;box-shadow:0 10px 26px -10px rgba(228,32,131,.9);
  text-shadow:0 0 10px rgba(255,255,255,.4);}
.dd-values{display:flex;flex-direction:column;gap:14px;}
.dd-value{padding:22px 24px;display:flex;gap:16px;align-items:flex-start;}
.dd-value .dot{flex:0 0 auto;width:44px;height:44px;border-radius:13px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--azul),#2a86d8);color:#fff;}
.dd-value h4{font-family:var(--font-display);margin:0 0 3px;color:var(--ink);font-size:18px;font-weight:700;}
.dd-value p{margin:0;color:var(--ink-soft);font-size:15px;line-height:1.5;}

/* Contacto */
.dd-contact{margin-top:34px;display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px;}
.dd-contact__item{padding:30px 28px;display:flex;flex-direction:column;gap:14px;}
.dd-contact__item .lbl{display:flex;align-items:center;gap:12px;color:var(--azul);font-family:var(--font-display);
  font-weight:700;font-size:19px;}
.dd-contact__item .lbl .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;
  background:rgba(0,93,168,.1);}
.dd-contact a,.dd-contact .val{color:var(--ink);text-decoration:none;font-size:17px;font-weight:600;
  transition:color .15s;word-break:break-word;}
.dd-contact a:hover{color:var(--magenta);}
.dd-contact .muted{color:var(--ink-soft);font-size:14px;font-weight:600;}

/* =================== Lista de destinos =================== */
.dd-dests{margin-top:34px;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px;}
.dd-dest{cursor:pointer;border-radius:var(--radius);overflow:hidden;
  background:linear-gradient(165deg, rgba(96,52,178,.52), rgba(228,32,131,.34));
  border:1px solid rgba(255,255,255,.32);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);
  box-shadow:0 22px 60px -24px rgba(228,32,131,.55), inset 0 0 34px rgba(255,255,255,.08);
  transition:transform .22s, box-shadow .22s, background .22s;display:flex;flex-direction:column;}
.dd-dest:hover{transform:translateY(-6px);
  background:linear-gradient(165deg, rgba(116,66,205,.6), rgba(244,52,151,.42));
  box-shadow:0 30px 70px -26px rgba(255,91,176,.7), inset 0 0 40px rgba(255,255,255,.12);}
.dd-dest__img{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:rgba(10,22,70,.45);}
.dd-dest__img image-slot{width:100%;height:100%;display:block;}
.dd-photo{width:100%;height:100%;object-fit:cover;display:block;}
.dd-dest:hover .dd-dest__img image-slot,.dd-dest:hover .dd-dest__img .dd-photo{transform:scale(1.04);transition:transform .4s;}
.dd-dest__badge{position:absolute;left:12px;top:12px;z-index:2;background:rgba(255,255,255,.18);
  border:1px solid rgba(255,255,255,.45);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  color:#fff;font-weight:800;font-size:11px;letter-spacing:1px;text-transform:uppercase;
  text-shadow:0 0 10px rgba(255,255,255,.6);padding:5px 12px;border-radius:999px;}
.dd-dest__body{padding:18px 20px 20px;display:flex;flex-direction:column;gap:6px;flex:1;}
.dd-dest__body h3{font-family:var(--font-display);margin:0;color:#fff;font-size:21px;font-weight:700;
  text-shadow:0 0 10px rgba(255,91,176,.95), 0 0 26px rgba(255,91,176,.6), 0 0 52px rgba(168,128,255,.5);}
.dd-dest__body p{margin:0;color:#eee0ff;font-size:14.5px;line-height:1.5;flex:1;}
.dd-dest__more{margin-top:6px;color:#ff9bd0;font-weight:800;font-size:14px;display:inline-flex;align-items:center;gap:7px;
  text-shadow:0 0 14px rgba(255,91,176,.8);}
.dd-dest:hover .dd-dest__more{gap:11px;}
.dd-dest__more svg{transition:transform .2s;}

/* =================== Detalle de destino =================== */
.dd-detail{margin-top:8px;}
.dd-detailhero{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-card);
  min-height:clamp(280px,46vh,440px);display:flex;align-items:flex-end;}
.dd-detailhero image-slot{position:absolute;inset:0;width:100%;height:100%;}
.dd-detailhero .dd-detailhero__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;}
.dd-detailhero .veil{position:absolute;inset:0;background:linear-gradient(0deg, rgba(7,16,50,.86) 4%, rgba(7,16,50,.15) 55%, rgba(7,16,50,.35));}
.dd-detailhero .cap{position:relative;z-index:2;padding:clamp(24px,4vw,44px);}
.dd-detailhero .cap .crumb{color:#bcd0ff;font-weight:700;font-size:14px;letter-spacing:.5px;
  display:inline-flex;align-items:center;gap:8px;cursor:pointer;}
.dd-detailhero .cap .crumb:hover{color:#fff;}
.dd-detailhero .cap h1{font-family:var(--font-display);color:#fff;font-weight:800;margin:10px 0 0;
  font-size:clamp(30px,5.2vw,58px);line-height:1.02;text-shadow:0 6px 26px rgba(0,0,0,.4);}
.dd-detailbody{margin-top:22px;display:grid;grid-template-columns:1.5fr .9fr;gap:22px;align-items:start;}
.dd-detailbody .prose{padding:32px clamp(24px,3vw,40px);}
.dd-detailbody .prose h2{font-family:var(--font-display);color:var(--ink);font-size:24px;margin:0 0 12px;font-weight:700;}
.dd-detailbody .prose p{color:var(--ink-soft);font-size:17.5px;line-height:1.75;margin:0;}
.dd-reservebox{padding:28px;position:sticky;top:96px;text-align:center;}
.dd-reservebox .price-note{color:var(--ink-soft);font-size:14px;font-weight:600;margin:0 0 6px;}
.dd-reservebox h3{font-family:var(--font-display);color:var(--ink);font-size:22px;margin:0 0 4px;font-weight:700;}
.dd-reservebox p{color:var(--ink-soft);font-size:14.5px;line-height:1.5;margin:8px 0 18px;}
.dd-reservebox .btn{width:100%;justify-content:center;}
.dd-reservebar{position:sticky;bottom:0;z-index:20;margin-top:26px;display:none;}

/* =================== Formulario de reserva =================== */
.dd-form{margin-top:30px;display:grid;grid-template-columns:1fr;gap:0;}
.dd-formcard{padding:clamp(26px,4vw,46px);}
.dd-form h2{font-family:var(--font-display);color:var(--ink);font-size:clamp(22px,3vw,30px);margin:0 0 4px;font-weight:700;}
.dd-form .formsub{color:var(--ink-soft);font-size:16px;margin:0 0 26px;line-height:1.5;}
.dd-fieldgrid{display:grid;grid-template-columns:1fr 1fr;gap:18px;}
.dd-field{display:flex;flex-direction:column;gap:7px;}
.dd-field.full{grid-column:1/-1;}
.dd-field label{font-weight:700;color:var(--ink);font-size:14.5px;}
.dd-field label .req{color:var(--magenta);}
.dd-field input,.dd-field textarea{font-family:var(--font-body);font-size:16px;color:var(--ink);
  padding:14px 16px;border-radius:14px;border:1.6px solid rgba(0,93,168,.25);background:rgba(255,255,255,.8);outline:none;
  transition:border-color .18s, box-shadow .18s;width:100%;}
.dd-field input:focus,.dd-field textarea:focus{border-color:var(--azul);box-shadow:0 0 0 4px rgba(0,93,168,.12);}
.dd-field input.err,.dd-field textarea.err{border-color:var(--magenta);box-shadow:0 0 0 4px rgba(228,32,131,.1);}
.dd-field .hint{color:#c2185b;font-size:12.5px;font-weight:600;min-height:0;}
.dd-field textarea{resize:vertical;min-height:96px;}
.dd-formfoot{margin-top:26px;display:flex;align-items:center;gap:16px;flex-wrap:wrap;}
.dd-formfoot .note{color:var(--ink-soft);font-size:13px;flex:1;min-width:200px;line-height:1.5;}
.dd-summary{background:rgba(0,93,168,.06);border:1px solid rgba(0,93,168,.16);border-radius:16px;
  padding:14px 18px;margin-bottom:24px;display:flex;align-items:center;gap:12px;color:var(--azul);font-weight:700;font-size:15px;}

/* éxito */
.dd-success{text-align:center;padding:clamp(32px,5vw,56px);}
.dd-success .ring{width:96px;height:96px;border-radius:50%;margin:0 auto 22px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--aurora-1),#2bb89a);box-shadow:0 18px 40px -14px rgba(43,184,154,.7);
  animation:pop .5s cubic-bezier(.34,1.56,.64,1);}
@keyframes pop{0%{transform:scale(.4);opacity:0;}100%{transform:scale(1);opacity:1;}}
.dd-success h2{font-family:var(--font-display);color:var(--ink);font-size:28px;margin:0 0 8px;font-weight:800;}
.dd-success p{color:var(--ink-soft);font-size:16.5px;line-height:1.6;max-width:44ch;margin:0 auto 24px;}

/* =================== Video de destino =================== */
.dd-videowrap{margin-top:24px;}
.dd-videotitle{font-family:var(--font-display);color:#fff;font-weight:700;font-size:clamp(22px,3vw,30px);
  margin:0 0 14px;text-shadow:0 0 12px rgba(255,91,176,.9), 0 0 32px rgba(168,128,255,.6);}
.dd-video{width:100%;display:block;border-radius:var(--radius);border:1px solid rgba(255,255,255,.3);
  box-shadow:0 22px 60px -24px rgba(228,32,131,.55);background:#05082a;}

/* tarjetas neón (detalle de destino) */
.dd-card.dd-cardneon{background:linear-gradient(165deg, rgba(96,52,178,.52), rgba(228,32,131,.34));
  border:1px solid rgba(255,255,255,.32);
  box-shadow:0 22px 60px -24px rgba(228,32,131,.55), inset 0 0 34px rgba(255,255,255,.08);}
.dd-card.dd-cardneon :is(h2,h3){color:#fff;
  text-shadow:0 0 10px rgba(255,91,176,.95), 0 0 26px rgba(255,91,176,.6), 0 0 52px rgba(168,128,255,.5);}
.dd-card.dd-cardneon p{color:#eee0ff;}

/* botón de música */
.dd-music{position:fixed;left:18px;bottom:18px;z-index:46;width:56px;height:56px;border-radius:50%;
  border:1.5px solid rgba(255,255,255,.45);cursor:pointer;display:grid;place-items:center;padding:0;
  background:linear-gradient(135deg, rgba(96,52,178,.9), rgba(228,32,131,.8));
  box-shadow:0 10px 30px -8px rgba(228,32,131,.8), 0 0 24px rgba(168,128,255,.55);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  transition:transform .2s, filter .2s, background .2s, box-shadow .2s;animation:musicPulse 3s ease-in-out infinite;}
.dd-music:hover{transform:scale(1.1);filter:brightness(1.12);}
.dd-music svg{filter:drop-shadow(0 0 6px rgba(255,255,255,.75));}
.dd-music.off{background:rgba(13,25,80,.8);box-shadow:0 8px 22px -8px rgba(0,0,0,.6);animation:none;}
@keyframes musicPulse{0%,100%{box-shadow:0 10px 30px -8px rgba(228,32,131,.8), 0 0 24px rgba(168,128,255,.55);}
  50%{box-shadow:0 10px 30px -8px rgba(228,32,131,.95), 0 0 38px rgba(168,128,255,.85);}}
.no-anim .dd-music{animation:none;}

/* videos destacados en inicio */
.dd-videoshome{margin-top:54px;}
.dd-videogrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(420px,100%),1fr));gap:22px;}
.dd-vcard{position:relative;border-radius:var(--radius);overflow:hidden;cursor:pointer;
  border:1px solid rgba(255,255,255,.3);box-shadow:0 22px 60px -24px rgba(228,32,131,.55);
  transition:transform .22s, box-shadow .22s;background:#05082a;}
.dd-vcard:hover{transform:translateY(-6px);box-shadow:0 30px 70px -26px rgba(255,91,176,.75), 0 0 30px rgba(168,128,255,.4);}
.dd-vcard video{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;}
.dd-vcard .cap{position:absolute;left:0;right:0;bottom:0;padding:20px 22px;
  background:linear-gradient(0deg, rgba(7,16,50,.88), rgba(7,16,50,.25) 70%, transparent);
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;}
.dd-vcard .cap h3{font-family:var(--font-display);color:#fff;margin:0;font-size:clamp(19px,2.2vw,24px);font-weight:700;
  text-shadow:0 0 10px rgba(255,91,176,.95), 0 0 26px rgba(255,91,176,.6);}
.dd-vcard .cap .go{flex:0 0 auto;color:#fff;font-weight:800;font-size:13px;letter-spacing:.6px;text-transform:uppercase;
  background:linear-gradient(120deg,var(--magenta),var(--magenta-soft));padding:9px 16px;border-radius:999px;
  box-shadow:0 10px 26px -10px rgba(228,32,131,.9);}

/* testimonios */
.dd-testis{margin-top:54px;}
.dd-testigrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(300px,100%),1fr));gap:20px;}
.dd-testi{padding:24px 24px 20px;display:flex;flex-direction:column;gap:12px;}
.dd-testi .stars{color:#ffd76a;letter-spacing:3.5px;font-size:16px;
  text-shadow:0 0 10px rgba(255,215,106,.85), 0 0 24px rgba(255,180,60,.5);}
.dd-testi blockquote{margin:0;color:#eee0ff;font-size:15.5px;line-height:1.65;flex:1;}
.dd-testi .who{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.dd-testi .nm{color:#fff;font-weight:800;font-size:15px;text-shadow:0 0 12px rgba(255,91,176,.6);}
.dd-testi .src{font-size:11px;font-weight:800;letter-spacing:.8px;text-transform:uppercase;color:#fff;
  background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.32);padding:5px 13px;border-radius:999px;}

/* =================== Mickey 3D =================== */
.dd-mickey3d{margin-top:54px;}
.dd-mickeywrap{position:relative;width:min(480px,92vw);height:430px;margin:0 auto;}
.dd-mickeyglow{position:absolute;left:50%;top:56%;transform:translate(-50%,-50%);width:78%;height:70%;
  border-radius:50%;pointer-events:none;filter:blur(22px);
  background:radial-gradient(circle, rgba(228,32,131,.4), rgba(96,52,178,.25) 55%, transparent 78%);
  animation:mickeyGlow 4s ease-in-out infinite;}
@keyframes mickeyGlow{0%,100%{opacity:.65;}50%{opacity:1;}}
.no-anim .dd-mickeyglow{animation:none;}
.dd-mickeywrap model-viewer{position:relative;z-index:1;width:100%;height:100%;
  background:transparent;--poster-color:transparent;cursor:grab;}
/* vida: flote/respiración constante */
.dd-mickeybob{width:100%;height:100%;animation:mickeyBob 3.2s ease-in-out infinite;transform-origin:50% 85%;}
@keyframes mickeyBob{0%,100%{transform:translateY(0);}50%{transform:translateY(-8px);}}
.no-anim .dd-mickeybob{animation:none;}
.dd-mickeywrap model-viewer:active{cursor:grabbing;}
.dd-mickeywrap model-viewer.jump{animation:mickeyJump .75s cubic-bezier(.3,1.8,.4,1);}
@keyframes mickeyJump{0%{transform:translateY(0) scale(1);}35%{transform:translateY(-30px) scale(1.05);}
  65%{transform:translateY(5px) scale(.97);}100%{transform:translateY(0) scale(1);}}
.dd-mickeybubble{position:absolute;left:50%;top:2px;transform:translateX(-50%);z-index:3;
  font-family:var(--font-display);font-weight:700;color:#fff;font-size:21px;white-space:nowrap;
  background:linear-gradient(120deg,var(--magenta),var(--magenta-soft));padding:10px 22px;border-radius:999px;
  box-shadow:0 12px 30px -10px rgba(228,32,131,.9), 0 0 26px rgba(255,91,176,.5);
  animation:bubblePop 1.9s cubic-bezier(.3,1.6,.4,1) forwards;pointer-events:none;}
@keyframes bubblePop{0%{opacity:0;transform:translateX(-50%) scale(.4);}
  12%{opacity:1;transform:translateX(-50%) scale(1.06);}20%{transform:translateX(-50%) scale(1);}
  80%{opacity:1;}100%{opacity:0;transform:translateX(-50%) translateY(-14px) scale(.92);}}
.dd-spark{position:absolute;left:50%;top:52%;z-index:2;border-radius:50%;pointer-events:none;
  animation:sparkFly .95s ease-out forwards;}
@keyframes sparkFly{0%{opacity:1;transform:translate(-50%,-50%) scale(.4);}
  100%{opacity:0;transform:translate(calc(-50% + var(--dx)), calc(-50% + var(--dy))) scale(1);}}

/* back link genérico */
.dd-back{display:inline-flex;align-items:center;gap:9px;color:#cdd9ff;font-weight:700;font-size:15px;
  cursor:pointer;background:none;border:none;font-family:var(--font-body);margin-bottom:4px;transition:color .15s,gap .15s;}
.dd-back:hover{color:#fff;gap:13px;}

/* ===== responsive ===== */
@media (max-width:860px){
  .dd-about{grid-template-columns:1fr;}
  .dd-detailbody{grid-template-columns:1fr;}
  .dd-reservebox{position:static;}
  .dd-reservebar{display:block;}
  .dd-navbtn{padding:9px 15px;font-size:14px;}
  .dd-navbtn .lbl-full{display:none;}
}
@media (max-width:560px){
  .dd-fieldgrid{grid-template-columns:1fr;}
  .dd-brandmini{display:none;}
  .dd-navleft{gap:7px;}
  .dd-navbtn{padding:9px 13px;}
}

/* scrollbar */
.dd-screen::-webkit-scrollbar,.dd-cats::-webkit-scrollbar{width:10px;}
.dd-screen::-webkit-scrollbar-thumb{background:rgba(255,255,255,.25);border-radius:10px;}
.dd-cats::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:10px;}
