/* ================================================================
   La Queretana — styles.css
   Hoja de estilos principal. Variables en :root para theming dinámico.
   ================================================================ */

:root {
  --rosa:         #e8216e;
  --rosa-claro:   #f7628b;
  --dorado:       #c9933a;
  --dorado-claro: #f0c060;
  --madera:       #2a1a0e;
  --madera-medio: #3d2410;
  --madera-claro: #5c3820;
  --crema:        #fdf6ee;
  --blanco:       #fff9f4;
  --acento:       #e8216e;
}

/* ── RESET & BASE ─────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html  { scroll-behavior:smooth; }
body  { font-family:'Nunito',sans-serif; background:var(--crema); color:var(--madera); overflow-x:hidden; }
img   { max-width:100%; display:block; }

/* ── TIPOGRAFÍA ───────────────────────────────────────────────── */
.t-pacifico { font-family:'Pacifico',cursive; }
.t-playfair { font-family:'Playfair Display',serif; }

/* ── ANIMACIONES GLOBALES ─────────────────────────────────────── */
@keyframes float    { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
@keyframes slideUp  { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
@keyframes marquee  { from{transform:translateX(0)} to{transform:translateX(-50%)} }
@keyframes nudge    { 0%,100%{transform:rotate(0)} 25%{transform:rotate(-8deg)} 75%{transform:rotate(8deg)} }
@keyframes fadeIn   { from{opacity:0} to{opacity:1} }
@keyframes popIn    { from{opacity:0;transform:scale(0.85)} to{opacity:1;transform:scale(1)} }

.reveal { opacity:0; transform:translateY(24px); transition:opacity .6s ease,transform .6s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ── BANNER DE TEMPORADA ──────────────────────────────────────── */
#bannerTemporada {
  position:relative; z-index:101; overflow:hidden;
  height:38px; align-items:center;
  background:var(--rosa);
  display:flex; /* js lo oculta/muestra */
}
.banner-inner {
  display:flex; white-space:nowrap;
  animation:marquee 22s linear infinite;
}
.banner-item {
  font-size:0.82rem; font-weight:700; color:#fff;
  padding:0 1.5rem; letter-spacing:0.04em;
}
#bannerTemporada:hover .banner-inner { animation-play-state:paused; }

/* ── NAV ──────────────────────────────────────────────────────── */
nav {
  position:fixed; top:0; left:0; right:0; z-index:100;
  background:rgba(42,26,14,0.93);
  backdrop-filter:blur(12px); -webkit-backdrop-filter:blur(12px);
  display:flex; align-items:center; justify-content:space-between;
  padding:0.75rem 1.5rem;
  border-bottom:1px solid rgba(201,147,58,0.22);
}
.nav-logo {
  font-family:'Pacifico',cursive; font-size:1.35rem;
  color:var(--dorado-claro); text-decoration:none; flex-shrink:0;
}

/* Links en desktop */
#navMenu {
  display:flex; gap:1.2rem; list-style:none;
  align-items:center;
}
#navMenu a {
  color:rgba(253,246,238,0.72); text-decoration:none;
  font-size:0.85rem; font-weight:600;
  transition:color .2s;
  white-space:nowrap;
}
#navMenu a:hover { color:var(--dorado-claro); }

/* Hamburguesa */
.hamburger {
  display:none; flex-direction:column; gap:5px;
  background:none; border:none; cursor:pointer; padding:4px;
  z-index:110;
}
.hamburger span {
  display:block; width:24px; height:2px;
  background:var(--dorado-claro); border-radius:2px;
  transition:transform .3s, opacity .3s;
}
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

@media (max-width:700px) {
  .hamburger { display:flex; }
  #navMenu {
    position:fixed; top:0; right:-100%; width:72vw; max-width:280px;
    height:100vh; flex-direction:column; gap:0; list-style:none;
    background:rgba(22,12,4,0.98); backdrop-filter:blur(16px);
    padding:5rem 2rem 2rem; border-left:1px solid rgba(201,147,58,0.2);
    transition:right .32s cubic-bezier(.4,0,.2,1); z-index:105;
    align-items:flex-start;
  }
  #navMenu.open { right:0; }
  #navMenu li { width:100%; }
  #navMenu a {
    display:block; padding:0.9rem 0; font-size:1rem;
    border-bottom:1px solid rgba(201,147,58,0.1);
    color:rgba(253,246,238,0.85);
  }
  #navMenu a:hover { color:var(--dorado-claro); padding-left:0.5rem; transition:padding .2s; }
}

/* ── PAPEL PICADO ─────────────────────────────────────────────── */
.papel-picado-top {
  width:100%; height:34px; background:var(--rosa);
  position:relative; overflow:hidden;
}
.papel-picado-top::after {
  content:''; position:absolute; bottom:0; left:0; width:100%; height:100%;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='34'%3E%3Cpath d='M0 0 L30 34 L60 0 Z' fill='%23fdf6ee'/%3E%3C/svg%3E") repeat-x bottom;
}
.papel-picado-dorado { width:100%; height:34px; background:var(--dorado); position:relative; overflow:hidden; }
.papel-picado-dorado::after {
  content:''; position:absolute; bottom:0; left:0; width:100%; height:100%;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='60' height='34'%3E%3Cpath d='M0 0 L30 34 L60 0 Z' fill='%232a1a0e'/%3E%3C/svg%3E") repeat-x bottom;
}

/* ── HERO ─────────────────────────────────────────────────────── */
.hero {
  background:var(--madera);
  background-image:
    radial-gradient(ellipse at 20% 50%,rgba(201,147,58,.18) 0%,transparent 60%),
    radial-gradient(ellipse at 80% 20%,rgba(232,33,110,.12) 0%,transparent 50%);
  min-height:100vh; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
  text-align:center; padding:6rem 2rem 3rem;
  position:relative; overflow:hidden;
}
.hero-mascota { font-size:4rem; margin-bottom:1rem; animation:float 3s ease-in-out infinite; display:block; }
.hero-badge {
  background:var(--rosa); color:#fff; font-size:0.78rem; font-weight:700;
  letter-spacing:.2em; text-transform:uppercase; padding:.4rem 1.2rem;
  border-radius:999px; margin-bottom:1.4rem; display:inline-block;
}
.hero h1 {
  font-family:'Pacifico',cursive; font-size:clamp(2.8rem,9vw,6rem);
  color:var(--crema); line-height:1.1;
  text-shadow:4px 4px 0 var(--rosa),8px 8px 0 rgba(232,33,110,.3);
  margin-bottom:.6rem; animation:slideUp .8s ease both;
}
.hero-subtitle {
  font-family:'Playfair Display',serif; font-style:italic;
  font-size:clamp(1rem,2.8vw,1.4rem); color:var(--dorado-claro);
  margin-bottom:1.4rem; animation:slideUp .8s .15s ease both;
}
.hero-desc {
  color:rgba(253,246,238,.75); font-size:1rem; max-width:460px;
  line-height:1.7; margin-bottom:2.5rem; animation:slideUp .8s .3s ease both;
}
.hero-ctas { display:flex; gap:1rem; flex-wrap:wrap; justify-content:center; animation:slideUp .8s .45s ease both; }
.hero-address { margin-top:2.5rem; color:rgba(253,246,238,.5); font-size:.85rem; display:flex; align-items:center; gap:.4rem; animation:slideUp .8s .6s ease both; }

/* ── BOTONES ──────────────────────────────────────────────────── */
.btn-primary {
  background:var(--rosa); color:#fff; font-family:'Nunito',sans-serif;
  font-weight:700; font-size:1rem; padding:.85rem 1.8rem; border-radius:999px;
  text-decoration:none; border:none; cursor:pointer;
  display:inline-flex; align-items:center; gap:.5rem;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 4px 20px rgba(232,33,110,.4);
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 8px 30px rgba(232,33,110,.5); }
.btn-secondary {
  background:transparent; color:var(--dorado-claro); font-family:'Nunito',sans-serif;
  font-weight:700; font-size:1rem; padding:.85rem 1.8rem; border-radius:999px;
  text-decoration:none; border:2px solid var(--dorado); cursor:pointer;
  display:inline-flex; align-items:center; gap:.5rem;
  transition:transform .2s,background .2s,color .2s;
}
.btn-secondary:hover { background:var(--dorado); color:var(--madera); transform:translateY(-3px); }

/* ── HIGHLIGHTS STRIP ─────────────────────────────────────────── */
.highlights {
  background:var(--rosa); padding:.9rem 2rem;
  display:flex; justify-content:center; gap:2rem; flex-wrap:wrap;
}
.highlight-item { color:#fff; font-weight:700; font-size:.9rem; display:flex; align-items:center; gap:.45rem; }

/* ── SECCIONES GENERALES ──────────────────────────────────────── */
section { padding:4.5rem 1.5rem; }
.section-title {
  font-family:'Pacifico',cursive; font-size:clamp(2rem,5vw,2.8rem);
  color:var(--rosa); text-align:center; margin-bottom:.5rem;
}
.section-sub { text-align:center; font-family:'Playfair Display',serif; font-style:italic; color:var(--dorado); font-size:1.05rem; margin-bottom:2.5rem; }
.divider { width:56px; height:3px; background:var(--dorado); margin:.7rem auto 0; border-radius:999px; }

/* ── TIEMPO CON MÚLTIPLES OPCIONES ───────────────────────────── */
.tiempo--multi { width:100%; text-align:center; padding:.5rem 0; }
.tiempo-opciones { color:var(--crema); font-size:.88rem; line-height:1.8; font-weight:600; }
.o-sep { color:var(--dorado); font-style:italic; font-weight:400; margin:0 .3rem; }

/* ── DESAYUNOS DEL DÍA ───────────────────────────────────────── */
.desayunos-dia-title { font-family:'Pacifico',cursive; font-size:1.3rem; color:var(--dorado-claro); margin-bottom:1rem; }
.desayunos-dia-chips { display:flex; flex-wrap:wrap; justify-content:center; gap:.5rem; margin-bottom:.5rem; }
.dia-chip { background:rgba(253,246,238,.1); border:1px solid rgba(201,147,58,.35); color:var(--crema); border-radius:999px; padding:.38rem .9rem; font-size:.88rem; font-weight:600; }

/* ── PLATILLO DE LA CASA / ESPECIALES ────────────────────────── */
#especiales,
.seccion-especiales {
  background:linear-gradient(135deg,var(--madera) 0%,var(--madera-medio) 100%);
  text-align:center;
}
.casa-card {
  max-width:560px; margin:0 auto; background:rgba(253,246,238,.05);
  border:2px solid rgba(201,147,58,.4); border-radius:24px;
  padding:2.5rem 2rem; position:relative; overflow:hidden;
  animation:popIn .5s ease;
}
.casa-card::before {
  content:''; position:absolute; top:-40px; right:-40px; width:180px; height:180px;
  background:radial-gradient(circle,rgba(201,147,58,.2) 0%,transparent 70%);
  pointer-events:none;
}
.casa-badge {
  display:inline-block; background:var(--dorado); color:var(--madera);
  font-size:.75rem; font-weight:800; letter-spacing:.12em;
  text-transform:uppercase; padding:.3rem 1rem; border-radius:999px; margin-bottom:1rem;
}
.casa-emoji-big { font-size:4rem; margin-bottom:.8rem; }
.casa-nombre { font-family:'Pacifico',cursive; font-size:1.9rem; color:var(--crema); margin-bottom:.6rem; }
.casa-desc  { color:rgba(253,246,238,.7); font-size:.95rem; line-height:1.6; margin-bottom:1rem; font-family:'Playfair Display',serif; font-style:italic; }
.casa-precio { font-family:'Pacifico',cursive; font-size:1.4rem; color:var(--dorado-claro); margin-bottom:1.5rem; }

/* ── DESAYUNOS ────────────────────────────────────────────────── */
.desayunos-bg {
  background:var(--madera);
  background-image:radial-gradient(ellipse at 10% 90%,rgba(201,147,58,.15) 0%,transparent 50%);
}
.desayunos-bg .section-title { color:var(--dorado-claro); }
.desayunos-bg .section-sub  { color:rgba(253,246,238,.6); }
.menu-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:1rem; max-width:860px; margin:0 auto; }
.menu-card {
  background:rgba(253,246,238,.05); border:1px solid rgba(201,147,58,.3);
  border-radius:16px; padding:1.4rem 1rem; text-align:center;
  transition:transform .25s,background .25s;
}
.menu-card:hover { transform:translateY(-6px); background:rgba(253,246,238,.1); }
.menu-card .emoji { font-size:1.9rem; margin-bottom:.45rem; display:block; }
.menu-card h3 { font-family:'Playfair Display',serif; font-size:1rem; color:var(--crema); font-weight:700; }
.menu-card p  { font-size:.8rem; color:rgba(253,246,238,.55); margin-top:.25rem; line-height:1.4; }

/* ── COMIDA DEL DÍA ───────────────────────────────────────────── */
.corrida-section { background:var(--crema); text-align:center; }
.corrida-card {
  max-width:520px; margin:0 auto; background:var(--madera);
  border-radius:24px; padding:2.8rem 2.2rem; position:relative; overflow:hidden;
  box-shadow:0 20px 60px rgba(42,26,14,.25);
}
.corrida-card::before {
  content:''; position:absolute; top:-40px; right:-40px; width:200px; height:200px;
  background:radial-gradient(circle,rgba(232,33,110,.25) 0%,transparent 70%); pointer-events:none;
}
.tiempos { display:flex; justify-content:center; gap:2rem; margin:1.4rem 0; flex-wrap:wrap; }
.tiempo  { display:flex; flex-direction:column; align-items:center; gap:.35rem; }
.tiempo .num   { font-family:'Pacifico',cursive; font-size:2.5rem; color:var(--dorado-claro); line-height:1; }
.tiempo .label { font-size:.78rem; color:rgba(253,246,238,.6); text-transform:uppercase; letter-spacing:.1em; max-width:110px; text-align:center; }
.corrida-includes { list-style:none; margin:1.4rem 0 2rem; }
.corrida-includes li { color:rgba(253,246,238,.8); padding:.38rem 0; font-size:.92rem; display:flex; align-items:center; justify-content:center; gap:.5rem; }
.corrida-includes li::before { content:'✦'; color:var(--dorado); }
.corrida-card h2 { font-family:'Pacifico',cursive; font-size:1.7rem; color:var(--crema); }
.precio-hint { color:var(--dorado-claro); font-style:italic; font-family:'Playfair Display',serif; font-size:.92rem; margin-bottom:1.4rem; }
.precio-hint--grande { font-size:1.35rem; font-style:normal; font-weight:700; letter-spacing:.01em; }
.precio-hint--grande strong { font-family:'Pacifico',cursive; font-size:1.6rem; color:var(--dorado-claro); font-weight:400; margin-left:.2rem; }

/* ── GALERÍA ──────────────────────────────────────────────────── */
.galeria-section {
  background:var(--madera-medio);
  background-image:radial-gradient(ellipse at 80% 30%,rgba(232,33,110,.1) 0%,transparent 60%);
  text-align:center; overflow:hidden;
}
.galeria-section .section-title { color:var(--dorado-claro); }
.galeria-section .section-sub   { color:rgba(253,246,238,.65); }
.galeria-grid {
  display:grid; grid-template-columns:1fr 1fr 1fr;
  grid-template-rows:240px 200px; gap:8px;
  max-width:940px; margin:0 auto;
  border-radius:20px; overflow:hidden;
}
@media (max-width:640px) {
  .galeria-grid { grid-template-columns:1fr 1fr; grid-template-rows:160px 160px 160px; }
  .galeria-item--grande { grid-column:span 2; }
}
.galeria-item { position:relative; overflow:hidden; cursor:pointer; background:var(--madera-claro); }
.galeria-item--grande { grid-row:span 2; }
.galeria-item img { width:100%; height:100%; object-fit:cover; transition:transform .5s ease; }
.galeria-item:hover img { transform:scale(1.07); }
.galeria-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to top,rgba(42,26,14,.72) 0%,transparent 60%);
  opacity:0; transition:opacity .3s;
  display:flex; align-items:flex-end; padding:1rem;
}
.galeria-item:hover .galeria-overlay { opacity:1; }
.galeria-overlay span { color:#fff; font-size:.82rem; font-weight:700; }
.galeria-frase {
  margin:2.2rem auto 0; font-family:'Playfair Display',serif; font-style:italic;
  font-size:1.25rem; color:var(--dorado-claro); max-width:540px;
}

/* ── TESTIMONIALES ────────────────────────────────────────────── */
.testis-section { background:var(--crema); text-align:center; padding:4rem 1.5rem; }
.testis-section .section-title { color:var(--rosa); }
.testis-section .section-sub   { color:var(--dorado); }
.testis-wrap { max-width:680px; margin:0 auto; position:relative; min-height:160px; }
.testi-card {
  background:var(--madera); border-radius:20px; padding:2rem 1.8rem;
  position:absolute; width:100%; opacity:0; transform:translateY(20px);
  transition:opacity .6s ease,transform .6s ease; pointer-events:none;
}
.testi-card.active { opacity:1; transform:translateY(0); pointer-events:auto; }
.testi-stars { color:var(--dorado-claro); font-size:1.15rem; margin-bottom:.7rem; letter-spacing:.1em; }
.testi-text  { color:var(--crema); font-family:'Playfair Display',serif; font-style:italic; font-size:1rem; line-height:1.7; margin-bottom:.9rem; }
.testi-autor { color:var(--dorado); font-size:.83rem; font-weight:700; }
.testi-dots  { display:flex; justify-content:center; gap:.5rem; margin-top:11rem; }
.testi-dot   { width:8px; height:8px; border-radius:50%; background:rgba(201,147,58,.3); border:none; cursor:pointer; transition:background .3s; }
.testi-dot.active { background:var(--dorado); }

/* ── ANTOJITOS ────────────────────────────────────────────────── */
.antojitos-section { background:var(--blanco); }
.dos-col { display:grid; grid-template-columns:1fr 1fr; gap:1.5rem; max-width:780px; margin:0 auto; }
@media (max-width:560px) { .dos-col { grid-template-columns:1fr; } }
.antojito-block { background:var(--madera); border-radius:20px; padding:1.8rem 1.6rem; position:relative; overflow:hidden; }
.antojito-block h3 { font-family:'Pacifico',cursive; font-size:1.4rem; color:var(--dorado-claro); margin-bottom:1rem; }
.antojito-block ul { list-style:none; }
.antojito-block ul li { color:rgba(253,246,238,.85); padding:.42rem 0; font-size:.92rem; border-bottom:1px solid rgba(201,147,58,.12); display:flex; align-items:center; gap:.55rem; }
.antojito-block ul li::before { content:'•'; color:var(--rosa); font-size:1.2rem; }
.antojito-block ul li:last-child { border-bottom:none; }

/* ── MENÚ A LA CARTA ──────────────────────────────────────────── */
.carta-section { background:var(--blanco); text-align:center; position:relative; overflow:hidden; }
.carta-banner {
  max-width:660px; margin:0 auto; background:var(--madera);
  border-radius:24px; padding:2.8rem 2.2rem;
  box-shadow:0 16px 50px rgba(42,26,14,.2);
}
.carta-banner h2 { font-family:'Pacifico',cursive; font-size:1.8rem; color:var(--crema); margin-bottom:.5rem; }
.carta-banner .carta-sub { font-family:'Playfair Display',serif; font-style:italic; color:var(--dorado-claro); font-size:.93rem; }
.carta-platos { display:flex; flex-wrap:wrap; justify-content:center; gap:.65rem; margin:1.6rem 0 2rem; }
.carta-plato  { background:rgba(253,246,238,.08); border:1px solid rgba(201,147,58,.3); color:rgba(253,246,238,.85); border-radius:999px; padding:.38rem .95rem; font-size:.82rem; font-weight:600; }

/* ── ZONA NIÑOS ───────────────────────────────────────────────── */
.ninos-section { background:linear-gradient(135deg,#1a3a1a 0%,#0d2b0d 100%); text-align:center; }
.ninos-section .section-title { color:#7ee87e; }
.ninos-section .section-sub   { color:rgba(200,240,200,.65); }
.juegos-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1rem; max-width:820px; margin:0 auto; }
.juego-card {
  background:rgba(255,255,255,.06); border:2px solid rgba(126,232,126,.2);
  border-radius:20px; padding:1.8rem 1.2rem; cursor:pointer;
  transition:transform .2s,background .2s,border-color .2s;
}
.juego-card:hover { transform:translateY(-6px) scale(1.02); background:rgba(255,255,255,.11); border-color:rgba(126,232,126,.5); }
.juego-icon  { font-size:2.8rem; display:block; margin-bottom:.7rem; }
.juego-card h3 { color:#c8f0c8; font-family:'Pacifico',cursive; font-size:1.1rem; margin-bottom:.4rem; }
.juego-card p  { color:rgba(200,240,200,.6); font-size:.8rem; line-height:1.5; }
.juego-badge { display:inline-block; margin-top:.7rem; background:rgba(126,232,126,.15); color:#7ee87e; font-size:.72rem; font-weight:700; padding:.22rem .75rem; border-radius:999px; letter-spacing:.05em; }

/* ── MODAL JUEGOS ─────────────────────────────────────────────── */
.modal-overlay { display:none; position:fixed; inset:0; z-index:999; background:rgba(0,0,0,.82); align-items:center; justify-content:center; padding:1rem; }
.modal-overlay.open { display:flex; }
.modal-box { background:#1a1a2e; border-radius:24px; width:100%; max-width:500px; max-height:90vh; overflow-y:auto; padding:1.8rem; position:relative; border:2px solid rgba(126,232,126,.3); box-shadow:0 0 60px rgba(126,232,126,.15); }
.modal-close { position:absolute; top:1rem; right:1rem; background:rgba(255,255,255,.1); border:none; color:#fff; width:34px; height:34px; border-radius:50%; font-size:1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.modal-close:hover { background:rgba(255,255,255,.22); }
.modal-title { font-family:'Pacifico',cursive; color:#7ee87e; font-size:1.45rem; margin-bottom:.25rem; text-align:center; }
.modal-score { text-align:center; color:rgba(200,240,200,.7); font-size:.83rem; margin-bottom:1rem; }
.modal-score span { color:#f0c060; font-weight:700; font-size:.95rem; }

/* Memoria */
.memoria-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:7px; }
.mem-card { aspect-ratio:1; border-radius:10px; font-size:1.7rem; display:flex; align-items:center; justify-content:center; cursor:pointer; background:#2a2a4a; border:2px solid rgba(126,232,126,.2); transition:transform .15s; user-select:none; }
.mem-card:hover { transform:scale(1.06); }
.mem-card.flipped { background:#3a3a6a; border-color:rgba(126,232,126,.6); }
.mem-card.matched { background:rgba(126,232,126,.2); border-color:#7ee87e; cursor:default; }
.mem-card.wrong   { background:rgba(232,33,110,.2); border-color:#e8216e; }

/* Canvas juegos */
#frutasCanvas, #globosCanvas { display:block; margin:0 auto; border-radius:12px; border:2px solid rgba(126,232,126,.22); max-width:100%; }

.game-msg  { text-align:center; margin-top:.7rem; color:#f0c060; font-weight:700; font-size:.95rem; min-height:1.3em; }
.juego-btns { display:flex; justify-content:center; gap:.8rem; margin-top:.9rem; flex-wrap:wrap; }
.btn-juego { background:rgba(126,232,126,.15); color:#7ee87e; border:2px solid rgba(126,232,126,.4); border-radius:999px; padding:.45rem 1.3rem; font-family:'Nunito',sans-serif; font-weight:700; font-size:.88rem; cursor:pointer; transition:background .2s; }
.btn-juego:hover { background:rgba(126,232,126,.3); }

/* ── PÚBLICO ──────────────────────────────────────────────────── */
.publico-section { background:linear-gradient(135deg,var(--madera) 0%,var(--madera-medio) 100%); text-align:center; }
.publico-section .section-title { color:var(--dorado-claro); }
.publico-section .section-sub   { color:rgba(253,246,238,.6); }
.publico-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:1.3rem; max-width:840px; margin:0 auto; }
.publico-card { background:rgba(253,246,238,.06); border:1px solid rgba(253,246,238,.1); border-radius:20px; padding:1.8rem 1.4rem; transition:transform .25s; }
.publico-card:hover { transform:translateY(-5px); }
.publico-card .ic { font-size:2.3rem; margin-bottom:.7rem; display:block; }
.publico-card h4  { color:var(--crema); font-size:.97rem; font-weight:700; margin-bottom:.35rem; }
.publico-card p   { color:rgba(253,246,238,.55); font-size:.83rem; line-height:1.5; }

/* ── CTA PEDIDO ───────────────────────────────────────────────── */
.pedido-section { background:var(--rosa); text-align:center; padding:4rem 1.5rem; position:relative; overflow:hidden; }
.pedido-section::before { content:'🌮'; position:absolute; font-size:11rem; opacity:.07; left:-1.5rem; top:50%; transform:translateY(-50%); pointer-events:none; }
.pedido-section::after  { content:'🫔'; position:absolute; font-size:9rem;  opacity:.07; right:-1rem; top:50%; transform:translateY(-50%); pointer-events:none; }
.pedido-section h2 { font-family:'Pacifico',cursive; font-size:clamp(1.7rem,4vw,2.6rem); color:#fff; margin-bottom:.5rem; }
.pedido-section p  { color:rgba(255,255,255,.85); font-size:1rem; margin-bottom:1.8rem; max-width:440px; margin-left:auto; margin-right:auto; }
.whatsapp-btn { background:#fff; color:var(--rosa); font-family:'Nunito',sans-serif; font-weight:800; font-size:1.1rem; padding:.95rem 2.3rem; border-radius:999px; text-decoration:none; display:inline-flex; align-items:center; gap:.55rem; transition:transform .2s,box-shadow .2s; box-shadow:0 8px 28px rgba(0,0,0,.2); }
.whatsapp-btn:hover { transform:translateY(-4px) scale(1.02); box-shadow:0 14px 38px rgba(0,0,0,.3); }
.whatsapp-btn:hover .whatsapp-icon { animation:nudge .4s ease; }
.whatsapp-icon { width:28px; height:28px; background:#25d366; border-radius:50%; display:inline-flex; align-items:center; justify-content:center; color:#fff; font-size:.95rem; flex-shrink:0; }
.phone-big { margin-top:1.1rem; color:rgba(255,255,255,.7); font-size:.95rem; letter-spacing:.05em; }

/* ── UBICACIÓN ────────────────────────────────────────────────── */
.ubicacion-section { background:var(--crema); text-align:center; }
.mapa-embed { width:100%; max-width:680px; margin:0 auto 1.4rem; display:flex; border-radius:20px; overflow:hidden; box-shadow:0 10px 38px rgba(42,26,14,.15); aspect-ratio:16/9; background:#e8ddd3; align-items:center; justify-content:center; }
.mapa-placeholder { display:flex; flex-direction:column; align-items:center; gap:.7rem; color:var(--madera-claro); font-size:.88rem; text-align:center; padding:1.5rem; }
.mapa-placeholder .pin-icon { font-size:2.8rem; }
.mapa-placeholder strong { font-family:'Playfair Display',serif; font-size:1.05rem; color:var(--madera); }
.mapa-link { display:inline-flex; align-items:center; gap:.4rem; color:var(--rosa); font-weight:700; text-decoration:none; font-size:.88rem; margin-top:.4rem; border:2px solid var(--rosa); padding:.38rem .95rem; border-radius:999px; transition:background .2s,color .2s; }
.mapa-link:hover { background:var(--rosa); color:#fff; }
.horarios { display:inline-grid; grid-template-columns:auto auto; gap:.45rem 1.8rem; background:var(--madera); border-radius:16px; padding:1.4rem 1.8rem; margin-top:1.8rem; text-align:left; }
.horario-label { color:rgba(253,246,238,.6); font-size:.88rem; }
.horario-val   { color:var(--dorado-claro); font-weight:700; font-size:.88rem; }

/* ── FOOTER ───────────────────────────────────────────────────── */
footer { background:var(--madera); color:rgba(253,246,238,.5); text-align:center; padding:2rem 1.5rem; font-size:.83rem; line-height:1.9; }
footer strong { color:var(--dorado-claro); }

/* ── BOTÓN FLOTANTE ADMIN ─────────────────────────────────────── */
#adminBtn {
  position:fixed; bottom:1.5rem; right:1.5rem; z-index:500;
  width:52px; height:52px; border-radius:50%;
  background:var(--madera); border:2px solid rgba(201,147,58,.4);
  color:var(--dorado-claro); font-size:1.4rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 4px 20px rgba(0,0,0,.35);
  transition:transform .2s,box-shadow .2s;
}
#adminBtn:hover { transform:rotate(30deg) scale(1.1); box-shadow:0 8px 28px rgba(0,0,0,.45); }

/* ── PANEL ADMIN ──────────────────────────────────────────────── */
#adminPanel {
  display:none; position:fixed; inset:0; z-index:2000;
  background:rgba(0,0,0,.75); align-items:center; justify-content:center; padding:1rem;
}
#adminPanel.open { display:flex; }
.admin-box {
  background:#1a1200; border-radius:24px; width:100%; max-width:520px;
  max-height:92vh; overflow-y:auto; position:relative;
  border:1.5px solid rgba(201,147,58,.35);
  box-shadow:0 24px 80px rgba(0,0,0,.6);
  animation:popIn .3s ease;
}
.admin-box-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:1.2rem 1.5rem; border-bottom:1px solid rgba(201,147,58,.15);
  position:sticky; top:0; background:#1a1200; z-index:10;
}
.admin-box-title { font-family:'Pacifico',cursive; font-size:1.2rem; color:var(--dorado-claro); }
.admin-close-btn { background:rgba(255,255,255,.08); border:none; color:rgba(253,246,238,.7); width:32px; height:32px; border-radius:50%; font-size:1rem; cursor:pointer; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.admin-close-btn:hover { background:rgba(255,255,255,.18); }
#adminContenido { padding:1.5rem; }

/* PIN screen */
.admin-pin-screen { text-align:center; padding:1rem 0; }
.admin-pin-lock   { font-size:3.5rem; margin-bottom:.8rem; }
.admin-pin-title  { font-family:'Pacifico',cursive; font-size:1.5rem; color:var(--dorado-claro); margin-bottom:.3rem; }
.admin-pin-sub    { color:rgba(253,246,238,.55); font-size:.9rem; margin-bottom:1.8rem; }
.pin-display { display:flex; gap:1rem; justify-content:center; margin-bottom:1.8rem; }
.pin-dot { width:18px; height:18px; border-radius:50%; border:2px solid rgba(201,147,58,.5); background:transparent; transition:background .15s; }
.pin-dot.filled { background:var(--dorado-claro); border-color:var(--dorado-claro); }
.pin-teclado { display:grid; grid-template-columns:repeat(3,1fr); gap:.6rem; max-width:220px; margin:0 auto; }
.pin-key { background:rgba(253,246,238,.07); border:1px solid rgba(201,147,58,.25); color:var(--crema); font-family:'Nunito',sans-serif; font-size:1.2rem; font-weight:700; height:52px; border-radius:12px; cursor:pointer; transition:background .15s,transform .1s; }
.pin-key:hover { background:rgba(253,246,238,.14); }
.pin-key:active { transform:scale(.93); }
.pin-key--vacio { visibility:hidden; }
.pin-error { color:#f07070; font-size:.88rem; margin-top:.8rem; min-height:1.3em; }

/* Admin menu grid */
.admin-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:1.2rem; }
.admin-logo   { font-family:'Pacifico',cursive; font-size:1.2rem; color:var(--dorado-claro); }
.admin-lock-btn { background:rgba(255,255,255,.07); border:1px solid rgba(201,147,58,.25); color:rgba(253,246,238,.7); padding:.3rem .8rem; border-radius:999px; font-size:.85rem; cursor:pointer; transition:background .2s; }
.admin-lock-btn:hover { background:rgba(255,255,255,.15); }
.admin-grid { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; }
.admin-card {
  background:rgba(253,246,238,.05); border:1px solid rgba(201,147,58,.22);
  border-radius:16px; padding:1.2rem 1rem; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; gap:.45rem;
  text-align:center; transition:background .2s,transform .15s;
}
.admin-card:hover { background:rgba(253,246,238,.1); transform:translateY(-2px); }
.admin-card-icon  { font-size:1.8rem; }
.admin-card-label { color:var(--crema); font-size:.82rem; font-weight:700; }

/* Admin secciones */
.admin-seccion {}
.admin-back { background:none; border:none; color:var(--dorado); font-family:'Nunito',sans-serif; font-weight:700; font-size:.88rem; cursor:pointer; margin-bottom:1rem; display:flex; align-items:center; gap:.3rem; padding:0; }
.admin-back:hover { color:var(--dorado-claro); }
.admin-sec-title { font-family:'Pacifico',cursive; font-size:1.3rem; color:var(--dorado-claro); margin-bottom:.3rem; }
.admin-sec-sub   { color:rgba(253,246,238,.55); font-size:.83rem; margin-bottom:1.4rem; line-height:1.5; }
.admin-form { display:flex; flex-direction:column; gap:1rem; }
.admin-label { display:flex; flex-direction:column; gap:.35rem; }
.admin-label > span { color:rgba(253,246,238,.7); font-size:.82rem; font-weight:600; }
.admin-label input[type=text],
.admin-label input[type=url],
.admin-label input[type=password],
.admin-label input[type=date],
.admin-label select,
.admin-label textarea {
  background:rgba(255,255,255,.07); border:1px solid rgba(201,147,58,.3);
  color:var(--crema); font-family:'Nunito',sans-serif; font-size:.9rem;
  padding:.55rem .85rem; border-radius:10px; outline:none; width:100%;
  transition:border-color .2s;
}
.admin-label input[type=checkbox] { width:20px; height:20px; cursor:pointer; accent-color:var(--dorado); }
.admin-label input:focus,
.admin-label select:focus,
.admin-label textarea:focus { border-color:var(--dorado-claro); }
.admin-label select option { background:#1a1200; }
.admin-btn-primary { background:var(--rosa); color:#fff; font-family:'Nunito',sans-serif; font-weight:700; font-size:.95rem; padding:.7rem 1.5rem; border:none; border-radius:999px; cursor:pointer; transition:transform .2s,box-shadow .2s; box-shadow:0 4px 16px rgba(232,33,110,.35); }
.admin-btn-primary:hover { transform:translateY(-2px); box-shadow:0 7px 22px rgba(232,33,110,.45); }
.admin-btn-secondary { background:rgba(201,147,58,.15); color:var(--dorado-claro); font-family:'Nunito',sans-serif; font-weight:700; font-size:.9rem; padding:.6rem 1.3rem; border:1.5px solid rgba(201,147,58,.4); border-radius:999px; cursor:pointer; transition:background .2s; }
.admin-btn-secondary:hover { background:rgba(201,147,58,.3); }
.admin-hint { color:rgba(253,246,238,.4); font-size:.78rem; line-height:1.5; }

/* Temas grid */
.temas-grid { display:grid; grid-template-columns:1fr 1fr; gap:.8rem; }
.tema-card {
  background:rgba(255,255,255,.05); border:2px solid rgba(201,147,58,.2);
  border-radius:16px; padding:1.2rem 1rem; cursor:pointer;
  display:flex; flex-direction:column; align-items:center; gap:.35rem;
  text-align:center; transition:all .2s; position:relative;
}
.tema-card:hover { background:rgba(255,255,255,.1); border-color:rgba(201,147,58,.5); }
.tema-card.activo { border-color:var(--dorado-claro); background:rgba(201,147,58,.12); }
.tema-emoji  { font-size:2rem; }
.tema-nombre { color:var(--crema); font-weight:700; font-size:.88rem; }
.tema-desc   { color:rgba(253,246,238,.5); font-size:.75rem; }
.tema-badge  { background:var(--dorado); color:var(--madera); font-size:.7rem; font-weight:800; padding:.18rem .7rem; border-radius:999px; letter-spacing:.05em; }

/* Catálogo */
.catalogo-check-list { display:flex; flex-direction:column; gap:.5rem; max-height:320px; overflow-y:auto; padding-right:.4rem; }
.cat-check-item { display:flex; align-items:center; gap:.7rem; padding:.5rem .6rem; background:rgba(255,255,255,.04); border-radius:10px; cursor:pointer; }
.cat-check-item:hover { background:rgba(255,255,255,.08); }
.cat-check-item input { flex-shrink:0; accent-color:var(--dorado); }
.cat-check-item span  { color:var(--crema); font-size:.88rem; flex:1; }
.cat-badge { background:rgba(201,147,58,.15); color:var(--dorado); font-size:.68rem; padding:.15rem .5rem; border-radius:999px; font-weight:700; white-space:nowrap; }
.cat-grupo { margin-bottom:1rem; }
.cat-grupo-title { color:var(--dorado-claro); font-family:'Pacifico',cursive; font-size:1rem; margin-bottom:.5rem; }
.cat-item { display:flex; align-items:center; gap:.6rem; padding:.4rem .5rem; border-bottom:1px solid rgba(201,147,58,.1); }
.cat-item-emoji  { font-size:1.1rem; }
.cat-item-nombre { color:var(--crema); font-size:.85rem; flex:1; }
.cat-del-btn { background:none; border:none; cursor:pointer; font-size:1rem; opacity:.5; transition:opacity .2s; }
.cat-del-btn:hover { opacity:1; }
.cat-nuevo { background:rgba(255,255,255,.04); border-radius:12px; padding:1rem; margin-bottom:1rem; }
.cat-nuevo-row { display:flex; gap:.5rem; align-items:center; flex-wrap:wrap; }
.cat-nuevo-row input, .cat-nuevo-row select { background:rgba(255,255,255,.08); border:1px solid rgba(201,147,58,.3); color:var(--crema); font-family:'Nunito',sans-serif; font-size:.88rem; padding:.45rem .7rem; border-radius:8px; outline:none; }

/* Galería admin */
.galeria-admin-item { margin-bottom:.6rem; }
.galeria-admin-row  { display:flex; align-items:center; gap:.6rem; }
.galeria-admin-num  { color:var(--dorado); font-weight:800; font-size:.9rem; width:18px; flex-shrink:0; }
.galeria-admin-fields { flex:1; display:flex; flex-direction:column; gap:.35rem; }
.galeria-admin-fields input { background:rgba(255,255,255,.07); border:1px solid rgba(201,147,58,.25); color:var(--crema); font-family:'Nunito',sans-serif; font-size:.82rem; padding:.42rem .7rem; border-radius:8px; outline:none; width:100%; }
.galeria-del-btn { background:none; border:none; cursor:pointer; font-size:1.1rem; opacity:.55; transition:opacity .2s; flex-shrink:0; }
.galeria-del-btn:hover { opacity:1; }
