/* ===== HOME Baricentro — sistema + secciones ===== */
:root{
  --r-md:12px; --r-lg:16px; --r-xl:20px;
  --sh-sm:0 2px 8px rgba(0,0,0,.08); --sh-md:0 6px 20px rgba(0,0,0,.10); --sh-lg:0 16px 40px rgba(0,0,0,.14);
  --sp-section:84px;
}
main{display:block}
.reveal{opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:none}
.center{text-align:center}
.sec-head.center{text-align:center;margin-bottom:26px}

/* ===== BENTO ===== */
.bento-wrap{max-width:var(--maxw);margin:0 auto;padding:28px 16px 8px}
.bento{display:grid;grid-template-columns:minmax(300px,344px) 1fr 1fr;grid-template-rows:1.8fr 1fr;gap:16px;height:640px}
.bento-card{position:relative;overflow:hidden;border-radius:var(--r-xl);cursor:pointer;display:block;
  background:#ddd;box-shadow:var(--sh-sm)}
.bento-card .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s ease}
.bento-card .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.72) 0%,rgba(0,0,0,.05) 58%)}
.bento-card:hover .bg{transform:scale(1.05)}
.bento-card .inner{position:absolute;inset:0;padding:18px;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;color:#fff}
.bento-card .pill{align-self:flex-start;font-size:.66rem;font-weight:800;text-transform:uppercase;letter-spacing:.06em;
  padding:5px 11px;border-radius:999px;color:#fff}
.bento-card h3{font-weight:800;line-height:1.08;letter-spacing:-.01em;font-size:1.05rem;text-shadow:0 1px 6px rgba(0,0,0,.3)}
.bento-card.big h3{font-size:1.9rem;max-width:14ch}
.bento-card .cta{align-self:flex-start;margin-top:6px;background:#fff;color:var(--brand-bright);font-weight:700;
  font-size:.82rem;padding:9px 18px;border-radius:999px}
.bento-card.big{grid-column:1;grid-row:1/3}      /* reel vertical 9:16 */
.bento-card:nth-child(2){grid-column:2;grid-row:1}
.bento-card:nth-child(3){grid-column:3;grid-row:1}
.bento-card:nth-child(4){grid-column:2;grid-row:2}
.bento-card:nth-child(5){grid-column:3;grid-row:2}

/* reel estilo Instagram (casilla grande) */
.reel{overflow:hidden}
.reel-bars{position:absolute;top:11px;left:13px;right:13px;z-index:6;display:flex;gap:5px}
.reel-bar{flex:1;height:3px;background:rgba(255,255,255,.38);border-radius:3px;overflow:hidden}
.reel-bar .fill{display:block;height:100%;width:0;background:#fff;border-radius:3px}
.reel-stage{position:absolute;inset:0}
.reel-slide{position:absolute;inset:0;opacity:0;transition:opacity .45s ease}
.reel-slide.on{opacity:1}
.reel-slide:not(.on) .inner{opacity:0;transition:opacity .15s ease}
.reel-media{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background-size:cover;background-position:center}
.reel-slide .inner{position:absolute;inset:0;padding:20px 18px 18px;display:flex;flex-direction:column;justify-content:flex-end;gap:8px;color:#fff;z-index:2}
.reel-zone{position:absolute;top:24px;bottom:0;width:36%;background:none;border:none;z-index:4;cursor:pointer}
.reel-zone.prev{left:0}
.reel-zone.next{right:0}

/* celdas funcionales (cine / club / agenda) */
.celda .inner{justify-content:space-between}
.celda-ic{font-size:1.5rem;align-self:flex-start;background:rgba(255,255,255,.2);width:42px;height:42px;border-radius:12px;display:grid;place-items:center}
.celda h3{font-size:1.02rem}
.celda-sub{font-size:.8rem;opacity:.85;font-weight:500;margin-top:2px}

/* estado del centro (abierto/cerrado automático) */
.estado{background:#fff;box-shadow:var(--sh-sm)}
.estado .inner{color:var(--text);justify-content:space-between}
.estado .estado-dot{width:14px;height:14px;border-radius:50%;align-self:flex-start}
.estado.abierto .estado-dot{background:#3fbf5a;animation:pulse-dot 1.8s infinite}
.estado.cerrado .estado-dot{background:#c2c2c2}
.estado-label{font-size:.72rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;display:block}
.estado.abierto .estado-label{color:#3fbf5a}
.estado.cerrado .estado-label{color:#999}
.estado h3{font-size:1.15rem;margin-top:1px}
.estado .celda-sub{color:var(--muted);opacity:1}
@keyframes pulse-dot{0%{box-shadow:0 0 0 0 rgba(63,191,90,.5)}70%{box-shadow:0 0 0 9px rgba(63,191,90,0)}100%{box-shadow:0 0 0 0 rgba(63,191,90,0)}}

/* ===== ACCESOS DIRECTOS ===== */
.accesos{background:var(--surface);margin-top:24px}
.accesos-inner{max-width:var(--maxw);margin:0 auto;padding:30px 16px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.acc{display:flex;flex-direction:column;align-items:center;gap:12px;background:#fff;border-radius:var(--r-lg);
  padding:26px 10px;box-shadow:var(--sh-sm);transition:transform .18s,box-shadow .18s;font-weight:700;font-size:.95rem;color:var(--text)}
.acc:hover{transform:translateY(-3px);box-shadow:var(--sh-md)}
.acc-ic{width:58px;height:58px;display:grid;place-items:center;transition:transform .2s}
.acc-ic img{width:100%;height:100%;object-fit:contain}
.acc:hover .acc-ic{transform:translateY(-2px) scale(1.06)}

/* ===== PROMOS / NOVEDADES ===== */
.promos{max-width:var(--maxw);margin:0 auto;padding:var(--sp-section) 16px 60px}
.promos h2{font-size:clamp(2rem,4vw,3rem);font-weight:800;color:var(--brand-bright);letter-spacing:-.01em}
.promos h2::after{content:"";display:block;width:min(440px,64%);height:2px;background:rgba(232,51,78,.35);margin:13px auto 2px}
.tabs{display:inline-flex;gap:4px;margin-top:16px;background:var(--surface);padding:5px;border-radius:999px}
.tab{padding:8px 20px;border-radius:999px;font-weight:700;font-size:.9rem;color:var(--muted);transition:.15s}
.tab.on{background:var(--brand-bright);color:#fff}
.promos-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin:26px 0 30px}
.promo-card{position:relative;aspect-ratio:3/4;border-radius:var(--r-xl);overflow:hidden;cursor:pointer;box-shadow:var(--sh-sm)}
.promo-card.big{grid-column:span 2;aspect-ratio:auto}
.promo-card .bg{position:absolute;inset:0;background-size:cover;background-position:center;transition:transform .5s}
.promo-card:hover .bg{transform:scale(1.05)}
.promo-card .ov{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.7),transparent 55%)}
.promo-card .inner{position:absolute;inset:0;padding:15px;display:flex;flex-direction:column;justify-content:flex-end;color:#fff}
.promo-card .tienda{align-self:flex-start;margin-bottom:auto;background:rgba(255,255,255,.92);color:#222;font-size:.7rem;font-weight:700;
  padding:4px 10px;border-radius:999px}
.promo-card h4{font-size:1rem;font-weight:800;line-height:1.12;text-shadow:0 1px 6px rgba(0,0,0,.35)}
.promo-card .fecha{font-size:.72rem;opacity:.85;margin-top:3px}
.btn-outline{display:inline-block;border:1.5px solid var(--brand-bright);color:var(--brand-bright);font-weight:700;
  padding:12px 26px;border-radius:999px;transition:.15s}
.btn-outline:hover{background:var(--brand-bright);color:#fff}

/* ===== migas + PÁGINA PROMOCIONES ===== */
.breadcrumb{max-width:var(--maxw);margin:0 auto 18px;font-size:.82rem;color:var(--muted)}
.breadcrumb a{color:var(--muted)}
.breadcrumb a:hover{color:var(--brand-bright)}
.breadcrumb span{color:var(--text);font-weight:600}
.promos-page{max-width:var(--maxw);margin:0 auto;padding:26px 16px 80px}
.promos-page .sec-head{margin-bottom:14px}
.promos-page .breadcrumb{padding:0}
.promo-toolbar{display:flex;flex-direction:column;align-items:center;gap:11px;margin:16px 0 24px}
.promo-toolbar .chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.promos-page .promos-grid{margin:4px 0 0}
.promo-card .promo-logo{position:absolute;top:12px;left:12px;z-index:3;width:56px;height:38px;background:#fff;border-radius:9px;
  background-size:76%;background-position:center;background-repeat:no-repeat;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.promos-empty{text-align:center;color:var(--muted);padding:50px 0}
@media(max-width:900px){.promos-page .promos-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:560px){.promos-page .promos-grid{grid-template-columns:1fr 1fr}}

/* ===== FICHA DE PROMOCIÓN ===== */
.volver{display:inline-block;font-size:.85rem;font-weight:600;color:var(--brand-bright);margin-bottom:20px}
.volver:hover{text-decoration:underline}
.promo-ficha{display:grid;grid-template-columns:1.12fr 1fr;gap:40px;align-items:start;margin-bottom:44px}
.pf-img{position:relative;aspect-ratio:4/3;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-md)}
.pf-img-logo{position:absolute;top:16px;left:16px;width:84px;height:50px;background:#fff;border-radius:10px;background-size:78%;background-position:center;background-repeat:no-repeat;box-shadow:0 3px 10px rgba(0,0,0,.22)}
.pf-body{padding-top:22px}
.pf-badge{display:inline-block;font-size:.74rem;font-weight:800;text-transform:uppercase;letter-spacing:.05em;color:var(--brand-bright)}
.pf-body h1{font-size:clamp(1.7rem,3.2vw,2.5rem);font-weight:800;letter-spacing:-.02em;margin:6px 0 14px}
.pf-fecha{display:inline-block;background:var(--brand-bright);color:#fff;font-weight:700;font-size:.85rem;padding:8px 16px;border-radius:999px;margin-bottom:18px}
.pf-text{color:#555;line-height:1.7}
.pf-text p{margin-bottom:12px}
.pf-main .btn-primary{margin-top:8px}
.pf-side .fp-card{text-align:left}
.pf-side .fp-logo{height:84px;background-position:left center;margin-bottom:16px}
.pf-side .fp-logo.ph{width:84px;border-radius:16px;place-items:center}
.pf-tienda-desc{color:#555;font-size:.92rem;line-height:1.6;margin-bottom:18px}
.pf-side .fp-meta{grid-template-columns:1fr 1fr;margin-bottom:16px}
.pf-side .fp-redes{margin-top:4px}
@media(max-width:820px){.promo-ficha{grid-template-columns:1fr;gap:26px}}

/* ===== PÁGINA PLANO DEL CENTRO ===== */
.plano-page{max-width:var(--maxw);margin:0 auto;padding:26px 16px 70px}
.plano-page .sec-head{margin-bottom:6px}
.plano-find{position:relative;max-width:460px;margin:16px auto 22px}
.plano-find .search{max-width:none}
.plano-suges{position:absolute;top:calc(100% + 6px);left:0;right:0;z-index:30;list-style:none;background:#fff;
  border:1px solid var(--line);border-radius:14px;box-shadow:0 12px 30px rgba(0,0,0,.15);overflow:hidden;max-height:320px;overflow-y:auto}
.plano-suges li{padding:11px 16px;font-size:.92rem;font-weight:600;cursor:pointer;border-bottom:1px solid var(--line)}
.plano-suges li:last-child{border-bottom:none}
.plano-suges li:hover{background:var(--surface);color:var(--brand-bright)}
.plano-suges li span{color:var(--muted);font-weight:500;font-size:.82rem}

/* ===== PÁGINAS DE INFO (Horarios · Servicios · Contacto) ===== */
.info-page{max-width:var(--maxw);margin:0 auto;padding:26px 16px 70px}
.info-page .sec-head{margin-bottom:24px}
/* horarios */
.hor-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-bottom:34px}
.hor-col{background:var(--surface);border-radius:16px;padding:22px 20px}
.hor-col h3{font-size:1.05rem;font-weight:800;color:var(--brand-bright);margin-bottom:10px}
.hor-b{font-weight:700;font-size:.92rem;margin-top:12px}
.hor-col p{font-size:.9rem;color:#555;line-height:1.5}
.hor-col .btn-outline{padding:9px 18px;font-size:.82rem}
.hor-foto{position:relative;border-radius:20px;overflow:hidden;min-height:300px;display:grid;place-items:center;text-align:center;background:linear-gradient(135deg,#0b1719,#1a2e30)}
.hor-foto-ov{position:absolute;inset:0;background:radial-gradient(circle at 50% 40%,rgba(255,37,91,.28),transparent 60%)}
.hor-foto-logo{position:relative;width:64px;filter:brightness(0) invert(1);opacity:.95;margin-bottom:12px}
.hor-foto-txt{position:relative;color:#fff}
.hor-foto-txt h3{font-size:1.8rem;font-weight:800}
.hor-foto-txt p{color:rgba(255,255,255,.8);font-size:1.1rem}
@media(max-width:860px){.hor-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.hor-grid{grid-template-columns:1fr}}
/* servicios */
.serv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.serv-card{display:flex;gap:14px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--sh-sm)}
.serv-ic{font-size:1.6rem;flex:none;width:48px;height:48px;display:grid;place-items:center;background:var(--surface);border-radius:12px}
.serv-card h3{font-size:1rem;font-weight:700;margin-bottom:4px}
.serv-card p{font-size:.86rem;color:#666;line-height:1.5}
@media(max-width:820px){.serv-grid{grid-template-columns:1fr 1fr}}
@media(max-width:520px){.serv-grid{grid-template-columns:1fr}}
/* contacto */
.contacto-grid{display:grid;grid-template-columns:1fr 1.2fr;gap:40px;align-items:start}
.cont-block{margin-bottom:22px}
.cont-block h4{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;color:var(--brand-bright);font-weight:800;margin-bottom:5px}
.cont-block p{font-size:1rem;color:var(--text);line-height:1.5}
.cont-block a{color:var(--text)}
.cont-block a:hover{color:var(--brand-bright)}
.cont-link{display:inline-block;margin-top:6px;color:var(--brand-bright)!important;font-weight:600;font-size:.9rem}
.cont-form{background:var(--surface);border-radius:18px;padding:26px}
.cont-form h3{font-size:1.3rem;font-weight:800;margin-bottom:16px}
.cont-form label{display:block;font-size:.85rem;font-weight:600;margin-bottom:13px}
.cont-form input,.cont-form textarea{width:100%;margin-top:5px;padding:11px 14px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:.95rem;background:#fff;color:var(--text)}
.cont-form input:focus,.cont-form textarea:focus{outline:2px solid var(--brand-bright);border-color:transparent}
.cont-check{display:flex;align-items:flex-start;gap:8px;font-weight:500;font-size:.82rem;color:#666}
.cont-check input{width:auto;margin-top:2px}
.cont-form .btn-primary{margin-top:6px;border:none;cursor:pointer;font-size:.95rem}
.cont-nota{font-size:.78rem;color:var(--muted);margin-top:10px}
@media(max-width:780px){.contacto-grid{grid-template-columns:1fr;gap:26px}}

/* ===== PLANO CTA ===== */
.plano-cta{position:relative;margin-top:30px;min-height:360px;display:grid;place-items:center;text-align:center;
  background:#1b1b1b url('assets/plano-bg.jpg') center/cover;color:#fff;overflow:hidden}
.plano-overlay{position:absolute;inset:0;background:rgba(0,0,0,.58)}
.plano-content{position:relative;max-width:600px;padding:50px 20px}
.plano-logo{filter:brightness(0) invert(1);margin:0 auto 14px}
.plano-content h2{font-size:clamp(1.8rem,3.4vw,2.6rem);font-weight:800;letter-spacing:-.02em}
.plano-content p{color:rgba(255,255,255,.8);margin:12px auto 24px;max-width:44ch}

/* ===== CENTRO DIFERENTE ===== */
.diferente{max-width:var(--maxw);margin:0 auto;padding:var(--sp-section) 16px;display:grid;grid-template-columns:1.2fr 1fr;gap:48px;align-items:center}
.dif-text .kicker{text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;font-weight:800;color:var(--brand-bright)}
.dif-text h2{font-size:clamp(2rem,3.6vw,2.8rem);font-weight:800;letter-spacing:-.02em;margin:8px 0 18px}
.dif-list{list-style:none;display:flex;flex-direction:column;gap:13px;margin-bottom:26px}
.dif-list li{position:relative;padding-left:22px;color:#444;font-size:1.02rem}
.dif-list li::before{content:"";position:absolute;left:0;top:9px;width:9px;height:9px;border-radius:50%;background:var(--brand-bright)}
.dif-img{aspect-ratio:4/3;border-radius:var(--r-xl);background:linear-gradient(135deg,#ffd9e2,#ffb3c6);box-shadow:var(--sh-md)}

/* ===== 3 COLUMNAS ===== */
.tres-col{background:var(--surface)}
.tres-col{display:grid;grid-template-columns:repeat(3,1fr);gap:36px;max-width:var(--maxw);margin:0 auto;padding:72px 16px}
.tres-col article{position:relative}
.tres-col .num{font-size:3.4rem;font-weight:800;color:var(--brand-bright);line-height:1;display:block;margin-bottom:8px}
.tres-col h3{font-size:1.25rem;font-weight:700;margin-bottom:7px}
.tres-col p{color:var(--muted);font-size:.95rem;max-width:34ch}

/* ===== FOOTER ===== */
.site-footer{background:#1e1e1e;color:rgba(255,255,255,.72)}
.footer-grid{max-width:var(--maxw);margin:0 auto;padding:54px 16px 30px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1.3fr;gap:36px}
.foot-col h4{color:#fff;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;font-weight:700;margin-bottom:16px}
.foot-col a{display:block;padding:5px 0;font-size:.9rem;color:rgba(255,255,255,.7);transition:.15s}
.foot-col a:hover{color:#fff}
.foot-brand img{filter:brightness(0) invert(1);margin-bottom:14px}
.foot-brand p{font-size:.85rem;line-height:1.7;margin-bottom:14px}
.btn-ghost{color:#fff;font-weight:600;font-size:.85rem;border:1px solid rgba(255,255,255,.4);border-radius:999px;padding:8px 16px;display:inline-block}
.btn-ghost:hover{background:#fff;color:#1e1e1e}
.social{display:flex;gap:9px;margin-bottom:18px}
.social a{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);color:#fff;display:grid;place-items:center;font-size:.72rem;font-weight:700;padding:0}
.social a:hover{background:var(--brand-bright)}
.news-label{font-size:.85rem;margin-bottom:8px}
.news{display:flex;background:rgba(255,255,255,.1);border-radius:999px;overflow:hidden;max-width:280px}
.news input{flex:1;border:none;background:none;outline:none;color:#fff;padding:10px 14px;font-size:.85rem}
.news input::placeholder{color:rgba(255,255,255,.5)}
.news button{background:var(--brand-bright);color:#fff;border:none;padding:0 16px;font-weight:700;font-size:.82rem;cursor:pointer}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:16px;display:flex;justify-content:space-between;
  max-width:var(--maxw);margin:0 auto;font-size:.78rem;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:8px}
.footer-bottom a{color:rgba(255,255,255,.6)}
.footer-bottom a:hover{color:#fff}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .bento{grid-template-columns:1fr 1fr;grid-template-rows:none;grid-auto-rows:minmax(150px,auto);height:auto}
  .bento-card.big{grid-column:1/3;grid-row:auto;aspect-ratio:9/16;max-width:380px;width:100%;justify-self:center}
  .bento-card:nth-child(2){grid-column:1;grid-row:auto}
  .bento-card:nth-child(3){grid-column:2;grid-row:auto}
  .bento-card:nth-child(4){grid-column:1;grid-row:auto}
  .bento-card:nth-child(5){grid-column:2;grid-row:auto}
  .accesos-inner{grid-template-columns:repeat(4,1fr)}
  .promos-grid{grid-template-columns:repeat(3,1fr)}
  .diferente{grid-template-columns:1fr;gap:28px}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .bento{grid-template-columns:1fr 1fr;grid-template-rows:none;grid-auto-rows:minmax(130px,auto);gap:12px}
  .bento-card.big{grid-column:1/3;grid-row:auto;aspect-ratio:9/16;max-width:none}
  .bento-card:nth-child(2),.bento-card:nth-child(3),.bento-card:nth-child(4),.bento-card:nth-child(5){grid-column:auto;grid-row:auto;aspect-ratio:1/1}
  .accesos-inner{grid-template-columns:repeat(2,1fr)}
  .promos-grid{grid-template-columns:1fr 1fr}
  .promo-card.big{grid-column:span 2}
  .tres-col{grid-template-columns:1fr;gap:24px}
  .footer-grid{grid-template-columns:1fr}
}
