:root{
  --maxw:1140px; --red:#c1121f; --ink:#181818; --muted:#6b6b6b;
  --line:#e4e4e4; --bg:#fff; --soft:#f5f5f4;
  --serif:Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--bg);line-height:1.5;font-size:16px}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:underline}
img{max-width:100%;height:auto;display:block}
.container{max-width:var(--maxw);margin:0 auto;padding:0 16px}

/* Header */
.topbar{background:#111;color:#cfcfcf;font-size:13px}
.topbar-in{display:flex;justify-content:space-between;align-items:center;height:34px}
.topbar a{color:#fff}
.today{text-transform:capitalize}
.masthead{display:flex;align-items:center;justify-content:space-between;padding:18px 16px;gap:16px}
.logo{font-family:var(--serif);font-weight:800;font-size:34px;letter-spacing:-.5px}
.logo img{max-height:54px}
.search{display:flex;border:1px solid var(--line);border-radius:6px;overflow:hidden}
.search input{border:0;padding:8px 14px;outline:0;font-size:14px;min-width:170px}
.search button{border:0;background:var(--soft);padding:0 14px;cursor:pointer}
.mainnav{border-top:2px solid var(--red);border-bottom:1px solid var(--line);background:#fff;position:sticky;top:0;z-index:50}
.mainnav-in{display:flex;gap:2px;overflow-x:auto;white-space:nowrap}
.mainnav a{padding:12px 14px;font-weight:600;font-size:14.5px}
.mainnav a:hover{color:var(--red);text-decoration:none;background:var(--soft)}

/* Layout */
.main{padding:22px 16px 40px}
.layout-2col{display:grid;grid-template-columns:1fr 320px;gap:34px}
.col-full{grid-column:1/-1}
@media(max-width:900px){.layout-2col{grid-template-columns:1fr}}

/* Hero */
.hero{display:grid;grid-template-columns:1.3fr 1fr;gap:20px;border-bottom:1px solid var(--line);padding-bottom:22px;margin-bottom:6px}
.hero-thumb img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:6px}
.hero-cat,.card-cat,.post-cat{color:var(--red);font-weight:700;text-transform:uppercase;font-size:12px;letter-spacing:.5px}
.hero-title{font-family:var(--serif);font-size:32px;line-height:1.15;margin:8px 0}
.hero-exc{color:var(--muted);font-size:17px}
.hero-date{color:#999;font-size:13px}
@media(max-width:700px){.hero{grid-template-columns:1fr}.hero-title{font-size:26px}}

.section-head{font-family:var(--serif);font-size:20px;border-left:4px solid var(--red);padding-left:10px;margin:26px 0 14px}

/* Cards */
.cards-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
@media(max-width:560px){.cards-grid{grid-template-columns:1fr}}
.card{display:flex;flex-direction:column}
.card-thumb img{width:100%;aspect-ratio:16/9;object-fit:cover;border-radius:6px}
.card-title{font-family:var(--serif);font-size:19px;line-height:1.25;margin:8px 0 6px}
.card-exc{color:var(--muted);font-size:14.5px;margin:0 0 8px}
.card-date{color:#9a9a9a;font-size:12.5px}

/* Sidebar */
.sidebar .widget{border:1px solid var(--line);border-radius:8px;padding:14px;margin-bottom:20px}
.widget-title{margin:0 0 10px;font-size:15px;border-bottom:2px solid var(--red);display:inline-block;padding-bottom:4px}
.mostread{margin:0;padding:0;list-style:none;counter-reset:mr}
.mostread li{counter-increment:mr;display:flex;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);align-items:baseline}
.mostread li:last-child{border-bottom:0}
.mostread li::before{content:counter(mr);color:var(--red);font-family:var(--serif);font-weight:800;font-size:20px;line-height:1}
.mostread a{font-weight:600;font-size:14px}
.mr-cat{display:block;color:var(--muted);font-size:11px;text-transform:uppercase}

/* Ads */
.ad{margin:18px 0;text-align:center}
.ad-placeholder{background:repeating-linear-gradient(45deg,#f3f3f3,#f3f3f3 10px,#ececec 10px,#ececec 20px);border:1px dashed #ccc;color:#999;font-size:12px;letter-spacing:1px;text-transform:uppercase;padding:34px 0;border-radius:6px}

/* Article */
.crumbs{font-size:13px;color:var(--muted);margin-bottom:10px}
.post-title{font-family:var(--serif);font-size:38px;line-height:1.12;margin:6px 0 10px}
.post-lead{font-size:20px;color:#333;line-height:1.45;margin:0 0 14px}
.post-meta{display:flex;gap:16px;flex-wrap:wrap;color:var(--muted);font-size:13.5px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:10px 0;margin-bottom:18px}
.post-cover img{width:100%;border-radius:8px}
.post-cover figcaption{color:#999;font-size:13px;margin-top:6px}
.share{display:flex;gap:8px;margin:16px 0}
.share a{font-size:13px;border:1px solid var(--line);padding:6px 12px;border-radius:999px}
.share a:hover{background:var(--soft);text-decoration:none}
.article-body{font-size:18px;line-height:1.7}
.article-body p{margin:0 0 18px}
.article-body h2{font-family:var(--serif);font-size:25px;margin:28px 0 12px}
.article-body h3{font-size:20px;margin:22px 0 10px}
.article-body img{border-radius:6px;margin:14px 0}
.article-body figure{margin:18px 0}
.article-body figcaption{color:#999;font-size:13px;text-align:center}
.article-body ul,.article-body ol{margin:0 0 18px 22px}
.article-body blockquote{border-left:4px solid var(--red);margin:18px 0;padding:4px 16px;color:#444;font-style:italic}
@media(max-width:700px){.post-title{font-size:28px}.article-body{font-size:17px}}

/* Misc */
.cat-head h1{font-family:var(--serif);font-size:30px;margin:0 0 6px}
.cat-head p{color:var(--muted);margin:0 0 10px}
.empty{color:var(--muted);padding:30px 0}
.pager{display:flex;justify-content:space-between;align-items:center;margin:28px 0;gap:12px}
.pager a{border:1px solid var(--line);padding:8px 14px;border-radius:6px}
.pager-info{color:var(--muted);font-size:13px}
.btn{display:inline-block;background:var(--soft);border:1px solid var(--line);padding:9px 16px;border-radius:6px;cursor:pointer;font-size:14px;color:var(--ink)}
.btn:hover{text-decoration:none;background:#ececec}
.btn-primary{background:var(--red);color:#fff;border-color:var(--red)}
.btn-primary:hover{background:#a30f1a}
.btn-sm{padding:6px 10px;font-size:13px}
.btn-block{width:100%}
.notfound{text-align:center;padding:60px 0}
.notfound h1{font-family:var(--serif);font-size:80px;color:var(--red);margin:0}

/* Footer */
.site-footer{background:#111;color:#bbb;margin-top:40px;padding:34px 0}
.footcols{display:grid;grid-template-columns:2fr 1fr 1fr;gap:24px}
.footcols h5{color:#fff;margin:0 0 10px}
.footcols a{display:block;color:#bbb;padding:3px 0;font-size:14px}
.foot-brand{font-family:var(--serif);font-size:22px;color:#fff}
.copyr{border-top:1px solid #333;margin-top:24px;padding-top:16px;font-size:13px;color:#888}
@media(max-width:700px){.footcols{grid-template-columns:1fr}}

/* ---------- Admin ---------- */
.admin{background:var(--soft)}
.admin-bar{background:#111;color:#fff}
.admin-bar-in{display:flex;justify-content:space-between;align-items:center;height:52px}
.admin-logo{font-weight:700;color:#fff}
.admin-nav{display:flex;gap:14px;flex-wrap:wrap}
.admin-nav a{color:#cfcfcf;font-size:14px}
.admin-nav a:hover{color:#fff}
.admin-main{padding:24px 16px 60px}
.admin-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px}
.admin-head h1{font-size:24px;margin:0}
.flash{background:#e7f6e7;border:1px solid #b6e0b6;color:#256b25;padding:10px 14px;border-radius:6px;margin-bottom:16px}
.form-error{background:#fdecec;border:1px solid #f3b6b6;color:#a12020;padding:10px 14px;border-radius:6px;margin-bottom:14px}
.form label{display:block;margin-bottom:14px;font-size:13px;font-weight:600;color:#444}
.form label.big input{font-size:20px;font-weight:700}
.form input[type=text],.form input[type=password],.form input[type=search],.form input[type=file],.form select,.form textarea{
  width:100%;margin-top:5px;padding:9px 10px;border:1px solid #ccc;border-radius:6px;font:inherit;font-weight:400}
.form textarea.code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:14px;line-height:1.5}
.login-box{max-width:360px;margin:50px auto;background:#fff;border:1px solid var(--line);border-radius:10px;padding:28px}
.login-box h1{font-size:22px;margin:0 0 18px}
.admin-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.admin-table th,.admin-table td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line);font-size:14px;vertical-align:middle}
.admin-table th{background:#fafafa;font-size:12px;text-transform:uppercase;color:#777}
.badge{font-size:11px;padding:3px 8px;border-radius:999px}
.badge-published{background:#e7f6e7;color:#256b25}
.badge-draft{background:#f0f0f0;color:#777}
.row-actions{display:flex;gap:12px;align-items:center}
.inline{display:inline}
.link-danger{background:none;border:0;color:var(--red);cursor:pointer;font:inherit;padding:0}
.link-danger:hover{text-decoration:underline}
.muted{color:#999}
.article-form .col-main{background:#fff;border:1px solid var(--line);border-radius:8px;padding:18px}
.admin-2col{grid-template-columns:1fr 320px}
.editor-toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:8px}
.editor-toolbar .hint{color:#999;font-size:12px}
.preview-pane{border:1px dashed #ccc;border-radius:6px;padding:16px;margin-top:12px;background:#fff}
.cover-preview{min-height:40px;margin-bottom:8px}
.cover-preview img{width:100%;border-radius:6px}
.contact-form{max-width:560px;margin-top:22px;border-top:1px solid var(--line);padding-top:18px}
.page-static .article-body{font-size:17px}

/* Video embeds (YouTube + video.js responsive) */
.video-embed{position:relative;margin:18px 0;border-radius:8px;overflow:hidden;background:#000}
.video-yt{aspect-ratio:16/9}
.video-yt iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.video-embed .video-js{width:100%}

/* Reacciones */
.reactions{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:22px 0;padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.react-btn{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--line);border-radius:999px;padding:9px 18px;cursor:pointer;font:inherit;font-weight:600;transition:.15s}
.react-btn:hover{border-color:var(--red)}
.react-btn.is-on{background:var(--red);color:#fff;border-color:var(--red)}
.react-btn .react-ico{font-size:18px;line-height:1}
.react-hint{color:var(--muted);font-size:13px}

/* Comentarios */
.comments{margin-top:30px}
.comment-form{margin-bottom:22px}
.comment-form textarea{width:100%;padding:11px;border:1px solid #ccc;border-radius:8px;font:inherit;resize:vertical}
.comment-form-foot{display:flex;justify-content:space-between;align-items:center;margin-top:8px;gap:10px;flex-wrap:wrap}
.comment-login{background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:14px 16px}
.comment-list{list-style:none;margin:0;padding:0}
.comment{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.comment-avatar{flex:0 0 auto;width:40px;height:40px;border-radius:50%;background:var(--red);color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--serif);font-size:18px}
.comment-head{font-size:13px;color:var(--muted);margin-bottom:3px}
.comment-head strong{color:var(--ink)}
.comment-body{font-size:15px;line-height:1.55}
.comment-empty{padding:18px 0}
.small{font-size:13px}

/* Auth (login / registro) — diseño profesional */
.auth-wrap{display:flex;justify-content:center;padding:32px 16px 56px}
.auth-card{width:100%;max-width:420px;background:#fff;border:1px solid var(--line);border-radius:16px;
  padding:32px 30px;box-shadow:0 8px 30px rgba(20,20,20,.07);animation:aggFadeUp .4s ease both}
.auth-head{text-align:center;margin-bottom:22px}
.auth-logo{display:inline-block;font-family:var(--serif);font-weight:800;font-size:26px;color:var(--red);
  letter-spacing:-.5px;margin-bottom:14px}
.auth-logo:hover{text-decoration:none;opacity:.85}
.auth-head h1{font-family:var(--serif);font-size:25px;margin:0 0 6px;line-height:1.2}
.auth-sub{color:var(--muted);font-size:14.5px;margin:0}
.auth-perks{list-style:none;margin:0 0 20px;padding:14px 16px;display:grid;gap:8px;
  background:var(--soft);border-radius:10px;font-size:14px;color:#444}
.auth-form .field{display:block;margin-bottom:16px}
.auth-form .field-label{display:block;font-weight:600;font-size:13px;color:#444;margin-bottom:6px}
.auth-form .field-label small{font-weight:400;color:var(--muted)}
.auth-form input{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;
  font:inherit;background:#fff;transition:border-color .15s ease,box-shadow .15s ease}
.auth-form input:focus{outline:0;border-color:var(--red);box-shadow:0 0 0 3px rgba(193,18,31,.12)}
.field-pass{position:relative;display:block}
.field-pass input{padding-right:46px}
.pass-toggle{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:0;
  cursor:pointer;font-size:17px;line-height:1;padding:6px;border-radius:6px;opacity:.6}
.pass-toggle:hover{opacity:1;background:var(--soft)}
.btn-lg{padding:13px 18px;font-size:15.5px;font-weight:700}
.auth-fine{font-size:12px;color:var(--muted);text-align:center;margin:14px 0 0}
.auth-fine a{color:var(--muted);text-decoration:underline}
.auth-alt{margin:16px 0 0;text-align:center;color:var(--muted);font-size:14px}
.auth-alt a{color:var(--red);font-weight:600}
.account-list{list-style:none;margin:0;padding:0}
.account-list li{padding:12px 0;border-bottom:1px solid var(--line)}
.account-quote{color:var(--muted);font-size:14px;margin:6px 0 0}
.account-head{display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--line);padding-bottom:18px;margin-bottom:18px}
.account-head-info{flex:1 1 auto;min-width:0}
.account-head-info h1{font-family:var(--serif);font-size:26px;margin:0 0 2px}
.account-quick{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:24px}
.account-tile{display:inline-flex;align-items:center;gap:8px;background:var(--soft);border:1px solid var(--line);
  border-radius:10px;padding:11px 16px;font-weight:600;font-size:14px;transition:all .18s ease}
.account-tile:hover{border-color:var(--red);transform:translateY(-2px);text-decoration:none}
.account-tile-ic{font-size:17px}

/* Newsletter / contest widgets */
.widget-news .news-form input{width:100%;padding:9px 10px;border:1px solid #ccc;border-radius:6px;margin-bottom:8px;font:inherit}
.widget-news,.widget-contest{background:var(--soft)}
.nav-promo{color:var(--red) !important;font-weight:800}

/* Concursos */
.contest-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
@media(max-width:560px){.contest-grid{grid-template-columns:1fr}}
.contest-card{border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}
.contest-thumb{position:relative;display:block}
.contest-thumb img{width:100%;aspect-ratio:16/9;object-fit:cover}
.contest-state{position:absolute;top:10px;left:10px;font-size:11px;font-weight:700;text-transform:uppercase;padding:4px 10px;border-radius:999px;color:#fff}
.contest-state.is-open{background:#1a9e4b}
.contest-state.is-closed{background:#888}
.contest-body{padding:14px}
.contest-body h3{font-family:var(--serif);font-size:19px;margin:0 0 8px}
.contest-prize{color:var(--red);font-weight:700;margin:0 0 6px}
.contest-prize-lg{font-size:18px;margin:0 0 14px}
.contest-meta{display:flex;gap:18px;flex-wrap:wrap;color:var(--muted);font-size:14px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:12px 0;margin:18px 0}
.contest-cta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:16px}
.contest-form{max-width:520px;margin-top:16px}
.contest-winner{background:#fff7e0;border:1px solid #f0d98a;border-radius:8px;padding:14px 16px;margin:16px 0;font-size:16px}
.flash-float{margin-bottom:18px}
.is-winner-row{background:#fff7e0}
.badge-win{background:#ffe9a8;color:#8a6b00}
.badge-visible{background:#e7f6e7;color:#256b25}
.badge-pending{background:#fff3cd;color:#856404}
.badge-spam{background:#fdecec;color:#a12020}
.link-act{background:none;border:0;color:#1a6fd6;cursor:pointer;font:inherit;padding:0}
.link-act:hover{text-decoration:underline}
.cell-wrap{max-width:280px;white-space:normal}

/* ---------- Agregador de noticias ---------- */
.agg-hero-head{margin-bottom:14px}
.agg-hero-head h1{font-family:var(--serif);font-size:30px;margin:0 0 4px}
.agg-scope-nav{display:flex;gap:6px;flex-wrap:wrap;border-bottom:2px solid var(--red);padding-bottom:10px;margin-bottom:20px}
.agg-scope-nav a{padding:7px 14px;border-radius:999px;background:var(--soft);font-weight:600;font-size:14px}
.agg-scope-nav a:hover,.agg-scope-nav a.is-active{background:var(--red);color:#fff;text-decoration:none}
.agg-section-head{display:flex;justify-content:space-between;align-items:baseline}
.agg-seemore{font-size:13px;color:var(--red);font-weight:600}
.agg-more{margin:18px 0;text-align:center}
.agg-card-tags{display:flex;gap:8px;align-items:center;margin-bottom:6px;flex-wrap:wrap}
.tag-police{background:#ffe3e3;color:#c1121f;font-size:11px;font-weight:700;padding:2px 8px;border-radius:999px;text-transform:uppercase}
.agg-card-meta{display:flex;gap:10px;flex-wrap:wrap;align-items:center;color:#9a9a9a;font-size:12.5px;margin-top:6px}
.agg-card-meta .agg-geo{color:var(--red);font-weight:600}
.agg-card-meta .agg-src{font-style:italic}
.agg-prov-list,.agg-cat-list{list-style:none;margin:0;padding:0}
.agg-prov-list li,.agg-cat-list li{display:flex;justify-content:space-between;align-items:center;padding:6px 0;border-bottom:1px solid var(--line);font-size:14px}
.agg-prov-list li:last-child,.agg-cat-list li:last-child{border-bottom:0}
.agg-count{background:var(--soft);color:#777;font-size:11px;padding:2px 8px;border-radius:999px;min-width:24px;text-align:center}
.agg-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:18px}
.agg-chip{background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:6px 12px;font-size:13px}
.agg-chip:hover{background:#ececec;text-decoration:none}
.agg-source-box{background:var(--soft);border:1px solid var(--line);border-left:4px solid var(--red);border-radius:8px;padding:16px 18px;margin:22px 0}
.agg-source-box p{margin:0 0 10px}
.badge-nacional{background:#e7eefc;color:#1a4fd6}
.badge-provincial{background:#fff3cd;color:#856404}
.badge-local{background:#e7f6e7;color:#256b25}
.agg-admin-actions{display:flex;gap:8px;flex-wrap:wrap}
.agg-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin:18px 0}
@media(max-width:700px){.agg-stats{grid-template-columns:repeat(2,1fr)}}
.agg-stat{background:#fff;border:1px solid var(--line);border-radius:8px;padding:14px;text-align:center}
.agg-stat .n{display:block;font-size:24px;font-weight:800;font-family:var(--serif);color:var(--red)}
.agg-stat .l{display:block;font-size:12px;color:#777;margin-top:4px}
.agg-add{margin:18px 0}
.agg-add-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px;margin:14px 0}
@media(max-width:700px){.agg-add-grid{grid-template-columns:1fr}}
.agg-row-fail{background:#fff8f8}
.agg-err{color:var(--red)}
details>summary.btn{display:inline-block;list-style:none;cursor:pointer}
details>summary.btn::-webkit-details-marker{display:none}
.agg-intro{background:var(--soft);border-left:4px solid var(--red);padding:12px 16px;border-radius:6px;color:#444;font-size:15px;margin-top:10px}
.agg-own{margin-bottom:8px}
.agg-promote{margin:18px 0;padding:14px 16px;background:#f3f8ff;border:1px solid #cfe0f5;border-radius:8px;display:flex;gap:12px;align-items:center;flex-wrap:wrap}
.agg-prov-grid-wrap{margin-top:34px}
.agg-prov-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
@media(max-width:700px){.agg-prov-grid{grid-template-columns:repeat(2,1fr)}}
.agg-prov-tile{display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid var(--line);border-radius:8px;padding:11px 14px;font-weight:600;font-size:14px}
.agg-prov-tile:hover{border-color:var(--red);text-decoration:none}
.agg-prov-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.langsw{display:inline-flex;gap:4px;margin-right:10px}
.langsw a{padding:2px 7px;border-radius:4px;font-weight:700;font-size:12px;color:#cfcfcf;border:1px solid #333}
.langsw a.is-on{background:var(--red);color:#fff;border-color:var(--red)}
.foot-langs{margin-top:8px}
.foot-langs a{display:inline;color:#bbb}
.agg-geo-banner{display:flex;align-items:center;gap:10px;flex-wrap:wrap;background:#eef6ff;border:1px solid #cfe0f5;border-radius:8px;padding:10px 14px;margin-bottom:18px;font-size:14px}
.agg-geo-banner .agg-geo-flag{font-size:18px}
.agg-geo-cta{margin-left:auto;color:var(--red);font-weight:700}
.agg-card-meta .agg-src{color:#555;font-weight:600}
.agg-card-meta .agg-src:hover{color:var(--red)}
/* Directorio de medios */
.agg-src-country{margin-bottom:22px}
.agg-src-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
@media(max-width:640px){.agg-src-grid{grid-template-columns:1fr}}
.agg-src-tile{display:flex;flex-direction:column;gap:5px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:12px 14px}
.agg-src-tile:hover{border-color:var(--red);text-decoration:none;box-shadow:0 1px 6px rgba(0,0,0,.06)}
.agg-src-name{font-family:var(--serif);font-weight:700;font-size:16px;color:var(--ink)}
.agg-src-meta{display:flex;justify-content:space-between;align-items:center;gap:8px;color:#888;font-size:12.5px}
.agg-src-geo{color:var(--red);font-weight:600}
/* Autores */
.agg-author-list{list-style:none;margin:0;padding:0}
.agg-author-list li{display:flex;justify-content:space-between;align-items:center;gap:8px;padding:6px 0;border-bottom:1px solid var(--line);font-size:14px}
.agg-author-list li:last-child{border-bottom:0}
.agg-author-list li.is-on a{color:var(--red);font-weight:700}
.agg-src-head h1{font-family:var(--serif)}
/* Bienvenida (visitante nuevo) */
.agg-welcome{background:linear-gradient(120deg,#c1121f,#7a0c14);color:#fff;border-radius:12px;padding:22px 24px;margin-bottom:18px}
.agg-welcome-title{margin:0 0 6px;font-family:var(--serif);font-size:26px}
.agg-welcome-text{margin:0 0 14px;font-size:15px;opacity:.95;max-width:640px}
.agg-welcome-cta{display:flex;gap:10px;flex-wrap:wrap}
.agg-welcome-cta .btn{background:#fff;color:var(--red);border:0}
.agg-welcome-cta .btn-primary{background:#111;color:#fff}
.agg-welcome-cta .btn-ghost{background:transparent;color:#fff;border:1px solid rgba(255,255,255,.6)}
.agg-welcome-cta .btn:hover{opacity:.9}
/* Nota de fallback geo (ciudad sin noticias -> provincia) */
.agg-geo-note{background:#fff7e0;border:1px solid #f0d98a;border-radius:6px;padding:8px 12px;font-size:13.5px;color:#7a5b00;margin:0 0 12px}
/* Diarios de la zona */
.agg-zone-sources{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:12px 0 4px}
.agg-zone-sources-label{font-size:13px;color:#666;font-weight:600;margin-right:4px}

/* ====================== Animaciones y micro-interacciones ====================== */
@keyframes aggFadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:none}}
@keyframes aggFadeIn{from{opacity:0}to{opacity:1}}
@keyframes aggSlideDown{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
@keyframes aggShimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}

/* Aparición suave de tarjetas (escalonada por posición) */
.cards-grid .card{animation:aggFadeUp .45s ease both}
.cards-grid .card:nth-child(2){animation-delay:.05s}
.cards-grid .card:nth-child(3){animation-delay:.1s}
.cards-grid .card:nth-child(4){animation-delay:.15s}
.cards-grid .card:nth-child(5){animation-delay:.2s}
.cards-grid .card:nth-child(6){animation-delay:.25s}
.hero{animation:aggFadeUp .5s ease both}
.agg-welcome{animation:aggSlideDown .5s ease both}
.agg-geo-banner{animation:aggFadeIn .6s ease both}

/* Transiciones generales */
.card,.agg-src-tile,.agg-prov-tile,.agg-chip,.btn,.card-thumb img,.hero-thumb img,
.mainnav a,.agg-scope-nav a,.card-title a,.widget,.react-btn{transition:all .2s ease}

/* Hover: levantar tarjetas y zoom suave de imagen */
.card:hover{transform:translateY(-4px)}
.card:hover .card-title a{color:var(--red)}
.card-thumb,.hero-thumb{overflow:hidden;border-radius:6px}
.card-thumb img:hover,.hero-thumb img:hover{transform:scale(1.05)}
.agg-src-tile:hover,.agg-prov-tile:hover{transform:translateY(-3px)}
.agg-chip:hover{transform:translateY(-2px)}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}

/* Subrayado animado en navegación */
.mainnav a{position:relative}
.mainnav a::after{content:"";position:absolute;left:14px;right:14px;bottom:6px;height:2px;background:var(--red);transform:scaleX(0);transform-origin:left;transition:transform .2s ease}
.mainnav a:hover::after{transform:scaleX(1)}

/* Botón "me gusta" al reaccionar */
.react-btn.is-on{animation:aggPulse .35s ease}
@keyframes aggPulse{0%{transform:scale(1)}40%{transform:scale(1.12)}100%{transform:scale(1)}}

/* Placeholder con shimmer mientras no hay imagen real */
.card-noimg .card-thumb{background:linear-gradient(90deg,#eee 25%,#f5f5f5 37%,#eee 63%);background-size:800px 100%;animation:aggShimmer 1.4s infinite linear}

/* Respeta a quienes prefieren menos movimiento (accesibilidad) */
@media (prefers-reduced-motion: reduce){
  *,*::before,*::after{animation:none !important;transition:none !important}
}

/* ====================== Avatares de autor ====================== */
.agg-avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;
  color:#fff;font-weight:700;font-family:var(--sans);line-height:1;flex:0 0 auto;vertical-align:middle;
  text-transform:uppercase;letter-spacing:.5px}
.agg-avatar-img{border-radius:50%;object-fit:cover;flex:0 0 auto;vertical-align:middle;background:#eee}
/* Header de página de autor */
.agg-author-head{display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:18px;animation:aggFadeUp .4s ease both}
.agg-author-head .agg-avatar,.agg-author-head .agg-avatar-img{box-shadow:0 2px 10px rgba(0,0,0,.12)}
.agg-author-head-info h1{font-family:var(--serif);margin:0 0 4px;font-size:30px}
.agg-author-head-info .muted a{color:var(--red);font-weight:600}
/* Lista de autores en el sidebar (con avatar) */
.agg-author-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.agg-author-link{display:flex;align-items:center;gap:8px;min-width:0}
.agg-author-link .agg-author-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.agg-author-row:hover .agg-author-name{color:var(--red)}
/* Autor en la nota */
.post-author a{display:inline-flex;align-items:center;gap:6px}
.badge-scrape{background:#ede7f6;color:#5e35b1;font-size:10px;margin-left:6px}

/* Barra de secciones (país↔categoría combinadas) */
.agg-sectionbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:0 0 18px;padding-bottom:12px;border-bottom:1px solid var(--line)}
.agg-sec-label{font-size:13px;color:#888;font-weight:600;margin-right:2px}
.agg-sec{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border:1px solid var(--line);border-radius:999px;font-size:13.5px;font-weight:600;background:#fff;transition:all .18s ease}
.agg-sec:hover{border-color:var(--red);transform:translateY(-2px);text-decoration:none}
.agg-sec.is-on{background:var(--red);color:#fff;border-color:var(--red)}
.agg-sec.is-on .agg-count{background:rgba(255,255,255,.25);color:#fff}
.agg-sec-police.is-on{background:#c1121f}
.agg-sec .agg-count{background:var(--soft);color:#777}

/* Botón Seguir / Siguiendo */
.agg-head-follow{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;flex-wrap:wrap}
.agg-follow-btn{flex:0 0 auto;display:inline-flex;align-items:center;gap:6px;cursor:pointer;
  background:#fff;border:1.5px solid var(--red);color:var(--red);border-radius:999px;
  padding:8px 16px;font:inherit;font-weight:700;font-size:14px;transition:all .18s ease;white-space:nowrap}
.agg-follow-btn:hover{background:var(--red);color:#fff;text-decoration:none;transform:translateY(-1px)}
.agg-follow-btn.is-on{background:var(--red);color:#fff}
.agg-follow-btn.is-on:hover{background:#a30f1a}
.agg-follow-login{border-color:var(--line);color:#555}
.agg-follow-login:hover{background:var(--soft);color:var(--ink)}
.agg-follow-chips{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:0 0 18px;padding-bottom:14px;border-bottom:1px solid var(--line)}
/* Bloque de "Seguir" en la noticia individual */
.agg-item-follow{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:0 0 16px}
.agg-item-follow-label{font-size:13px;font-weight:600;color:#888;margin-right:2px}
.agg-item-follow .agg-follow-btn{padding:6px 13px;font-size:13px}

/* ===================== Comunidad: header (campanita + sobre + avatar) ===================== */
.topbar-links{display:flex;align-items:center;gap:14px}
.tb-user{display:inline-flex;align-items:center;gap:6px}
.tb-user .agg-avatar,.tb-user .agg-avatar-img{width:22px;height:22px;font-size:10px}
.hdr-ind{position:relative;display:inline-flex}
.hdr-btn{position:relative;background:transparent;border:0;color:#fff;cursor:pointer;font-size:16px;line-height:1;padding:4px;border-radius:6px}
.hdr-btn:hover{background:rgba(255,255,255,.12)}
.hdr-badge{position:absolute;top:-4px;right:-6px;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--red);color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;box-shadow:0 0 0 2px #111}
.hdr-pop{position:absolute;top:34px;right:0;width:330px;max-width:88vw;background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:10px;box-shadow:0 12px 40px rgba(0,0,0,.18);z-index:120;overflow:hidden;animation:aggFadeUp .16s ease both}
.hdr-pop-head{display:flex;justify-content:space-between;align-items:center;padding:11px 14px;border-bottom:1px solid var(--line);font-size:14px}
.hdr-pop-mark{background:transparent;border:0;color:var(--red);cursor:pointer;font-size:12px;font-weight:600}
.hdr-pop-mark:hover{text-decoration:underline}
.hdr-pop-body{max-height:60vh;overflow:auto}
.hdr-pop-empty{padding:26px 16px;text-align:center;color:var(--muted);font-size:13.5px}
.hdr-pop-item{display:flex;gap:10px;align-items:flex-start;padding:11px 14px;border-bottom:1px solid var(--line)}
.hdr-pop-item:hover{background:var(--soft);text-decoration:none}
.hdr-pop-item.is-unseen{background:#fbf3f3}
.hdr-pop-item.is-unseen:hover{background:#f7eaea}
.hdr-pop-ic{font-size:18px;flex:0 0 auto;line-height:1.3}
.hdr-pop-av{flex:0 0 auto}
.hdr-pop-txt{min-width:0;display:flex;flex-direction:column;gap:1px}
.hdr-pop-t{font-size:13.5px;font-weight:600;color:var(--ink)}
.hdr-pop-d{font-size:12.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.hdr-pop-time{font-size:11px;color:#aaa}
.hdr-pop-foot{display:block;text-align:center;padding:10px;font-size:13px;font-weight:600;color:var(--red);border-top:1px solid var(--line)}
.hdr-pop-foot:hover{background:var(--soft);text-decoration:none}
@media(max-width:560px){.tb-hide-sm{display:none}}

/* ===================== Página de notificaciones ===================== */
.notif-page-list{list-style:none;margin:0;padding:0;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.notif-item{border-bottom:1px solid var(--line)}
.notif-item:last-child{border-bottom:0}
.notif-item a{display:flex;gap:12px;align-items:flex-start;padding:14px 16px}
.notif-item a:hover{background:var(--soft);text-decoration:none}
.notif-item.is-unseen{background:#fbf3f3}
.notif-ic{font-size:22px;flex:0 0 auto}
.notif-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.notif-title{font-weight:600}
.notif-detail{color:var(--muted);font-size:14px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.notif-time{color:#aaa;font-size:12px}

/* ===================== Mensajería: bandeja ===================== */
.dm-wrap{max-width:720px;margin:0 auto}
.dm-threads{list-style:none;margin:0;padding:0;border:1px solid var(--line);border-radius:10px;overflow:hidden}
.dm-threads-mini{margin-bottom:8px}
.dm-thread{border-bottom:1px solid var(--line)}
.dm-thread:last-child{border-bottom:0}
.dm-thread a{display:flex;align-items:center;gap:12px;padding:12px 14px}
.dm-thread a:hover{background:var(--soft);text-decoration:none}
.dm-thread-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.dm-thread-top{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.dm-thread-name{font-size:15px}
.dm-thread-time{font-size:11.5px;color:#aaa;flex:0 0 auto}
.dm-thread-snippet{font-size:13.5px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.dm-thread.has-unread .dm-thread-name{font-weight:800}
.dm-thread.has-unread .dm-thread-snippet{color:var(--ink);font-weight:600}
.dm-badge{flex:0 0 auto;min-width:20px;height:20px;padding:0 6px;border-radius:999px;background:var(--red);color:#fff;font-size:11px;font-weight:700;line-height:20px;text-align:center}
.dm-badge.sm{display:inline-block;min-width:16px;height:16px;line-height:16px;font-size:10px;vertical-align:middle;margin-left:4px}

/* ===================== Mensajería: chat ===================== */
.dm-chat{display:flex;flex-direction:column;height:calc(100vh - 220px);min-height:420px;max-width:720px;margin:0 auto;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}
.dm-chat-head{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);background:var(--soft)}
.dm-back{font-size:24px;line-height:1;color:var(--muted);padding:0 4px}
.dm-back:hover{color:var(--red);text-decoration:none}
.dm-chat-peer{display:flex;flex-direction:column;line-height:1.25}
.dm-chat-peer strong{font-size:15px}
.dm-typing{font-size:12px;color:var(--red);font-style:italic}
.dm-messages{flex:1;overflow-y:auto;padding:18px 16px;display:flex;flex-direction:column;gap:8px;background:linear-gradient(#fff,#fafafa)}
.dm-empty{text-align:center;margin:auto;color:var(--muted)}
.dm-daysep{text-align:center;margin:6px 0}
.dm-daysep span{display:inline-block;background:#ececec;color:#777;font-size:11.5px;padding:3px 12px;border-radius:999px;text-transform:capitalize}
.dm-msg{display:flex;max-width:78%}
.dm-msg.mine{align-self:flex-end;justify-content:flex-end}
.dm-bubble{position:relative;background:#fff;border:1px solid var(--line);padding:9px 13px 6px;border-radius:14px;font-size:15px;line-height:1.4;white-space:pre-wrap;word-wrap:break-word;border-bottom-left-radius:4px}
.dm-msg.mine .dm-bubble{background:var(--red);color:#fff;border-color:var(--red);border-radius:14px;border-bottom-right-radius:4px;border-bottom-left-radius:14px}
.dm-time{display:block;text-align:right;font-size:10.5px;color:#aaa;margin-top:3px}
.dm-msg.mine .dm-time{color:rgba(255,255,255,.8)}
.dm-composer{display:flex;gap:8px;align-items:flex-end;padding:10px 12px;border-top:1px solid var(--line);background:#fff}
.dm-composer textarea{flex:1;resize:none;border:1px solid var(--line);border-radius:18px;padding:9px 14px;font:inherit;font-size:15px;outline:0;max-height:140px}
.dm-composer textarea:focus{border-color:var(--red)}
.dm-send{flex:0 0 auto;border-radius:50%;width:42px;height:42px;padding:0;font-size:17px;display:grid;place-items:center}
@media(max-width:700px){.dm-chat{height:calc(100vh - 150px);border-radius:0;border-left:0;border-right:0}}

/* ===================== Comentarios: respuestas (threading) ===================== */
.comment-actions{margin-top:4px}
.comment-reply-btn{background:transparent;border:0;color:var(--muted);cursor:pointer;font-size:12.5px;font-weight:600;padding:2px 0}
.comment-reply-btn:hover{color:var(--red)}
.comment-reply-form{margin:10px 0 4px}
.comment-children{margin-top:10px;padding-left:0;border-left:2px solid var(--line);padding-left:14px}
.comment-children .comment{padding:10px 0}
.comment-dm{color:var(--muted);font-size:13px;margin-left:4px;text-decoration:none}
.comment-dm:hover{color:var(--red)}
.btn-sm{padding:6px 12px;font-size:13px}
.comment-new{animation:aggFadeUp .4s ease both}
.comment-new>.comment-main>.comment-body{background:#fff7e6;border-radius:6px}

/* ===================== Formulario de perfil / cuenta ===================== */
.form-error{background:#fdecec;border:1px solid #f3c2c2;color:#a12020;padding:10px 14px;border-radius:8px;margin-bottom:16px}
.field{display:block;margin-bottom:14px}
.field-label{display:block;font-size:13px;font-weight:600;color:#555;margin-bottom:5px}
.field input,.field textarea{width:100%;padding:10px 12px;border:1px solid #ccc;border-radius:8px;font:inherit;outline:0}
.field input:focus,.field textarea:focus{border-color:var(--red)}
.profile-form,.password-form{max-width:560px}
.profile-avatar-row{display:flex;gap:18px;align-items:center;margin-bottom:16px}
.profile-avatar-prev .agg-avatar,.profile-avatar-prev .agg-avatar-img{width:96px;height:96px;font-size:40px;box-shadow:0 2px 10px rgba(0,0,0,.12)}
.profile-avatar-ctrls{display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.profile-remove{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px;cursor:pointer}
.account-head .agg-avatar,.account-head .agg-avatar-img{width:72px;height:72px;font-size:30px}
.account-head{display:flex;align-items:center;gap:16px;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:8px}
.account-head-info{flex:1;min-width:0}
.account-head-info h1{font-family:var(--serif);margin:0 0 2px;font-size:28px}

/* Preferencias de email + newsletter (admin) */
.emailprefs-form{max-width:560px}
.check{display:flex;align-items:flex-start;gap:9px;margin-bottom:12px;font-size:14.5px;line-height:1.45;cursor:pointer}
.check input{margin-top:3px;flex:0 0 auto;width:16px;height:16px}
.nl-stats{display:flex;flex-wrap:wrap;gap:10px;margin:6px 0 18px}
.nl-stat{background:var(--soft);border:1px solid var(--line);border-radius:8px;padding:8px 14px;font-size:14px}
.nl-stat strong{color:var(--red)}

/* Indicador de video en tarjetas/hero + portada de video en la nota */
.card-thumb,.hero-thumb{position:relative;display:block}
.card-play{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:46px;height:46px;border-radius:50%;background:rgba(0,0,0,.62);color:#fff;display:grid;place-items:center;font-size:17px;padding-left:3px;pointer-events:none}
.card-play-lg{width:66px;height:66px;font-size:27px}
.post-cover.post-video{background:transparent}
.post-cover.post-video .video-embed{margin:0}

/* ===================== Breaking news (ticker en tiempo real) ===================== */
.breaking{background:#b00610;color:#fff;border-bottom:2px solid #7d040c;overflow:hidden}
.breaking-in{display:flex;align-items:center;gap:14px;height:40px}
.breaking-badge{flex:0 0 auto;display:inline-flex;align-items:center;gap:7px;font-weight:800;font-size:12.5px;letter-spacing:.6px;text-transform:uppercase;background:rgba(0,0,0,.22);padding:5px 11px;border-radius:4px;white-space:nowrap}
.breaking-dot{width:9px;height:9px;border-radius:50%;background:#fff;animation:brkPulse 1.4s infinite}
@keyframes brkPulse{0%{box-shadow:0 0 0 0 rgba(255,255,255,.6)}70%{box-shadow:0 0 0 8px rgba(255,255,255,0)}100%{box-shadow:0 0 0 0 rgba(255,255,255,0)}}
.breaking-ticker{position:relative;flex:1;min-width:0;height:40px}
.breaking-item{position:absolute;inset:0;display:flex;align-items:center;color:#fff;font-weight:600;font-size:14.5px;opacity:0;transform:translateY(9px);transition:opacity .45s ease,transform .45s ease;pointer-events:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.breaking-item.is-active{opacity:1;transform:none;pointer-events:auto}
.breaking-item:hover{text-decoration:underline}
@media(max-width:560px){.breaking-badge .breaking-txt{display:none}.breaking-badge{padding:6px 8px}}

/* "Leyendo ahora" + vistas */
.live-badge{display:inline-flex;align-items:center;gap:6px;color:#137333;font-weight:700;font-size:13px}
.live-dot{width:8px;height:8px;border-radius:50%;background:#1a9e4b;animation:brkPulse 1.6s infinite}
.views-badge{color:var(--muted)}

/* Widget tendencias / más leído */
.trending-list,.stat-list{list-style:none;margin:0;padding:0;counter-reset:tr}
.trending-list li,.stat-list li{counter-increment:tr;display:flex;gap:9px;align-items:baseline;padding:7px 0;border-bottom:1px solid var(--line)}
.trending-list li:last-child,.stat-list li:last-child{border-bottom:0}
.trending-list li::before,.stat-list li::before{content:counter(tr);color:var(--red);font-family:var(--serif);font-weight:800;font-size:17px;line-height:1;flex:0 0 auto;min-width:14px}
.trending-list a,.stat-list a{font-weight:600;font-size:13.5px;flex:1;min-width:0}
.trending-n,.stat-num{color:var(--muted);font-size:12px;font-weight:700;white-space:nowrap}
.widget-trending{border:1px solid #f0c9cc;background:#fff7f7}

/* Panel de métricas */
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:6px 0 10px}
.kpi{background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:14px 16px;text-align:center}
.kpi-live{background:#eafaf0;border-color:#bfe6cd}
.kpi-n{display:block;font-size:26px;font-weight:800;font-family:var(--serif);line-height:1.1}
.kpi-l{display:block;color:var(--muted);font-size:12.5px;margin-top:4px}
.chart{display:flex;align-items:flex-end;gap:6px;height:190px;padding:18px 4px 0;border-bottom:1px solid var(--line);overflow-x:auto}
.chart-col{flex:1;min-width:26px;display:flex;flex-direction:column;align-items:center;justify-content:flex-end;height:100%}
.chart-bar{width:60%;max-width:34px;background:linear-gradient(180deg,var(--red),#e0566a);border-radius:4px 4px 0 0;min-height:2px;transition:height .3s}
.chart-v{font-size:10px;color:var(--muted);margin-bottom:3px}
.chart-x{font-size:10.5px;color:var(--muted);margin-top:5px}
.stats-2col{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:8px}
@media(max-width:760px){.stats-2col{grid-template-columns:1fr}}
.stats-sub{font-size:14px;color:var(--muted);margin:14px 0 6px}

/* === Responsive hardening (anexado por soporte: aditivo y seguro) === */
img, video, iframe, embed, object { max-width: 100%; }
img, video { height: auto; }
pre, code { overflow-wrap: anywhere; word-break: break-word; }
table { max-width: 100%; }

/* ===== Responsive 100% + comentarios en vivo (ajuste dinmico) ===== */
*, *::before, *::after { box-sizing: border-box; }
img, svg, video, iframe, table, pre { max-width: 100%; }
.comments, .comment, .comment-main, .comment-body { min-width: 0; }
.comment-body { overflow-wrap: anywhere; word-break: break-word; }
.comment-head { flex-wrap: wrap; }
.comment-list, .comment-root { list-style: none; padding-left: 0; }
/* Sangra de respuestas escalable segn el ancho disponible */
.comment-children { margin-left: clamp(10px, 3.5vw, 34px); padding-left: 0; }
.comment-form textarea, .comment-reply-form textarea { width: 100%; max-width: 100%; }
.comment-form, .comment-reply-form { max-width: 100%; }
.comment-actions { display: flex; flex-wrap: wrap; gap: 6px; }
.comment-reply-btn, .comment-report-btn { cursor: pointer; }
/* Resaltado suave de comentarios recin llegados (polling en vivo) */
@keyframes commentNewFade { 0% { background: rgba(255, 214, 102, .35); } 100% { background: transparent; } }
.comment.comment-new { animation: commentNewFade 2.4s ease-out 1; border-radius: 8px; }

@media (max-width: 640px) {
  .comment-head { gap: 4px; font-size: .95em; }
  .comment-children { margin-left: clamp(8px, 4vw, 20px); }
  .comment .agg-avatar { width: 32px !important; height: 32px !important; font-size: 14px !important; }
  .comment-reply-btn, .comment-report-btn, .comment-form .btn, .comment-reply-form .btn { min-height: 40px; }
  .comment-form-foot { flex-wrap: wrap; gap: 6px; }
}

/* ===== Publicidad: creativos house responsive (resolucion correcta por dispositivo) ===== */
.ad{margin:18px auto;text-align:center;max-width:100%;}
.ad-house{display:block;}
.ad-house .ad-label{display:block;font:700 10px/1 Arial,Helvetica,sans-serif;letter-spacing:1.4px;text-transform:uppercase;color:#9aa0a6;margin:0 0 6px;}
.ad-house .ad-link{display:inline-block;line-height:0;max-width:100%;}
.ad-house img{max-width:100%;height:auto;border-radius:6px;display:block;margin:0 auto;}
.ad-desktop{display:inline-block;}
.ad-mobile{display:none;}
.ad-header img,.ad-footer img{width:728px;}
.ad-sidebar img{width:300px;}
.ad-in_article img{width:300px;max-width:336px;}
@media (max-width:760px){
  .ad-header .ad-desktop,.ad-footer .ad-desktop{display:none;}
  .ad-header .ad-mobile,.ad-footer .ad-mobile{display:inline-block;}
}
@media (max-width:980px){
  .ad-sidebar .ad-desktop{display:none;}
  .ad-sidebar .ad-mobile{display:inline-block;}
}

/* Fix especificidad: toggle correcto desktop/movil de los creativos */
.ad-house img.ad-mobile{display:none;}
.ad-house img.ad-desktop{display:block;margin:0 auto;}
.ad-header img.ad-mobile,.ad-footer img.ad-mobile{width:320px;}
.ad-sidebar img.ad-mobile{width:300px;}
@media (max-width:760px){
  .ad-header img.ad-desktop,.ad-footer img.ad-desktop{display:none;}
  .ad-header img.ad-mobile,.ad-footer img.ad-mobile{display:block;margin:0 auto;}
}
@media (max-width:980px){
  .ad-sidebar img.ad-desktop{display:none;}
  .ad-sidebar img.ad-mobile{display:block;margin:0 auto;}
}

/* Toggle correcto: las clases viven en el <a>, especificidad > .ad-house .ad-link */
.ad-house .ad-link.ad-mobile{display:none;}
.ad-house .ad-link.ad-desktop{display:inline-block;}
.ad-header .ad-mobile img,.ad-footer .ad-mobile img{width:320px;}
.ad-sidebar .ad-mobile img{width:300px;}
@media (max-width:760px){
  .ad-header .ad-link.ad-desktop,.ad-footer .ad-link.ad-desktop{display:none;}
  .ad-header .ad-link.ad-mobile,.ad-footer .ad-link.ad-mobile{display:inline-block;}
}
@media (max-width:980px){
  .ad-sidebar .ad-link.ad-desktop{display:none;}
  .ad-sidebar .ad-link.ad-mobile{display:inline-block;}
}

/* ===== Indicador "esta escribiendo" en comentarios ===== */
.comment-typing{display:flex;align-items:center;gap:8px;color:#6b7280;font-size:.9em;font-style:italic;margin:6px 0 10px;min-height:18px;}
.typing-dots{display:inline-flex;gap:3px;}
.typing-dots i{width:6px;height:6px;border-radius:50%;background:#c1121f;display:inline-block;animation:typingBlink 1.2s infinite ease-in-out;}
.typing-dots i:nth-child(2){animation-delay:.2s;}
.typing-dots i:nth-child(3){animation-delay:.4s;}
@keyframes typingBlink{0%,80%,100%{opacity:.25;transform:translateY(0);}40%{opacity:1;transform:translateY(-2px);}}

/* ===== Optimizacion movil: ads, chat DM y comentarios al crecer ===== */
/* 1) Evitar dos anuncios pegados al fondo en movil: ocultar slot sidebar */
@media (max-width:980px){
  .ad.ad-sidebar{display:none !important;}
}
/* 2) Chat de mensajes: viewport dinamico (compositor siempre visible) + scroll contenido */
.dm-messages{overscroll-behavior:contain;-webkit-overflow-scrolling:touch;}
.dm-bubble{max-width:85%;}
@media (max-width:700px){
  .dm-chat{height:calc(100dvh - 120px);min-height:0;}
  .dm-bubble{max-width:90%;}
}
/* 3) Comentarios: anidado compacto en movil, sin scroll horizontal */
@media (max-width:600px){
  #comentarios{overflow-x:hidden;}
  .comment-children{margin-left:10px;padding-left:8px;border-left:2px solid var(--line);}
  .comment-children .comment-children .comment-children{margin-left:0;padding-left:6px;}
  .comment-body{font-size:.97em;}
}

/* Chat movil: flujo natural + compositor pegado al fondo (siempre accesible) */
@media (max-width:700px){
  .dm-chat{height:auto;min-height:0;overflow:visible;border-radius:0;border-left:0;border-right:0;}
  .dm-messages{overflow-y:visible;min-height:42vh;}
  .dm-composer{position:sticky;bottom:0;background:#fff;z-index:20;box-shadow:0 -2px 10px rgba(0,0,0,.08);}
}

/* ===== /cuenta: diseno movil pulido ===== */
@media (max-width:640px){
  .account-head{flex-wrap:wrap;gap:12px;}
  .account-head-info{flex:1 1 55%;min-width:0;}
  .account-head-info h1{font-size:22px;}
  .account-head .btn{flex:1 1 100%;text-align:center;}
  .account-quick{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;}
  .account-tile{justify-content:center;flex-direction:column;text-align:center;gap:6px;padding:14px 8px;border-radius:12px;font-weight:600;}
  .account-tile-ic{font-size:22px;}
  .profile-form,.password-form,.emailprefs-form{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;box-shadow:0 1px 3px rgba(0,0,0,.05);margin-bottom:18px;}
  .profile-form .btn,.password-form .btn{width:100%;}
  .profile-avatar-row{flex-direction:column;align-items:center;text-align:center;gap:12px;}
  .profile-avatar-ctrls{align-items:center;}
}

/* ===== Mejora movil: scroll horizontal en filas que no entran + escalado dinamico ===== */
@media (max-width:640px){
  .agg-scope-nav,.agg-zone-sources{flex-wrap:nowrap;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;}
  .agg-scope-nav>*,.agg-zone-sources>*{flex:0 0 auto;}
  .agg-scope-nav a{font-size:13.5px;padding:6px 12px;}
}
.mainnav-in,.agg-scope-nav,.agg-zone-sources{scrollbar-width:none;}
.mainnav-in::-webkit-scrollbar,.agg-scope-nav::-webkit-scrollbar,.agg-zone-sources::-webkit-scrollbar{display:none;}
.hero-title{font-size:clamp(22px,6vw,32px);}
.section-head{font-size:clamp(17px,4.6vw,20px);}
.card-title{font-size:clamp(16px,4.2vw,19px);}

/* Fix: columnas flex se achican (min-width:0) para que los carruseles recorten y no desborden la pagina */
.layout-2col>.col-main{min-width:0;}
.agg-scope-nav,.agg-zone-sources,.cards-grid{min-width:0;max-width:100%;}

/* Fix burbujas de chat: la fila ocupa todo el ancho para que las palabras no se corten */
.dm-msg{width:100%;}
.dm-bubble{width:fit-content;max-width:80%;}
.dm-msg.mine .dm-bubble{margin-left:auto;}

/* ===== /cuenta: pestaas de secciones ===== */
.acct-tabs{display:flex;gap:4px;overflow-x:auto;white-space:nowrap;scrollbar-width:none;margin:6px 0 20px;border-bottom:1px solid var(--line);}
.acct-tabs::-webkit-scrollbar{display:none;}
.acct-tab{flex:0 0 auto;background:none;border:0;border-bottom:3px solid transparent;padding:11px 14px;font-family:inherit;font-size:14px;font-weight:600;color:#666;cursor:pointer;transition:color .15s,border-color .15s;}
.acct-tab:hover{color:var(--red);}
.acct-tab.is-active{color:var(--red);border-bottom-color:var(--red);}
.acct-section>.section-head:first-child{margin-top:4px;}

/* Notificaciones/mensajes: respaldo CSS para que el panel no se salga en movil */
@media (max-width:640px){
  .hdr-pop{left:auto;right:0;max-width:92vw;}
}

/* ===== EN VIVO: boton de menu + reproductor ===== */
.nav-live{display:inline-flex;align-items:center;gap:6px;color:var(--red);background:none;border-radius:0;white-space:nowrap;}
.nav-live-dot{width:7px;height:7px;border-radius:50%;background:var(--red);display:inline-block;flex:0 0 auto;}
.nav-live:hover{color:var(--red);background:var(--soft);text-decoration:none;}
.live-dot{display:inline-block;width:11px;height:11px;border-radius:50%;background:#ff3b3b;animation:livePulse 1.4s infinite;vertical-align:middle;}
@keyframes livePulse{0%{box-shadow:0 0 0 0 rgba(255,59,59,.6)}70%{box-shadow:0 0 0 9px rgba(255,59,59,0)}100%{box-shadow:0 0 0 0 rgba(255,59,59,0)}}
.live-player{position:relative;background:#000;border-radius:10px;overflow:hidden;aspect-ratio:16/9;max-width:900px;margin:6px 0 10px;}
.live-player video{position:absolute;inset:0;width:100%;height:100%;display:block;background:#000;}

/* video.js live fit */
.live-player .video-js{position:absolute;inset:0;width:100%;height:100%;}
.live-player .vjs-tech{width:100%;height:100%;}
.live-player .video-js .vjs-big-play-button{top:50%;left:50%;transform:translate(-50%,-50%);margin:0;}

/* embed / compartir vivo */
.embed-share{margin-top:22px;padding-top:18px;border-top:1px solid var(--line)}
.embed-share .section-head{font-size:18px}
.embed-code{display:flex;flex-direction:column;gap:8px;max-width:680px}
.embed-code textarea{width:100%;font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px;padding:10px;border:1px solid var(--line);border-radius:8px;background:var(--soft);color:inherit;resize:vertical;box-sizing:border-box}
.embed-share .btn{align-self:flex-start;background:var(--red);color:#fff;border:0;padding:8px 16px;border-radius:8px;font-weight:600;cursor:pointer}
.embed-share .btn:hover{filter:brightness(.93)}
.embed-tech{margin-top:18px;background:var(--soft);border:1px solid var(--line);border-radius:10px;padding:14px 16px}
.embed-tech h3{margin:0 0 6px;font-size:15px}
.embed-specs{margin:8px 0;padding-left:18px;line-height:1.7}
.embed-specs code{background:#fff;border:1px solid var(--line);border-radius:6px;padding:2px 6px;font-size:12.5px;word-break:break-all}
.btn-sm{background:#fff;border:1px solid var(--line);border-radius:6px;padding:2px 8px;font-size:12px;cursor:pointer;margin-left:4px}
.btn-sm:hover{background:var(--line)}
@media(max-width:640px){.embed-specs code{display:block;margin:4px 0}.btn-sm{margin-left:0}}

/* embeds en cuerpo de articulo */
.agg-embeds{margin:18px 0;display:flex;flex-direction:column;gap:16px;align-items:flex-start}
.agg-embeds .twitter-tweet,.agg-embeds .instagram-media{margin:0 auto!important;max-width:550px}
.agg-embed-yt{position:relative;width:100%;max-width:680px;aspect-ratio:16/9}
.agg-embed-yt iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:8px}
@media(max-width:640px){.agg-embeds{align-items:stretch}}

/* guia de programacion */
.guide-tabs{display:flex;gap:6px;flex-wrap:wrap;margin:10px 0 14px;border-bottom:1px solid var(--line);padding-bottom:8px}
.guide-tab{background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-weight:600;font-size:14px;cursor:pointer;color:inherit}
.guide-tab.is-on{background:var(--red);color:#fff;border-color:var(--red)}
.g-cards{display:flex;gap:14px;flex-wrap:wrap}
.g-card{flex:1 1 260px;border:1px solid var(--line);border-radius:12px;padding:14px 16px;background:#fff}
.g-card-now{border-color:var(--red);box-shadow:0 0 0 2px rgba(255,59,59,.12)}
.g-card-lbl{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--red);margin-bottom:6px}
.g-card-next .g-card-lbl{color:#888}
.g-card-show{font-size:18px;font-weight:700;line-height:1.2}
.g-ep{font-size:14px;color:#555;margin-top:3px}
.g-meta{margin-top:8px;display:flex;flex-wrap:wrap;gap:6px;align-items:center;font-size:12.5px}
.g-time2{font-weight:700}
.g-dp{background:var(--soft);border:1px solid var(--line);border-radius:6px;padding:1px 7px;font-size:11.5px;text-transform:uppercase;letter-spacing:.03em}
.g-th{color:#777;font-size:12px}
.g-dayhead{font-weight:700;font-size:15px;margin:16px 0 8px;padding-bottom:4px;border-bottom:2px solid var(--red)}
.g-list{display:flex;flex-direction:column}
.g-row{display:flex;gap:12px;padding:9px 4px;border-bottom:1px solid var(--line)}
.g-row:last-child{border-bottom:0}
.g-time{flex:0 0 96px;font-weight:700;font-size:13px;color:#444}
.g-now{display:block;margin-top:3px;font-size:10px;font-weight:800;color:#fff;background:var(--red);border-radius:5px;padding:1px 5px;width:fit-content;letter-spacing:.04em}
.g-info{flex:1;min-width:0}
.g-show{font-weight:600}
.g-live{background:rgba(255,59,59,.06);border-radius:8px}
.g-live .g-show{color:var(--red)}
@media(max-width:560px){.g-time{flex-basis:74px;font-size:12px}.g-card-show{font-size:16px}}

/* ahora/proximo en vivo */
.live-now{margin:10px 0 4px;padding:10px 12px;background:var(--soft);border:1px solid var(--line);border-radius:10px;font-size:14px;display:flex;flex-wrap:wrap;gap:6px 14px;align-items:center}
.live-now .ln-dot{width:9px;height:9px;border-radius:50%;background:var(--red);display:inline-block;flex:0 0 auto;animation:livePulse 1.4s infinite}
.live-now .ln-t{color:#777;font-size:12.5px}
.live-now .ln-next{color:#555}
.live-now .ln-link{margin-left:auto;font-weight:600;white-space:nowrap}
@media(max-width:560px){.live-now .ln-link{margin-left:0}}

/* herramientas de articulo: escuchar + compartir */
.art-tools{display:flex;flex-wrap:wrap;align-items:center;gap:8px;margin:14px 0;padding:10px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.at-btn{display:inline-flex;align-items:center;gap:6px;background:var(--soft);border:1px solid var(--line);border-radius:999px;padding:6px 14px;font-weight:600;font-size:14px;cursor:pointer;color:inherit}
.at-btn.on{background:var(--red);color:#fff;border-color:var(--red)}
.at-sep{width:1px;align-self:stretch;background:var(--line);margin:0 2px}
.at-share-lbl{font-size:13px;color:#777;font-weight:600}
.at-sh{display:inline-flex;align-items:center;border-radius:999px;padding:6px 12px;font-size:13px;font-weight:600;text-decoration:none;color:#fff;border:0;cursor:pointer}
.at-wa{background:#25D366}
.at-x{background:#111}
.at-fb{background:#1877F2}
.at-copy{background:var(--soft);color:inherit;border:1px solid var(--line)}
.at-sh:hover{filter:brightness(.94);text-decoration:none}
@media(max-width:560px){.at-share-lbl{display:none}.art-tools{gap:6px}}

.form-ok{background:#e9f7ef;border:1px solid #b7e4c7;color:#1b6b3a;border-radius:10px;padding:12px 14px;margin:0 0 14px;font-size:14px}

/* Botones de cuenta (topbar) */
.tb-login,.tb-reg{display:inline-flex;align-items:center;padding:3px 12px;border-radius:6px;font-weight:700;font-size:12.5px;line-height:1;text-decoration:none;white-space:nowrap;transition:background .15s,color .15s,border-color .15s}
.tb-login{border:1px solid rgba(255,255,255,.4);color:#fff;background:transparent}
.tb-login:hover{background:rgba(255,255,255,.14);border-color:#fff}
.tb-reg{border:1px solid var(--red);background:var(--red);color:#fff}
.tb-reg:hover{background:#a30f1a;border-color:#a30f1a}
@media(max-width:560px){.tb-login,.tb-reg{padding:3px 9px;font-size:11.5px}}
