:root{
  --bg0:#06080d;
  --bg1:#0a1020;
  --ink:rgba(240,245,255,.92);
  --mut:rgba(240,245,255,.70);
  --line:rgba(240,245,255,.14);
  --line2:rgba(240,245,255,.22);
  --glow:rgba(120,160,255,.20);
  --maxw: 1040px;
  --radius: 18px;
}

*{ box-sizing: border-box; }

html,body{
  margin:0; padding:0;
  color:var(--ink);
  background:
    radial-gradient(900px 420px at 50% -10%, rgba(120,160,255,.18), transparent 55%),
    radial-gradient(700px 320px at 80% 10%, rgba(90,210,255,.10), transparent 50%),
    linear-gradient(180deg, var(--bg1), var(--bg0));
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, Helvetica, sans-serif;
}

a{ color: inherit; }

.wrap{
  max-width: var(--maxw);
  margin: 24px auto 70px;
  padding: 0 18px;
}

/* ===== Banner visual controlado ===== */
.heroBanner{
  position: relative;
  border-radius: 22px;
  overflow: hidden;
  border: 1px solid rgba(240,245,255,.10);
  box-shadow: 0 18px 60px rgba(0,0,0,.60);
  height: 260px;
}

.heroBannerImg{
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.heroBannerShade{
  position:absolute; inset:0;
  background:
    radial-gradient(900px 360px at 50% 35%, rgba(0,0,0,0), rgba(0,0,0,.55) 70%),
    linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.55));
  pointer-events:none;
}

/* ===== Secciones ===== */
.section{ margin-top: 18px; }

.sectionHead{
  display:flex;
  align-items: baseline;
  justify-content: space-between;
  margin: 16px 0 10px;
}

.kicker{
  font-size: 12px;
  letter-spacing: .24em;
  text-transform: uppercase;
  color: var(--mut);
}

/* ===== Feature ===== */
.heroFeature{
  border: 1px solid var(--line2);
  background: rgba(255,255,255,.03);
  border-radius: var(--radius);
  padding: 14px;
  box-shadow: 0 16px 54px rgba(0,0,0,.55);
}

.heroPlayer{
  border-radius: 16px;
  overflow:hidden;
  outline: 1px solid rgba(240,245,255,.10);
  background:#000;
}

.heroVideo{
  width: 100%;
  max-width: 860px;
  aspect-ratio: 16/9;
  display:block;
  margin: 0 auto;
  border:0;
  background:#000;
}

.heroMeta{
  margin-top: 12px;
  display:flex;
  flex-direction: column;
  gap: 6px;
}

.heroTitle{
  color: var(--ink);
  text-decoration: none;
  font-weight: 900;
  font-size: 20px;
  letter-spacing: .02em;
  text-shadow: 0 0 16px var(--glow);
}

.heroTitle:hover{ text-decoration: underline; }

.heroSub{
  font-size: 12px;
  color: var(--mut);
}

/* ===== Cards ===== */
.grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
}

.card{
  border: 1px solid rgba(240,245,255,.12);
  background: rgba(255,255,255,.03);
  border-radius: 18px;
  overflow:hidden;
  box-shadow: 0 14px 40px rgba(0,0,0,.45);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.card:hover{
  transform: translateY(-2px);
  border-color: rgba(120,160,255,.34);
  box-shadow: 0 18px 56px rgba(0,0,0,.55);
}

.cardLink{
  display:block;
  text-decoration:none;
}

.thumb{
  position: relative;
  background:#000;
  aspect-ratio: 16/9;
  overflow:hidden;
}

.thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
  filter: contrast(1.02) saturate(1.04);
}

.thumb::after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(300px 160px at 50% 55%, rgba(0,0,0,0), rgba(0,0,0,.55) 78%),
    linear-gradient(180deg, rgba(0,0,0,.00), rgba(0,0,0,.25));
}

.playBadge{
  position:absolute;
  left: 12px;
  bottom: 12px;
  width: 44px;
  height: 44px;
  border-radius: 999px;
  display:grid;
  place-items:center;
  background: rgba(0,0,0,.46);
  border: 1px solid rgba(240,245,255,.18);
  box-shadow: 0 10px 30px rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
}

.cardBody{
  padding: 12px 12px 12px;
}

.cardTitle{
  color: var(--ink);
  font-size: 13px;
  line-height: 1.25;
  font-weight: 800;
}

.cardMeta{
  margin-top: 6px;
  font-size: 11px;
  color: var(--mut);
}

/* Si por alguna raz¨Žn falta miniatura */
.thumbFallback{
  width:100%;
  height:100%;
  display:grid;
  place-items:center;
  color: rgba(240,245,255,.65);
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  background:
    radial-gradient(240px 120px at 50% 40%, rgba(120,160,255,.10), transparent 60%),
    rgba(0,0,0,.55);
}

/* ===== CTA ===== */
.ctaRow{
  display:flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  margin-top: 18px;
  flex-wrap: wrap;
}

.ctaBtn{
  color: var(--ink);
  text-decoration:none;
  font-weight: 900;
  letter-spacing: .02em;
  padding: 12px 16px;
  border-radius: 16px;
  border: 1px solid rgba(120,160,255,.45);
  background: linear-gradient(180deg, rgba(120,160,255,.22), rgba(120,160,255,.08));
  box-shadow: 0 18px 50px rgba(0,0,0,.45);
}

.ctaBtn:hover{ opacity: .92; }

/* ===== Paneles (video page) ===== */
.panel{
  border: 1px solid var(--line);
  background: rgba(255,255,255,.03);
  border-radius: 16px;
  padding: 14px;
  box-shadow: 0 14px 34px rgba(0,0,0,.35);
  margin-top: 12px;
  font-size: 13px;
  color: var(--ink);
  white-space: pre-wrap;
}

.panel.subtle{ color: var(--mut); }

.cHead{
  display:flex;
  justify-content: space-between;
  gap: 12px;
  align-items: baseline;
}

.cDate{ font-size: 11px; color: var(--mut); }
.cBody{ margin-top: 10px; line-height: 1.45; }

.form-row{
  display:grid;
  gap: 10px;
  margin-top: 12px;
}

.input, .textarea{
  border: 1px solid var(--line2);
  background: rgba(0,0,0,.22);
  color: var(--ink);
  border-radius: 14px;
  padding: 10px 12px;
  font-size: 13px;
  width: 100%;
  font-family: inherit;
  outline: none;
}

.textarea{ min-height: 120px; resize: vertical; }

.btn{
  border: 1px solid rgba(120,160,255,.55);
  background: linear-gradient(180deg, rgba(120,160,255,.22), rgba(120,160,255,.08));
  color: var(--ink);
  border-radius: 14px;
  padding: 10px 14px;
  font-weight: 900;
  cursor:pointer;
  width:max-content;
}

/* ===== Pager ===== */
.pager{
  margin-top: 18px;
  display:flex;
  gap: 10px;
  justify-content: center;
  flex-wrap: wrap;
}

.pager a{
  border: 1px solid var(--line);
  padding: 8px 12px;
  text-decoration: none;
  color: var(--ink);
  font-size: 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.03);
}

.pager a.active{
  border-color: rgba(120,160,255,.60);
  box-shadow: 0 0 0 4px rgba(120,160,255,.12);
}

/* ===== Responsive ===== */
@media (max-width: 1040px){
  .grid{ grid-template-columns: repeat(2, 1fr); }
  .heroBanner{ height: 220px; }
}

@media (max-width: 640px){
  .grid{ grid-template-columns: 1fr; }
  .heroBanner{ height: 180px; }
}