/* ════════════════════════════════════════════════════════
   CHIGNAHUAPAN PUEBLO MÁGICO · Estilos compartidos
   by Skyframe
   ════════════════════════════════════════════════════════ */
:root{
  --rosa:#EC0A82;--rojo:#F0183A;--naranja:#F7941D;--amarillo:#FBB200;
  --verde:#5FB924;--turquesa:#00A6C8;--azul:#1CA9DD;--purpura:#7C2D8E;
  --tinta:#241D38;--soft:#5d5570;--papel:#FFFDF8;--crema:#FFF4EC;--linea:#ece3d9;
  --rainbow:linear-gradient(90deg,#EC0A82,#F0183A,#F7941D,#FBB200,#5FB924,#00A6C8,#7C2D8E);
  --dark1:#1e1530;--dark2:#2a1c44;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'Figtree',system-ui,sans-serif;color:var(--tinta);background:var(--papel);-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
section{scroll-margin-top:74px}
.wrap{max-width:1140px;margin:0 auto;padding:0 28px}
.block{padding:72px 0}
.ey{font-family:'Oswald';letter-spacing:.22em;text-transform:uppercase;font-size:11.5px;color:var(--c,#EC0A82);display:flex;align-items:center;gap:10px}
.ey::before{content:"";width:28px;height:3px;border-radius:3px;background:var(--c,#EC0A82)}
.h2{font-family:'Fraunces';font-weight:900;font-size:clamp(26px,4vw,40px);line-height:1.04;letter-spacing:-.01em;margin:13px 0 0}
.lead{font-size:15.5px;line-height:1.65;color:var(--soft);max-width:60ch;margin-top:12px}
.btn{font-family:'Oswald';font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:13.5px;padding:13px 24px;border-radius:999px;transition:.18s;cursor:pointer;border:2px solid transparent;display:inline-flex;align-items:center;gap:8px}
.btn-rosa{background:var(--rosa);color:#fff;border-color:var(--rosa)}.btn-rosa:hover{filter:brightness(1.08);transform:translateY(-2px)}
.btn-amar{background:var(--amarillo);color:var(--tinta);border-color:var(--amarillo)}.btn-amar:hover{filter:brightness(1.06);transform:translateY(-2px)}
.btn-out{border-color:currentColor;background:transparent}.btn-out:hover{background:rgba(255,255,255,.12)}
.btn-dark{background:var(--tinta);color:#fff;border-color:var(--tinta)}.btn-dark:hover{filter:brightness(1.2);transform:translateY(-2px)}

/* ───── NAV (compartido) ───── */
.nav{position:sticky;top:0;z-index:300;display:flex;align-items:center;gap:14px;padding:11px 28px;background:rgba(255,253,248,.92);backdrop-filter:blur(14px);border-bottom:1px solid var(--linea);transition:.25s}
.nav.solid{box-shadow:0 6px 28px rgba(36,29,56,.09)}
.nav .brand{display:flex;align-items:center;gap:10px;font-family:'Fraunces';font-weight:900;font-size:17px;position:relative;padding:4px 8px;border-radius:12px;transition:background .18s}
.nav .brand:hover{background:rgba(236,10,130,.07)}
.nav .brand img{width:34px;height:34px;transition:transform .8s cubic-bezier(.34,1.56,.64,1)}
.nav .brand:hover img{transform:rotate(180deg)}
.nav .brand .bt{display:flex;flex-direction:column;line-height:1}
.nav .brand .bt small{font-family:'Oswald';font-weight:500;letter-spacing:.14em;text-transform:uppercase;font-size:8.5px;color:var(--rosa);margin-top:2px}
.nav .brand .home-ico{font-size:13px;color:var(--rosa);opacity:.85}
.nav .links{display:flex;gap:6px;margin-left:auto;font-family:'Oswald';letter-spacing:.05em;text-transform:uppercase;font-size:12px;align-items:center}
.nav .links a{color:var(--soft);transition:transform .18s cubic-bezier(.34,1.56,.64,1),background .18s,color .18s,box-shadow .18s;padding:8px 13px;border-radius:11px;position:relative;transform-origin:bottom center;font-weight:500}
.nav .links a.activo{color:var(--rosa);font-weight:700}
.nav .links a:hover{color:#fff;background:var(--dc,var(--rosa));transform:translateY(-5px) scale(1.12);box-shadow:0 8px 20px color-mix(in srgb,var(--dc,var(--rosa)) 45%,transparent)}
.nav .links a:nth-child(1){--dc:var(--azul)}
.nav .links a:nth-child(2){--dc:var(--naranja)}
.nav .links a:nth-child(3){--dc:var(--amarillo)}
.nav .links a:nth-child(4){--dc:var(--verde)}
.nav .links a:nth-child(5){--dc:var(--purpura)}
.nav .links a:nth-child(6){--dc:var(--turquesa)}
.nav .links a:nth-child(7){--dc:var(--rojo)}
.nav .ncta{font-family:'Oswald';font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-size:12px;background:var(--rainbow);background-size:200% auto;color:#fff;padding:10px 18px;border-radius:999px;animation:shine 4s linear infinite;box-shadow:0 4px 14px rgba(236,10,130,.3)}
.nav .ncta:hover{transform:translateY(-2px) scale(1.04)}
@keyframes shine{to{background-position:200% center}}
.burger{display:none;margin-left:auto;background:none;border:none;font-size:22px;cursor:pointer;color:var(--tinta)}

/* ───── PAGE HERO (páginas internas) ───── */
.page-hero{position:relative;overflow:hidden;color:#fff;padding:64px 0 56px;background:linear-gradient(135deg,var(--ph1,#EC0A82),var(--ph2,#7C2D8E))}
.page-hero .reh-bg{position:absolute;width:420px;right:-110px;top:-90px;opacity:.12;animation:spin 80s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.page-hero .inner{position:relative;z-index:1}
.page-hero .crumb{font-family:'Oswald';letter-spacing:.16em;text-transform:uppercase;font-size:11px;color:rgba(255,255,255,.7);margin-bottom:12px}
.page-hero .crumb a:hover{color:#fff}
.page-hero h1{font-family:'Fraunces';font-weight:900;font-size:clamp(32px,5.5vw,52px);line-height:1;letter-spacing:-.02em;text-shadow:0 4px 14px rgba(0,0,0,.2)}
.page-hero p{font-size:16px;line-height:1.6;color:rgba(255,255,255,.92);max-width:56ch;margin-top:14px}
.page-hero .rb{height:7px;background:var(--rainbow);position:absolute;bottom:0;left:0;right:0}

/* ───── DIRECTORIO (tarjetas hospedaje/resto/activ) ───── */
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;margin-bottom:8px}
.filtro{font-family:'Oswald';letter-spacing:.06em;text-transform:uppercase;font-size:12px;padding:8px 16px;border-radius:999px;border:1.5px solid var(--linea);color:var(--soft);cursor:pointer;transition:.18s;background:#fff}
.filtro.on{background:var(--c,var(--rosa));border-color:var(--c,var(--rosa));color:#fff;font-weight:600}
.filtro:hover:not(.on){border-color:var(--c,var(--rosa));color:var(--c,var(--rosa))}
.dir-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px}
.dir-card{border-radius:18px;background:#fff;border:1.5px solid var(--linea);overflow:hidden;transition:.2s;display:flex;flex-direction:column}
.dir-card:hover{transform:translateY(-5px);box-shadow:0 16px 40px rgba(36,29,56,.12);border-color:var(--c)}
.dir-card .top-bar{height:5px;background:var(--c)}
.dir-card .img-slot{height:180px;background:linear-gradient(135deg,color-mix(in srgb,var(--c) 15%,#fff),color-mix(in srgb,var(--c) 7%,#fff));display:flex;align-items:center;justify-content:center;font-size:46px;position:relative;overflow:hidden}
.dir-card .img-slot img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.dir-card .badge-top{position:absolute;top:12px;left:12px;font-family:'Oswald';letter-spacing:.08em;text-transform:uppercase;font-size:9px;background:var(--c);color:#fff;padding:4px 10px;border-radius:999px;z-index:2}
.dir-card .body{padding:18px 18px 20px;flex:1;display:flex;flex-direction:column}
.dir-card .tipo{font-family:'Oswald';letter-spacing:.12em;text-transform:uppercase;font-size:9.5px;color:var(--c);margin-bottom:6px}
.dir-card h3{font-family:'Fraunces';font-weight:700;font-size:19px;line-height:1.15}
.dir-card .stars{color:var(--amarillo);font-size:13px;margin-top:5px;letter-spacing:1px}
.dir-card p{font-size:13px;line-height:1.5;color:var(--soft);margin-top:8px;flex:1}
.dir-card .actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.acbtn{font-family:'Oswald';font-weight:600;letter-spacing:.05em;text-transform:uppercase;font-size:11px;padding:8px 13px;border-radius:999px;transition:.16s;display:inline-flex;align-items:center;gap:6px;border:none;cursor:pointer}
.acbtn-c{background:var(--c);color:#fff}.acbtn-c:hover{filter:brightness(1.1)}
.acbtn-w{background:#25D366;color:#fff}.acbtn-w:hover{filter:brightness(1.08)}
.acbtn-o{background:transparent;border:1.5px solid var(--linea);color:var(--soft)}.acbtn-o:hover{border-color:var(--c);color:var(--c)}
.acbtn-air{background:#FF5A5F;color:#fff}.acbtn-air:hover{filter:brightness(1.08)}
.acbtn-book{background:#003580;color:#fff}.acbtn-book:hover{filter:brightness(1.15)}
.acbtn-exp{background:#FFC72C;color:#1a1a2e}.acbtn-exp:hover{filter:brightness(1.05)}
.dir-card.slot{border-style:dashed;border-color:#d4c9e2}
.dir-card.slot .img-slot{background:rgba(124,45,142,.06)}
.dir-card.slot h3{color:var(--soft)}

/* ───── FOOTER (compartido) ───── */
.foot{background:var(--tinta);color:#fff;padding:52px 28px 28px}
.foot-top{max-width:1140px;margin:0 auto;display:grid;grid-template-columns:1.3fr 1fr 1fr;gap:36px}
.foot-brand .logo{display:flex;align-items:center;gap:11px;margin-bottom:12px}
.foot-brand .logo img{width:44px;height:44px}
.foot-brand .logo .t{font-family:'Fraunces';font-weight:900;font-size:19px;line-height:1.1}
.foot-brand .logo .t span{display:block;font-family:'Oswald';font-weight:400;letter-spacing:.18em;text-transform:uppercase;font-size:9.5px;color:#b9add0;margin-top:2px}
.foot-brand p{font-size:13px;line-height:1.6;color:#9d93ae}
.foot-links h4,.foot-contact h4{font-family:'Oswald';letter-spacing:.16em;text-transform:uppercase;font-size:11px;color:#b9add0;margin-bottom:14px}
.foot-links ul{list-style:none;display:flex;flex-direction:column;gap:9px}
.foot-links ul a{font-size:14px;color:#d3c9e2;transition:.15s}.foot-links ul a:hover{color:var(--rosa)}
.foot-contact .item{display:flex;align-items:center;gap:9px;font-size:13.5px;color:#d3c9e2;margin-bottom:10px}
.foot-contact .item a{color:var(--amarillo);font-weight:600}
.foot-social{max-width:1140px;margin:28px auto 0;padding-top:22px;border-top:1px solid rgba(255,255,255,.1);display:flex;flex-wrap:wrap;gap:10px;align-items:center;justify-content:space-between}
.foot-social .icons{display:flex;gap:10px;flex-wrap:wrap}
.fsoc{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);display:flex;align-items:center;justify-content:center;color:#d3c9e2;transition:.16s}
.fsoc:hover{background:var(--rc,var(--rosa));color:#fff;border-color:transparent;transform:translateY(-3px)}
.fsoc svg{width:22px;height:22px}
.foot-bottom{max-width:1140px;margin:20px auto 0;padding-top:18px;border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px}
.foot-bottom .legal{font-size:11.5px;color:#7d7393;line-height:1.5}
.foot-bottom .sky{font-family:'Oswald';letter-spacing:.18em;text-transform:uppercase;font-size:10.5px;color:#b9add0}
.foot-bottom .sky b{color:var(--rosa)}
.mx-logo{height:24px;width:auto;opacity:.8;margin-top:14px}

/* ───── RESPONSIVE compartido ───── */
@media(max-width:960px){.dir-grid{grid-template-columns:repeat(2,1fr)}.foot-top{grid-template-columns:1fr 1fr}}
@media(max-width:720px){
  .nav .links,.nav .ncta{display:none}
  .nav.open .links{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--papel);border-bottom:1px solid var(--linea);padding:8px 0;z-index:300}
  .nav.open .links a{padding:12px 28px}
  .nav.open .ncta{display:block;margin:8px 28px}
  .burger{display:block}
  .dir-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr}
}
@media(prefers-reduced-motion:reduce){*{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}
