/* ===========================================
   MeXPresate — Global Stylesheet
   (fonts are loaded via <link> in each HTML
    page — no @import needed here)
   =========================================== */

/* === CSS Variables === */
:root {
  --bg-darkest: #0e0e0e;
  --bg-dark:    #121212;
  --bg-medium:  #161616;
  --bg-card:    #1a1a1a;
  --bg-elevated:#222222;
  --accent:     #F8C900;
  --accent-dim: rgba(248,201,0,0.18);
  --accent-glow: 0 0 20px rgba(248,201,0,0.4), 0 0 40px rgba(248,201,0,0.15);
  --text-white:  #FFFFFF;
  --text-gray:   rgba(255,255,255,0.65);
  --text-dim:    rgba(255,255,255,0.35);
  --border:      rgba(248,201,0,0.12);
  --border-hover:rgba(248,201,0,0.5);
  --radius:      6px;
  --radius-lg:   12px;
  --nav-h:       68px;
  --transition:  all 0.3s cubic-bezier(0.4,0,0.2,1);
  --font-display:'Orbitron', monospace;
  --font-sub:    'Rajdhani', sans-serif;
  --font-body:   'Exo 2', sans-serif;
}

/* === Reset === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{
  font-family:var(--font-body);
  background:var(--bg-darkest);
  color:var(--text-white);
  overflow-x:hidden;
  line-height:1.6;
}
img,video{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{cursor:pointer;border:none;background:none;font-family:inherit}
ul{list-style:none}

/* === Canvas Background (fixed) === */
#bg-canvas{
  position:fixed;top:0;left:0;
  width:100%;height:100%;
  z-index:0;pointer-events:none;
  opacity:0.7;
}

/* === Custom Cursor (desktop only) === */
.cursor,.cursor-dot{
  position:fixed;pointer-events:none;z-index:9998;
  transform:translate(-50%,-50%);
  transition:transform 0.05s linear,width 0.2s ease,height 0.2s ease,background 0.2s ease;
}
.cursor{
  width:28px;height:28px;
  border:1.5px solid var(--accent);
  border-radius:50%;
  background:transparent;
  mix-blend-mode:normal;
  transition:all 0.12s ease;
}
.cursor.hovered{
  width:50px;height:50px;
  background:var(--accent-dim);
  border-color:var(--accent);
  box-shadow:var(--accent-glow);
}
.cursor-dot{
  width:5px;height:5px;
  background:var(--accent);
  border-radius:50%;
  box-shadow:0 0 8px var(--accent);
}
@media(hover:none){.cursor,.cursor-dot{display:none}}

/* === Loader === */
#loader{
  position:fixed;inset:0;
  background:#080808;
  z-index:10000;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:0;
}
#loader.fade-out{
  animation:loaderFade 0.7s ease forwards;
}
@keyframes loaderFade{
  0%{opacity:1;transform:scale(1)}
  100%{opacity:0;transform:scale(1.02);pointer-events:none}
}
.loader-scanlines{
  position:absolute;inset:0;
  background:repeating-linear-gradient(
    0deg,
    transparent,transparent 2px,
    rgba(0,0,0,0.18) 2px,rgba(0,0,0,0.18) 4px
  );
  pointer-events:none;
  animation:scanAnim 8s linear infinite;
}
@keyframes scanAnim{
  0%{background-position:0 0}
  100%{background-position:0 200px}
}
.loader-logo-wrap{
  font-family:var(--font-display);
  font-size:clamp(2.2rem,8vw,4.5rem);
  font-weight:900;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:#fff;
  display:flex;align-items:center;gap:0;
  margin-bottom:10px;
}
.loader-logo-wrap .accent{color:var(--accent);text-shadow:var(--accent-glow)}
.loader-signal{
  font-family:var(--font-sub);
  font-size:0.8rem;
  letter-spacing:0.4em;
  color:var(--text-dim);
  text-transform:uppercase;
  margin-bottom:30px;
  animation:blink 1.5s ease-in-out infinite;
}
@keyframes blink{0%,100%{opacity:0.3}50%{opacity:1}}
.loader-bar-wrap{
  width:min(320px,70vw);
  height:2px;
  background:rgba(255,255,255,0.08);
  border-radius:2px;
  overflow:hidden;
  margin-bottom:14px;
}
.loader-bar-fill{
  height:100%;width:0%;
  background:var(--accent);
  border-radius:2px;
  box-shadow:0 0 12px var(--accent);
  transition:width 0.08s linear;
}
.loader-pct{
  font-family:var(--font-sub);
  font-size:0.75rem;
  color:var(--accent);
  letter-spacing:0.2em;
}
.loader-glitch-line{
  position:absolute;
  width:100%;height:2px;
  background:var(--accent);
  opacity:0;
  animation:glitchLine 3s ease-in-out infinite;
}
@keyframes glitchLine{
  0%,90%,100%{opacity:0;top:0%}
  92%{opacity:0.6;top:30%;height:1px}
  94%{opacity:0;top:70%;height:3px}
  96%{opacity:0.4;top:55%;height:1px}
}

/* === Page Transition Overlay === */
#page-overlay{
  position:fixed;inset:0;
  background:var(--accent);
  z-index:9999;
  transform:scaleX(0);
  transform-origin:left center;
  pointer-events:none;
}
#page-overlay.slide-in{
  animation:overlayIn 0.45s cubic-bezier(0.77,0,0.18,1) forwards;
}
#page-overlay.slide-out{
  transform-origin:right center;
  animation:overlayOut 0.45s cubic-bezier(0.77,0,0.18,1) forwards;
}
@keyframes overlayIn{0%{transform:scaleX(0)}100%{transform:scaleX(1)}}
@keyframes overlayOut{0%{transform:scaleX(1)}100%{transform:scaleX(0)}}

/* === Navigation === */
#main-nav{
  position:fixed;top:0;left:0;right:0;
  height:var(--nav-h);
  z-index:1000;
  background:rgba(8,8,8,0.82);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  transition:var(--transition);
}
#main-nav.scrolled{
  background:rgba(8,8,8,0.97);
  border-color:rgba(248,201,0,0.2);
}
.nav-inner{
  max-width:1400px;margin:0 auto;
  padding:0 clamp(1rem,3vw,2rem);
  height:100%;
  display:flex;align-items:center;justify-content:space-between;
  gap:2rem;
}
.nav-logo{
  font-family:var(--font-display);
  font-size:clamp(1.1rem,2.5vw,1.4rem);
  font-weight:900;
  letter-spacing:0.06em;
  text-transform:uppercase;
  flex-shrink:0;
  transition:var(--transition);
}
.nav-logo:hover{text-shadow:var(--accent-glow)}
.logo-accent{color:var(--accent)}

.nav-links{
  display:flex;align-items:center;gap:clamp(1rem,2.5vw,2rem);
  flex-wrap:wrap;
}
.nav-link{
  font-family:var(--font-sub);
  font-size:0.95rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--text-gray);
  position:relative;
  padding:4px 0;
  transition:color 0.25s ease;
}
.nav-link::after{
  content:'';
  position:absolute;bottom:-2px;left:0;width:0;height:2px;
  background:var(--accent);
  transition:width 0.3s ease;
  box-shadow:0 0 8px var(--accent);
}
.nav-link:hover,.nav-link.active{color:var(--text-white)}
.nav-link:hover::after,.nav-link.active::after{width:100%}
.nav-link.live-badge{color:var(--accent)}
.nav-link.live-badge::before{
  content:'●';
  margin-right:5px;
  animation:blink 1s ease-in-out infinite;
}

/* Hamburger */
.hamburger{
  display:none;flex-direction:column;gap:5px;
  width:32px;padding:4px;
  z-index:1001;
}
.hamburger span{
  display:block;width:100%;height:2px;
  background:var(--text-white);
  border-radius:2px;
  transition:all 0.3s ease;
}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media(max-width:768px){
  .hamburger{display:flex}
  .nav-links{
    position:fixed;
    top:var(--nav-h);left:0;right:0;bottom:0;
    background:rgba(8,8,8,0.97);
    flex-direction:column;align-items:center;justify-content:center;
    gap:2rem;
    transform:translateX(100%);
    transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-link{font-size:1.4rem}
}

/* === Content Layout === */
.main-content{
  position:relative;z-index:1;
  padding-top:var(--nav-h);
}

.container{
  max-width:1300px;
  margin:0 auto;
  padding:0 clamp(1rem,3vw,2.5rem);
}

.section{
  padding:clamp(3rem,8vh,7rem) 0;
  position:relative;
}

.section-header{
  text-align:center;
  margin-bottom:clamp(2rem,5vw,4rem);
}
.section-tag{
  display:inline-block;
  font-family:var(--font-sub);
  font-size:0.75rem;
  font-weight:700;
  letter-spacing:0.35em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:12px;
  padding:5px 14px;
  border:1px solid var(--border);
  border-radius:20px;
}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(1.8rem,4vw,2.8rem);
  font-weight:700;
  line-height:1.15;
  margin-bottom:1rem;
}
.section-title .accent{color:var(--accent)}
.section-desc{
  color:var(--text-gray);
  max-width:600px;
  margin:0 auto;
  font-size:1rem;
  line-height:1.7;
}

/* === Hero === */
.hero{
  min-height:100svh;
  display:grid;
  place-items:center;
  position:relative;
  overflow:hidden;
  padding:var(--nav-h) 1rem 4rem;
}
.hero-content{
  position:relative;z-index:2;
  text-align:center;
  max-width:900px;
  padding:2rem 1rem;
}
.hero-eyebrow{
  font-family:var(--font-sub);
  font-size:0.82rem;
  font-weight:600;
  letter-spacing:0.35em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1.5rem;
  opacity:0;
  animation:fadeUp 0.8s ease 0.5s forwards;
}
.hero-title{
  font-family:var(--font-display);
  font-size:clamp(3rem,10vw,7.5rem);
  font-weight:900;
  line-height:0.95;
  text-transform:uppercase;
  letter-spacing:-0.02em;
  margin-bottom:1rem;
  opacity:0;
  animation:fadeUp 0.8s ease 0.7s forwards;
}
.glitch-text{
  position:relative;
  display:inline-block;
}
.glitch-text::before,.glitch-text::after{
  content:attr(data-text);
  position:absolute;top:0;left:0;width:100%;height:100%;
}
.glitch-text::before{
  color:var(--accent);
  animation:glitch1 4s infinite;
  clip-path:polygon(0 0,100% 0,100% 35%,0 35%);
}
.glitch-text::after{
  color:#fff;
  animation:glitch2 4s infinite;
  clip-path:polygon(0 60%,100% 60%,100% 100%,0 100%);
}
@keyframes glitch1{
  0%,90%,100%{transform:translate(0)}
  91%{transform:translate(-3px,1px)}
  92%{transform:translate(3px,-1px)}
  93%{transform:translate(-2px,2px)}
  94%{transform:translate(0)}
}
@keyframes glitch2{
  0%,87%,100%{transform:translate(0)}
  88%{transform:translate(4px,-2px)}
  89%{transform:translate(-4px,2px)}
  90%{transform:translate(0)}
}
.hero-slogan{
  font-family:var(--font-sub);
  font-size:clamp(1.2rem,3vw,1.8rem);
  font-weight:600;
  letter-spacing:0.04em;
  margin-bottom:1.2rem;
  color:var(--text-gray);
  opacity:0;
  animation:fadeUp 0.8s ease 0.9s forwards;
}
.slogan-accent{color:var(--accent)}
.hero-desc{
  font-size:clamp(0.95rem,2vw,1.1rem);
  color:var(--text-gray);
  max-width:620px;
  margin:0 auto 2.5rem;
  line-height:1.75;
  opacity:0;
  animation:fadeUp 0.8s ease 1.1s forwards;
}
.hero-ctas{
  display:flex;flex-wrap:wrap;gap:1rem;
  justify-content:center;
  opacity:0;
  animation:fadeUp 0.8s ease 1.3s forwards;
}

/* === Buttons === */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:0.75rem 1.8rem;
  border-radius:var(--radius);
  font-family:var(--font-sub);
  font-size:0.95rem;
  font-weight:700;
  letter-spacing:0.08em;
  text-transform:uppercase;
  transition:var(--transition);
  position:relative;overflow:hidden;
}
.btn::before{
  content:'';
  position:absolute;inset:0;
  background:rgba(255,255,255,0.08);
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.3s ease;
}
.btn:hover::before{transform:scaleX(1)}
.btn-primary{
  background:var(--accent);
  color:#000;
  box-shadow:0 4px 20px rgba(248,201,0,0.3);
}
.btn-primary:hover{
  background:#ffe433;
  box-shadow:0 6px 30px rgba(248,201,0,0.5);
  transform:translateY(-2px);
}
.btn-secondary{
  background:transparent;
  color:var(--text-white);
  border:1.5px solid var(--border-hover);
}
.btn-secondary:hover{
  background:var(--accent-dim);
  border-color:var(--accent);
  box-shadow:var(--accent-glow);
  transform:translateY(-2px);
}
.live-dot{
  display:inline-block;
  width:8px;height:8px;
  background:#ff4444;
  border-radius:50%;
  box-shadow:0 0 6px #ff4444;
  animation:blink 1s ease-in-out infinite;
}

/* === Live Section === */
.live-indicator{
  display:inline-flex;align-items:center;gap:8px;
  font-family:var(--font-sub);
  font-size:0.75rem;
  font-weight:700;
  letter-spacing:0.35em;
  text-transform:uppercase;
  color:#ff4444;
  margin-bottom:14px;
}
.live-indicator .live-dot{width:8px;height:8px;background:#ff4444}
.live-player{
  display:grid;
  grid-template-columns:1fr 320px;
  gap:2rem;
  align-items:start;
}
@media(max-width:900px){
  .live-player{grid-template-columns:1fr}
}
.live-embed-wrapper{
  border-radius:var(--radius-lg);
  overflow:hidden;
  border:1px solid var(--border);
  background:var(--bg-card);
  aspect-ratio:16/9;
}
.live-embed-wrapper iframe{width:100%;height:100%;border:none}
.embed-placeholder{
  width:100%;height:100%;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-medium);
}
.placeholder-inner{
  text-align:center;
  color:var(--text-dim);
}
.placeholder-icon{font-size:3rem;margin-bottom:1rem;filter:grayscale(1);opacity:0.5}
.placeholder-title{
  font-family:var(--font-display);
  font-size:1rem;color:var(--text-gray);
  margin-bottom:6px;
}
.placeholder-subtitle{font-size:0.85rem}
.live-sidebar{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.5rem;
}
.live-sidebar-title{
  font-family:var(--font-sub);
  font-size:0.75rem;
  font-weight:700;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1.2rem;
}
.schedule-item{
  display:flex;align-items:center;gap:10px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,0.06);
  cursor:pointer;
  transition:var(--transition);
}
.schedule-item:last-child{border-bottom:none}
.schedule-item:hover{color:var(--accent);padding-left:6px}
.schedule-day{
  font-family:var(--font-sub);
  font-size:0.7rem;font-weight:700;
  letter-spacing:0.1em;
  color:var(--accent);
  text-transform:uppercase;
  min-width:60px;
}
.schedule-info{flex:1}
.schedule-channel{font-size:0.88rem;font-weight:600;line-height:1.2}
.schedule-time{font-size:0.75rem;color:var(--text-dim);margin-top:2px}
.schedule-emoji{font-size:1.1rem}
.live-social{margin-top:1.2rem;padding-top:1.2rem;border-top:1px solid rgba(255,255,255,0.06)}
.live-social p{font-size:0.78rem;color:var(--text-dim);margin-bottom:10px}
.social-mini{display:flex;gap:8px;flex-wrap:wrap}
.social-btn{
  font-family:var(--font-sub);
  font-size:0.78rem;font-weight:600;
  padding:5px 12px;
  border:1px solid var(--border);
  border-radius:4px;
  color:var(--text-gray);
  transition:var(--transition);
}
.social-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}

/* === Channels Grid === */
.channels-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));
  gap:1.5rem;
}
.channel-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  overflow:hidden;
  position:relative;
  cursor:pointer;
  transition:transform 0.35s ease,box-shadow 0.35s ease,border-color 0.35s ease;
  text-decoration:none;
  display:block;
}
.channel-card::before{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,transparent 60%,var(--card-accent,rgba(248,201,0,0.06)));
  transition:opacity 0.35s ease;
  opacity:0;z-index:0;
}
.channel-card:hover{
  transform:translateY(-8px) scale(1.02);
  box-shadow:0 20px 60px rgba(0,0,0,0.5), 0 0 0 1px var(--border-hover);
  border-color:var(--border-hover);
}
.channel-card:hover::before{opacity:1}
.channel-card-top{
  padding:1.5rem 1.5rem 0;
  position:relative;z-index:1;
  display:flex;align-items:flex-start;justify-content:space-between;
}
.channel-emoji{font-size:2.2rem;line-height:1}
.channel-live-badge{
  font-family:var(--font-sub);
  font-size:0.62rem;
  font-weight:700;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:#000;
  background:#ff4444;
  padding:3px 8px;
  border-radius:3px;
  display:flex;align-items:center;gap:4px;
  animation:blink 1.5s ease-in-out infinite;
}
.channel-card-body{
  padding:1rem 1.5rem 1.5rem;
  position:relative;z-index:1;
}
.channel-name{
  font-family:var(--font-display);
  font-size:0.95rem;
  font-weight:700;
  letter-spacing:0.04em;
  text-transform:uppercase;
  margin-bottom:6px;
  transition:color 0.25s ease;
}
.channel-card:hover .channel-name{color:var(--accent)}
.channel-tagline{
  font-family:var(--font-sub);
  font-size:0.85rem;
  font-weight:600;
  color:var(--text-gray);
  margin-bottom:0.8rem;
}
.channel-desc{
  font-size:0.82rem;
  color:var(--text-dim);
  line-height:1.55;
  display:-webkit-box;
  -webkit-line-clamp:3;
  -webkit-box-orient:vertical;
  overflow:hidden;
  margin-bottom:1rem;
}
.channel-footer{
  display:flex;align-items:center;justify-content:space-between;
  padding-top:1rem;
  border-top:1px solid rgba(255,255,255,0.06);
}
.channel-schedule{
  font-size:0.72rem;
  color:var(--text-dim);
  font-family:var(--font-sub);
}
.channel-cta{
  font-family:var(--font-sub);
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--accent);
  display:flex;align-items:center;gap:4px;
  transition:gap 0.2s ease;
}
.channel-card:hover .channel-cta{gap:8px}
.channel-tags{
  display:flex;flex-wrap:wrap;gap:5px;
  margin-bottom:0.8rem;
}
.channel-tag{
  font-family:var(--font-sub);
  font-size:0.62rem;
  font-weight:600;
  letter-spacing:0.1em;
  text-transform:uppercase;
  padding:3px 8px;
  border-radius:20px;
  border:1px solid rgba(255,255,255,0.1);
  color:var(--text-dim);
}

/* === Social Section === */
.social-section{
  padding:4rem 0;
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,var(--bg-darkest),var(--bg-medium),var(--bg-darkest));
}
.social-title{
  font-family:var(--font-sub);
  font-size:0.75rem;
  font-weight:700;
  letter-spacing:0.4em;
  text-transform:uppercase;
  color:var(--text-dim);
  text-align:center;
  margin-bottom:2rem;
}
.social-links{
  display:flex;
  flex-wrap:wrap;
  gap:1rem;
  justify-content:center;
}
.social-link{
  display:flex;align-items:center;gap:10px;
  padding:0.7rem 1.4rem;
  border:1px solid var(--border);
  border-radius:var(--radius);
  background:var(--bg-card);
  color:var(--text-gray);
  font-family:var(--font-sub);
  font-size:0.85rem;
  font-weight:600;
  letter-spacing:0.08em;
  text-transform:uppercase;
  transition:var(--transition);
}
.social-link:hover{
  border-color:var(--accent);
  color:var(--accent);
  background:var(--accent-dim);
  transform:translateY(-3px);
  box-shadow:0 8px 25px rgba(0,0,0,0.3);
}
.social-icon{
  font-size:1rem;
  font-weight:900;
  line-height:1;
}

/* === Footer === */
.footer{
  background:var(--bg-medium);
  border-top:1px solid var(--border);
  padding:4rem 0 2rem;
}
.footer-inner{
  display:grid;
  grid-template-columns:auto 1fr;
  gap:3rem;
  margin-bottom:3rem;
}
@media(max-width:768px){
  .footer-inner{grid-template-columns:1fr}
}
.footer-logo{
  font-family:var(--font-display);
  font-size:1.2rem;
  font-weight:900;
  letter-spacing:0.06em;
  text-transform:uppercase;
  margin-bottom:0.8rem;
}
.footer-tagline{
  font-family:var(--font-sub);
  font-size:0.85rem;
  color:var(--text-dim);
  max-width:220px;
  line-height:1.5;
}
.footer-links{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:2rem;
}
@media(max-width:600px){
  .footer-links{grid-template-columns:1fr 1fr}
}
.footer-col h4{
  font-family:var(--font-sub);
  font-size:0.7rem;
  font-weight:700;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1rem;
}
.footer-col a{
  display:block;
  font-size:0.85rem;
  color:var(--text-dim);
  margin-bottom:0.55rem;
  transition:color 0.2s ease,padding-left 0.2s ease;
}
.footer-col a:hover{color:var(--text-white);padding-left:5px}
.footer-bottom{
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:1rem;
  padding-top:2rem;
  border-top:1px solid rgba(255,255,255,0.06);
}
.copyright{
  font-size:0.75rem;
  color:var(--text-dim);
  font-family:var(--font-sub);
  letter-spacing:0.05em;
}
.footer-social{
  display:flex;gap:1rem;
}
.footer-social a{
  font-family:var(--font-sub);
  font-size:0.72rem;
  font-weight:700;
  letter-spacing:0.15em;
  text-transform:uppercase;
  color:var(--text-dim);
  padding:4px;
  transition:color 0.2s ease;
}
.footer-social a:hover{color:var(--accent)}

/* === Channel Page Specific === */
.channel-hero{
  min-height:45vh;
  display:flex;align-items:flex-end;
  padding-top:var(--nav-h);
  position:relative;
  overflow:hidden;
}
.channel-hero-bg{
  position:absolute;inset:0;
  background:var(--bg-dark);
  z-index:0;
}
.channel-hero-overlay{
  position:absolute;inset:0;
  background:linear-gradient(0deg,var(--bg-darkest) 0%,transparent 60%);
  z-index:1;
}
.channel-hero-content{
  position:relative;z-index:2;
  width:100%;
  padding:4rem clamp(1rem,3vw,2.5rem) 3rem;
  max-width:1300px;margin:0 auto;
}
.channel-back{
  font-family:var(--font-sub);
  font-size:0.8rem;
  font-weight:600;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--text-dim);
  display:inline-flex;align-items:center;gap:6px;
  margin-bottom:1.5rem;
  transition:color 0.2s ease;
}
.channel-back:hover{color:var(--accent)}
.channel-big-emoji{font-size:3.5rem;margin-bottom:1rem;display:block}
.channel-page-name{
  font-family:var(--font-display);
  font-size:clamp(2rem,6vw,4.5rem);
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:-0.01em;
  line-height:1;
  margin-bottom:0.5rem;
}
.channel-page-tagline{
  font-family:var(--font-sub);
  font-size:clamp(1rem,2vw,1.3rem);
  color:var(--text-gray);
  font-weight:600;
}

/* === Episodes Grid === */
.episodes-grid{
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(min(280px,100%),1fr));
  gap:1.2rem;
}
.episode-card{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  overflow:hidden;
  cursor:pointer;
  transition:var(--transition);
}
.episode-card:hover{
  border-color:var(--border-hover);
  transform:translateY(-4px);
  box-shadow:0 12px 40px rgba(0,0,0,0.4);
}
.episode-thumb{
  width:100%;aspect-ratio:16/9;
  background:var(--bg-medium);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.episode-thumb-inner{
  font-size:2rem;opacity:0.4;
  transition:opacity 0.25s ease,transform 0.25s ease;
}
.episode-card:hover .episode-thumb-inner{opacity:0.7;transform:scale(1.1)}
.episode-play-btn{
  position:absolute;
  width:44px;height:44px;
  background:var(--accent);
  border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1rem;
  color:#000;
  opacity:0;
  transition:opacity 0.25s ease;
}
.episode-card:hover .episode-play-btn{opacity:1}
.episode-info{padding:1rem}
.episode-title{
  font-weight:600;
  font-size:0.88rem;
  line-height:1.4;
  margin-bottom:6px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.episode-date{
  font-family:var(--font-sub);
  font-size:0.72rem;
  color:var(--text-dim);
  font-weight:600;
}
.episode-desc{
  font-size:0.78rem;
  color:var(--text-dim);
  margin-top:6px;
  line-height:1.45;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}

/* === Channel Info Layout === */
.channel-layout{
  display:grid;
  grid-template-columns:1fr 300px;
  gap:2.5rem;
  align-items:start;
}
@media(max-width:1000px){
  .channel-layout{grid-template-columns:1fr}
}
.channel-sidebar{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius-lg);
  padding:1.5rem;
  position:sticky;top:calc(var(--nav-h) + 1rem);
}
.sidebar-title{
  font-family:var(--font-sub);
  font-size:0.7rem;
  font-weight:700;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--accent);
  margin-bottom:1.2rem;
}
.other-channel-link{
  display:flex;align-items:center;gap:10px;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,0.05);
  color:var(--text-gray);
  font-size:0.85rem;
  font-weight:600;
  transition:var(--transition);
}
.other-channel-link:last-child{border-bottom:none}
.other-channel-link:hover{color:var(--accent);padding-left:5px}
.other-channel-link .oc-emoji{font-size:1.1rem;flex-shrink:0}

/* === Info Pages (Privacidad, Publicidad) === */
.info-hero{
  padding:calc(var(--nav-h) + 4rem) 0 3rem;
  border-bottom:1px solid var(--border);
  background:linear-gradient(180deg,var(--bg-medium) 0%,var(--bg-darkest) 100%);
}
.info-content{
  max-width:820px;margin:0 auto;
  padding:4rem clamp(1rem,3vw,2.5rem);
}
.info-content h2{
  font-family:var(--font-display);
  font-size:1.3rem;
  font-weight:700;
  color:var(--accent);
  margin:2.5rem 0 1rem;
  text-transform:uppercase;
  letter-spacing:0.05em;
}
.info-content h3{
  font-family:var(--font-sub);
  font-size:1rem;
  font-weight:700;
  color:var(--text-white);
  margin:1.8rem 0 0.7rem;
  letter-spacing:0.05em;
  text-transform:uppercase;
}
.info-content p{
  color:var(--text-gray);
  line-height:1.8;
  margin-bottom:1.2rem;
  font-size:0.95rem;
}
.info-content ul{
  list-style:none;
  margin-bottom:1.2rem;
}
.info-content ul li{
  color:var(--text-gray);
  font-size:0.95rem;
  line-height:1.7;
  padding:5px 0;
  padding-left:1.2rem;
  position:relative;
}
.info-content ul li::before{
  content:'→';
  position:absolute;left:0;
  color:var(--accent);
}
.info-content a{color:var(--accent);text-decoration:underline;text-underline-offset:3px}
.info-divider{
  border:none;border-top:1px solid var(--border);
  margin:2.5rem 0;
}
.info-highlight-box{
  background:var(--bg-card);
  border:1px solid var(--border);
  border-left:3px solid var(--accent);
  border-radius:var(--radius);
  padding:1.2rem 1.5rem;
  margin:1.5rem 0;
}
.info-highlight-box p{margin:0;font-size:0.9rem}

/* === Utility Animations === */
@keyframes fadeUp{
  from{opacity:0;transform:translateY(24px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fadeIn{
  from{opacity:0}to{opacity:1}
}
.reveal{
  opacity:0;
  transform:translateY(30px);
  transition:opacity 0.7s ease,transform 0.7s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

/* === Scrollbar === */
::-webkit-scrollbar{width:5px}
::-webkit-scrollbar-track{background:var(--bg-darkest)}
::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:5px}
::-webkit-scrollbar-thumb:hover{background:var(--accent)}

/* === Selection === */
::selection{background:var(--accent);color:#000}

/* === Focus-visible (keyboard nav) === */
:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:3px;
  border-radius:2px;
}
/* Nav links, buttons, cards */
.nav-link:focus-visible,
.btn:focus-visible,
.hamburger:focus-visible,
.channel-card:focus-visible,
.social-link:focus-visible,
.footer-col a:focus-visible{
  outline:2px solid var(--accent);
  outline-offset:3px;
  border-radius:var(--radius);
}

/* === Footer social icon links ===
   Used as inline <a> tags in index.html;
   .footer-social is also a legacy class on
   the container div — both patterns work. */
a.footer-social-icon{
  display:inline-block;
  padding:5px 10px;
  border:1px solid var(--border);
  border-radius:4px;
  color:var(--text-dim);
  font-size:0.72rem;
  font-family:var(--font-sub);
  letter-spacing:0.1em;
  transition:all 0.2s ease;
}
a.footer-social-icon:hover{
  border-color:var(--accent);
  color:var(--accent);
  background:var(--accent-dim);
}
