/* La Prensa de Coahuila — Rediseño estilo CNN
   Tokens, layout y componentes compartidos por home / categoría / nota */

:root{
  --rojo:#cc0000;
  --rojo-osc:#a30000;
  --tinta:#171717;
  --tinta-2:#3a3a3a;
  --gris:#5a5a5a;
  --gris-claro:#e8e8e8;
  --crema:#f6f6f4;
  --rule:#dcdcdc;
  --azul:#1a4ba8;
  --max:1400px;
  --serif:'Playfair Display',Georgia,serif;
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Helvetica Neue',Arial,sans-serif;
}

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:#fff;color:var(--tinta);line-height:1.55;font-size:16px;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{display:block;max-width:100%;height:auto}
a{color:inherit;text-decoration:none}
a:hover{color:var(--rojo)}
button{font-family:inherit;cursor:pointer;border:0;background:transparent}

/* Focus visible accesible */
:focus{outline:none}
:focus-visible{outline:2px solid var(--rojo);outline-offset:2px;border-radius:2px}

/* Skip-link accesibilidad */
.skip-link{position:absolute;top:-100px;left:8px;background:var(--rojo);color:#fff;padding:10px 16px;font-weight:700;font-size:14px;z-index:200;border-radius:4px}
.skip-link:focus{top:8px;color:#fff}

/* Respeta motion preference */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  .ticker .feed-inner{animation:none!important}
  .ticker .live::before,.hero-main .badge::before{animation:none!important}
}

.wrap{max-width:var(--max);margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif)}
.uppercase{text-transform:uppercase;letter-spacing:.05em}

/* ============ TICKER / TOPBAR ============ */
.ticker{background:var(--tinta);color:#fff;font-size:12px;border-bottom:3px solid var(--rojo)}
.ticker .wrap{display:flex;align-items:stretch;height:36px}
.ticker .live{background:var(--rojo);color:#fff;padding:0 14px;display:flex;align-items:center;font-weight:800;font-size:11px;letter-spacing:.14em;text-transform:uppercase;gap:8px}
.ticker .live::before{content:"";width:8px;height:8px;background:#fff;border-radius:50%;animation:blink 1.2s infinite}
@keyframes blink{50%{opacity:.2}}
.ticker .feed{flex:1;overflow:hidden;display:flex;align-items:center;padding:0 16px;white-space:nowrap;position:relative}
.ticker .feed-inner{display:flex;gap:38px;animation:marquee 60s linear infinite}
.ticker .feed a{color:#ddd;font-size:12.5px}
.ticker .feed a:hover{color:#fff}
.ticker .feed b{color:#fff;margin-right:4px}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker .meta{display:flex;align-items:center;gap:14px;padding:0 14px;border-left:1px solid #2a2a2a;color:#aaa}
.ticker .meta .pill{background:#222;padding:4px 10px;border-radius:99px;font-size:11px}

/* ============ HEADER ============ */
.header{background:#fff;border-bottom:1px solid var(--rule);padding:18px 0;position:relative;z-index:50}
.header .wrap{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:24px}
.header .left,.header .right{display:flex;align-items:center;gap:16px;font-size:12.5px;color:var(--gris);font-weight:600}
.header .right{justify-content:flex-end}
.header .icon-btn,.header .menu-btn{width:44px;height:44px;display:inline-flex;align-items:center;justify-content:center;border-radius:50%;color:var(--tinta);transition:background .15s}
.header .icon-btn:hover,.header .menu-btn:hover{background:var(--gris-claro)}
.header .menu-btn{display:none}
.header .suscribe{background:var(--rojo);color:#fff;padding:11px 20px;border-radius:99px;font-weight:700;font-size:12.5px;text-transform:uppercase;letter-spacing:.06em;transition:background .15s;min-height:44px;display:inline-flex;align-items:center}
.header .suscribe:hover{background:var(--rojo-osc);color:#fff}
.header .logo img{height:48px;width:auto}
.header .clima{display:flex;align-items:center;gap:8px}
.header .clima .temp{font-weight:800;color:var(--tinta);font-size:14px}

/* ============ NAV ============ */
.nav{background:#fff;border-bottom:1px solid var(--rule);position:sticky;top:0;z-index:40;box-shadow:0 1px 0 rgba(0,0,0,.04)}
.nav-scrolled .wrap{padding-top:0;padding-bottom:0}
.nav .wrap{display:flex;align-items:center;gap:0;height:48px}
.nav .menu{display:flex;list-style:none;flex:1;height:100%;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-snap-type:x proximity}
.nav .menu::-webkit-scrollbar{display:none}
.nav .menu li{scroll-snap-align:start}
.nav .menu a{display:inline-flex;align-items:center;height:100%;padding:0 16px;font-size:12.5px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;border-bottom:3px solid transparent;color:var(--tinta);white-space:nowrap;transition:color .15s,border-color .15s;min-height:44px}
.nav .menu a:hover,.nav .menu a.on{color:var(--rojo);border-color:var(--rojo)}
.nav .extra{display:flex;align-items:center;gap:8px;padding-left:10px;border-left:1px solid var(--rule);color:var(--gris);font-size:12.5px}
.nav .extra a{font-weight:700}

/* ============ HERO ============ */
.hero{padding:28px 0 18px}
.hero-grid{display:grid;grid-template-columns:1fr 380px;gap:32px}
.hero-main{position:relative;display:block}
.hero-main .ph{position:relative;overflow:hidden;background:#000;aspect-ratio:16/10}
.hero-main .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.hero-main:hover .ph img{transform:scale(1.02)}
.hero-main .badge{position:absolute;top:16px;left:16px;background:var(--rojo);color:#fff;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;padding:6px 12px;display:inline-flex;align-items:center;gap:6px}
.hero-main .badge::before{content:"";width:6px;height:6px;background:#fff;border-radius:50%;animation:blink 1.2s infinite}
.hero-main .copy{padding:22px 0 0}
.hero-main .kicker{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.16em;color:var(--rojo);margin-bottom:10px;display:inline-block;border-bottom:2px solid var(--rojo);padding-bottom:4px}
.hero-main h1{font-family:var(--sans);font-weight:900;font-size:46px;line-height:1.05;letter-spacing:-.015em;color:var(--tinta);margin-bottom:14px}
.hero-main .dek{font-size:17px;color:var(--gris);line-height:1.5;font-weight:400;max-width:90%}
.hero-main .meta{display:flex;align-items:center;gap:14px;margin-top:14px;font-size:12px;color:var(--gris);text-transform:uppercase;letter-spacing:.08em;font-weight:600}

.hero-side{display:flex;flex-direction:column;gap:18px}
.hero-side .item{display:grid;grid-template-columns:130px 1fr;gap:14px;padding-bottom:18px;border-bottom:1px solid var(--rule);min-height:44px}
.hero-side .item:last-child{border-bottom:0}
.hero-side .item img{width:130px;height:90px;object-fit:cover;aspect-ratio:13/9}
.hero-side .item .k{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--rojo);margin-bottom:6px}
.hero-side .item h3{font-size:16px;line-height:1.25;font-weight:700;color:var(--tinta);letter-spacing:-.005em}
.hero-side .item h3:hover{color:var(--rojo)}

/* ============ SECTION HEADERS ============ */
.section-h{display:flex;align-items:baseline;gap:18px;margin:36px 0 18px;padding-bottom:8px;border-bottom:3px solid var(--tinta)}
.section-h h2{font-size:22px;font-weight:900;text-transform:uppercase;letter-spacing:-.005em;color:var(--tinta);position:relative}
.section-h h2 .red{color:var(--rojo);font-weight:900}
.section-h .more{margin-left:auto;font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--rojo)}
.section-h .more::after{content:" ›";font-size:14px}

/* ============ GRID DE NOTAS ============ */
.grid{display:grid;gap:28px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2-1{grid-template-columns:1.4fr .8fr .8fr}

.card{display:block;background:#fff;cursor:pointer}
.card .ph{position:relative;overflow:hidden;background:var(--gris-claro);aspect-ratio:16/10}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.card:hover .ph img{transform:scale(1.04)}
.card.lg .ph{aspect-ratio:16/9}
.card.xl .ph{aspect-ratio:4/3}
.card .ph .cat{position:absolute;top:10px;left:10px;background:var(--rojo);color:#fff;font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;padding:5px 9px}
.card .copy{padding:14px 0 0}
.card h3{font-size:17px;line-height:1.25;font-weight:700;color:var(--tinta);letter-spacing:-.005em}
.card.lg h3{font-size:22px}
.card.xl h3{font-size:26px;line-height:1.15}
.card:hover h3{color:var(--rojo)}
.card .meta{display:flex;align-items:center;gap:10px;margin-top:8px;font-size:11px;color:var(--gris);text-transform:uppercase;letter-spacing:.08em;font-weight:600}
.card .meta .dot::before{content:"·";margin:0 4px;color:var(--gris)}

/* lista vertical estilo "más leídas" */
.tops{list-style:none;counter-reset:t}
.tops li{counter-increment:t;display:grid;grid-template-columns:48px 1fr;gap:14px;padding:14px 0;border-bottom:1px solid var(--rule);align-items:center}
.tops li:last-child{border-bottom:0}
.tops li::before{content:counter(t);font-family:var(--serif);font-size:36px;font-weight:900;color:var(--rojo);line-height:1}
.tops li a{font-size:14.5px;line-height:1.3;font-weight:600;color:var(--tinta)}
.tops li a:hover{color:var(--rojo)}

/* lista horizontal compacta */
.compact-list{list-style:none}
.compact-list li{padding:14px 0;border-bottom:1px solid var(--rule)}
.compact-list li:last-child{border-bottom:0}
.compact-list .k{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--rojo);margin-bottom:5px;display:inline-block}
.compact-list a{font-size:15px;line-height:1.3;font-weight:700;color:var(--tinta);display:block}
.compact-list a:hover{color:var(--rojo)}
.compact-list .t{font-size:11px;color:var(--gris);margin-top:5px;text-transform:uppercase;letter-spacing:.08em}

/* ============ AD SLOT ============ */
.ad{background:#f0f0f0;border:1px dashed #bbb;color:#888;text-align:center;padding:40px 12px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.18em;display:flex;align-items:center;justify-content:center}
.ad.banner{height:90px;padding:0;margin:24px 0}
.ad.lg{height:280px}
.ad.skyscraper{height:600px}
.ad .label{position:absolute;top:6px;left:8px;font-size:9px;color:#aaa;letter-spacing:.2em;font-weight:700;text-transform:uppercase}
.ad-wrap{position:relative;margin:24px 0}
.ad-wrap::before{content:"PUBLICIDAD";position:absolute;top:-16px;left:0;font-size:9px;color:#aaa;letter-spacing:.2em;font-weight:700}

/* ============ SECCIÓN CON SIDEBAR ============ */
.has-side{display:grid;grid-template-columns:1fr 320px;gap:48px;margin:32px 0}
.has-side aside{position:sticky;top:60px;align-self:start}

/* ============ FRANJA OPINION ============ */
.opinion{background:var(--crema);padding:40px 0;margin-top:40px}
.opinion .heading{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:24px;padding-bottom:8px;border-bottom:2px solid var(--tinta)}
.opinion .heading h2{font-family:var(--serif);font-size:30px;font-weight:900;letter-spacing:-.01em}
.opinion .grid-3{gap:32px}
.op{display:grid;grid-template-columns:80px 1fr;gap:14px}
.op .av{width:80px;height:80px;border-radius:50%;background:#ccc center/cover;border:3px solid #fff;box-shadow:0 2px 8px rgba(0,0,0,.08)}
.op h4{font-family:var(--serif);font-size:18px;font-weight:700;line-height:1.25;margin-bottom:8px;letter-spacing:-.005em}
.op:hover h4{color:var(--rojo)}
.op .author{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.12em;color:var(--rojo);margin-bottom:6px}
.op .ex{font-size:13px;color:var(--gris);line-height:1.4;font-style:italic;font-family:var(--serif)}

/* ============ FOOTER ============ */
footer{background:var(--tinta);color:#bbb;padding:60px 0 24px;margin-top:60px;border-top:6px solid var(--rojo)}
footer .grid-foot{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:48px;margin-bottom:40px}
footer img.flogo{filter:brightness(0) invert(1);height:42px;margin-bottom:16px}
footer .blurb{font-size:13.5px;line-height:1.55;color:#999;margin-bottom:18px}
footer h5{font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:#fff;margin-bottom:14px}
footer ul{list-style:none}
footer ul li{padding:5px 0;font-size:13px}
footer ul a{color:#bbb}
footer ul a:hover{color:#fff}
footer .social{display:flex;gap:10px;margin-top:14px}
footer .social a{width:36px;height:36px;background:#2a2a2a;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;color:#fff;transition:background .15s}
footer .social a:hover{background:var(--rojo)}
footer .bottom{border-top:1px solid #2a2a2a;padding-top:20px;display:flex;justify-content:space-between;align-items:center;font-size:11.5px;color:#777;text-transform:uppercase;letter-spacing:.06em}
footer .bottom a{color:#999}

/* ============ NOTA ============ */
.crumbs{padding:18px 0;font-size:11.5px;color:var(--gris);text-transform:uppercase;letter-spacing:.06em;font-weight:600}
.crumbs a:hover{color:var(--rojo)}
.crumbs .sep{margin:0 8px;color:#bbb}

.article-head{padding:14px 0 28px;max-width:880px;margin:0 auto;text-align:left}
.article-head .kicker{font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.18em;color:var(--rojo);margin-bottom:16px;display:inline-block;padding-bottom:5px;border-bottom:2px solid var(--rojo)}
.article-head h1{font-family:var(--sans);font-weight:900;font-size:54px;line-height:1.05;letter-spacing:-.018em;margin-bottom:18px;color:var(--tinta)}
.article-head .dek{font-size:21px;font-family:var(--serif);font-style:italic;color:var(--tinta-2);line-height:1.4;margin-bottom:24px;font-weight:400}
.article-head .byline{display:flex;align-items:center;gap:14px;padding:18px 0;border-top:1px solid var(--rule);border-bottom:1px solid var(--rule);font-size:13px;color:var(--gris)}
.article-head .byline .av{width:42px;height:42px;border-radius:50%;background:var(--gris-claro) center/cover}
.article-head .byline .who b{color:var(--tinta);font-weight:700;font-size:13.5px}
.article-head .byline .when{margin-left:auto;font-size:12px;text-transform:uppercase;letter-spacing:.06em}
.article-head .byline .share{display:flex;gap:8px;margin-left:14px}
.article-head .byline .share a{width:34px;height:34px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center;background:var(--gris-claro);color:var(--tinta-2);transition:background .15s,color .15s}
.article-head .byline .share a:hover{background:var(--rojo);color:#fff}

.article-hero{margin:0 -24px 32px;background:#000}
.article-hero img{width:100%;max-height:620px;object-fit:cover}
.article-hero .cap{padding:14px 32px;background:#171717;color:#aaa;font-size:12px;font-style:italic;line-height:1.4;border-left:4px solid var(--rojo)}
.article-hero .cap b{color:#ddd;font-style:normal;font-weight:700;text-transform:uppercase;letter-spacing:.08em;font-size:10.5px;margin-right:6px}

.article-body{display:grid;grid-template-columns:1fr 320px;gap:60px;max-width:1180px;margin:0 auto;padding-bottom:60px}
.article-body .content{font-size:18px;line-height:1.7;color:var(--tinta-2);font-family:var(--serif)}
.article-body .content p{margin-bottom:1.2em}
.article-body .content p:first-of-type::first-letter{font-family:var(--serif);font-weight:900;font-size:74px;line-height:.85;float:left;margin:6px 12px 0 0;color:var(--rojo)}
.article-body .content h2{font-family:var(--sans);font-size:26px;font-weight:800;line-height:1.2;color:var(--tinta);margin:32px 0 14px;letter-spacing:-.01em}
.article-body .content blockquote{margin:32px 0;padding:18px 0 18px 28px;border-left:5px solid var(--rojo);font-family:var(--serif);font-size:24px;font-style:italic;color:var(--tinta);font-weight:500;line-height:1.4}
.article-body .content ul{padding-left:24px;margin-bottom:1.2em}
.article-body .content li{margin-bottom:6px}
.article-body .content figure{margin:32px 0}
.article-body .content figure img{width:100%}
.article-body .content figcaption{font-size:12.5px;color:var(--gris);font-style:italic;padding-top:8px;text-transform:none}
.article-body .content a{color:var(--rojo);border-bottom:1px solid currentColor}

.tags{margin-top:32px;padding-top:24px;border-top:1px solid var(--rule);display:flex;flex-wrap:wrap;gap:8px}
.tags span{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--gris);margin-right:6px}
.tag{display:inline-flex;align-items:center;min-height:34px;padding:8px 16px;background:var(--gris-claro);color:var(--tinta-2);font-size:12.5px;font-weight:600;border-radius:99px;transition:background .15s,color .15s}
.tag:hover,.tag:focus-visible{background:var(--rojo);color:#fff}

.article-side{position:sticky;top:60px;align-self:start;display:flex;flex-direction:column;gap:32px}
.article-side .panel h3{font-size:13px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--tinta);padding-bottom:10px;border-bottom:3px solid var(--rojo);margin-bottom:16px}

.related{background:var(--crema);padding:40px 0 60px}
.related .heading{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:24px;padding-bottom:8px;border-bottom:2px solid var(--tinta)}
.related .heading h2{font-size:22px;font-weight:900;text-transform:uppercase;letter-spacing:-.005em}

/* ============ CATEGORIA ============ */
.cat-head{padding:36px 0 24px;border-bottom:3px solid var(--tinta);margin-bottom:32px}
.cat-head .badge{display:inline-block;background:var(--rojo);color:#fff;padding:6px 14px;font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;margin-bottom:14px}
.cat-head h1{font-size:54px;font-weight:900;letter-spacing:-.02em;line-height:1;color:var(--tinta);margin-bottom:10px;font-family:var(--sans)}
.cat-head p{font-size:17px;color:var(--gris);max-width:700px;line-height:1.4}

.cat-hero{margin-bottom:36px}
.cat-hero-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:32px}
.cat-hero .lead .ph{aspect-ratio:16/10;background:var(--gris-claro);overflow:hidden}
.cat-hero .lead .ph img{width:100%;height:100%;object-fit:cover}
.cat-hero .lead h2{font-size:38px;font-weight:900;line-height:1.05;letter-spacing:-.015em;margin-top:18px;color:var(--tinta)}
.cat-hero .lead h2:hover{color:var(--rojo)}
.cat-hero .lead .dek{font-size:16px;color:var(--gris);margin-top:10px;line-height:1.5;font-family:var(--serif);font-style:italic;max-width:90%}
.cat-hero .lead .m{font-size:11.5px;color:var(--gris);text-transform:uppercase;letter-spacing:.08em;margin-top:14px;font-weight:600}
.cat-hero .side{display:flex;flex-direction:column;gap:0}
.cat-hero .side .item{display:grid;grid-template-columns:1fr;padding:18px 0;border-bottom:1px solid var(--rule)}
.cat-hero .side .item:first-child{padding-top:0}
.cat-hero .side .item:last-child{border-bottom:0}
.cat-hero .side .k{font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--rojo);margin-bottom:6px}
.cat-hero .side h3{font-size:18px;line-height:1.3;font-weight:700;letter-spacing:-.005em}
.cat-hero .side h3:hover{color:var(--rojo)}
.cat-hero .side .t{font-size:11px;color:var(--gris);margin-top:6px;text-transform:uppercase;letter-spacing:.08em}

.cat-list{display:grid;grid-template-columns:1fr 320px;gap:48px;margin-bottom:60px}
.cat-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:36px 32px}
.cat-grid .card .ph{aspect-ratio:16/10}
.cat-grid .card h3{font-size:20px}

.pagination{display:flex;justify-content:center;gap:6px;margin-top:40px;flex-wrap:wrap}
.pagination a,.pagination span{min-width:44px;height:44px;padding:0 12px;display:inline-flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;background:#fff;border:1px solid var(--rule);color:var(--tinta);transition:all .15s}
.pagination a:hover{background:var(--rojo);border-color:var(--rojo);color:#fff}
.pagination .on{background:var(--tinta);border-color:var(--tinta);color:#fff}

/* ============ SHARE STICKY MOBILE (NOTA) ============ */
.share-mobile{display:none}

/* iOS safe-area en footer y elementos pegados */
footer{padding-bottom:calc(24px + env(safe-area-inset-bottom))}

/* ============ RESPONSIVE ============ */
@media (max-width:1100px){
  .hero-grid{grid-template-columns:1fr}
  .has-side{grid-template-columns:1fr}
  .has-side aside{position:static}
  .grid-4{grid-template-columns:repeat(2,1fr)}
  .article-body{grid-template-columns:1fr;gap:32px}
  .article-side{position:static}
  .footer .grid-foot{grid-template-columns:1fr 1fr}
  .cat-list{grid-template-columns:1fr}
  .cat-hero-grid{grid-template-columns:1fr}
  .hero-main h1{font-size:38px}
}
@media (max-width:780px){
  .wrap{padding:0 16px}
  .header{padding:14px 0}
  .header .wrap{grid-template-columns:auto 1fr auto;gap:12px}
  .header .left{gap:6px}
  .header .left a:not(.icon-btn):not(.menu-btn){display:none}
  .header .right a:not(.suscribe){display:none}
  .header .right .clima{display:none}
  .header .menu-btn{display:inline-flex}
  .header .logo img{height:38px}
  .header .suscribe{padding:9px 14px;font-size:11.5px}

  .ticker{font-size:11.5px}
  .ticker .wrap{height:32px}
  .ticker .meta{display:none}
  .ticker .live{padding:0 10px;font-size:10px;letter-spacing:.1em}

  .nav .wrap{padding:0 12px}
  .nav .menu a{padding:0 14px}
  .nav .extra{display:none}

  .grid{gap:22px}
  .grid-3,.grid-2-1,.cat-grid,.grid-4{grid-template-columns:1fr}

  .hero{padding:18px 0 12px}
  .hero-main h1{font-size:28px;line-height:1.1}
  .hero-main .dek{font-size:15.5px;max-width:100%}
  .hero-main .copy{padding:16px 0 0}

  .hero-side .item{grid-template-columns:110px 1fr;gap:12px;padding-bottom:14px}
  .hero-side .item img{width:110px;height:75px}
  .hero-side .item h3{font-size:14.5px}

  .section-h{margin:28px 0 14px}
  .section-h h2{font-size:18px}
  .opinion .heading h2{font-size:22px}

  .card.lg h3,.card.xl h3{font-size:20px}
  .card h3{font-size:16px}

  .cat-head{padding:24px 0 18px}
  .cat-head h1{font-size:32px}
  .cat-head p{font-size:15px}

  .cat-hero .lead h2{font-size:24px;line-height:1.15}
  .cat-hero .lead .dek{font-size:14.5px}

  .article-head{padding:8px 0 20px}
  .article-head h1{font-size:28px;line-height:1.1}
  .article-head .dek{font-size:17px;line-height:1.45}
  .article-head .byline{flex-wrap:wrap;gap:12px;font-size:12.5px}
  .article-head .byline .when{margin-left:0;width:100%;order:3}
  .article-head .byline .share{margin-left:auto;order:2}

  .article-hero{margin:0 -16px 24px}
  .article-hero .cap{padding:12px 16px;font-size:11.5px}

  .article-body{padding-bottom:40px;gap:24px}
  .article-body .content{font-size:17px;line-height:1.65}
  .article-body .content h2{font-size:21px;margin:24px 0 10px}
  .article-body .content blockquote{font-size:19px;padding-left:18px;margin:24px 0}
  .article-body .content p:first-of-type::first-letter{font-size:54px;margin:4px 8px 0 0}

  .opinion{padding:30px 0;margin-top:30px}
  .opinion .heading h2{font-size:22px}
  .op{grid-template-columns:60px 1fr}
  .op .av{width:60px;height:60px}
  .op h4{font-size:16px}

  footer{padding:40px 0 calc(20px + env(safe-area-inset-bottom));margin-top:36px}
  footer .grid-foot{grid-template-columns:1fr;gap:28px;margin-bottom:28px}
  footer .bottom{flex-direction:column;gap:8px;text-align:center}

  /* Share sticky mobile en nota */
  .share-mobile{display:flex;position:fixed;left:0;right:0;bottom:0;z-index:60;background:#fff;border-top:1px solid var(--rule);padding:8px calc(8px + env(safe-area-inset-left)) calc(8px + env(safe-area-inset-bottom)) calc(8px + env(safe-area-inset-right));gap:6px;justify-content:space-around;box-shadow:0 -4px 14px rgba(0,0,0,.06)}
  .share-mobile a{flex:1;height:44px;display:inline-flex;align-items:center;justify-content:center;gap:6px;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;border-radius:6px;color:var(--tinta);background:var(--gris-claro)}
  .share-mobile a.wa{background:#25D366;color:#fff}
  .share-mobile a.tw{background:#000;color:#fff}
  .share-mobile a.fb{background:#1877F2;color:#fff}
  .share-mobile a.cp{background:var(--gris-claro);color:var(--tinta)}
  body.has-share-mobile{padding-bottom:64px}
}
@media (max-width:420px){
  .hero-main h1{font-size:24px}
  .article-head h1{font-size:24px}
  .cat-head h1{font-size:28px}
  .hero-side .item{grid-template-columns:96px 1fr}
  .hero-side .item img{width:96px;height:66px}
}
