/* ===========================================================================
   Tema "noticias" — Aquí en Sonora. Estructura editorial estilo Forbes.
   Colores vía variables (--ns-primary, --ns-ink, --ns-footer) inyectadas por
   header.php desde la apariencia del sitio. Tipos: Plus Jakarta Sans (títulos)
   + Inter (cuerpo).
   =========================================================================== */
:root{
  --ns-primary:#FF6A13; --ns-ink:#2A211B; --ns-footer:#2A211B;
  --ns-cream:#FBEAD0; --ns-line:#e7e3dd; --ns-muted:#6b6258; --ns-bg:#ffffff;
  --ns-wrap:1200px;
  --ns-head:'Plus Jakarta Sans',system-ui,sans-serif;
  --ns-body:'Inter',system-ui,sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{background:var(--ns-bg);color:var(--ns-ink);font-family:var(--ns-body);font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4{font-family:var(--ns-head);font-weight:800;line-height:1.15;margin:0;letter-spacing:-.02em}
.ns-wrap{max-width:var(--ns-wrap);margin:0 auto;padding:0 20px}

/* ── Barra superior ── */
.ns-topbar{background:var(--ns-ink);color:#e7d9c8;font-size:12.5px;letter-spacing:.01em}
.ns-topbar-in{display:flex;justify-content:space-between;align-items:center;height:34px}
.ns-date{opacity:.85}
.ns-top-social a{margin-left:14px;color:#e7d9c8;font-weight:600}
.ns-top-social a:hover{color:var(--ns-primary)}

/* ── Masthead ── */
.ns-masthead{border-bottom:1px solid var(--ns-line);background:#fff}
.ns-masthead-in{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:18px 20px}
.ns-brand img{height:46px;width:auto}
.ns-brand-text{font-family:var(--ns-head);font-weight:800;font-size:28px;color:var(--ns-ink)}
.ns-search{display:flex;align-items:center;border:1.5px solid var(--ns-line);border-radius:999px;overflow:hidden;background:#faf8f5}
.ns-search input{border:0;background:transparent;padding:9px 16px;font:inherit;font-size:14px;width:230px;outline:none;color:var(--ns-ink)}
.ns-search button{border:0;background:var(--ns-primary);color:#fff;padding:0 16px;align-self:stretch;font-size:16px;cursor:pointer}

/* ── Nav de secciones ── */
.ns-nav{border-bottom:2px solid var(--ns-ink);position:sticky;top:0;z-index:30;background:#fff}
.ns-nav-in{display:flex;gap:4px;overflow-x:auto;scrollbar-width:none}
.ns-nav-in::-webkit-scrollbar{display:none}
.ns-nav-in a{white-space:nowrap;padding:13px 14px;font-family:var(--ns-head);font-weight:700;font-size:14px;color:var(--ns-ink);border-bottom:3px solid transparent;transition:.12s}
.ns-nav-in a:hover{color:var(--ns-primary)}
.ns-nav-in a.active{border-bottom-color:var(--sec,var(--ns-primary))}

/* ── Ticker ── */
.ns-ticker{background:var(--ns-cream);border-bottom:1px solid var(--ns-line)}
.ns-ticker-in{display:flex;align-items:center;gap:14px;height:40px;overflow:hidden}
.ns-ticker-label{flex:none;background:var(--ns-primary);color:#fff;font-family:var(--ns-head);font-weight:800;font-size:11px;letter-spacing:.06em;padding:4px 10px;border-radius:4px}
.ns-ticker-track{display:flex;align-items:center;gap:10px;overflow:hidden;white-space:nowrap;font-size:14px;font-weight:600}
.ns-ticker-track a:hover{color:var(--ns-primary)}
.ns-ticker-sep{color:var(--ns-primary)}

/* ── Layout general ── */
.ns-main{padding:28px 0 10px}
.ns-section-h{font-size:15px;text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--ns-ink);padding-bottom:8px;margin:0 0 18px}

/* ── Hero (líder + secundarias) ── */
.ns-hero{display:grid;grid-template-columns:1.7fr 1fr;gap:32px;padding-bottom:30px;margin-bottom:26px;border-bottom:1px solid var(--ns-line)}
.ns-hero--single{grid-template-columns:1fr}
.ns-hero-side{display:flex;flex-direction:column;gap:20px}

/* ── Tarjetas ── */
.ns-card{display:flex;flex-direction:column}
.ns-card-img{display:block;overflow:hidden;border-radius:8px;background:var(--ns-cream)}
.ns-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.ns-card-img:hover img{transform:scale(1.03)}
.ns-eyebrow{display:inline-block;font-family:var(--ns-head);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.05em;margin:0 0 6px}
.ns-uh{background:var(--ns-primary);color:#fff;padding:1px 6px;border-radius:3px;margin-right:4px}
.ns-card-title a{transition:.12s}
.ns-card-title a:hover{color:var(--ns-primary)}
.ns-card-dek{color:var(--ns-muted);font-size:15px;margin:8px 0 0}
.ns-card-meta{color:var(--ns-muted);font-size:12.5px;margin-top:8px;display:block}

.ns-card--lead .ns-card-img{aspect-ratio:16/9;margin-bottom:14px}
.ns-card--lead .ns-card-title{font-size:30px}
.ns-card--feature{border-top:1px solid var(--ns-line);padding-top:18px}
.ns-card--feature:first-child{border-top:0;padding-top:0}
.ns-card--feature .ns-card-img{aspect-ratio:16/9;margin-bottom:10px}
.ns-card--feature .ns-card-title{font-size:20px}
.ns-card--row .ns-card-img{aspect-ratio:16/9;margin-bottom:10px}
.ns-card--row .ns-card-title{font-size:16px}

/* ── Río + sidebar ── */
.ns-cols{display:grid;grid-template-columns:1fr 320px;gap:36px;padding:8px 0 26px}
.ns-river{display:block}
.ns-aside-box{background:#faf8f5;border:1px solid var(--ns-line);border-radius:10px;padding:18px}
.ns-ranked{list-style:none;margin:0;padding:0;counter-reset:r}
.ns-ranked li{display:flex;gap:12px;align-items:flex-start;padding:12px 0;border-bottom:1px solid var(--ns-line)}
.ns-ranked li:last-child{border-bottom:0}
.ns-rank{font-family:var(--ns-head);font-weight:800;font-size:22px;color:var(--ns-primary);line-height:1;min-width:22px}
.ns-ranked a{font-family:var(--ns-head);font-weight:700;font-size:15px}
.ns-ranked a:hover{color:var(--ns-primary)}

/* ── Bloques por sección ── */
.ns-secblock{padding:26px 0;border-top:1px solid var(--ns-line)}
.ns-secblock-h{display:flex;align-items:center;justify-content:space-between;border-left:5px solid var(--ns-primary);padding-left:12px;margin-bottom:18px}
.ns-secblock-h h2{font-size:20px}
.ns-secblock-h h2 a:hover{color:var(--ns-primary)}
.ns-more{font-family:var(--ns-head);font-weight:700;font-size:13px;color:var(--ns-primary)}
.ns-grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:26px 24px}

/* ── Artículo ── */
.ns-article{max-width:760px;padding:30px 20px 10px}
.ns-art-eyebrow{font-size:13px;margin-bottom:14px}
.ns-art-title{font-size:34px;line-height:1.12;margin:0 0 14px}
.ns-art-dek{font-size:21px;line-height:1.45;color:#4a4239;font-weight:500;margin:0 0 18px;font-family:var(--ns-head)}
.ns-art-byline{display:flex;flex-wrap:wrap;gap:8px 16px;color:var(--ns-muted);font-size:13.5px;padding:14px 0;border-top:1px solid var(--ns-line);border-bottom:1px solid var(--ns-line)}
.ns-art-hero{margin:22px 0}
.ns-art-hero img{width:100%;border-radius:10px}
.ns-art-hero figcaption{color:var(--ns-muted);font-size:12.5px;margin-top:7px}
.ns-art-grid{display:grid;grid-template-columns:1fr 64px;gap:22px}
.ns-art-body{font-size:18px}
.ns-art-body p{margin:0 0 20px}
.ns-keybox{background:var(--ns-cream);border-left:5px solid var(--ns-primary);border-radius:0 10px 10px 0;padding:16px 20px;margin:0 0 24px}
.ns-keybox h2{font-size:14px;text-transform:uppercase;letter-spacing:.05em;margin:0 0 10px}
.ns-keybox ul{margin:0;padding-left:18px}
.ns-keybox li{margin:5px 0;font-size:16px}
.ns-tags{display:flex;flex-wrap:wrap;gap:8px;margin:26px 0}
.ns-tag{background:#f1ede7;border-radius:999px;padding:5px 12px;font-size:13px;color:var(--ns-muted);font-weight:600}
.ns-sources{background:#faf8f5;border:1px solid var(--ns-line);border-radius:10px;padding:18px 20px;margin-top:26px}
.ns-sources h2{font-size:15px;text-transform:uppercase;letter-spacing:.05em;margin:0 0 8px}
.ns-sources-note{color:var(--ns-muted);font-size:14px;margin:0 0 10px}
.ns-sources ul{margin:0;padding-left:18px}
.ns-sources li{margin:5px 0}
.ns-sources a{color:var(--ns-primary);font-weight:600;word-break:break-word}
.ns-art-aside .ns-share{position:sticky;top:80px;display:flex;flex-direction:column;gap:8px;font-size:11px;text-align:center}
.ns-share span{color:var(--ns-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:700}
.ns-share a{border:1px solid var(--ns-line);border-radius:8px;padding:8px 4px;font-weight:700;font-size:12px}
.ns-share a:hover{background:var(--ns-primary);color:#fff;border-color:var(--ns-primary)}
.ns-related{margin-top:40px;padding-top:10px;border-top:2px solid var(--ns-ink)}

/* ── Cabecera de sección ── */
.ns-sec-head{border-bottom:3px solid var(--ns-primary);padding:24px 0 14px;margin:6px 0 28px}
.ns-sec-kicker{color:#fff;font-family:var(--ns-head);font-weight:800;font-size:11px;letter-spacing:.06em;padding:3px 9px;border-radius:4px}
.ns-sec-head h1{font-size:35px;margin-top:8px}
.ns-sec-grid{margin-bottom:30px}

/* ── Footer ── */
.ns-footer{background:var(--ns-footer);color:#c9b8a4;margin-top:48px;border-top:4px solid var(--ns-primary)}
.ns-footer-grid{display:grid;grid-template-columns:1.6fr 1fr .8fr 1fr;gap:40px;padding:44px 20px 36px}
.ns-footer-logo{height:40px;width:auto;margin-bottom:12px}
.ns-footer-name{font-family:var(--ns-head);font-weight:800;font-size:24px;color:#fff}
.ns-footer-tag{font-family:var(--ns-head);font-weight:700;color:#fff;margin:0 0 12px;font-size:16px}
.ns-footer-about{color:#a89784;font-size:13.5px;line-height:1.6;max-width:34ch;margin:0 0 16px}
.ns-footer-social{display:flex;flex-wrap:wrap;gap:8px}
.ns-footer-social a{font-size:12.5px;font-weight:600;color:#e7d9c8;border:1px solid rgba(255,255,255,.16);border-radius:999px;padding:5px 12px}
.ns-footer-social a:hover{background:var(--ns-primary);border-color:var(--ns-primary);color:#fff}
.ns-footer-col h4{font-family:var(--ns-head);font-size:12px;text-transform:uppercase;letter-spacing:.06em;color:#fff;margin:0 0 14px}
.ns-footer-col a{display:block;color:#c9b8a4;padding:5px 0;font-size:14px}
.ns-footer-col a:hover{color:var(--ns-primary)}
.ns-footer-seclist{display:grid;grid-template-columns:1fr 1fr;gap:0 18px}
.ns-footer-contact{color:#a89784;font-size:14px;margin:0 0 8px;line-height:1.5}
.ns-footer-tip{color:#8f7f6c;font-size:13px;margin:14px 0 0}
.ns-footer-legal{border-top:1px solid rgba(255,255,255,.12)}
.ns-legal-in{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;padding-top:16px;padding-bottom:20px;font-size:12.5px;color:#8f7f6c}
.ns-legal-right{display:inline-flex;align-items:center;gap:10px}
.ns-totop{display:inline-flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;border:1px solid rgba(255,255,255,.18);color:#e7d9c8;font-size:14px}
.ns-totop:hover{background:var(--ns-primary);border-color:var(--ns-primary);color:#fff}

/* ── Estado vacío ── */
.ns-empty{text-align:center;padding:70px 20px;color:var(--ns-muted)}
.ns-empty h1{font-size:30px;color:var(--ns-ink);margin-bottom:10px}

/* ── Responsivo ── */
@media(max-width:980px){
  .ns-hero{grid-template-columns:1fr;gap:24px}
  .ns-cols{grid-template-columns:1fr}
  .ns-grid4{grid-template-columns:repeat(2,1fr)}
  .ns-card--lead .ns-card-title{font-size:30px}
  .ns-art-grid{grid-template-columns:1fr}
  .ns-art-aside{display:none}
}
@media(max-width:560px){
  body{font-size:16px}
  .ns-river{grid-template-columns:1fr}
  .ns-grid4{grid-template-columns:1fr}
  .ns-search input{width:140px}
  .ns-art-title{font-size:31px}
  .ns-footer-grid{grid-template-columns:1fr;gap:26px}
}
@media(max-width:900px){ .ns-footer-grid{grid-template-columns:1fr 1fr;gap:30px} .ns-footer-brand{grid-column:1 / -1} }

/* ===========================================================================
   Home rework: tarjetas image-forward (el titular vive en la imagen), grid de
   "Lo último" y navegación por sección en el sidebar.
   =========================================================================== */
.ns-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}
.ns-card-img{position:relative}
.ns-card-uh{position:absolute;top:8px;left:8px;background:var(--ns-primary);color:#fff;font-family:var(--ns-head);font-weight:800;font-size:10px;letter-spacing:.05em;padding:3px 7px;border-radius:4px}
.ns-card-body{padding-top:9px}
.ns-card--lead .ns-card-body{padding-top:12px}
/* Tarjeta de SOLO texto (nota sin imagen) */
.ns-card--text{background:#faf8f5;border:1px solid var(--ns-line);border-radius:10px;padding:15px 16px 17px}
.ns-card--text .ns-card-title{font-size:18px;margin-top:5px}
.ns-card--text.ns-card--lead .ns-card-title{font-size:30px}

/* Tarjeta compacta (columna derecha del hero): miniatura + titular */
.ns-hero-side{display:flex;flex-direction:column;gap:0}
.ns-card--compact{display:grid;grid-template-columns:118px 1fr;gap:14px;align-items:start;padding:14px 0;border-bottom:1px solid var(--ns-line)}
.ns-card--compact:first-child{padding-top:0}
.ns-card--compact:last-child{border-bottom:0;padding-bottom:0}
.ns-card--compact .ns-card-img{margin:0;aspect-ratio:1;border-radius:8px}
.ns-card--compact .ns-card-img img{width:100%;height:100%;object-fit:cover}
.ns-card--compact .ns-card-body{padding-top:0}
.ns-card--compact .ns-card-title{font-size:16px;line-height:1.22;margin-top:3px}
.ns-card--compact .ns-card-uh{font-size:9px;padding:2px 5px;top:6px;left:6px}

/* Título SOBREPUESTO en la imagen (estilo portada, texto real) */
.ns-card--ov .ns-card-img{position:relative;overflow:hidden;border-radius:9px;display:block;margin:0}
.ns-card--ov .ns-card-img img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s}
.ns-card--ov .ns-card-img:hover img{transform:scale(1.03)}
.ns-card--lead.ns-card--ov .ns-card-img{aspect-ratio:16/10}
.ns-card--row.ns-card--ov .ns-card-img,.ns-card--feature.ns-card--ov .ns-card-img{aspect-ratio:16/10}
.ns-card-ov{position:absolute;left:0;right:0;bottom:0;padding:16px 16px 13px;background:linear-gradient(to top,rgba(18,13,9,.95),rgba(18,13,9,.6) 55%,transparent);pointer-events:none}
.ns-card-ov a{pointer-events:auto}
.ns-ov-eyebrow{display:inline-flex;align-items:center;gap:6px;color:#fff;font-family:var(--ns-head);font-weight:800;font-size:11px;text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px;opacity:.96}
.ns-ov-dot{width:9px;height:9px;border-radius:2px;display:inline-block}
.ns-ov-title{display:block;color:#fff;font-family:var(--ns-head);font-weight:800;line-height:1.18;letter-spacing:-.01em;text-shadow:0 1px 4px rgba(0,0,0,.4)}
.ns-ov-title:hover{opacity:.9}
.ns-card--lead .ns-ov-title{font-size:27px}
.ns-card--feature .ns-ov-title{font-size:18px}
.ns-card--row .ns-ov-title{font-size:16px}
.ns-card--ov .ns-card-meta{margin-top:8px}

/* "Lo último" en grid */
.ns-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:26px 22px}

/* Sidebar: navegación por sección */
.ns-seclist{list-style:none;margin:0;padding:0}
.ns-seclist li{display:flex;align-items:center;justify-content:space-between;padding:11px 2px;border-bottom:1px solid var(--ns-line)}
.ns-seclist li:last-child{border-bottom:0}
.ns-seclist a{display:flex;align-items:center;gap:9px;font-family:var(--ns-head);font-weight:700;font-size:15px}
.ns-seclist a:hover{color:var(--ns-primary)}
.ns-seclist .ns-dot{width:11px;height:11px;border-radius:3px;display:inline-block;flex:none}
.ns-seccount{color:var(--ns-muted);font-size:13px;font-weight:700}

@media(max-width:980px){ .ns-grid3{grid-template-columns:repeat(2,1fr)} }
@media(max-width:560px){ .ns-grid3{grid-template-columns:1fr} }
