:root{
  /* Paleta base (IG) */
  --ig-blue:   #4f5bd5;
  --ig-purple: #962fbf;
  --ig-magenta:#d62976;
  --ig-orange: #fa7e1e;
  --ig-yellow: #feda75;
  --ig-gradient: linear-gradient(135deg,
    var(--ig-blue) 0%,
    var(--ig-purple) 20%,
    var(--ig-magenta) 45%,
    var(--ig-orange) 70%,
    var(--ig-yellow) 100%
  );

  /* Colores UI (tema oscuro minimal) */
  --bg:#0f0f12;
  --ink:#f2f2f2;
  --muted:#cfcfcf;
  --card:rgba(255,255,255,0.06);
  --surface:rgba(255,255,255,0.08);
  --border:rgba(255,255,255,0.14);
  --line:rgba(255,255,255,0.16);

  /* Primarios (aún overrideables vía JSON si quieres) */
  --primary: var(--ig-magenta);
  --accent:  var(--ig-orange);

  --radius:18px;
  --shadow-lg:0 18px 60px rgba(0,0,0,.28);
  --shadow-md:0 10px 30px rgba(0,0,0,.22);
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; font-family: ui-sans-serif, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Noto Sans";
  color:var(--ink); background:var(--bg); -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}

/* WOW background (sutil sobre fondo oscuro) */
.bg-waves{ position:fixed; inset:0; z-index:-1; }
.bg-waves::before, .bg-waves::after{
  content:""; position:absolute; inset:0; pointer-events:none;
  background:
    radial-gradient(600px 240px at 80% -10%, rgba(79,91,213,.18), transparent 60%),
    radial-gradient(720px 260px at 10% -5%, rgba(214,41,118,.16), transparent 62%);
}
.bg-waves::after{
  background:
    radial-gradient(420px 220px at 90% 85%, rgba(250,126,30,.14), transparent 60%),
    radial-gradient(520px 260px at 8% 92%,  rgba(253,234,117,.12), transparent 62%);
}

/* Header (minimal, sin degradado) */
header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background:#0f0f12;                 /* sólido */
  border-bottom:1px solid var(--line); /* línea sutil */
  color:#fff;
}
.nav{ max-width:920px; margin:0 auto; padding:12px 16px; display:flex; align-items:center; gap:12px; }
.brand-wrap{ display:flex; align-items:center; gap:10px; text-decoration:none; color:inherit; }
.brand-logo{
  height:40px; max-height:60px; width:auto; display:block; object-fit:contain;
}
@media(min-width:520px){ .brand-logo{ height:44px; } }
.brand{ font-weight:900; letter-spacing:.5px; color:#fff; }

/* Botón hamburguesa */
.icon-btn{
  margin-left:auto;
  display:inline-flex; align-items:center; justify-content:center;
  width:40px; height:40px;
  border-radius:12px; border:1px solid var(--border);
  background:transparent;             /* sin caja clara */
  color:#fff;
  box-shadow:none;
  cursor:pointer;
}
.icon-btn:focus-visible{ outline:2px solid rgba(79,91,213,.55); outline-offset:2px; }
.icon-btn:active{ transform:translateY(1px); }
.icon-btn[aria-expanded="true"]{
  background:#1a1a1d;
  color:#fff; border-color:var(--line);
}

/* Secciones */
.section{ max-width:920px; margin:0 auto; padding:14px 16px; }
.section h2{ font-size:18px; margin:10px 0 12px; font-weight:900; }

/* BARRA DE ÁREAS (iconos) */
.areas{ display:grid; grid-template-columns:repeat(4,1fr); gap:10px; }
.area-pill{
  display:flex; align-items:center; justify-content:center; gap:8px;
  min-height:46px; border-radius:14px; font-weight:900;
  border:1px solid var(--border); background:var(--card); color:var(--ink);
}
.area-pill[aria-pressed="true"]{
  background:#ffffff;                /* sólido minimal */
  color:#111; border:none;
}
.area-pill span{ font-size:14px }

/* Banners / Carrusel (Eventos) | aspecto 4:5 = 1080x1350 */
.banners{ position:relative; }
.slider{ display:flex; gap:12px; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; padding-bottom:8px; }
.slider::-webkit-scrollbar{ display:none; }
.slide{
  flex:0 0 84%; max-width:84%; scroll-snap-align:start;
  border-radius:18px; border:1px solid var(--border);
  box-shadow:var(--shadow-lg); background:var(--card);
  position:relative; overflow:hidden;
}
.banner-img{ width:100%; aspect-ratio:4/5; object-fit:cover; display:block; }
.label{
  position:absolute; left:10px; bottom:10px;
  background:rgba(0,0,0,.55); color:#fff; font-weight:900; font-size:12px;
  padding:6px 10px; border-radius:999px; box-shadow:0 6px 18px rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.18);
}
.dots{ display:flex; gap:6px; justify-content:center; margin-top:6px; }
.dot{ width:8px; height:8px; border-radius:999px; background:var(--border); border:none; }
.dot[aria-current="true"]{
  background: linear-gradient(135deg, var(--ig-magenta), var(--ig-orange));
  box-shadow: 0 0 0 3px rgba(214,41,118,0.25);
}

/* Historias / Logos circulares — SOLO círculo con aro (sin “cajón” ni nombre) */
.stories{
  display:flex; gap:12px; overflow:auto;
  padding:8px 2px 8px;               /* un poco menos alto */
  margin:0;                          /* sin margen extra que parezca caja */
  background:transparent;            /* sin fondo */
}
.story{
  flex:0 0 auto; width:68px;         /* compacto */
  text-align:center;
  background:transparent;            /* sin “cajón” */
  border:none; box-shadow:none;      /* cero sombra */
}
.avatar-wrap{
  width:68px; height:68px; border-radius:999px; padding:2px;
  background: var(--ig-gradient);    /* aro degradado OK */
  box-shadow:none;
  margin:0 auto;
  display:block;
}
.avatar{
  width:100%; height:100%; border-radius:999px;
  object-fit:contain;                /* no recorta logos */
  background:transparent;            /* sin gris dentro */
  border:none;                       /* sin borde interno */
}
/* Oculta los nombres bajo los logos */
.story-name{ display:none; }

/* Search + chips */
.search{
  display:flex; align-items:center; gap:8px;
  border:1px solid var(--border); background:var(--card);
  border-radius:14px; padding:10px 12px; box-shadow:var(--shadow-md);
}
.search input{ flex:1; border:0; outline:0; font-size:16px; background:transparent; color:var(--ink); }
.search input::placeholder{ color:var(--muted); }
.chips{ display:flex; gap:8px; overflow:auto; padding:10px 0 2px; }
.chip{
  flex:0 0 auto; border:1px solid var(--border); background:var(--card);
  color:var(--ink); border-radius:999px; padding:8px 12px; font-size:13px; font-weight:700;
}
.chip[aria-pressed="true"]{
  background:#ffffff; color:#111; border-color:transparent; /* minimal */
}

/* Grid restaurantes */
.grid{ display:grid; grid-template-columns:1fr; gap:14px; }
@media(min-width:520px){ .grid{ grid-template-columns:1fr 1fr; } }
.card{
  background:var(--card); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg);
}
.thumb{ width:100%; aspect-ratio:16/10; object-fit:cover; display:block; background:#1a1a1a; }
.card-body{ padding:12px; }
.title-row{ display:grid; grid-template-columns:auto 1fr auto; align-items:center; gap:8px; }
.title{ font-size:16px; font-weight:900; color:var(--ink); }
.badge{
  display:inline-flex; align-items:center; gap:6px; padding:6px 10px; border-radius:999px; font-size:12px;
  border:1px solid var(--border); background:var(--surface); color:var(--ink);
}
.badge .dot{ width:8px; height:8px; border-radius:999px; background: #19c26b; box-shadow:0 0 0 3px rgba(25,194,107,.18); }
.category{ color:var(--muted); font-size:13px; margin-top:2px; }
.logo-sm{
  width:32px; height:32px; border-radius:10px; object-fit:contain;
  background:transparent; border:none; box-shadow:none;
}

/* Featured: carrusel horizontal */
.featured{ display:flex; gap:10px; overflow:auto; padding:10px 2px 2px; margin:6px -2px 0; }
.f-item{
  min-width:120px; max-width:130px; background:var(--surface);
  border:1px solid var(--border); border-radius:14px; overflow:hidden; box-shadow:var(--shadow-md);
  color:var(--ink);
}
.f-img{ width:100%; aspect-ratio:1/1; object-fit:cover; background:#111; display:block; }
.f-body{ padding:8px; }
.f-name{ font-size:12px; font-weight:700; line-height:1.2; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.f-price{ font-size:12px; font-weight:900; margin-top:4px; }

/* Acciones / Botones (minimal) */
.actions{ display:grid; grid-template-columns:1fr; gap:8px; margin-top:10px; }
.action{
  min-height:46px; display:inline-flex; align-items:center; justify-content:center;
  border-radius:12px; text-decoration:none; font-weight:800;
  border:1px solid var(--border); color:var(--ink); background:var(--card);
}
.action.primary{
  border:1px solid var(--border);
  background:#ffffff; color:#111;              /* sin degradado */
}

/* Tarjetas de info/eventos */
.service{
  display:grid; grid-template-columns:64px 1fr; gap:12px; padding:12px;
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius); box-shadow:var(--shadow-lg);
}
.icon{
  width:64px; height:64px; border-radius:16px; display:flex; align-items:center; justify-content:center;
  font-size:28px; background: var(--ig-gradient); color:#111;
}

.event-card{
  display:grid; grid-template-columns:1fr; gap:10px; margin-top:14px;
  background:var(--card); border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow-lg);
}
.event-card img{ width:100%; aspect-ratio:16/9; object-fit:cover; display:block; background:#1a1a1a; }
.event-body{ padding:12px; }
.event-title{ font-weight:900; font-size:16px; color:var(--ink); }
.list{ margin:8px 0 0 18px; color:var(--ink); }

/* OVERLAY (menú) */
.overlay{ position:fixed; inset:0; z-index:60; }
.overlay[hidden]{ display:none; }
.overlay-backdrop{ position:absolute; inset:0; background:rgba(0,0,0,.4); }
.sheet{
  position:absolute; right:0; top:0; bottom:0; width:min(420px, 88vw);
  background:var(--bg); border-left:1px solid var(--line); box-shadow:var(--shadow-lg);
  display:flex; flex-direction:column; color:var(--ink);
}
.sheet-head{ display:flex; align-items:center; justify-content:space-between; padding:12px 14px; border-bottom:1px solid var(--line); }
.sheet-title{ font-weight:900; }
.sheet-close{ border:0; background:transparent; font-size:26px; line-height:1; cursor:pointer; color:var(--ink); }
.sheet-nav{ display:flex; flex-direction:column; padding:8px; gap:6px; }
.sheet-link{
  display:flex; gap:10px; align-items:center; padding:12px; border-radius:12px; text-decoration:none; color:var(--ink);
  border:1px solid var(--border); background:var(--card);
}
.sheet-link:active{ transform:translateY(1px); }

/* Footer */
footer{ padding:26px 16px 44px; text-align:center; color:var(--muted); font-size:12px; }

/* Accesibilidad: foco visible */
:focus-visible{
  outline: 2px solid transparent;
  box-shadow: 0 0 0 3px rgba(79,91,213,.45);
  border-radius: 12px;
}

/* Interacciones móviles */
a,button{ -webkit-tap-highlight-color:transparent; }
