:root{
  --paper:#ffffff; --surface:#ffffff; --surface-2:#f7f5f0; --sunk:#f5f3ec;
  --ink:#22201d; --ink-2:#55514a; --ink-3:#8a8579;
  --line:#eae7de; --line-2:#ddd8cb;
  --accent:#c96442; --accent-soft:#f3e4dc; --accent-ink:#a34d30;
  --tv:#3f6f6b; --radio:#9a6a3c;
  --radius:16px; --radius-sm:11px;
  --shadow:0 1px 2px rgba(40,34,24,.04),0 8px 24px -14px rgba(40,34,24,.18);
  --wrap:1120px;
  --serif:ui-serif,"Iowan Old Style",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
}
@media (prefers-color-scheme:dark){
  :root{
    --paper:#232220; --surface:#2b2a27; --surface-2:#302f2c; --sunk:#1e1d1b;
    --ink:#f4f2ec; --ink-2:#c3bfb5; --ink-3:#928d81;
    --line:#3a3833; --line-2:#454037;
    --accent:#d97757; --accent-soft:#3a2b23; --accent-ink:#e79a80;
    --tv:#6fa5a0; --radio:#c99a63;
    --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 28px -16px rgba(0,0,0,.6);
  }
}
:root[data-theme="light"]{
  --paper:#ffffff; --surface:#ffffff; --surface-2:#f7f5f0; --sunk:#f5f3ec;
  --ink:#22201d; --ink-2:#55514a; --ink-3:#8a8579; --line:#eae7de; --line-2:#ddd8cb;
  --accent:#c96442; --accent-soft:#f3e4dc; --accent-ink:#a34d30; --tv:#3f6f6b; --radio:#9a6a3c;
  --shadow:0 1px 2px rgba(40,34,24,.04),0 8px 24px -14px rgba(40,34,24,.18);
}
:root[data-theme="dark"]{
  --paper:#232220; --surface:#2b2a27; --surface-2:#302f2c; --sunk:#1e1d1b;
  --ink:#f4f2ec; --ink-2:#c3bfb5; --ink-3:#928d81; --line:#3a3833; --line-2:#454037;
  --accent:#d97757; --accent-soft:#3a2b23; --accent-ink:#e79a80; --tv:#6fa5a0; --radio:#c99a63;
  --shadow:0 1px 2px rgba(0,0,0,.3),0 10px 28px -16px rgba(0,0,0,.6);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{margin:0;background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:16px;line-height:1.6;
  -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{max-width:100%}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.15;text-wrap:balance;margin:0}
p{margin:0}
button{font-family:inherit;cursor:pointer}
:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:4px}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--ink-3);font-weight:600}
.skip{position:absolute;left:-999px}.skip:focus{left:16px;top:10px;z-index:200;background:var(--surface);padding:8px 14px;border-radius:8px;border:1px solid var(--line-2)}

/* header */
header.site{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--paper) 90%,transparent);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.navrow{display:flex;align-items:center;gap:18px;height:66px}
.brand{display:flex;align-items:center;gap:11px;font-family:var(--serif);font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--ink)}
.brand .mark{width:30px;height:30px;border-radius:9px;background:var(--accent);display:grid;place-items:center;flex:none}
.brand .mark svg{width:17px;height:17px}
nav.main{display:flex;gap:2px;align-items:center}
nav.main a{font-size:14.5px;font-weight:550;color:var(--ink-2);padding:8px 12px;border-radius:9px;transition:.15s}
nav.main a:hover{background:var(--surface-2);color:var(--ink)}
.search{margin-left:auto;display:flex;align-items:center;gap:9px;background:var(--surface);border:1px solid var(--line-2);
  border-radius:999px;padding:8px 15px;min-width:220px;box-shadow:var(--shadow)}
.search input{border:0;background:transparent;color:var(--ink);font-size:14px;width:100%;outline:none}
.search svg{width:16px;height:16px;color:var(--ink-3);flex:none}
.search button{border:0;background:transparent;padding:0;display:grid;place-items:center;color:var(--ink-3)}
.icon-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--line-2);background:var(--surface);
  display:grid;place-items:center;color:var(--ink-2);flex:none;position:relative;text-decoration:none}
.icon-btn svg{width:18px;height:18px}
.icon-btn .count{position:absolute;top:-6px;right:-6px;min-width:18px;height:18px;padding:0 4px;border-radius:999px;
  background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;font-family:var(--sans)}
.menu-btn{display:none}

/* hero */
.hero{padding:56px 0 26px}
.hero h1{font-size:clamp(32px,5.2vw,54px);letter-spacing:-.02em}
.hero h1 em{font-style:italic;color:var(--accent)}
.hero .lede{margin-top:16px;max-width:46ch;font-size:18px;color:var(--ink-2)}
.bigsearch{margin-top:26px;display:flex;align-items:center;gap:10px;background:var(--surface);border:1px solid var(--line-2);
  border-radius:999px;padding:7px 8px 7px 20px;max-width:520px;box-shadow:var(--shadow)}
.bigsearch input{flex:1;border:0;background:transparent;font-size:16px;color:var(--ink);outline:none}
.bigsearch button{border:0;background:var(--accent);color:#fff;font-weight:600;font-size:15px;padding:11px 20px;border-radius:999px}
.stats{display:flex;gap:28px;margin-top:24px;flex-wrap:wrap}
.stats b{font-family:var(--serif);font-size:23px;font-weight:600;display:block;line-height:1}
.stats span{font-size:12.5px;color:var(--ink-3)}

.chips{display:flex;gap:9px;flex-wrap:wrap}
.chip{border:1px solid var(--line-2);background:var(--surface);border-radius:999px;padding:8px 15px;font-size:13.5px;
  font-weight:550;color:var(--ink-2);transition:.15s;display:inline-flex;gap:7px;align-items:center}
.chip:hover{border-color:var(--accent);color:var(--accent-ink)}
.chip.on{border-color:var(--accent);color:var(--accent-ink);background:var(--accent-soft)}
.chip .dot{width:7px;height:7px;border-radius:50%}
.chip .cnt{font-size:11px;font-weight:700;color:var(--ink-3);background:var(--surface-2);border-radius:999px;padding:1px 7px;font-variant-numeric:tabular-nums}
.chip:hover .cnt{color:var(--accent-ink)}
.ctx{margin:26px 0 8px;padding:20px;background:var(--sunk);border:1px solid var(--line);border-radius:var(--radius)}
.ctx h2{font-size:18px;margin-bottom:12px}

section.block{padding:32px 0}
.block-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin-bottom:18px}
.block-head h2{font-size:23px;letter-spacing:-.01em}
.block-head .more{font-size:13.5px;font-weight:600;color:var(--accent-ink);white-space:nowrap}

/* grid + cards */
.grid{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(258px,1fr))}
.card{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:15px;
  display:flex;flex-direction:column;gap:11px;transition:.18s}
.card:hover{border-color:var(--line-2);box-shadow:var(--shadow);transform:translateY(-2px)}
.card .top{display:flex;gap:12px;align-items:center}
.logo{width:52px;height:52px;border-radius:12px;flex:none;overflow:hidden;display:grid;place-items:center;position:relative}
.logo img{width:100%;height:100%;object-fit:cover;display:block}
.logo.noimg::after{content:attr(data-ini);font-family:var(--serif);font-weight:600;font-size:19px;color:#fff;letter-spacing:-.02em}
.cardtext{min-width:0}
.card .name{font-weight:650;font-size:15.5px;letter-spacing:-.01em;line-height:1.2;color:var(--ink);display:block;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.card .name:hover{color:var(--accent-ink)}
.card .slogan{font-size:12.8px;color:var(--ink-3);margin-top:2px;line-height:1.35;
  display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.badges{display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.badge{font-size:11px;font-weight:600;padding:3px 9px;border-radius:999px;background:var(--surface-2);color:var(--ink-2)}
.badge.tv{color:var(--tv);background:color-mix(in srgb,var(--tv) 12%,transparent)}
.badge.radio{color:var(--radio);background:color-mix(in srgb,var(--radio) 14%,transparent)}
.badge.ok{color:#2f7d52;background:color-mix(in srgb,#2f7d52 14%,transparent);display:inline-flex;gap:4px;align-items:center}
.badge.warn{color:#b0563e;background:color-mix(in srgb,#b0563e 14%,transparent);display:inline-flex;gap:4px;align-items:center}
@media (prefers-color-scheme:dark){.badge.ok{color:#7fc79b}.badge.warn{color:#e79a80}}
:root[data-theme="dark"] .badge.ok{color:#7fc79b}
:root[data-theme="dark"] .badge.warn{color:#e79a80}
.card .foot{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:3px}
.play{display:inline-flex;align-items:center;gap:8px;background:var(--accent-soft);color:var(--accent-ink);font-weight:650;
  font-size:13.5px;padding:8px 15px;border-radius:999px;transition:.15s}
.card:hover .play{background:var(--accent);color:#fff}
.play svg{width:13px;height:13px}
.fav{width:34px;height:34px;border-radius:9px;border:1px solid var(--line);background:transparent;display:grid;place-items:center;
  color:var(--ink-3);transition:.15s;flex:none}
.fav:hover{color:var(--accent);border-color:var(--accent)}
.fav svg{width:16px;height:16px}
.fav.on{color:var(--accent);border-color:var(--accent-soft);background:var(--accent-soft)}
.fav.on svg{fill:var(--accent)}

/* hubs */
.hubs{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}
.hub{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius-sm);padding:15px 16px;display:flex;
  align-items:center;justify-content:space-between;gap:10px;transition:.15s;color:var(--ink)}
.hub:hover{border-color:var(--accent);transform:translateY(-2px);box-shadow:var(--shadow)}
.hub .n{font-weight:600;font-size:15px}
.hub .c{font-size:12.5px;color:var(--ink-3)}
.hub .fl{font-size:22px;line-height:1}

/* breadcrumb */
.breadcrumb{display:flex;gap:8px;align-items:center;font-size:13px;color:var(--ink-3);padding:20px 0 4px;flex-wrap:wrap}
.breadcrumb a{color:var(--ink-3)}.breadcrumb a:hover{color:var(--accent-ink)}
.intro-lead{color:var(--ink-2);font-size:15.5px;max-width:70ch;margin-top:8px}
.page-h1{font-size:clamp(26px,3.6vw,38px);letter-spacing:-.02em;margin-top:8px}
.center-h2{font-size:22px;text-align:left;margin:24px 0 16px}

/* channel page */
.channel{display:grid;grid-template-columns:1fr 340px;gap:30px;padding:12px 0 40px;align-items:start}
.player-frame{background:#141311;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.player-frame.tv{aspect-ratio:16/9}
.player-frame.radio{height:90px}
.player-frame iframe{width:100%;height:100%;border:0;display:block}
.ch-head{display:flex;gap:16px;align-items:center;margin:22px 0 4px}
.ch-head .logo{width:64px;height:64px;border-radius:15px}
.ch-head .logo.noimg::after{font-size:24px}
.ch-head h1{font-size:clamp(24px,3.4vw,32px);letter-spacing:-.02em}
.ch-head .slogan{color:var(--ink-2);font-size:15px;margin-top:3px}
.metaline{display:flex;gap:8px;flex-wrap:wrap;margin:14px 0}
.prose{color:var(--ink-2);font-size:15.5px;line-height:1.7}
.prose p+p{margin-top:12px}
.actions{display:flex;gap:10px;margin:18px 0 6px;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:650;font-size:14.5px;padding:11px 18px;border-radius:999px;
  border:1px solid var(--line-2);background:var(--surface);color:var(--ink)}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn svg{width:16px;height:16px}
.btn.on{background:var(--accent-soft);color:var(--accent-ink);border-color:var(--accent-soft)}
.updown{display:flex;justify-content:space-between;gap:12px;margin:26px 0 6px;font-size:14px;font-weight:600}
.updown a{color:var(--ink-2);display:inline-flex;gap:7px;align-items:center}
.updown a:hover{color:var(--accent-ink)}
aside .panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin-bottom:16px}
aside .panel h3{font-size:16px;margin-bottom:12px}
.kv{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px solid var(--line);font-size:14px}
.kv:last-child{border-bottom:0}.kv span{color:var(--ink-3)}.kv b{font-weight:600}
.related{display:flex;flex-direction:column;gap:6px}
.rel{display:flex;gap:11px;align-items:center;padding:8px;border-radius:11px;transition:.15s;color:var(--ink)}
.rel:hover{background:var(--surface-2)}
.rel .logo{width:40px;height:40px;border-radius:10px}
.rel .logo.noimg::after{font-size:15px}
.rel .n{font-weight:600;font-size:14px}
.rel .m{font-size:12px;color:var(--ink-3)}

/* pagination */
.pager{display:flex;gap:6px;justify-content:center;align-items:center;padding:28px 0;flex-wrap:wrap}
.pager a{min-width:40px;height:40px;padding:0 12px;display:grid;place-items:center;border:1px solid var(--line);border-radius:10px;
  background:var(--surface);font-size:14px;font-weight:600;color:var(--ink-2);font-variant-numeric:tabular-nums}
.pager a.on{background:var(--accent);color:#fff;border-color:var(--accent)}
.pager a:hover:not(.on){border-color:var(--accent)}
.pager .dots{color:var(--ink-3);padding:0 2px}

/* footer */
footer.site{border-top:1px solid var(--line);margin-top:30px;padding:40px 0 30px;background:var(--sunk)}
.foot-grid{display:flex;gap:40px;flex-wrap:wrap;justify-content:space-between}
.foot-grid .col h4{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);margin:0 0 12px}
.foot-grid .col a{display:block;font-size:14px;color:var(--ink-2);padding:4px 0}
.foot-grid .col a:hover{color:var(--accent-ink)}
.foot-brand{max-width:290px}.foot-brand p{font-size:13.5px;color:var(--ink-3);margin-top:12px}
.social{display:flex;gap:10px;margin:26px 0 6px;flex-wrap:wrap}
.social a{width:38px;height:38px;border-radius:10px;border:1px solid var(--line);background:var(--surface);display:grid;place-items:center;color:var(--ink-2)}
.social a:hover{color:var(--accent);border-color:var(--accent)}
.social svg{width:17px;height:17px}
.subpie{text-align:center;color:var(--ink-3);font-size:13px;margin-top:24px}
.subpie a{color:var(--ink-2)}.subpie a:hover{color:var(--accent-ink)}

/* message box (contacto / favoritos) */
.msgbox{position:fixed;left:50%;bottom:20px;transform:translateX(-50%);width:min(560px,92vw);background:var(--surface);
  border:1px solid var(--line-2);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;z-index:120;display:none}
.msgbox.show{display:block}
.msgbox input,.msgbox textarea{width:100%;padding:10px 12px;border:1px solid var(--line-2);border-radius:10px;background:var(--paper);
  color:var(--ink);font-family:inherit;font-size:14px;margin-top:8px}
.msgbox .row{display:flex;gap:10px;justify-content:flex-end;margin-top:14px}
.msgbox h3{font-size:17px;margin-bottom:4px}
.cerrar{position:absolute;top:12px;right:14px;color:var(--ink-3);font-size:20px;background:none;border:0}

/* mobile drawer */
.drawer{position:fixed;inset:0;background:rgba(20,17,13,.4);z-index:100;display:none}
.drawer.show{display:block}
.drawer .panel{position:absolute;top:0;right:0;height:100%;width:min(320px,86vw);background:var(--paper);
  border-left:1px solid var(--line);padding:20px;overflow-y:auto}
.drawer .panel a{display:block;padding:11px 8px;font-size:16px;color:var(--ink);border-bottom:1px solid var(--line)}
.drawer .panel .grp{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-3);margin:16px 0 4px}

.prose-page{max-width:74ch;margin:10px auto 30px;color:var(--ink-2);font-size:15.5px;line-height:1.75}
.prose-page h2{font-size:22px;color:var(--ink);margin:22px 0 8px}
.empty{padding:40px 0;text-align:center;color:var(--ink-3)}

@media (max-width:860px){
  .channel{grid-template-columns:1fr}
  nav.main{display:none}
  .menu-btn{display:grid}
  .search{min-width:0}
}
@media (max-width:560px){
  .wrap{padding:0 16px}
  .search{width:40px;padding:9px;border-radius:10px}
  .search input,.search .lbl{display:none}
}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}
