/*
Theme Name: Cronista Nacional Editorial
Theme URI: https://cronistanacional.com.mx/
Author: Maya Comunicación
Author URI: https://mayacomunicacion.com.mx/
Description: Tema editorial para Cronista Nacional: periódico digital mexicano con estética de tinta, papel, crónica política, CDMX y agenda nacional. Incluye portada, directorio, páginas institucionales y espacios publicitarios.
Version: 1.5.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
License: GPL v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: cronista-nacional
Tags: news, blog, custom-logo, featured-images, editor-style, threaded-comments
*/

:root{
  --cn-tinta:#111111;
  --cn-papel:#f5efe4;
  --cn-papel-2:#fffaf0;
  --cn-guinda:#7b1020;
  --cn-rojo:#b3202e;
  --cn-verde:#0f5b3d;
  --cn-oro:#c79b3b;
  --cn-gris:#6c6259;
  --cn-borde:#d8cbb7;
  --cn-blanco:#ffffff;
  --cn-sombra:0 12px 30px rgba(17,17,17,.12);
  --cn-serif: Georgia, 'Times New Roman', serif;
  --cn-sans: Arial, Helvetica, sans-serif;
}

*{box-sizing:border-box}
body{
  margin:0;
  color:var(--cn-tinta);
  background:
    radial-gradient(circle at top left, rgba(199,155,59,.14), transparent 28%),
    linear-gradient(180deg,var(--cn-papel),var(--cn-papel-2));
  font-family:var(--cn-sans);
  line-height:1.55;
}
a{color:inherit;text-decoration:none}
a:hover{color:var(--cn-guinda)}
img{max-width:100%;height:auto;display:block}
.cn-wrap{width:min(1180px, calc(100% - 32px));margin:0 auto}

.cn-topline{
  background:var(--cn-tinta);
  color:var(--cn-papel);
  font-size:13px;
  letter-spacing:.02em;
}
.cn-topline .cn-wrap{display:flex;justify-content:space-between;gap:16px;padding:8px 0;align-items:center;flex-wrap:wrap}
.cn-date{opacity:.9}
.cn-toplinks a{margin-left:16px;color:var(--cn-papel)}

.cn-header{
  border-bottom:4px double var(--cn-tinta);
  background:rgba(245,239,228,.92);
  backdrop-filter:blur(8px);
}
.cn-brandbar{display:grid;grid-template-columns:1fr auto;align-items:center;gap:24px;padding:24px 0 18px}
.cn-brand{display:flex;align-items:center;gap:16px;min-width:0}
.cn-logo-mark{
  width:62px;height:62px;border:3px solid var(--cn-tinta);border-radius:50%;
  display:grid;place-items:center;background:var(--cn-guinda);color:var(--cn-papel);font-family:var(--cn-serif);font-size:24px;font-weight:900;
  box-shadow:inset 0 0 0 4px rgba(245,239,228,.25);
}
.cn-title{font-family:var(--cn-serif);font-size:clamp(34px,5vw,64px);font-weight:900;line-height:.9;letter-spacing:-.04em;text-transform:uppercase}
.cn-slogan{margin-top:8px;color:var(--cn-guinda);font-weight:700;letter-spacing:.05em;text-transform:uppercase;font-size:13px}
.cn-ad-top{
  width:min(370px,100%);min-height:82px;border:2px dashed var(--cn-borde);background:var(--cn-blanco);
  display:grid;place-items:center;text-align:center;padding:12px;color:var(--cn-gris);font-size:13px;text-transform:uppercase;font-weight:700;
}

.cn-mainnav{border-top:1px solid var(--cn-borde);background:var(--cn-papel-2)}
.cn-menu{display:flex;gap:0;list-style:none;padding:0;margin:0;overflow-x:auto}
.cn-menu li a{display:block;padding:13px 15px;font-weight:800;font-size:14px;text-transform:uppercase;border-right:1px solid var(--cn-borde);white-space:nowrap}
.cn-menu li:first-child a{border-left:1px solid var(--cn-borde)}
.cn-menu li a:hover{background:var(--cn-guinda);color:var(--cn-papel)}

.cn-breaking{background:var(--cn-guinda);color:var(--cn-papel);border-bottom:1px solid rgba(0,0,0,.2)}
.cn-breaking .cn-wrap{display:flex;gap:14px;align-items:center;padding:10px 0;font-size:14px;overflow:hidden}
.cn-breaking strong{background:var(--cn-tinta);padding:5px 9px;text-transform:uppercase;font-size:12px;letter-spacing:.06em;white-space:nowrap}
.cn-breaking span{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.cn-grid{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:28px;padding:30px 0}
.cn-section-title{font-family:var(--cn-serif);font-size:28px;margin:0 0 16px;border-bottom:3px solid var(--cn-tinta);padding-bottom:8px;text-transform:uppercase;letter-spacing:-.02em}
.cn-section-title span{color:var(--cn-guinda)}

.cn-hero{display:grid;grid-template-columns:1.35fr .9fr;gap:18px;margin-bottom:30px}
.cn-card{background:var(--cn-blanco);border:1px solid var(--cn-borde);box-shadow:var(--cn-sombra);overflow:hidden}
.cn-card-body{padding:16px}
.cn-kicker{display:inline-block;background:var(--cn-tinta);color:var(--cn-papel);padding:4px 8px;font-size:11px;font-weight:900;letter-spacing:.08em;text-transform:uppercase;margin-bottom:10px}
.cn-card h2,.cn-card h3{font-family:var(--cn-serif);letter-spacing:-.025em;line-height:1.08;margin:0 0 10px}
.cn-card h2{font-size:clamp(30px,4vw,48px)}
.cn-card h3{font-size:22px}
.cn-meta{font-size:12px;color:var(--cn-gris);text-transform:uppercase;font-weight:700;margin-bottom:8px}
.cn-excerpt{color:#38332d;margin:0}
.cn-hero-list{display:grid;gap:16px}
.cn-thumb{aspect-ratio:16/9;background:linear-gradient(135deg,#d8cbb7,#fffaf0);object-fit:cover;width:100%}

.cn-three{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:30px}
.cn-two-col{display:grid;grid-template-columns:repeat(2,1fr);gap:18px;margin-bottom:30px}
.cn-list{display:grid;gap:12px}
.cn-list-item{display:grid;grid-template-columns:110px 1fr;gap:12px;border-bottom:1px solid var(--cn-borde);padding-bottom:12px}
.cn-list-item h4{font-family:var(--cn-serif);font-size:18px;line-height:1.12;margin:0 0 6px}
.cn-list-item img{aspect-ratio:4/3;object-fit:cover;background:#eee}

.cn-sidebar{display:grid;gap:18px;align-content:start}
.cn-widget{background:var(--cn-blanco);border:1px solid var(--cn-borde);box-shadow:var(--cn-sombra);padding:16px}
.cn-widget h3{margin:0 0 12px;font-family:var(--cn-serif);font-size:23px;border-bottom:2px solid var(--cn-guinda);padding-bottom:8px}
.cn-ad{min-height:260px;border:2px dashed var(--cn-borde);display:grid;place-items:center;text-align:center;background:linear-gradient(135deg,var(--cn-guinda),var(--cn-tinta));color:var(--cn-papel);padding:22px}
.cn-ad strong{font-family:var(--cn-serif);font-size:30px;text-transform:uppercase;line-height:1}
.cn-ad small{display:block;margin-top:10px;color:#eadfc9}
.cn-widget ul{padding-left:18px;margin:0}.cn-widget li{margin:9px 0}

.cn-page{background:var(--cn-blanco);border:1px solid var(--cn-borde);box-shadow:var(--cn-sombra);padding:clamp(20px,4vw,42px);margin:30px 0}
.cn-page h1{font-family:var(--cn-serif);font-size:clamp(36px,5vw,58px);line-height:.98;margin:0 0 14px;letter-spacing:-.04em}
.cn-page h2{font-family:var(--cn-serif);font-size:30px;margin:30px 0 10px;border-bottom:2px solid var(--cn-borde);padding-bottom:8px}
.cn-page p{font-size:17px;color:#2f2a25}
.cn-directory{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-top:22px}
.cn-person{border:1px solid var(--cn-borde);padding:16px;background:var(--cn-papel-2)}
.cn-person strong{font-family:var(--cn-serif);font-size:21px;display:block}.cn-person em{color:var(--cn-guinda);font-style:normal;font-weight:800}.cn-person p{font-size:15px;margin:8px 0 0}
.cn-contact-box{background:var(--cn-papel);border-left:6px solid var(--cn-guinda);padding:18px;margin:18px 0;font-weight:700}

.cn-footer{background:var(--cn-tinta);color:var(--cn-papel);margin-top:30px;padding:34px 0;border-top:6px solid var(--cn-guinda)}
.cn-footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:28px}
.cn-footer h3{font-family:var(--cn-serif);font-size:26px;margin:0 0 10px}.cn-footer p,.cn-footer a{color:#dfd4c0}
.cn-footer-bottom{border-top:1px solid rgba(245,239,228,.2);margin-top:24px;padding-top:16px;color:#b8ad9b;font-size:13px}

@media(max-width:900px){
  .cn-brandbar,.cn-grid,.cn-hero,.cn-three,.cn-two-col,.cn-footer-grid{grid-template-columns:1fr}
  .cn-ad-top{width:100%}.cn-directory{grid-template-columns:1fr}.cn-list-item{grid-template-columns:88px 1fr}.cn-card h2{font-size:32px}
}

/* Ajustes v1.1: cabecera centrada, banner derecho, carrusel principal y nuevos espacios publicitarios */
.cn-brandbar{
  grid-template-columns: minmax(220px, 1fr) minmax(260px, auto) minmax(280px, 1fr);
  padding:24px 0 22px;
  min-height:185px;
}
.cn-brand{justify-content:center;text-align:center;place-self:center;max-width:420px}
.cn-brand .custom-logo-link{display:flex;justify-content:center;align-items:center;width:100%}
.cn-brand img,.cn-brand .custom-logo{max-height:168px;width:auto;max-width:360px;object-fit:contain;margin:0 auto}
.cn-brand-spacer{min-height:1px}
.cn-ad-top{
  justify-self:end;
  width:min(420px,100%);
  min-height:96px;
  border:2px dashed var(--cn-borde);
  background:linear-gradient(135deg,#fffaf0,#ffffff);
  color:var(--cn-tinta);
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:4px;
}
.cn-ad-top strong{font-family:var(--cn-serif);font-size:18px;color:var(--cn-guinda);text-transform:uppercase}.cn-ad-top span{font-size:12px;text-transform:uppercase;font-weight:900;color:var(--cn-gris)}

.cn-carousel{position:relative;overflow:hidden;background:var(--cn-blanco);border:1px solid var(--cn-borde);box-shadow:var(--cn-sombra);margin-bottom:24px}
.cn-carousel-track{display:flex;transition:transform .45s ease;will-change:transform}
.cn-slide{min-width:100%;display:grid;grid-template-columns:1.25fr .95fr;background:var(--cn-blanco)}
.cn-slide-media{background:linear-gradient(135deg,#d8cbb7,#fffaf0);min-height:380px}.cn-slide-media img,.cn-slide-media .cn-thumb{width:100%;height:100%;object-fit:cover;aspect-ratio:auto}
.cn-slide-copy{padding:clamp(22px,4vw,42px);display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--cn-borde)}
.cn-slide-copy h2{font-family:var(--cn-serif);font-size:clamp(34px,4.2vw,58px);line-height:.98;margin:0 0 12px;letter-spacing:-.04em}.cn-slide-copy p{font-size:17px;margin:0;color:#342f29}
.cn-carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:42px;height:54px;border:0;background:rgba(17,17,17,.78);color:var(--cn-papel);font-size:38px;line-height:1;cursor:pointer;z-index:2}.cn-carousel-btn:hover{background:var(--cn-guinda);color:var(--cn-papel)}.cn-prev{left:0}.cn-next{right:0}
.cn-carousel-dots{position:absolute;left:0;right:0;bottom:12px;display:flex;justify-content:center;gap:8px}.cn-carousel-dots button{width:10px;height:10px;border-radius:50%;border:1px solid var(--cn-papel);background:rgba(17,17,17,.45);padding:0;cursor:pointer}.cn-carousel-dots button.is-active{background:var(--cn-guinda);border-color:var(--cn-guinda)}

.cn-ad-strip{margin:24px 0 30px;border:2px dashed var(--cn-borde);background:var(--cn-papel-2);min-height:92px;display:flex;align-items:center;justify-content:center;gap:14px;text-align:center;padding:14px;color:var(--cn-gris)}
.cn-ad-strip strong{font-family:var(--cn-serif);font-size:24px;color:var(--cn-guinda);text-transform:uppercase}.cn-ad-strip span{font-weight:700}.cn-ad-strip-dark{background:linear-gradient(135deg,var(--cn-guinda),#4f0712);color:var(--cn-papel);border-color:#331018}.cn-ad-strip-dark strong{color:var(--cn-papel)}.cn-ad-strip-dark span{color:#eadfc9}
.cn-category-row{margin-bottom:28px}

@media(max-width:1020px){
  .cn-brandbar{grid-template-columns:1fr;min-height:auto;text-align:center}.cn-brand-spacer{display:none}.cn-ad-top{justify-self:center}.cn-brand img,.cn-brand .custom-logo{max-height:150px}.cn-slide{grid-template-columns:1fr}.cn-slide-media{min-height:260px}.cn-slide-copy{border-left:0;border-top:1px solid var(--cn-borde)}
}


/* Ajustes v1.2: carrusel 16:9 y portada sin barra lateral */
.cn-home{padding:30px 0}
.cn-home-main{width:100%}
.cn-grid.cn-home, .cn-home.cn-grid{display:block}

/* En la portada ya no se usa barra lateral */
.home .cn-sidebar{display:none}

/* Carrusel con proporción 16:9 */
.cn-carousel{aspect-ratio:16/9; min-height:0; width:100%}
.cn-carousel-track{height:100%}
.cn-slide{min-width:100%; height:100%; display:grid; grid-template-columns:1.18fr .82fr; align-items:stretch}
.cn-slide-media{min-height:0; height:100%}
.cn-slide-media img,.cn-slide-media .cn-thumb{width:100%; height:100%; object-fit:cover}
.cn-slide-copy{min-height:0; overflow:auto}
.cn-slide-copy h2{font-size:clamp(30px,4vw,56px)}

/* Sin sidebar, los anuncios quedan integrados en la columna principal */
.cn-ad-strip{width:100%}

@media(max-width:1020px){
  .cn-carousel{aspect-ratio:auto}
  .cn-slide{grid-template-columns:1fr; height:auto}
  .cn-slide-media{aspect-ratio:16/9}
  .cn-slide-copy{overflow:visible}
}


/* Ajustes v1.3: cabecera con logotipo a la izquierda */
.cn-brandbar{grid-template-columns:minmax(280px,auto) 1fr;align-items:center;min-height:170px}
.cn-brand{justify-content:flex-start;text-align:left;place-self:center start;max-width:none}
.cn-brand .custom-logo-link{justify-content:flex-start;width:auto}
.cn-brand img,.cn-brand .custom-logo{margin:0;max-height:152px;max-width:440px}
.cn-brand-spacer{display:none !important}
.cn-ad-top{justify-self:end}

@media(max-width:1020px){
  .cn-brandbar{grid-template-columns:1fr;gap:18px;text-align:center}
  .cn-brand{justify-content:center;text-align:center;place-self:center}
  .cn-brand .custom-logo-link{justify-content:center;width:100%}
  .cn-brand img,.cn-brand .custom-logo{margin:0 auto}
  .cn-ad-top{justify-self:center}
}


/* Ajustes v1.4: alinear logo y banner centrados en la cabecera */
.cn-header .cn-wrap.cn-brandbar{
  max-width:1100px;
  margin:0 auto;
  justify-content:center;
  column-gap:56px;
}
.cn-brandbar{
  grid-template-columns:minmax(340px, auto) minmax(280px, 728px);
  justify-content:center;
}
.cn-brand{
  justify-content:center;
  text-align:center;
  place-self:center end;
}
.cn-brand .custom-logo-link{
  justify-content:center;
}
.cn-brand img,.cn-brand .custom-logo{
  margin:0 auto;
}
.cn-ad-top{
  justify-self:start;
  align-self:center;
}
@media(max-width:1020px){
  .cn-header .cn-wrap.cn-brandbar{column-gap:18px}
  .cn-brandbar{grid-template-columns:1fr}
  .cn-brand{place-self:center}
  .cn-ad-top{justify-self:center}
}


/* Ajustes v1.5: cabecera sin espacio publicitario */
.cn-header .cn-wrap.cn-brandbar{
  display:flex;
  justify-content:center;
  align-items:center;
  min-height:150px;
  padding:22px 0;
}
.cn-brandbar{
  grid-template-columns:1fr;
}
.cn-brand{
  justify-content:center;
  text-align:center;
  place-self:center;
}
.cn-brand .custom-logo-link{
  justify-content:center;
  width:100%;
}
.cn-brand img,.cn-brand .custom-logo{
  margin:0 auto;
  max-height:150px;
  max-width:560px;
}
.cn-ad-top{
  display:none !important;
}
