/*
Theme Name: Milongas
Theme URI: https://www.restaurantemilongas.es/
Description: Tema hijo de GeneratePress para Milongas — asador argentino en Sevilla. Sistema de diseño propio.
Author: Milongas
Template: generatepress
Version: 1.0.0
Text Domain: milongas
*/

/* ============================================================
   MILONGAS · SISTEMA DE DISEÑO
   Asador argentino · estética oscura + rojo brasa
   ============================================================ */
:root{
  --mil-black:#0d0d0d;
  --mil-ink:#141414;
  --mil-red:#9b000e;
  --mil-red-dark:#7a000b;
  --mil-cream:#f5f2ee;
  --mil-cream-2:#efe9e1;
  --mil-white:#ffffff;
  --mil-grey:#cfcfcf;
  --mil-muted:rgba(255,255,255,.62);
  --mil-line:rgba(255,255,255,.16);
  --f-display:"Vast Shadow", serif;
  --f-serif:"Playfair Display", Georgia, serif;
  --f-body:"Cairo", "Segoe UI", sans-serif;
  --f-round:"Varela Round", sans-serif;
  --mil-wrap:1180px;
}

/* ---------- BASE ---------- */
body{ font-family:var(--f-body); color:var(--mil-ink); background:var(--mil-cream); line-height:1.7; }
.site-content{ background:var(--mil-cream); }
h1,h2,h3,h4,h5,h6{ font-family:var(--f-serif); line-height:1.25; }
a{ color:var(--mil-red); }
img{ max-width:100%; height:auto; }

/* Quitar márgenes raros del contenedor GP en páginas full-design */
.mil-page .entry-content{ margin:0; }
.mil-page .inside-article{ padding:0; }
.mil-page .entry-header{ display:none; }

/* Contenedor centrado reutilizable */
.mil-wrap{ max-width:var(--mil-wrap); margin:0 auto; padding:0 24px; }

/* ---------- ETIQUETA / EYEBROW ---------- */
.mil-eyebrow{
  display:inline-block; font-family:var(--f-body); font-weight:900;
  letter-spacing:.28em; text-transform:uppercase; font-size:.72rem;
  color:var(--mil-red);
}
.mil-eyebrow--light{ color:#e7b9bd; }

/* ---------- BOTONES ---------- */
.mil-btn{
  display:inline-block; font-family:var(--f-body); font-weight:700;
  letter-spacing:.12em; text-transform:uppercase; font-size:.82rem;
  padding:15px 34px; background:var(--mil-black); color:#fff !important;
  border:none; text-decoration:none; cursor:pointer; transition:.2s ease;
}
.mil-btn:hover{ background:var(--mil-red); color:#fff !important; }
.mil-btn--red{ background:var(--mil-red); }
.mil-btn--red:hover{ background:var(--mil-black); }
.mil-btn--ghost{ background:transparent; border:1px solid #fff; }
.mil-btn--ghost:hover{ background:#fff; color:var(--mil-black) !important; }
.mil-btn-row{ display:flex; flex-wrap:wrap; gap:14px; }
.mil-btn-row.is-center{ justify-content:center; }

/* ---------- SECCIONES ---------- */
.mil-section{ padding:84px 0; }
.mil-section--dark{ background:var(--mil-black); color:#fff; }
.mil-section--ink{ background:var(--mil-ink); color:#fff; }
.mil-section--cream{ background:var(--mil-cream); }
.mil-section--tight{ padding:56px 0; }
.mil-section--dark h1,.mil-section--dark h2,.mil-section--dark h3,
.mil-section--ink h1,.mil-section--ink h2,.mil-section--ink h3{ color:#fff; }

.mil-head{ text-align:center; max-width:760px; margin:0 auto 48px; }
.mil-head h2{ font-size:clamp(2rem,4vw,3.2rem); margin:.3em 0 .2em; }
.mil-head p{ color:inherit; opacity:.85; }
.mil-section--cream .mil-head p{ color:#5a5450; opacity:1; }

/* ---------- HERO ---------- */
.mil-hero{
  position:relative; min-height:78vh; display:flex; align-items:center;
  justify-content:center; text-align:center; color:#fff;
  background:#000 center/cover no-repeat;
}
.mil-hero::before{
  content:""; position:absolute; inset:0;
  background:radial-gradient(ellipse at bottom right, rgba(0,0,0,.5) 30%, #000 100%);
  opacity:.92;
}
.mil-hero__inner{ position:relative; z-index:2; padding:90px 24px; max-width:880px; }
.mil-hero__eyebrow{
  font-family:var(--f-body); font-weight:900; letter-spacing:.5em;
  text-transform:uppercase; font-size:.95rem; display:block; margin-bottom:18px;
  text-shadow:0 2px 14px rgba(0,0,0,.8);
}
.mil-hero__title{
  font-family:var(--f-serif); font-weight:900;
  font-size:clamp(2.2rem,5.2vw,4rem); line-height:1.12; margin:0 0 .25em;
  text-shadow:0 6px 26px rgba(0,0,0,.85);
}
.mil-hero__title--display{
  font-family:var(--f-display); font-weight:400;
  font-size:clamp(2.6rem,7vw,5.2rem); letter-spacing:.02em;
}
.mil-hero__sub{
  font-family:var(--f-body); font-weight:700; letter-spacing:.34em;
  text-transform:uppercase; font-size:.9rem; opacity:.92; margin-bottom:32px;
}

/* ---------- TIRA DE CARACTERÍSTICAS (parrilla / vinos / punto) ---------- */
.mil-features{ display:grid; grid-template-columns:repeat(4,1fr); gap:1px; background:var(--mil-line); }
.mil-features .feat{ background:var(--mil-black); padding:30px 18px; text-align:center; }
.mil-features .feat h5{ font-family:var(--f-body); font-weight:900; letter-spacing:.06em; color:#fff; font-size:1rem; margin:0 0 4px; }
.mil-features .feat span{ color:var(--mil-red); font-weight:700; font-size:.85rem; letter-spacing:.04em; }

/* ---------- TARJETAS DE RESTAURANTE ---------- */
.mil-cards{ display:grid; grid-template-columns:repeat(2,1fr); gap:28px; }
.mil-card{ background:#fff; overflow:hidden; box-shadow:0 18px 40px rgba(0,0,0,.10); }
.mil-card__img{ aspect-ratio:16/10; background:#222 center/cover no-repeat; }
.mil-card__body{ padding:28px; text-align:center; }
.mil-card__body h3{ font-size:1.7rem; margin:.1em 0 .3em; }
.mil-card__meta{ color:#6a6460; font-size:.92rem; margin-bottom:18px; }

/* ---------- BLOQUES DE CONTACTO / BLURB ---------- */
.mil-blurbs{ display:grid; grid-template-columns:repeat(3,1fr); gap:24px; text-align:center; }
.mil-blurb{ padding:14px; }
.mil-blurb .ic{ font-size:1.8rem; color:var(--mil-red); margin-bottom:8px; }
.mil-blurb h4{ font-family:var(--f-round); font-size:1.15rem; margin:0 0 4px; color:inherit; }
.mil-blurb a{ color:inherit; text-decoration:none; }

/* ---------- HORARIOS ---------- */
.mil-hours{ max-width:480px; margin:0 auto; width:100%; }
.mil-hours li{ display:flex; justify-content:space-between; gap:16px; padding:9px 4px; border-bottom:1px solid var(--mil-line); list-style:none; }
.mil-hours li span:first-child{ font-weight:700; }
.mil-hours li.closed span:last-child{ color:var(--mil-red); font-weight:700; }
.mil-hours ul{ margin:0; padding:0; }

/* ---------- GALERÍA ---------- */
.mil-gallery{ display:grid; grid-template-columns:repeat(4,1fr); gap:8px; }
.mil-gallery .g{ aspect-ratio:1/1; background:#222 center/cover no-repeat; }

/* ---------- BADGES (tripadvisor) ---------- */
.mil-badges{ display:flex; flex-wrap:wrap; gap:22px; justify-content:center; align-items:center; }
.mil-badges img{ height:96px; width:auto; }

/* ---------- CTA ---------- */
.mil-cta{ background:var(--mil-red); color:#fff; text-align:center; padding:70px 24px; }
.mil-cta h2{ color:#fff; font-size:clamp(1.8rem,3.5vw,2.8rem); margin:0 0 .4em; }
.mil-cta .mil-btn{ background:#fff; color:var(--mil-red) !important; }
.mil-cta .mil-btn:hover{ background:var(--mil-black); color:#fff !important; }

/* ---------- RESERVAS (CoverManager) ---------- */
.mil-reserve{ max-width:880px; margin:0 auto; }
.mil-reserve iframe{ width:100%; min-height:620px; border:0; background:#fff; }

/* ---------- CARTA / MENÚ ---------- */
.mil-menu-cat{ margin:0 auto 46px; max-width:760px; }
.mil-menu-cat > h3{ text-align:center; font-size:1.9rem; color:var(--mil-red); margin-bottom:6px; }
.mil-menu-cat__rule{ width:60px; height:3px; background:var(--mil-red); margin:0 auto 26px; }
.mil-dish{ display:flex; justify-content:space-between; gap:16px; align-items:baseline; padding:12px 0; border-bottom:1px dashed rgba(0,0,0,.14); }
.mil-dish__name{ font-weight:700; }
.mil-dish__desc{ display:block; font-weight:400; font-size:.9rem; color:#6a6460; }
.mil-dish__price{ font-family:var(--f-serif); font-weight:700; color:var(--mil-red); white-space:nowrap; }

/* ---------- PÁGINAS LEGALES / TEXTO ---------- */
.mil-prose{ max-width:820px; margin:0 auto; }
.mil-prose h2{ font-size:1.6rem; margin:1.4em 0 .4em; }
.mil-prose h3{ font-size:1.25rem; margin:1.2em 0 .3em; }
.mil-prose ul{ padding-left:1.2em; }

/* ---------- FORMULARIO ---------- */
.mil-form-wrap{ max-width:760px; margin:0 auto; }
.mil-form .hp{ position:absolute; left:-9999px; }
.mil-form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.mil-form label{ display:block; font-weight:700; font-size:.85rem; letter-spacing:.04em; }
.mil-form input,.mil-form select,.mil-form textarea{
  width:100%; margin-top:6px; padding:11px 12px; border:1px solid #cfc7bf;
  background:#fff; font-family:var(--f-body); font-weight:400; font-size:1rem;
}
.mil-form-radio{ border:1px solid #cfc7bf; padding:12px 16px; margin:16px 0; }
.mil-form-radio legend{ font-weight:700; padding:0 6px; }
.mil-form-radio label{ display:inline-block; margin-right:22px; font-weight:400; }
.mil-form-radio input{ width:auto; margin:0 6px 0 0; display:inline; }
.mil-form-full{ display:block; margin:6px 0 18px; }
.mil-form button{ margin-top:6px; }
.mil-form-ok{ background:#e7f4e8; border:1px solid #28a745; color:#1c6b2c; padding:16px 18px; margin-bottom:22px; font-weight:600; }
@media (max-width:560px){ .mil-form-grid{ grid-template-columns:1fr; } }

/* ============================================================
   CABECERA + NAVEGACIÓN (GeneratePress)
   ============================================================ */
.site-header{ background:var(--mil-black); }
.site-header .inside-header{ padding-top:12px; padding-bottom:12px; }
.site-logo img,.custom-logo,.header-image{ max-height:68px; width:auto; }
/* Con logo, ocultamos el texto del título y la descripción */
.site-branding .main-title,.site-description{ display:none; }
.main-navigation{ background:var(--mil-black); }
.main-navigation .main-nav ul li a{
  font-family:var(--f-body); font-weight:700; letter-spacing:.12em;
  text-transform:uppercase; font-size:.8rem; color:#fff;
}
.main-navigation .main-nav ul li a:hover,
.main-navigation .main-nav ul li.current-menu-item a{ color:var(--mil-red); }
.main-navigation .main-nav ul li.menu-item-has-children > a{ }
.main-navigation ul ul{ background:var(--mil-ink); }
.main-navigation .main-nav ul ul li a{ font-size:.78rem; }
.site-logo img,.header-image{ max-height:64px; width:auto; }
.site-branding .site-title{ font-family:var(--f-display); }
.site-branding a{ color:#fff; }
/* conmutador de idiomas — pastilla flotante arriba a la derecha */
.mil-lang{
  position:fixed; top:16px; right:18px; z-index:9999;
  display:flex; align-items:center; gap:9px; list-style:none; margin:0; padding:7px 12px;
  background:rgba(13,13,13,.72); border:1px solid rgba(255,255,255,.18); border-radius:30px;
  backdrop-filter:blur(4px);
}
.mil-lang li{ margin:0; }
.mil-lang a{ display:block; opacity:.6; transition:.2s; }
.mil-lang a:hover,.mil-lang .current-lang a{ opacity:1; }
.mil-lang .current-lang a{ outline:2px solid var(--mil-red); outline-offset:1px; border-radius:2px; }
.mil-lang img{ width:24px; height:auto; display:block; border-radius:2px; }
.mil-lang-wrap{ display:contents; }

/* botón reservar en menú */
.main-navigation .main-nav ul li.mil-nav-cta a{ background:var(--mil-red); color:#fff; margin:6px 0; }
.main-navigation .main-nav ul li.mil-nav-cta a:hover{ background:#fff; color:var(--mil-red); }

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer,.footer-widgets{ background:var(--mil-black); color:var(--mil-muted); }
.site-footer .footer-widget-area .widget-title,
.footer-widgets .widget-title{ color:#fff; font-family:var(--f-serif); font-size:1.15rem; }
.site-info{ background:var(--mil-ink); color:var(--mil-muted); padding:0; }
.site-info .inside-site-info{ padding:0; max-width:none; }
.footer-widgets a,.site-info a{ color:var(--mil-grey); text-decoration:none; }
.footer-widgets a:hover{ color:var(--mil-red); }

/* Footer personalizado */
.mil-footer{ background:var(--mil-black); color:var(--mil-muted); }
.mil-footer__grid{ display:grid; grid-template-columns:1.4fr 1fr 1.3fr; gap:40px; padding:60px 24px 40px; text-align:left; }
.mil-footer__brand{ font-family:var(--f-display); font-size:1.9rem; color:#fff; margin-bottom:12px; }
.mil-footer h4{ color:#fff; font-family:var(--f-serif); font-size:1.15rem; margin:0 0 14px; }
.mil-footer ul{ list-style:none; margin:0; padding:0; }
.mil-footer li{ margin:0 0 8px; }
.mil-footer p{ margin:0 0 14px; font-size:.92rem; line-height:1.7; }
.mil-footer__social{ display:flex; gap:18px; margin-top:14px; }
.mil-footer__social a{ font-weight:700; letter-spacing:.04em; text-transform:uppercase; font-size:.78rem; color:#fff; }
.mil-footer__social a:hover{ color:var(--mil-red); }
.mil-footer__bar{ border-top:1px solid var(--mil-line); padding:20px 24px; display:flex; justify-content:space-between; flex-wrap:wrap; gap:12px; font-size:.82rem; max-width:1180px; margin:0 auto; }
.mil-footer__legal{ display:flex; gap:16px; flex-wrap:wrap; }
@media (max-width:900px){ .mil-footer__grid{ grid-template-columns:1fr; gap:28px; } .mil-footer__bar{ flex-direction:column; } }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:900px){
  .mil-cards,.mil-blurbs{ grid-template-columns:1fr; }
  .mil-features{ grid-template-columns:repeat(2,1fr); }
  .mil-gallery{ grid-template-columns:repeat(2,1fr); }
  .mil-section{ padding:60px 0; }
}
@media (max-width:560px){
  .mil-features{ grid-template-columns:1fr; }
  .mil-badges img{ height:70px; }
}
