/*
Theme Name: Café Grillo Nacionalista
Theme URI: https://www.cafegrillo.com.mx/
Author: Maya Comunicación
Author URI: https://www.mayacomunicacion.com.mx/
Description: Tema editorial mexicano, colorido e interactivo para Café Grillo. Diseñado para noticias nacionales, política, CDMX, Congreso, opinión y monetización publicitaria.
Version: 1.4.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GNU General Public License v2 or later
Text Domain: cafe-grillo-nacionalista
Tags: news, magazine, mexican, editorial, responsive, custom-logo, featured-images
*/

:root{
  --cg-cafe:#3A2417;
  --cg-cafe-2:#5B321D;
  --cg-crema:#FFF4DA;
  --cg-maiz:#F6B630;
  --cg-rojo:#B3261E;
  --cg-verde:#1F7A3A;
  --cg-verde-2:#0B5F35;
  --cg-azul:#0B3D91;
  --cg-tinta:#111111;
  --cg-gris:#f4f4f4;
  --cg-blanco:#ffffff;
  --cg-sombra:0 16px 40px rgba(0,0,0,.14);
  --cg-radio:22px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  color:var(--cg-tinta);
  background:
    radial-gradient(circle at top left, rgba(246,182,48,.25), transparent 28%),
    radial-gradient(circle at top right, rgba(31,122,58,.20), transparent 25%),
    linear-gradient(180deg,var(--cg-crema),#fff);
  line-height:1.58;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.container{width:min(1180px,92vw);margin:auto}
.screen-reader-text{position:absolute;left:-9999px}

.top-strip{
  background:linear-gradient(90deg,var(--cg-verde),var(--cg-blanco),var(--cg-rojo));
  height:9px;
}
.site-header{
  background:rgba(58,36,23,.96);
  color:var(--cg-crema);
  position:sticky;
  top:0;
  z-index:50;
  box-shadow:0 10px 24px rgba(0,0,0,.22);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  padding:14px 0;
}
.brand{
  display:flex;
  align-items:center;
  gap:14px;
  min-width:240px;
}
.brand-copy{
  display:flex;
  flex-direction:column;
  gap:4px;
}
.admin-bar .site-header{top:32px}
.brand-mark{
  width:58px;
  height:58px;
  border-radius:18px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--cg-maiz),#ffe7a0);
  color:var(--cg-cafe);
  box-shadow:inset 0 0 0 3px rgba(58,36,23,.2);
  font-size:32px;
}
.site-title{
  margin:0;
  font-family: Georgia, "Times New Roman", serif;
  font-size:clamp(1.45rem,3vw,2.2rem);
  letter-spacing:.5px;
  line-height:1;
  display:block;
  font-weight:900;
}
.site-title span{color:var(--cg-maiz)}
.site-description{
  margin:4px 0 0;
  color:#f9db9b;
  font-size:.86rem;
  display:block;
}
.custom-logo-link img{max-height:64px;width:auto}

.main-navigation ul{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  padding:0;
  margin:0;
  align-items:center;
  justify-content:flex-end;
}
.main-navigation a{
  display:block;
  padding:10px 12px;
  border-radius:999px;
  font-weight:800;
  font-size:.9rem;
  text-transform:uppercase;
  letter-spacing:.02em;
}
.main-navigation a:hover{
  background:var(--cg-maiz);
  color:var(--cg-cafe);
}
.menu-toggle{
  display:none;
  border:0;
  padding:10px 14px;
  border-radius:999px;
  font-weight:900;
  background:var(--cg-maiz);
  color:var(--cg-cafe);
}

.breaking{
  background:var(--cg-rojo);
  color:#fff;
  overflow:hidden;
  border-bottom:4px solid var(--cg-maiz);
}
.breaking .container{
  display:flex;
  gap:16px;
  align-items:center;
  padding:9px 0;
}
.breaking-label{
  white-space:nowrap;
  background:#fff;
  color:var(--cg-rojo);
  padding:5px 10px;
  border-radius:999px;
  font-weight:900;
  text-transform:uppercase;
}
.breaking-marquee{
  overflow:hidden;
  white-space:nowrap;
  flex:1;
}
.breaking-track{
  display:inline-block;
  animation:cg-marquee 28s linear infinite;
}
.breaking-track a{margin-right:42px;font-weight:700}
@keyframes cg-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

.ad-slot{
  border:2px dashed rgba(58,36,23,.35);
  background:
    linear-gradient(135deg,rgba(31,122,58,.13),rgba(246,182,48,.18),rgba(179,38,30,.12)),
    #fff;
  border-radius:var(--cg-radio);
  color:var(--cg-cafe);
  display:grid;
  place-items:center;
  text-align:center;
  padding:22px;
  font-weight:900;
  min-height:110px;
}
.ad-slot small{display:block;font-weight:600;margin-top:4px}
.ad-top{margin:24px auto}

.hero{
  padding:26px 0;
}
.hero-grid{
  display:grid;
  grid-template-columns:1.35fr .75fr;
  gap:22px;
}
.card{
  background:rgba(255,255,255,.92);
  border-radius:var(--cg-radio);
  overflow:hidden;
  box-shadow:var(--cg-sombra);
  border:1px solid rgba(58,36,23,.12);
}
.hero-main{
  min-height:520px;
  display:grid;
  grid-template-rows:1fr auto;
  position:relative;
  isolation:isolate;
  color:#fff;
}
.hero-main::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.05),rgba(0,0,0,.85));
  z-index:-1;
}
.hero-main .post-thumb{
  position:absolute;
  inset:0;
  z-index:-2;
}
.post-thumb img{width:100%;height:100%;object-fit:cover}
.hero-content{
  align-self:end;
  padding:32px;
}
.kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--cg-maiz);
  color:var(--cg-cafe);
  padding:6px 11px;
  border-radius:999px;
  font-size:.78rem;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.hero-title{
  margin:18px 0 10px;
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(2rem,5vw,4.3rem);
  line-height:.98;
  text-wrap:balance;
}
.excerpt{color:rgba(255,255,255,.88);font-size:1.05rem}
.meta{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  font-size:.85rem;
  color:#6c5a4b;
}
.hero-main .meta{color:#ffe7a0}
.read-more{
  display:inline-flex;
  align-items:center;
  gap:8px;
  margin-top:16px;
  background:var(--cg-verde);
  color:#fff;
  border-radius:999px;
  padding:10px 15px;
  font-weight:900;
}
.read-more:hover{background:var(--cg-rojo)}

.side-stack{
  display:grid;
  grid-template-rows:1fr 1fr;
  gap:22px;
}
.side-card{
  min-height:249px;
  position:relative;
  display:grid;
  align-content:end;
  color:#fff;
  overflow:hidden;
}
.side-card::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,.08),rgba(0,0,0,.8));
}
.side-card > *{position:relative;z-index:2}
.side-card-content{padding:22px}
.side-card h2{font-family:Georgia,"Times New Roman",serif;font-size:1.45rem;line-height:1.05;margin:12px 0 0}

.section{
  padding:28px 0;
}
.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:16px;
  margin-bottom:18px;
  border-bottom:5px solid var(--cg-cafe);
}
.section-title{
  display:inline-block;
  margin:0;
  color:#fff;
  background:linear-gradient(90deg,var(--cg-cafe),var(--cg-rojo));
  padding:9px 16px;
  border-radius:18px 18px 0 0;
  font-family:Georgia,"Times New Roman",serif;
  font-size:1.55rem;
}
.section-desc{margin:0 0 10px;color:#6c5a4b;font-weight:700}

.news-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.post-card{
  transition:.2s ease;
}
.post-card:hover{
  transform:translateY(-4px);
  box-shadow:0 22px 45px rgba(0,0,0,.18);
}
.post-card .post-thumb{aspect-ratio:16/10;background:#ddd}
.post-card-content{padding:18px}
.post-card h3{
  margin:10px 0;
  font-size:1.15rem;
  line-height:1.15;
  font-family:Georgia,"Times New Roman",serif;
}
.post-card p{color:#4a4a4a;margin:.5rem 0}

.two-col{
  display:grid;
  grid-template-columns:2fr .85fr;
  gap:24px;
  align-items:start;
}
.sidebar{
  position:sticky;
  top:115px;
  display:grid;
  gap:18px;
}
.widgetish{
  padding:20px;
  background:#fff;
  border-radius:var(--cg-radio);
  box-shadow:var(--cg-sombra);
}
.widgetish h3{
  margin-top:0;
  color:var(--cg-cafe);
  font-family:Georgia,"Times New Roman",serif;
}
.trend-list{counter-reset:trend;list-style:none;margin:0;padding:0}
.trend-list li{
  counter-increment:trend;
  display:grid;
  grid-template-columns:42px 1fr;
  gap:12px;
  padding:12px 0;
  border-bottom:1px solid #eee;
}
.trend-list li::before{
  content:counter(trend);
  width:36px;height:36px;border-radius:50%;
  display:grid;place-items:center;
  background:var(--cg-maiz);
  color:var(--cg-cafe);
  font-weight:1000;
}
.trend-list a{font-weight:900}

.category-band{
  background:
    linear-gradient(135deg,rgba(58,36,23,.93),rgba(11,95,53,.9)),
    var(--cg-cafe);
  color:#fff;
  padding:34px 0;
  margin:28px 0;
}
.category-pills{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.category-pill{
  padding:22px;
  border-radius:24px;
  background:rgba(255,255,255,.1);
  border:1px solid rgba(255,255,255,.22);
  min-height:130px;
  transition:.2s ease;
}
.category-pill:hover{
  background:var(--cg-maiz);
  color:var(--cg-cafe);
  transform:scale(1.02);
}
.category-pill strong{
  display:block;
  font-family:Georgia,"Times New Roman",serif;
  font-size:1.35rem;
  margin-bottom:6px;
}

.site-footer{
  margin-top:40px;
  background:var(--cg-cafe);
  color:var(--cg-crema);
  padding:38px 0 18px;
  border-top:8px solid var(--cg-maiz);
}
.footer-grid{
  display:grid;
  grid-template-columns:1.3fr 1fr 1fr;
  gap:24px;
}
.site-footer h3{font-family:Georgia,"Times New Roman",serif;color:var(--cg-maiz)}
.footer-bottom{
  margin-top:26px;
  padding-top:18px;
  border-top:1px solid rgba(255,255,255,.18);
  color:#dfc690;
  font-size:.9rem;
}
.footer-bottom a{text-decoration:underline}

.article-wrap{
  width:min(840px,92vw);
  margin:34px auto;
  background:#fff;
  padding:clamp(22px,5vw,48px);
  border-radius:var(--cg-radio);
  box-shadow:var(--cg-sombra);
}
.article-title{
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(2rem,5vw,3.5rem);
  line-height:1;
  margin:.3em 0;
}
.article-content{
  font-size:1.1rem;
}
.article-content p{margin:1.1em 0}
.article-content a{text-decoration:underline;color:var(--cg-rojo)}
.article-content h2,.article-content h3{
  font-family:Georgia,"Times New Roman",serif;
  color:var(--cg-cafe);
}
.archive-header{
  padding:38px 0 10px;
}
.pagination{
  display:flex;
  justify-content:center;
  gap:8px;
  margin:28px 0;
}
.pagination .page-numbers{
  padding:9px 13px;
  border-radius:12px;
  background:#fff;
  box-shadow:0 6px 15px rgba(0,0,0,.08);
  font-weight:800;
}
.pagination .current{background:var(--cg-cafe);color:#fff}

.floating-whatsapp{
  position:fixed;
  right:18px;
  bottom:18px;
  z-index:60;
  background:#25d366;
  color:#fff;
  border-radius:999px;
  padding:13px 17px;
  font-weight:1000;
  box-shadow:0 12px 30px rgba(0,0,0,.25);
}
.floating-whatsapp:hover{filter:brightness(.95)}

@media(max-width:900px){
  .menu-toggle{display:inline-flex}
  .main-navigation{display:none;position:absolute;left:0;right:0;top:100%;background:var(--cg-cafe);padding:14px 4vw}
  .main-navigation.is-open{display:block}
  .main-navigation ul{display:grid;justify-content:stretch}
  .main-navigation a{background:rgba(255,255,255,.08)}
  .hero-grid,.two-col,.footer-grid{grid-template-columns:1fr}
  .side-stack{grid-template-rows:auto}
  .news-grid{grid-template-columns:1fr 1fr}
  .category-pills{grid-template-columns:1fr 1fr}
  .sidebar{position:static}
}
@media(max-width:620px){
  .header-inner{align-items:flex-start}
  .brand-mark{width:48px;height:48px}
  .news-grid,.category-pills{grid-template-columns:1fr}
  .hero-main{min-height:430px}
  .hero-content{padding:22px}
}

@media(max-width:782px){.admin-bar .site-header{top:46px}}


/* === Café Grillo v1.2: cabecera premium nacionalista === */
.admin-bar .site-header{top:32px}
.site-header{
  background:
    radial-gradient(circle at 88% 30%, rgba(185,130,43,.18), transparent 22%),
    radial-gradient(circle at 8% 30%, rgba(246,182,48,.10), transparent 24%),
    linear-gradient(135deg,#1d0f08 0%,#3A2417 45%,#1a0d07 100%);
  color:var(--cg-crema);
  position:sticky;
  top:0;
  z-index:50;
  box-shadow:0 18px 40px rgba(0,0,0,.35);
  isolation:isolate;
}
.site-header::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    repeating-linear-gradient(45deg, rgba(255,255,255,.025) 0 1px, transparent 1px 12px),
    radial-gradient(circle at 92% 45%, rgba(255,244,218,.08), transparent 28%);
  z-index:-2;
}
.site-header::after{
  content:"";
  position:absolute;
  right:7vw;
  top:10px;
  width:210px;
  height:150px;
  border-radius:50%;
  background:
    radial-gradient(circle, rgba(185,130,43,.18), transparent 62%);
  opacity:.8;
  z-index:-1;
}
.header-inner{
  min-height:132px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:28px;
  padding:18px 0 15px;
}
.brand{
  display:flex;
  align-items:center;
  gap:18px;
  min-width:420px;
}
.brand-logo-lockup{
  display:flex;
  align-items:center;
  gap:18px;
}
.brand-mark{
  width:104px;
  height:104px;
  border-radius:30px;
  display:grid;
  place-items:center;
  background:
    linear-gradient(145deg,rgba(255,244,218,.08),rgba(246,182,48,.20)),
    #241006;
  color:var(--cg-crema);
  box-shadow:
    inset 0 0 0 3px rgba(246,182,48,.78),
    inset 0 0 0 8px rgba(58,36,23,.9),
    0 18px 30px rgba(0,0,0,.34);
  position:relative;
  overflow:hidden;
}
.brand-mark::before{
  content:"☕";
  font-size:56px;
  line-height:1;
  filter:drop-shadow(0 3px 0 rgba(0,0,0,.24));
}
.brand-mark::after{
  content:"";
  position:absolute;
  left:20px;
  right:20px;
  bottom:17px;
  height:3px;
  border-radius:999px;
  background:linear-gradient(90deg,transparent,var(--cg-maiz),transparent);
}
.brand-text{display:block}
.site-title{
  margin:0;
  font-family:Georgia,"Times New Roman",serif;
  font-size:clamp(2.45rem,5vw,4.45rem);
  letter-spacing:.02em;
  line-height:.84;
  text-transform:uppercase;
  color:#fff3d2;
  text-shadow:0 4px 0 rgba(0,0,0,.18), 0 10px 28px rgba(0,0,0,.42);
}
.site-title span{color:#fff3d2}
.site-description{
  margin:13px 0 0;
  display:flex;
  align-items:center;
  gap:10px;
  color:#f5cc72;
  font-size:.96rem;
  font-weight:900;
  letter-spacing:.22em;
  text-transform:uppercase;
}
.site-description::before,
.site-description::after{
  content:"";
  width:44px;
  height:2px;
  background:var(--cg-maiz);
  display:inline-block;
}
.custom-logo-link{
  display:flex;
  align-items:center;
}
.custom-logo-link img{
  max-height:112px;
  width:auto;
  filter:drop-shadow(0 12px 18px rgba(0,0,0,.35));
}
.main-navigation{
  margin-left:auto;
  max-width:540px;
}
.main-navigation ul{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:6px 10px;
  padding:0;
  margin:0;
  align-items:center;
  justify-content:flex-end;
}
.main-navigation a{
  display:block;
  padding:9px 10px;
  border-radius:0;
  font-weight:1000;
  font-size:.86rem;
  text-transform:uppercase;
  letter-spacing:.045em;
  color:#fff6df;
  border-bottom:2px solid transparent;
}
.main-navigation a:hover,
.main-navigation .current-menu-item > a{
  color:#fff;
  border-bottom-color:var(--cg-maiz);
  background:rgba(255,244,218,.08);
}
.menu-toggle{
  display:none;
  border:0;
  padding:11px 16px;
  border-radius:999px;
  font-weight:1000;
  background:var(--cg-maiz);
  color:var(--cg-cafe);
}
.cg-tricolor{
  height:9px;
  background:linear-gradient(90deg,var(--cg-verde) 0 33.3%,#fff 33.3% 66.6%,var(--cg-rojo) 66.6% 100%);
  box-shadow:0 5px 15px rgba(0,0,0,.25);
}
.header-eagle{
  position:absolute;
  right:5.5vw;
  top:12px;
  width:190px;
  height:130px;
  opacity:.16;
  pointer-events:none;
  background:
    radial-gradient(circle at 45% 42%, rgba(246,182,48,.7), transparent 12%),
    radial-gradient(circle at 50% 50%, transparent 0 38%, rgba(246,182,48,.45) 39% 40%, transparent 41%);
  border-radius:50%;
}
.header-eagle::before{
  content:"";
  position:absolute;
  inset:25px 28px;
  border:2px solid rgba(246,182,48,.55);
  border-left:0;
  border-bottom:0;
  transform:rotate(-18deg);
  border-radius:50%;
}
.header-eagle::after{
  content:"";
  position:absolute;
  right:35px;
  top:22px;
  width:62px;
  height:62px;
  border-top:5px solid rgba(246,182,48,.65);
  border-right:5px solid rgba(246,182,48,.65);
  transform:rotate(35deg);
  border-radius:10px;
}

@media(max-width:900px){
  .admin-bar .site-header{top:46px}
  .header-inner{min-height:auto;align-items:center}
  .brand{min-width:auto}
  .brand-mark{width:74px;height:74px;border-radius:22px}
  .brand-mark::before{font-size:42px}
  .site-title{font-size:clamp(2rem,8vw,3rem)}
  .site-description{font-size:.7rem;letter-spacing:.12em}
  .site-description::before,.site-description::after{width:24px}
  .menu-toggle{display:inline-flex}
  .main-navigation{display:none;position:absolute;left:0;right:0;top:100%;background:#241006;padding:14px 4vw;max-width:none}
  .main-navigation.is-open{display:block}
  .main-navigation ul{display:grid;justify-content:stretch}
  .main-navigation a{background:rgba(255,255,255,.08);border-radius:14px;border-bottom:0}
  .header-eagle{display:none}
}
@media(max-width:620px){
  .brand-logo-lockup{gap:12px}
  .brand-mark{width:60px;height:60px}
  .brand-mark::before{font-size:34px}
  .site-title{font-size:2rem}
  .site-description{margin-top:8px}
  .site-description::before,.site-description::after{display:none}
}


/* === Café Grillo v1.3: cabecera reducida + segundo menú === */
.site-header.compact-header{
  background:
    radial-gradient(circle at 8% 20%, rgba(246,182,48,.10), transparent 24%),
    linear-gradient(135deg,#1d0f08 0%,#3A2417 52%,#1a0d07 100%);
  position:sticky;
  top:0;
  z-index:70;
}
.admin-bar .site-header.compact-header{top:32px}

.compact-header .header-inner{
  min-height:76px;
  padding:8px 0 7px;
  gap:20px;
}

.compact-header .brand{
  min-width:330px;
}

.compact-header .brand-logo-lockup{
  gap:13px;
}

.compact-header .brand-mark{
  width:64px;
  height:64px;
  border-radius:18px;
  box-shadow:
    inset 0 0 0 2px rgba(246,182,48,.78),
    inset 0 0 0 5px rgba(58,36,23,.9),
    0 10px 18px rgba(0,0,0,.28);
}

.compact-header .brand-mark::before{
  font-size:36px;
}

.compact-header .brand-mark::after{
  left:14px;
  right:14px;
  bottom:11px;
}

.compact-header .site-title{
  font-size:clamp(1.85rem,3.4vw,3rem);
  line-height:.88;
  letter-spacing:.01em;
}

.compact-header .site-description{
  margin:8px 0 0;
  font-size:.68rem;
  letter-spacing:.28em;
  color:#f5cc72;
}

.compact-header .site-description::before,
.compact-header .site-description::after{
  width:28px;
}

.compact-header .custom-logo-link img,
.compact-header .custom-logo{
  max-height:78px;
  width:auto;
}

.compact-header .main-navigation{
  max-width:580px;
}

.compact-header .main-navigation a{
  padding:7px 8px;
  font-size:.78rem;
  line-height:1.15;
}

.compact-header .cg-tricolor{
  height:6px;
}

.secondary-navigation{
  position:sticky;
  top:89px;
  z-index:60;
  background:
    linear-gradient(90deg,rgba(11,95,53,.96),rgba(58,36,23,.98),rgba(179,38,30,.96));
  color:#fff;
  box-shadow:0 8px 18px rgba(0,0,0,.18);
  border-bottom:2px solid var(--cg-maiz);
}

.admin-bar .secondary-navigation{
  top:121px;
}

.secondary-inner{
  display:flex;
  align-items:center;
  gap:16px;
  min-height:42px;
}

.secondary-label{
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  gap:8px;
  background:var(--cg-maiz);
  color:var(--cg-cafe);
  padding:7px 12px;
  border-radius:999px;
  font-weight:1000;
  text-transform:uppercase;
  font-size:.72rem;
  letter-spacing:.08em;
}

.secondary-label::before{
  content:"☕";
  font-size:.9rem;
}

.secondary-navigation ul{
  list-style:none;
  display:flex;
  flex-wrap:wrap;
  gap:4px 10px;
  padding:0;
  margin:0;
  align-items:center;
}

.secondary-navigation a{
  display:block;
  padding:10px 9px;
  color:#fff;
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.05em;
  text-transform:uppercase;
  border-radius:999px;
}

.secondary-navigation a:hover,
.secondary-navigation .current-menu-item > a{
  background:rgba(255,244,218,.16);
  color:#fff4da;
}

@media(max-width:900px){
  .admin-bar .site-header.compact-header{top:46px}
  .compact-header .header-inner{
    min-height:70px;
    padding:7px 0;
  }
  .compact-header .brand{min-width:auto}
  .compact-header .brand-mark{
    width:54px;
    height:54px;
    border-radius:16px;
  }
  .compact-header .brand-mark::before{font-size:31px}
  .compact-header .site-title{font-size:clamp(1.7rem,7vw,2.35rem)}
  .compact-header .site-description{
    font-size:.58rem;
    letter-spacing:.16em;
  }
  .compact-header .site-description::before,
  .compact-header .site-description::after{display:none}
  .compact-header .custom-logo{
    max-height:60px;
  }
  .secondary-navigation{
    position:relative;
    top:auto;
  }
  .admin-bar .secondary-navigation{top:auto}
  .secondary-inner{
    align-items:flex-start;
    padding:8px 0;
    flex-direction:column;
    gap:8px;
  }
  .secondary-navigation ul{
    width:100%;
    overflow-x:auto;
    flex-wrap:nowrap;
    padding-bottom:4px;
  }
  .secondary-navigation a{
    white-space:nowrap;
    background:rgba(255,255,255,.08);
  }
}

@media(max-width:620px){
  .compact-header .brand-logo-lockup{gap:10px}
  .compact-header .brand-mark{width:48px;height:48px}
  .compact-header .brand-mark::before{font-size:28px}
  .compact-header .site-title{font-size:1.65rem}
  .compact-header .site-description{margin-top:5px}
}


/* === Café Grillo v1.4: ajustes finos de cabecera, menús, hero, sidebar y widgets === */

/* 1) Logo 35%-50% más visible sin inflar demasiado la cabecera */
.compact-header .header-inner{
  min-height:88px;
  padding:10px 0 9px;
}
.compact-header .brand{
  min-width:390px;
}
.compact-header .brand-logo-lockup{
  gap:16px;
}
.compact-header .brand-mark{
  width:82px;
  height:82px;
  border-radius:22px;
}
.compact-header .brand-mark::before{
  font-size:46px;
}
.compact-header .site-title{
  font-size:clamp(2.25rem,4vw,3.65rem);
  line-height:.86;
}
.compact-header .site-description{
  margin-top:9px;
  font-size:.74rem;
  letter-spacing:.30em;
}
.compact-header .custom-logo,
.compact-header .custom-logo-link img{
  max-height:104px;
  width:auto;
}

/* 2) Menú superior menos apretado */
.compact-header .main-navigation{
  max-width:650px;
}
.compact-header .main-navigation ul{
  gap:8px 14px;
}
.compact-header .main-navigation a{
  padding:9px 11px;
  font-size:.86rem;
  line-height:1.2;
  letter-spacing:.055em;
  border-radius:12px;
}
.compact-header .main-navigation a:hover,
.compact-header .main-navigation .current-menu-item > a{
  background:rgba(255,244,218,.12);
}

/* 3) Segundo menú con más aire, etiqueta más visible y separación */
.secondary-navigation{
  top:103px;
  margin-bottom:4px;
  border-bottom:3px solid var(--cg-maiz);
}
.admin-bar .secondary-navigation{
  top:135px;
}
.secondary-inner{
  min-height:52px;
  gap:20px;
}
.secondary-label{
  padding:9px 15px;
  font-size:.78rem;
  box-shadow:0 6px 16px rgba(0,0,0,.18);
}
.secondary-navigation ul{
  gap:6px 14px;
}
.secondary-navigation a{
  padding:11px 12px;
  font-size:.82rem;
}
.secondary-navigation a:hover,
.secondary-navigation .current-menu-item > a{
  background:rgba(255,244,218,.24);
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(255,244,218,.28);
}

/* 4) Hero menos oscuro para recuperar detalle del rostro */
.hero-main::after{
  background:linear-gradient(180deg,rgba(0,0,0,.02) 0%,rgba(0,0,0,.18) 38%,rgba(0,0,0,.68) 100%);
}
.hero-main .post-thumb img{
  filter:brightness(1.10) contrast(1.02);
}

/* 5) Tarjetas secundarias con más aire */
.side-card::after{
  background:linear-gradient(180deg,rgba(0,0,0,.03),rgba(0,0,0,.72));
}
.side-card-content{
  padding:26px 24px;
}
.side-card h2{
  font-size:1.35rem;
  line-height:1.12;
  margin-top:12px;
}

/* 6) Layout de contenido 68% / sidebar 32% */
.two-col{
  grid-template-columns:minmax(0, 68fr) minmax(280px, 32fr);
  gap:30px;
}
.sidebar{
  gap:20px;
}
.widgetish{
  padding:22px;
}

/* Sidebar widgets interactivos */
.cg-chat-widget{
  border:1px solid rgba(58,36,23,.12);
  background:
    radial-gradient(circle at top right, rgba(246,182,48,.18), transparent 38%),
    #fff;
}
.cg-chat-widget h3{
  margin:.45rem 0 .35rem;
  color:var(--cg-cafe);
  font-size:1.22rem;
}
.cg-widget-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  background:var(--cg-cafe);
  color:var(--cg-crema);
  border-radius:999px;
  padding:6px 10px;
  font-size:.72rem;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.05em;
}
.cg-horoscope-widget .cg-widget-badge{
  background:linear-gradient(90deg,var(--cg-cafe),var(--cg-azul));
}
.cg-refran-widget .cg-widget-badge{
  background:linear-gradient(90deg,var(--cg-verde),var(--cg-cafe));
}
.cg-chat-intro{
  color:#5d4b3b;
  font-size:.92rem;
  margin:.35rem 0 .9rem;
}
.cg-chat-select{
  width:100%;
  border:1px solid rgba(58,36,23,.25);
  border-radius:14px;
  padding:11px 12px;
  font-weight:800;
  background:#fffdf5;
  color:var(--cg-cafe);
  margin-bottom:10px;
}
.cg-chat-button{
  width:100%;
  border:0;
  border-radius:999px;
  padding:11px 14px;
  background:var(--cg-rojo);
  color:#fff;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.04em;
  cursor:pointer;
  box-shadow:0 8px 18px rgba(179,38,30,.22);
}
.cg-chat-button:hover{
  background:var(--cg-verde);
}
.cg-chat-response{
  margin-top:12px;
  padding:13px 14px;
  border-radius:16px;
  background:#fff4da;
  border:1px solid rgba(246,182,48,.55);
  color:#352014;
  font-weight:750;
  font-size:.93rem;
  min-height:68px;
}

@media(max-width:1100px){
  .compact-header .brand{min-width:330px}
  .compact-header .main-navigation{max-width:560px}
  .compact-header .main-navigation a{font-size:.78rem;padding:8px 8px}
}

@media(max-width:900px){
  .compact-header .header-inner{
    min-height:76px;
    padding:8px 0;
  }
  .compact-header .brand{min-width:auto}
  .compact-header .brand-mark{
    width:62px;
    height:62px;
  }
  .compact-header .brand-mark::before{
    font-size:36px;
  }
  .compact-header .site-title{
    font-size:clamp(1.9rem,7vw,2.6rem);
  }
  .compact-header .custom-logo,
  .compact-header .custom-logo-link img{
    max-height:74px;
  }
  .secondary-navigation{
    position:relative;
    top:auto;
    margin-bottom:0;
  }
  .admin-bar .secondary-navigation{top:auto}
  .two-col{
    grid-template-columns:1fr;
  }
}

@media(max-width:620px){
  .compact-header .brand-mark{
    width:54px;
    height:54px;
  }
  .compact-header .brand-mark::before{
    font-size:31px;
  }
  .compact-header .site-title{
    font-size:1.85rem;
  }
  .compact-header .site-description{
    font-size:.6rem;
    letter-spacing:.16em;
  }
  .compact-header .custom-logo,
  .compact-header .custom-logo-link img{
    max-height:62px;
  }
  .secondary-inner{
    min-height:auto;
    padding:10px 0;
  }
}
