/* ============================================================
   MUY LATINOS — Directorio de Negocios Latinos en España
   Design system · Familia Latinos · Junio 2026
   ============================================================ */

:root{
  /* Verdes */
  --verde:        #1A6B45;
  --verde-osc:    #0F4A2E;
  --verde-claro:  #2D9E68;
  /* Dorados */
  --oro:          #E8A020;
  --oro-claro:    #F5C355;
  /* Rojos */
  --rojo:         #C0392B;
  --rojo-suave:   #E74C3C;
  /* Neutros */
  --crema:        #FAF7F2;
  --humo:         #F0EBE2;
  --carbon:       #1C1C1C;
  --gris:         #5A5A5A;
  --blanco:       #FFFFFF;

  --radio:        14px;
  --pill:         50px;
  --sombra-sm:    0 2px 10px rgba(60,40,20,.06);
  --sombra:       0 8px 26px rgba(60,40,20,.10);
  --sombra-lg:    0 18px 48px rgba(60,40,20,.18);

  --font-display: "Fraunces", Georgia, "Times New Roman", serif;
  --font-ui:      "DM Sans", system-ui, sans-serif;

  --maxw: 1180px;
}

*,*::before,*::after{ box-sizing:border-box; }

html{ scroll-behavior:smooth; -webkit-text-size-adjust:100%; }

body{
  margin:0;
  font-family:var(--font-ui);
  font-weight:400;
  color:var(--carbon);
  background:var(--crema);
  line-height:1.6;
  overflow-x:hidden;
}

img{ max-width:100%; display:block; }
a{ color:inherit; text-decoration:none; }
button{ font-family:inherit; cursor:pointer; border:none; }

h1,h2,h3{ font-family:var(--font-display); line-height:1.08; margin:0; }

.wrap{ width:100%; max-width:var(--maxw); margin:0 auto; padding:0 22px; }

/* ---------- Etiquetas de sección ---------- */
.eyebrow{
  font-size:.75rem;
  font-weight:600;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:var(--verde);
  margin:0 0 12px;
}
.section-title{
  font-weight:700;
  font-size:clamp(1.8rem, 3.4vw, 2.6rem);
  color:var(--carbon);
}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-ui); font-weight:600; font-size:.95rem;
  padding:13px 26px; border-radius:var(--pill);
  transition:transform .2s ease, background .2s ease, box-shadow .2s ease;
  white-space:nowrap;
}
.btn-oro{ background:var(--oro); color:var(--carbon); }
.btn-oro:hover{ background:var(--oro-claro); transform:translateY(-2px); box-shadow:0 8px 20px rgba(232,160,32,.35); }
.btn-verde{ background:var(--verde); color:#fff; }
.btn-verde:hover{ background:var(--verde-claro); transform:translateY(-2px); }
.btn-ghost{ background:transparent; color:var(--verde); border:2px solid var(--verde); }
.btn-ghost:hover{ background:var(--verde); color:#fff; transform:translateY(-2px); }

/* ============================================================
   1 · NAVBAR
   ============================================================ */
.nav{
  position:sticky; top:0; z-index:100;
  background:var(--verde);
  height:64px;
  box-shadow:0 2px 14px rgba(15,74,46,.25);
}
.nav .wrap{ height:100%; display:flex; align-items:center; gap:26px; }
.brand{ font-family:var(--font-display); font-weight:900; font-size:1.5rem; letter-spacing:-.01em; }
.brand .muy{ color:var(--crema); }
.brand .lat{ color:var(--oro); }
/* Logo SVG (Muy Latinos) */
.brand-logo{ display:flex; align-items:center; }
.brand-logo .ml-logo{ height:42px; width:auto; display:block; }
.brand-logo--footer{ display:inline-flex; }
.brand-logo--footer .ml-logo{ height:78px; margin-bottom:10px; }

.nav-links{ display:flex; gap:26px; margin-left:14px; list-style:none; padding:0; }
.nav-links a{
  color:rgba(255,255,255,.88); font-weight:500; font-size:.95rem;
  padding:6px 2px; position:relative; transition:color .2s;
}
.nav-links a::after{
  content:""; position:absolute; left:0; bottom:-2px; width:0; height:2px;
  background:var(--oro); transition:width .25s ease;
}
.nav-links a:hover{ color:#fff; }
.nav-links a:hover::after{ width:100%; }

.nav-cta{ margin-left:auto; }
.nav-cta .btn{ padding:10px 20px; }

.hamb{
  display:none; margin-left:auto; background:transparent; padding:8px;
  flex-direction:column; gap:5px;
}
.hamb span{ width:24px; height:2px; background:#fff; border-radius:2px; transition:.25s; }

/* Menú móvil desplegable */
.mobile-menu{
  display:none; position:fixed; top:64px; left:0; right:0; z-index:99;
  background:var(--verde-osc); padding:14px 22px 22px;
  box-shadow:0 12px 24px rgba(0,0,0,.3);
}
.mobile-menu.open{ display:block; }
.mobile-menu a{ display:block; color:#fff; font-weight:500; padding:13px 0; border-bottom:1px solid rgba(255,255,255,.12); }

/* ============================================================
   2 · HERO
   ============================================================ */
.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px;
  overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0;
}
.hero{
  background:linear-gradient(160deg, var(--verde) 0%, var(--verde-osc) 100%);
  color:#fff; text-align:center;
  padding:90px 22px 80px;
  position:relative; overflow:hidden;
}
/* Hero compacta y delgada (~175px) */
.hero--compact{
  min-height:175px; padding:18px 22px;
  display:flex; align-items:center; justify-content:center;
}
.hero--compact .hero-inner{ width:100%; }
.hero.hero--compact h1{
  white-space:nowrap; text-align:center;
  font-size:clamp(0.76rem, 3.6vw, 1.6rem); margin-bottom:14px;
}
.hero--compact .chips{ margin-top:14px; }
.hero::before{
  content:""; position:absolute; top:-120px; right:-100px; width:380px; height:380px;
  background:radial-gradient(circle, rgba(232,160,32,.22), transparent 68%);
  pointer-events:none;
}
.hero::after{
  content:""; position:absolute; bottom:-140px; left:-90px; width:340px; height:340px;
  background:radial-gradient(circle, rgba(192,57,43,.16), transparent 68%);
  pointer-events:none;
}
.hero-inner{ position:relative; max-width:760px; margin:0 auto; }
.hero-badge{
  display:inline-block; font-size:.72rem; font-weight:600; letter-spacing:.14em;
  text-transform:uppercase; color:var(--oro-claro);
  background:rgba(232,160,32,.16); border:1px solid rgba(232,160,32,.4);
  padding:7px 16px; border-radius:var(--pill); margin-bottom:24px;
}
.hero h1{
  font-weight:900; font-size:clamp(2.6rem, 6vw, 4.2rem);
  letter-spacing:-.02em; margin-bottom:18px;
}
.hero h1 em{ font-style:italic; color:var(--oro); }
.hero-sub{
  font-size:1.1rem; color:rgba(255,255,255,.75);
  max-width:540px; margin:0 auto 38px;
}

/* Buscador */
.search{
  display:flex; align-items:stretch; background:#fff; border-radius:var(--pill);
  max-width:660px; margin:0 auto; box-shadow:0 20px 46px rgba(15,74,46,.30);
  overflow:hidden;
}
.search .city{
  display:flex; align-items:center; gap:6px; padding:0 16px;
  border-right:1px solid #eadfce; color:var(--verde); font-weight:600;
  position:relative;
}
.search .city select{
  -webkit-appearance:none; appearance:none; border:none; background:transparent;
  font-family:var(--font-ui); font-weight:600; font-size:.95rem; color:var(--verde);
  padding:16px 18px 16px 4px; cursor:pointer; outline:none;
}
.search input{
  flex:1; border:none; outline:none; padding:16px 18px;
  font-family:var(--font-ui); font-size:1rem; color:var(--carbon); min-width:0;
}
.search input::placeholder{ color:#a59a8b; }
.search .btn-buscar{
  background:var(--oro); color:var(--carbon); font-weight:700;
  padding:0 30px; border-radius:0; transition:background .2s;
}
.search .btn-buscar:hover{ background:var(--oro-claro); }

/* Chips */
.chips{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-top:26px; }
.chip{
  font-size:.85rem; font-weight:500; padding:8px 17px; border-radius:var(--pill);
  background:rgba(255,255,255,.12); color:#fff; border:1px solid rgba(255,255,255,.18);
  transition:.2s;
}
.chip:hover{ background:rgba(255,255,255,.22); }
.chip.active{ background:var(--oro); color:var(--carbon); font-weight:600; border-color:var(--oro); }

/* ============================================================
   Secciones genéricas
   ============================================================ */
.section{ padding:78px 0; }
.section.crema{ background:var(--crema); }
.section.humo{ background:var(--humo); }
.section-head{ text-align:center; max-width:640px; margin:0 auto 46px; }
.section-head .eyebrow{ margin-bottom:10px; }

/* ============================================================
   3 · CATEGORÍAS
   ============================================================ */
.cat-grid{
  display:grid; grid-template-columns:repeat(auto-fit, minmax(160px,1fr)); gap:20px;
}
.cat-card{
  background:#fff; border-radius:var(--radio); padding:34px 18px;
  text-align:center; box-shadow:var(--sombra-sm);
  border-bottom:3px solid transparent;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.cat-card .ico{ font-size:2.4rem; line-height:1; margin-bottom:14px; }
.cat-card .name{ font-weight:600; font-size:1rem; color:var(--carbon); }
.cat-card:hover{ transform:translateY(-5px); box-shadow:var(--sombra); border-bottom-color:var(--verde); }

/* ============================================================
   4 · NEGOCIOS DESTACADOS
   ============================================================ */
.tabs{ display:flex; flex-wrap:wrap; justify-content:center; gap:10px; margin-bottom:38px; }
.tab{
  font-size:.9rem; font-weight:600; padding:9px 20px; border-radius:var(--pill);
  background:#fff; color:var(--gris); box-shadow:var(--sombra-sm); transition:.2s;
}
.tab:hover{ color:var(--verde); }
.tab.active{ background:var(--verde); color:#fff; }

.biz-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(300px,1fr)); gap:26px; }
.biz-card{
  background:#fff; border-radius:var(--radio); overflow:hidden; box-shadow:var(--sombra-sm);
  transition:transform .2s ease, box-shadow .2s ease;
}
.biz-card:hover{ transform:translateY(-4px); box-shadow:var(--sombra); }
.biz-img{
  height:180px; position:relative; display:flex; align-items:center; justify-content:center;
  font-size:3.2rem;
}
.biz-img.g-verde{ background:linear-gradient(135deg,var(--verde-osc),var(--verde)); }
.biz-img.g-verde-med{ background:linear-gradient(135deg,var(--verde),var(--verde-claro)); }
.biz-img.g-oro{ background:linear-gradient(135deg,var(--oro),var(--oro-claro)); }
.biz-img.g-rojo{ background:linear-gradient(135deg,var(--rojo),var(--rojo-suave)); }
.badge-plan{
  position:absolute; top:12px; right:12px; font-size:.72rem; font-weight:700;
  padding:5px 12px; border-radius:var(--pill);
}
.badge-plan.dest{ background:var(--oro); color:var(--carbon); }
.badge-plan.basic{ background:#fff; color:var(--verde); }
.biz-body{ padding:18px 20px 20px; }
.biz-cat{ font-size:.72rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--verde-claro); margin-bottom:8px; }
.biz-name{ font-family:var(--font-display); font-weight:700; font-size:1.2rem; margin-bottom:8px; }
.biz-desc{ font-size:.85rem; color:var(--gris); margin:0 0 16px; }
.biz-meta{ display:flex; justify-content:space-between; align-items:center; font-size:.8rem; color:var(--gris); }
.biz-meta .loc{ display:flex; align-items:center; gap:4px; }
.stars{ color:var(--oro); letter-spacing:1px; }
.biz-meta .rev{ color:#9a8f7f; }

/* ============================================================
   5 · CIUDADES
   ============================================================ */
.city-grid{ display:grid; grid-template-columns:repeat(auto-fill, minmax(280px,1fr)); gap:24px; }
.city-card{
  position:relative; aspect-ratio:4/3; border-radius:var(--radio); overflow:hidden;
  color:#fff; box-shadow:var(--sombra-sm); transition:transform .2s ease, box-shadow .2s ease;
  display:block;
}
.city-card::after{ content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(0,0,0,.5) 0%, transparent 55%); }
.city-card.has-photo{ background-size:cover; background-position:center; }
.city-card.has-photo::after{ background:linear-gradient(to top, rgba(0,0,0,.66) 0%, rgba(0,0,0,.12) 55%, rgba(0,0,0,.18) 100%); }
.city-card:hover{ transform:scale(1.03); box-shadow:var(--sombra-lg); }
.city-card .emoji{ position:absolute; top:16px; right:18px; font-size:2rem; z-index:2; filter:drop-shadow(0 2px 4px rgba(0,0,0,.3)); }
.city-card .info{ position:absolute; left:18px; bottom:16px; z-index:2; }
.city-card .cname{ font-family:var(--font-display); font-weight:900; font-size:1.5rem; }
.city-card .ccount{ font-size:.82rem; opacity:.9; }
.cg-madrid{ background:linear-gradient(140deg,#7a1d14,var(--rojo)); }
.cg-bcn{ background:linear-gradient(140deg,var(--verde-osc),var(--verde-claro)); }
.cg-vlc{ background:linear-gradient(140deg,#a36c0c,var(--oro)); }
.cg-sev{ background:linear-gradient(140deg,#7a1d14,var(--oro-claro)); }
.cg-bil{ background:linear-gradient(140deg,#0a3a23,var(--verde)); }
.cg-mal{ background:linear-gradient(140deg,var(--oro),var(--verde-claro)); }

/* ============================================================
   6 · BANNER DUEÑOS
   ============================================================ */
.owner-wrap{ padding:78px 0; background:var(--crema); }
.owner{
  position:relative; overflow:hidden;
  background:var(--carbon); color:#fff; border-radius:20px;
  display:grid; grid-template-columns:1.1fr 1fr; gap:48px;
  padding:54px 50px;
}
.owner::before{
  content:""; position:absolute; top:-120px; right:-80px; width:360px; height:360px;
  background:radial-gradient(circle, rgba(232,160,32,.28), transparent 66%);
  pointer-events:none;
}
.owner .col{ position:relative; z-index:1; }
.owner .badge-mini{
  display:inline-block; font-size:.72rem; font-weight:600; letter-spacing:.12em; text-transform:uppercase;
  color:var(--oro-claro); background:rgba(232,160,32,.16); border:1px solid rgba(232,160,32,.35);
  padding:6px 14px; border-radius:var(--pill); margin-bottom:18px;
}
.owner h2{ font-weight:700; font-size:clamp(1.7rem,3vw,2.3rem); margin-bottom:16px; }
.owner p{ color:rgba(255,255,255,.72); font-size:1rem; margin-bottom:26px; max-width:420px; }
.benefits{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:16px; }
.benefits li{ display:flex; align-items:center; gap:14px; font-weight:500; }
.benefits .b-ico{
  width:44px; height:44px; flex:none; border-radius:12px; display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; background:rgba(232,160,32,.16); border:1px solid rgba(232,160,32,.28);
}

/* ============================================================
   7 · PLANES
   ============================================================ */
.plans{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; align-items:start; }
.plan{
  background:#fff; border-radius:var(--radio); padding:34px 28px;
  box-shadow:var(--sombra-sm); border:2px solid transparent; position:relative;
  transition:transform .2s ease, box-shadow .2s ease;
}
.plan:hover{ transform:translateY(-4px); box-shadow:var(--sombra); }
.plan.popular{ border-color:var(--oro); box-shadow:var(--sombra); }
.plan .tag-pop{
  position:absolute; top:-15px; left:50%; transform:translateX(-50%);
  background:var(--oro); color:var(--carbon); font-size:.74rem; font-weight:700;
  padding:6px 18px; border-radius:var(--pill); white-space:nowrap;
}
.plan h3{ font-weight:700; font-size:1.4rem; margin-bottom:6px; }
.plan .price{ font-family:var(--font-display); font-weight:900; font-size:2rem; color:var(--verde); margin:8px 0; min-height:2.4rem; }
.plan .price small{ font-family:var(--font-ui); font-weight:500; font-size:.85rem; color:var(--gris); }
.plan .p-desc{ font-size:.88rem; color:var(--gris); margin-bottom:22px; min-height:42px; }
.plan ul{ list-style:none; margin:0 0 26px; padding:0; display:flex; flex-direction:column; gap:11px; }
.plan li{ font-size:.88rem; display:flex; gap:10px; align-items:flex-start; }
.plan li .ck{ color:var(--verde-claro); font-weight:700; }
.plan li.no{ color:#aaa; }
.plan li.no .ck{ color:#ccc; }
.plan .btn{ width:100%; justify-content:center; }

/* ============================================================
   8 · ARTÍCULOS
   ============================================================ */
.art-head{ display:flex; align-items:flex-end; justify-content:space-between; max-width:var(--maxw); margin:0 auto 40px; gap:20px; flex-wrap:wrap; }
.art-head .link{ color:var(--verde); font-weight:600; font-size:.92rem; white-space:nowrap; }
.art-head .link:hover{ color:var(--verde-claro); }
.art-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:26px; }
.art-card{ background:#fff; border-radius:var(--radio); overflow:hidden; box-shadow:var(--sombra-sm); transition:transform .3s ease, box-shadow .3s ease; }
.art-card:hover{ transform:translateY(-3px); box-shadow:var(--sombra); }
.art-imgwrap{ aspect-ratio:16/9; overflow:hidden; }
.art-img{ width:100%; height:100%; display:flex; align-items:center; justify-content:center; font-size:2.8rem; transition:transform .3s ease; }
.art-card:hover .art-img{ transform:scale(1.05); }
.art-body{ padding:20px 22px 24px; }
.art-tag{ font-size:.72rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--verde-claro); margin-bottom:10px; }
.art-title{ font-family:var(--font-display); font-weight:700; font-size:1.1rem; line-height:1.25; margin-bottom:10px; }
.art-ex{ font-size:.85rem; color:var(--gris); margin:0 0 16px; }
.art-meta{ font-size:.78rem; color:#9a8f7f; }

/* ============================================================
   9 · SABORES
   ============================================================ */
.dish-grid{ display:grid; grid-template-columns:repeat(4,1fr); gap:22px; }
.dish-card{ background:#fff; border-radius:var(--radio); overflow:hidden; box-shadow:var(--sombra-sm); transition:transform .2s ease, box-shadow .2s ease; }
.dish-card:hover{ transform:translateY(-4px); box-shadow:var(--sombra); }
.dish-img{ aspect-ratio:4/3; display:flex; align-items:center; justify-content:center; font-size:3rem; background:var(--humo); }
.dish-img.has-photo{ background-size:cover; background-position:center; background-repeat:no-repeat; }
.dish-body{ padding:16px 18px 20px; }
.dish-name{ font-family:var(--font-display); font-weight:700; font-size:1.08rem; margin-bottom:3px; }
.dish-origin{ font-size:.75rem; font-weight:600; text-transform:uppercase; letter-spacing:.05em; color:var(--rojo); margin-bottom:9px; }
.dish-desc{ font-size:.82rem; color:var(--gris); margin:0 0 14px; }
.dish-link{ font-size:.82rem; font-weight:600; color:var(--verde); }
.dish-link:hover{ color:var(--verde-claro); }

/* ============================================================
   10 · FOOTER
   ============================================================ */
.footer{ background:var(--carbon); color:#c9c2b8; padding:60px 0 0; }
.footer-grid{ display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:46px; }
.footer .brand{ font-size:1.6rem; display:inline-block; margin-bottom:14px; }
.footer-about{ font-size:.88rem; max-width:300px; color:#9a958c; }
.footer h4{ color:#fff; font-family:var(--font-ui); font-weight:600; font-size:.95rem; margin:0 0 16px; }
.footer ul{ list-style:none; margin:0; padding:0; display:flex; flex-direction:column; gap:10px; }
.footer ul a{ font-size:.88rem; color:#9a958c; transition:color .2s; }
.footer ul a:hover{ color:var(--oro-claro); }
.footer-bar{
  border-top:1px solid rgba(255,255,255,.1); padding:22px 0;
  display:flex; justify-content:space-between; align-items:center; gap:14px; flex-wrap:wrap;
  font-size:.82rem; color:#8a857c;
}
.footer-bar .legal{ display:flex; gap:18px; flex-wrap:wrap; }
.footer-bar a:hover{ color:var(--oro-claro); }

/* ============================================================
   Animaciones (fade-up al hacer scroll)
   ============================================================ */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s ease, transform .6s ease; }
.reveal.in{ opacity:1; transform:none; }

@media (prefers-reduced-motion:reduce){
  .reveal{ opacity:1; transform:none; transition:none; }
  html{ scroll-behavior:auto; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:1024px){
  .plans{ grid-template-columns:1fr; max-width:480px; margin:0 auto; }
  .dish-grid{ grid-template-columns:repeat(2,1fr); }
  .art-grid{ grid-template-columns:1fr 1fr; }
  .owner{ grid-template-columns:1fr; gap:34px; padding:42px 34px; }
  .footer-grid{ grid-template-columns:1fr 1fr; gap:32px; }
}

@media (max-width:768px){
  .nav-links, .nav-cta{ display:none; }
  .hamb{ display:flex; }
  .hero{ padding:62px 20px 56px; }
  .hero--compact{ min-height:175px; padding:24px 20px; }
  .search{ flex-direction:column; border-radius:22px; }
  .search .city{ border-right:none; border-bottom:1px solid #eadfce; padding:6px 14px; }
  .search .btn-buscar{ border-radius:0; padding:15px; }
  .cat-grid{ grid-template-columns:1fr 1fr; }
  .art-grid{ grid-template-columns:1fr; }
  .art-head{ flex-direction:column; align-items:flex-start; }
  .footer-bar{ flex-direction:column; align-items:flex-start; }
}

@media (max-width:520px){
  .dish-grid{ grid-template-columns:1fr; }
  .footer-grid{ grid-template-columns:1fr; }
  .city-grid{ grid-template-columns:1fr; }
}

/* ============================================================
   PÁGINAS INTERNAS (listados, ficha, búsqueda, legales)
   ============================================================ */
.subhero{
  background:linear-gradient(160deg,var(--verde) 0%, var(--verde-osc) 100%);
  color:#fff; padding:54px 22px 46px; text-align:center; position:relative; overflow:hidden;
}
.subhero::before{ content:""; position:absolute; top:-100px; right:-80px; width:300px; height:300px;
  background:radial-gradient(circle, rgba(232,160,32,.2), transparent 68%); }
.subhero .inner{ position:relative; max-width:780px; margin:0 auto; }
.subhero .eyebrow{ color:var(--oro-claro); }
.subhero h1{ font-weight:900; font-size:clamp(2rem,4.6vw,3.2rem); margin-bottom:12px; }
.subhero h1 em{ font-style:italic; color:var(--oro); }
.subhero p{ color:rgba(255,255,255,.78); max-width:560px; margin:0 auto; font-size:1.05rem; }

.breadcrumb{ font-size:.82rem; color:var(--gris); padding:16px 0 0; }
.breadcrumb a{ color:var(--verde); }
.breadcrumb a:hover{ color:var(--verde-claro); }
.breadcrumb span{ color:#b3a899; }

.filterbar{ display:flex; flex-wrap:wrap; gap:10px; justify-content:center; margin:0 0 36px; }

.count-note{ text-align:center; color:var(--gris); font-size:.9rem; margin:-26px 0 30px; }

/* Listado de categoría dentro de ciudad (city page agrupado) */
.group-head{ display:flex; align-items:center; gap:10px; margin:46px 0 22px; }
.group-head .gemoji{ font-size:1.6rem; }
.group-head h2{ font-family:var(--font-display); font-weight:700; font-size:1.5rem; }
.group-head a{ margin-left:auto; font-size:.85rem; font-weight:600; color:var(--verde); white-space:nowrap; }

.empty{ text-align:center; color:var(--gris); padding:40px 0; }

/* ---------- Ficha de negocio ---------- */
.detail{ padding:34px 0 70px; }
.detail-grid{ display:grid; grid-template-columns:1.6fr 1fr; gap:36px; align-items:start; }
.gallery{ display:grid; grid-template-columns:1fr 1fr; gap:10px; border-radius:var(--radio); overflow:hidden; }
.gallery .main{ grid-column:1 / -1; aspect-ratio:16/9; }
.gallery img{ width:100%; height:100%; object-fit:cover; display:block; background:var(--humo); }
.gallery .ph{ width:100%; aspect-ratio:1/1; display:flex; align-items:center; justify-content:center; font-size:3rem; }
.gallery.single .main{ aspect-ratio:16/9; }
.gallery.single .ph{ aspect-ratio:16/9; }

.detail h1{ font-weight:900; font-size:clamp(1.8rem,3.4vw,2.6rem); margin:22px 0 8px; }
.detail .d-cat{ font-size:.78rem; font-weight:600; letter-spacing:.06em; text-transform:uppercase; color:var(--verde-claro); }
.detail .d-rating{ display:inline-flex; align-items:center; gap:8px; margin:10px 0 6px; font-size:.95rem; color:var(--gris); }
.detail .d-rating .stars{ font-size:1.05rem; }
.detail .d-resumen{ font-size:1.02rem; color:#3a3a3a; margin:16px 0 0; }

.infocard{ background:#fff; border-radius:var(--radio); box-shadow:var(--sombra-sm); padding:24px; position:sticky; top:84px; }
.infocard h3{ font-family:var(--font-display); font-weight:700; font-size:1.15rem; margin-bottom:16px; }
.info-row{ display:flex; gap:12px; align-items:flex-start; font-size:.9rem; padding:11px 0; border-bottom:1px solid #f0ebe2; color:#3a3a3a; }
.info-row:last-of-type{ border-bottom:none; }
.info-row .ic{ font-size:1.1rem; flex:none; line-height:1.3; }
.info-row a{ color:var(--verde); word-break:break-word; }
.info-row a:hover{ color:var(--verde-claro); }
.hours{ list-style:none; margin:0; padding:0; font-size:.85rem; color:var(--gris); }
.hours li{ display:flex; justify-content:space-between; padding:3px 0; }
.map-wrap{ border-radius:var(--radio); overflow:hidden; box-shadow:var(--sombra-sm); margin-top:18px; border:1px solid #eadfce; }
.map-wrap iframe{ width:100%; height:260px; border:0; display:block; }
.detail .cta-row{ display:flex; gap:10px; flex-wrap:wrap; margin-top:18px; }

.related{ background:var(--humo); }

/* ---------- Búsqueda ---------- */
.search-page-bar{ max-width:660px; margin:0 auto 8px; }
#searchResults.biz-grid{ margin-top:20px; }

/* ---------- Páginas simples (sobre, legal, artículos) ---------- */
.prose{ max-width:760px; margin:0 auto; padding:50px 0 70px; }
.prose h2{ font-family:var(--font-display); font-weight:700; font-size:1.5rem; margin:34px 0 12px; }
.prose p{ color:#3a3a3a; margin:0 0 14px; }
.prose ul{ color:#3a3a3a; }

@media (max-width:768px){
  .detail-grid{ grid-template-columns:1fr; }
  .infocard{ position:static; }
}
