/*
Theme Name: Live Factor Noticias ULTRA PRO (Eventos + Unboxing)
Theme URI: https://example.com/
Author: ChatGPT
Author URI: https://example.com/
Description: Tema liviano estilo sitio de noticias (naranjo/verde/negro), con portada tipo “headline + secciones”, responsive y listo para usar.
Version: 4.5.3
License: GNU General Public License v2 or later
License URI: https://www.gnu.org/licenses/gpl-2.0.html
Text Domain: livefactor
Tags: news, blog, dark, two-columns, right-sidebar, custom-menu, featured-images, sticky-post, responsive-layout
*/

/* =========================
   Variables / Base
========================= */
:root{
  --lf-white: rgba(255,255,255,.96);
  --lf-white-soft: rgba(255,255,255,.86);
  --lf-shadow: 0 18px 42px rgba(0,0,0,.38);
  --lf-radius-xl: 22px;
  --lf-radius-lg: 18px;
  --lf-radius-md: 14px;
  --nvn-logo-size: 64px; /* Logo más grande */
  --nvn-bg-overlay: .55; /* Opacidad overlay para foto de fondo */
  --nvn-orange: #ff7a00;
  --nvn-green: #00e676;
  --nvn-black: #0a0a0a;
  --nvn-white: #ffffff;
  --nvn-navy: #00001e; /* barra oscura (estilo cover) */
  --nvn-ink: #111;
  --nvn-surface: #151515;
  --nvn-surface-2: #1b1b1b;
  --nvn-text: #eaeaea;
  --nvn-muted: #b8b8b8;
  --nvn-border: rgba(255,255,255,.08);
  --nvn-shadow: 0 10px 30px rgba(0,0,0,.35);
  --nvn-radius: 14px;
  --nvn-maxw: 1200px;
  --nvn-footer-cols: 3;
  --nvn-ticker-speed: 18s;
  --nvn-gap: 18px;

  /* Texturas (sutiles) */
  --lf-texture-opacity: .10;
  --lf-noise-opacity: .045;
  --lf-grid-opacity: .06;
  --lf-stripe-opacity: .07;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background: linear-gradient(180deg, #070707 0%, var(--nvn-black) 55%, #070707 100%);
  color:var(--nvn-text);
  font-family: system-ui, -apple-system, Segoe UI, Roboto, Ubuntu, Cantarell, Noto Sans, Arial, "Apple Color Emoji","Segoe UI Emoji";
  line-height:1.55;
}


/* =========================
   TEXTURAS GLOBAL (Blanco / Negro / Verde / Naranjo)
   - No usa imágenes externas
   - Se basa en gradientes/patrones CSS
========================= */
body{
  position:relative;
  overflow-x:hidden;
}

/* Noise + grid sutil (fijo) */
body::before{
  content:"";
  position:fixed;
  inset:-40px;
  pointer-events:none;
  z-index:0;
  opacity: var(--lf-noise-opacity);
  mix-blend-mode: overlay;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255,255,255,.22) 0 1px, transparent 2px),
    radial-gradient(circle at 80% 70%, rgba(0,230,118,.18) 0 1px, transparent 2px),
    radial-gradient(circle at 40% 80%, rgba(255,122,0,.16) 0 1px, transparent 2px),
    radial-gradient(circle at 60% 20%, rgba(255,255,255,.14) 0 1px, transparent 2px),
    repeating-linear-gradient(0deg, rgba(255,255,255,var(--lf-grid-opacity)) 0 1px, transparent 1px 26px),
    repeating-linear-gradient(90deg, rgba(255,255,255,var(--lf-grid-opacity)) 0 1px, transparent 1px 26px);
  background-size:
    180px 180px,
    220px 220px,
    240px 240px,
    260px 260px,
    100% 100%,
    100% 100%;
  filter: contrast(115%) saturate(110%);
}

/* Vignette + acentos (verdes/naranjos) */
body::after{
  content:"";
  position:fixed;
  inset:-60px;
  pointer-events:none;
  z-index:0;
  opacity: .55;
  background:
    radial-gradient(1200px 520px at 50% -10%, rgba(0,230,118,.10), transparent 60%),
    radial-gradient(900px 420px at 110% 15%, rgba(255,122,0,.10), transparent 55%),
    radial-gradient(900px 420px at -10% 20%, rgba(255,255,255,.05), transparent 55%),
    radial-gradient(1400px 900px at 50% 70%, rgba(0,0,0,.65), rgba(0,0,0,.92));
}

/* Elevar el contenido por encima de overlays */
.nvn-header,
.nvn-container,
.nvn-footer{
  position:relative;
  z-index:1;
}

a{color:inherit;text-decoration:none}
a:hover{color:var(--nvn-orange)}
img{max-width:100%;height:auto;display:block}
hr{border:0;border-top:1px solid var(--nvn-border)}
code, pre{font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}
pre{
  background: #0d0d0d;
  border: 1px solid var(--nvn-border);
  padding: 14px;
  border-radius: 12px;
  overflow:auto;
}

.screen-reader-text{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link{
  position:absolute;left:-9999px;top:10px;
  background:#fff;color:#000;padding:10px 12px;border-radius:10px;z-index:9999
}
.skip-link:focus{left:10px}

/* =========================
   Layout helpers
========================= */
.nvn-container{max-width:var(--nvn-maxw);margin:0 auto;padding:0 18px}
.nvn-card{
  background: linear-gradient(180deg, var(--nvn-surface) 0%, var(--nvn-ink) 100%);
  border:1px solid var(--nvn-border);
  border-radius:var(--nvn-radius);
  box-shadow:var(--nvn-shadow);
}
.nvn-pad{padding:18px}
.nvn-pill{
  display:inline-flex;gap:8px;align-items:center;
  padding:6px 10px;border-radius:999px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  font-size:12px;color:var(--nvn-muted)
}
.nvn-pill strong{color:var(--nvn-text)}

/* =========================
   Header
========================= */
.nvn-topbar{
  background:#050505;
  border-bottom:1px solid var(--nvn-border);
}
.nvn-topbar .nvn-container{
  display:flex;align-items:center;justify-content:space-between;
  gap:10px;padding:10px 18px;
}
.nvn-topbar .nvn-date{font-size:12px;color:var(--nvn-muted)}
.nvn-topbar .nvn-toplinks a{font-size:12px;color:var(--nvn-muted);margin-left:10px}
.nvn-topbar .nvn-toplinks a:hover{color:var(--nvn-green)}

body.admin-bar .nvn-header{top:32px}
body.admin-bar .nvn-topbar{top:32px}
.nvn-header{
  position:sticky;top:0;z-index:999;
  backdrop-filter: blur(10px);
  background: rgba(10,10,10,.72);
  border-bottom: 1px solid var(--nvn-border);
}
.nvn-header .nvn-container{
  padding:14px 18px;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.nvn-header-top{
  display:grid;
  grid-template-columns: 1fr auto;
  align-items:center;
  gap:14px;
}
.nvn-brandrow{
  display:flex;
  align-items:center;
  justify-content:center;
  justify-self:center;
  gap:18px;
  flex-wrap:wrap;
}
.nvn-actions{justify-self:end}

.nvn-brand{
  display:flex;align-items:center;gap:12px;min-width:200px
}
.nvn-logo{display:block;
  width:var(--nvn-logo-size);height:var(--nvn-logo-size);border-radius:12px;
  background: conic-gradient(from 210deg, var(--nvn-orange), var(--nvn-green), var(--nvn-orange));
  box-shadow: 0 10px 22px rgba(0,0,0,.35);
}
.nvn-site-title{font-weight:800;letter-spacing:.2px;line-height:1.1}
.nvn-site-title span{
  background: linear-gradient(90deg, var(--nvn-orange), var(--nvn-green));
  -webkit-background-clip:text;background-clip:text;color:transparent
}
.nvn-site-desc{font-size:12px;color:var(--nvn-muted)}

.nvn-nav{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding: 10px 0 2px;
  position:relative;
}
.nvn-nav::before{
  content:"";
  position:absolute;
  left:0; right:0; top:0;
  height:1px;
  background: linear-gradient(90deg, transparent, rgba(0,230,118,.35), rgba(255,122,0,.35), transparent);
  opacity:.65;
  pointer-events:none;
}
.nvn-nav ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:center;
  flex-wrap:wrap;
}
.nvn-nav li{position:relative}
.nvn-nav a{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 9px 12px;
  border-radius: 14px;
  font-weight: 800;
  font-size: 14px;
  color: var(--nvn-text);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
  box-shadow: 0 10px 22px rgba(0,0,0,.18);
  transition: transform .12s ease, border-color .12s ease, background .12s ease, box-shadow .12s ease, color .12s ease;
}
.nvn-nav a:hover{
  transform: translateY(-1px);
  background: rgba(255,255,255,.05);
  border-color: rgba(255,122,0,.38);
  color: rgba(255,255,255,.98);
  box-shadow: 0 18px 34px rgba(0,0,0,.28);
}
.nvn-nav .menu-item-has-children > a::after{
  content:"▾";
  font-size: 11px;
  line-height: 1;
  opacity: .72;
  margin-left: 2px;
}
.nvn-nav .current-menu-item > a,
.nvn-nav .current-menu-ancestor > a,
.nvn-nav .current_page_parent > a{
  background: linear-gradient(90deg, rgba(255,122,0,.22), rgba(0,230,118,.18));
  border-color: rgba(255,255,255,.18);
  box-shadow: 0 18px 36px rgba(0,0,0,.32);
}
.nvn-nav .current-menu-item>a,
.nvn-nav .current_page_item>a{background: rgba(255,255,255,.06);border:1px solid var(--nvn-border)}

.nvn-actions{display:flex;align-items:center;gap:10px}
.nvn-btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:9px 12px;border-radius:12px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  font-weight:700;font-size:13px;
}
.nvn-btn:hover{border-color:rgba(255,122,0,.45);color:var(--nvn-orange)}
.nvn-btn--accent{
  background: linear-gradient(90deg, rgba(255,122,0,.18), rgba(37,211,102,.18));
  border-color: rgba(255,255,255,.12);
}
.nvn-btn--accent:hover{color:var(--nvn-green)}

.nvn-menu-toggle{display:none}

/* Search form */
.nvn-search{position:relative}
.nvn-search input[type="search"]{
  width:240px;max-width:42vw;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  color:var(--nvn-text);
  outline:none;
}
.nvn-search input[type="search"]::placeholder{color:rgba(255,255,255,.45)}
.nvn-search button{
  position:absolute;right:6px;top:50%;transform:translateY(-50%);
  border:0;background:transparent;color:var(--nvn-muted);
  padding:6px 8px;border-radius:10px;cursor:pointer
}
.nvn-search button:hover{color:var(--nvn-orange);background: rgba(255,255,255,.04)}

/* =========================
   Main layout
========================= */
.nvn-main{
  padding:22px 0 30px;
}
.nvn-grid{
  display:grid;
  grid-template-columns: 1fr 340px;
  gap: var(--nvn-gap);
  align-items:start;
}
.nvn-content{min-width:0}
.nvn-sidebar{min-width:0}

/* =========================
   Hero / featured
========================= */
.nvn-hero{
  display:grid;
  grid-template-columns: 1fr;
  gap: var(--nvn-gap);
}

.nvn-featured{
  overflow:hidden;position:relative;
}
.nvn-featured .nvn-thumb{
  aspect-ratio: 16/9;
  background: #0d0d0d;
}
.nvn-featured .nvn-overlay{
  position:absolute;inset:0;
  background: linear-gradient(180deg, transparent 35%, rgba(0,0,0,.75) 100%);
}
.nvn-featured .nvn-meta{
  position:absolute;left:16px;right:16px;bottom:14px;
}
.nvn-meta .nvn-kicker{
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-bottom:8px
}
.nvn-kicker .nvn-cat{
  background: rgba(255,122,0,.16);
  border: 1px solid rgba(255,122,0,.35);
  color: var(--nvn-orange);
  padding:4px 10px;border-radius:999px;font-size:12px;font-weight:800;
}
.nvn-kicker .nvn-date{font-size:12px;color:rgba(255,255,255,.75)}
.nvn-featured h2{
  margin:0;
  font-size: clamp(20px, 2.4vw, 34px);
  line-height:1.15;
  letter-spacing:-.2px;
  text-shadow: 0 10px 25px rgba(0,0,0,.5);
}
.nvn-featured p{margin:10px 0 0;color:rgba(255,255,255,.85);max-width:62ch}

.nvn-hero-list .nvn-item{display:flex;gap:12px;padding:12px;border-radius:16px}
.nvn-hero-list .nvn-item:hover{background: rgba(255,255,255,.03)}
.nvn-hero-list .nvn-mini{
  width:110px;flex:0 0 110px;border-radius:14px;overflow:hidden;
  background:#0d0d0d;border:1px solid var(--nvn-border);
}
.nvn-hero-list h3{margin:0;font-size:14px;line-height:1.25}
.nvn-hero-list .nvn-small{font-size:12px;color:var(--nvn-muted);margin-top:6px}

/* =========================
   Post list cards
========================= */
.nvn-section-title{
  display:flex;align-items:center;justify-content:space-between;gap:12px;
  margin:22px 0 12px;
}
.nvn-section-title h2, .nvn-section-title h3{
  margin:0;font-size:16px;letter-spacing:.2px
}
.nvn-section-title .nvn-line{
  height:2px;
  flex:1;
  background: linear-gradient(90deg, rgba(0,230,118,.55), rgba(255,122,0,.55));
  border-radius:999px;
  opacity:.85;
}

.nvn-postcard{
  display:flex;gap:14px;padding:14px;border-radius:18px
}
.nvn-postcard:hover{background: rgba(255,255,255,.03)}
.nvn-postcard .nvn-thumb{
  width:160px;flex:0 0 160px;border-radius:16px;overflow:hidden;
  background:#0d0d0d;border:1px solid var(--nvn-border);
}
.nvn-postcard h2{margin:0;font-size:18px;line-height:1.25}
.nvn-postcard .nvn-excerpt{margin:8px 0 0;color:var(--nvn-muted);font-size:14px}
.nvn-postcard .nvn-meta-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px;color:var(--nvn-muted);font-size:12px}
.nvn-postcard .nvn-meta-row a{color:var(--nvn-green);font-weight:700}
.nvn-postcard .nvn-meta-row a:hover{color:var(--nvn-orange)}

/* =========================
   Single / content
========================= */
.nvn-article{
  padding:20px;
}
.nvn-article h1{
  margin:0 0 10px;
  font-size: clamp(22px, 2.6vw, 38px);
  line-height:1.15;
}
.nvn-byline{color:var(--nvn-muted);font-size:13px;margin-bottom:14px}
.nvn-feature-image{
  border-radius: 18px;
  overflow:hidden;
  border:1px solid var(--nvn-border);
  background:#0d0d0d;
  margin: 12px 0 16px;
}
.nvn-content-area{
  color: rgba(255,255,255,.92);
}
.nvn-content-area p{margin:0 0 14px}
.nvn-content-area h2, .nvn-content-area h3, .nvn-content-area h4{margin:22px 0 10px}
.nvn-content-area a{color:var(--nvn-green);font-weight:700}
.nvn-content-area a:hover{color:var(--nvn-orange)}
.nvn-content-area blockquote{
  margin:18px 0;padding:14px 16px;
  border-left: 4px solid rgba(255,122,0,.6);
  background: rgba(255,122,0,.07);
  border-radius: 14px;
  color: rgba(255,255,255,.9);
}
.nvn-content-area ul, .nvn-content-area ol{padding-left:20px}
.nvn-tags{margin-top:16px}
.nvn-tags a{
  display:inline-block;margin:6px 6px 0 0;
  padding:6px 10px;border-radius:999px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  font-size:12px;color:var(--nvn-muted)
}
.nvn-tags a:hover{border-color:rgba(37,211,102,.5);color:var(--nvn-green)}

/* =========================
   Sidebar widgets
========================= */
.widget{
  margin-bottom: var(--nvn-gap);
}
.widget .nvn-card{padding:16px}
.widget-title{
  margin:0 0 12px;
  font-size:14px;letter-spacing:.3px;text-transform:uppercase;
  color: rgba(255,255,255,.85);
}
.widget a{color:var(--nvn-text)}
.widget a:hover{color:var(--nvn-orange)}
.widget ul{list-style:none;margin:0;padding:0}
.widget li{padding:8px 0;border-bottom:1px solid var(--nvn-border)}
.widget li:last-child{border-bottom:0}
.widget input[type="search"], .widget input[type="text"], .widget input[type="email"]{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  color:var(--nvn-text);
}
.widget button, .widget input[type="submit"]{
  margin-top:10px;
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid rgba(37,211,102,.45);
  background: rgba(37,211,102,.12);
  color: var(--nvn-green);
  font-weight:800;
  cursor:pointer;
}
.widget button:hover, .widget input[type="submit"]:hover{
  border-color: rgba(255,122,0,.55);
  background: rgba(255,122,0,.12);
  color: var(--nvn-orange);
}

/* =========================
   Pagination
========================= */
.navigation.pagination{
  margin: 18px 0;
}
.nav-links{
  display:flex;gap:10px;flex-wrap:wrap
}
.nav-links .page-numbers{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:40px;height:40px;
  border-radius:12px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  font-weight:800;font-size:13px;color:var(--nvn-text)
}
.nav-links .page-numbers:hover{color:var(--nvn-orange);border-color:rgba(255,122,0,.45)}
.nav-links .current{background: rgba(255,122,0,.14);border-color:rgba(255,122,0,.45);color:var(--nvn-orange)}

/* =========================
   Footer
========================= */
.nvn-footer{
  border-top:1px solid var(--nvn-border);
  background:#050505;
  padding:22px 0 30px;
}
.nvn-footer .nvn-container{
  display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between
}
.nvn-footer small{color:var(--nvn-muted)}
.nvn-footer a{color:var(--nvn-green);font-weight:800}
.nvn-footer a:hover{color:var(--nvn-orange)}

/* =========================
   Mobile
========================= */
@media (max-width: 980px){
  .nvn-grid{grid-template-columns:1fr}
  .nvn-search input[type="search"]{width:200px}
}
@media (max-width: 760px){
  .nvn-header .nvn-container{flex-wrap:wrap}
  .nvn-nav{display:none;width:100%}
  .nvn-nav ul{flex-direction:column;align-items:stretch}

  /* MOBILE NAV POLISH */
  .nvn-nav{
    margin-top: 10px;
    padding: 12px;
    border: 1px solid var(--nvn-border);
    border-radius: 18px;
    background:
      radial-gradient(520px 220px at 10% 0%, rgba(0,230,118,.10), transparent 60%),
      radial-gradient(520px 220px at 90% 0%, rgba(255,122,0,.09), transparent 60%),
      rgba(0,0,0,.35);
  }
  .nvn-nav a{
    width:100%;
    justify-content:space-between;
  }
  .nvn-menu-toggle{
    font-size:0;
    position:relative;
  }
  .nvn-menu-toggle::before{
    content:"≡";
    font-size: 18px;
    line-height: 1;
    opacity:.9;
  }

  .nvn-nav a{padding:10px 12px}
  .nvn-menu-toggle{
    display:inline-flex;align-items:center;justify-content:center;
    width:44px;height:44px;border-radius:14px;
    border:1px solid var(--nvn-border);
    background: rgba(255,255,255,.03);
    cursor:pointer;
  }
  .nvn-menu-toggle:hover{border-color:rgba(255,122,0,.45);color:var(--nvn-orange)}
  .nvn-search{flex:1}
  .nvn-search input[type="search"]{width:100%;max-width:none}
  .nvn-hero{grid-template-columns:1fr}
  .nvn-featured .nvn-meta{left:14px;right:14px}
  .nvn-postcard{flex-direction:column}
  .nvn-postcard .nvn-thumb{width:100%;flex:0 0 auto}
  .nvn-hero-list .nvn-mini{width:100px;flex:0 0 100px}


  /* MOBILE SUBMENU TOGGLE */
  .nvn-nav li.menu-item-has-children{position:relative;}
  .nvn-nav li.menu-item-has-children > a{padding-right: 40px; position:relative;}
  .nvn-nav li.menu-item-has-children > a::after{
    content:"▾";
    position:absolute;
    right: 14px;
    top: 50%;
    transform: translateY(-50%);
    font-weight: 950;
    opacity: .85;
  }

  .nvn-nav .sub-menu{
    position: static;
    top: auto;
    left: auto;
    min-width: 0;
    margin: 0;
    padding: 8px 0 10px 12px;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transform: none;
    display: none;
  }
  .nvn-nav li.is-sub-open > .sub-menu{display:block;}


}

/* WordPress core blocks tweaks */
.wp-block-image img{border-radius:16px}
.wp-block-separator{border-top:1px solid var(--nvn-border)}
.wp-block-table table{width:100%;border-collapse:collapse}
.wp-block-table th,.wp-block-table td{border:1px solid var(--nvn-border);padding:10px}


/* =========================
   Logo + Banner rotativo
========================= */
.custom-logo-link{display:inline-flex;align-items:center;justify-content:center}
.custom-logo-link img.custom-logo{
  width:var(--nvn-logo-size);height:var(--nvn-logo-size);
  object-fit:contain;
  border-radius:12px;
  background: rgba(255,255,255,.04);
  border:1px solid var(--nvn-border);
  padding:6px;
}

/* Banner (home) */
.nvn-banner{
  position:relative;
  overflow:hidden;
  border:1px solid var(--nvn-border);
  border-radius: var(--nvn-radius);
  box-shadow: var(--nvn-shadow);
  background:#0d0d0d;
  margin-bottom: var(--nvn-gap);
}
.nvn-banner::after{
  content:"";
  position:absolute;inset:0;
  background: linear-gradient(180deg, rgba(0,0,0,.15) 0%, rgba(0,0,0,.65) 100%);
  pointer-events:none;
}
.nvn-banner-track{
  position:relative;
  width:100%;
  aspect-ratio: 21/7; /* banner tipo noticia */
  min-height: 180px;
}
.nvn-banner-slide{
  position:absolute;inset:0;
  opacity:0;
  transition: opacity .9s ease;
}
.nvn-banner-slide.is-active{opacity:1}
.nvn-banner-slide img{
  width:100%;height:100%;
  object-fit:cover;
}
.nvn-banner-caption{
  position:absolute;
  left:16px;right:16px;bottom:14px;
  z-index:2;
  display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap;
}
.nvn-banner-caption .nvn-banner-title{
  margin:0;
  font-size: clamp(16px, 2vw, 22px);
  font-weight:900;
  letter-spacing:-.2px;
  text-shadow: 0 10px 25px rgba(0,0,0,.55);
}
.nvn-banner-caption .nvn-banner-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 10px;border-radius:999px;
  border:1px solid rgba(37,211,102,.45);
  background: rgba(37,211,102,.12);
  color: var(--nvn-green);
  font-weight:900;
  font-size:12px;
}
@media (max-width: 760px){
  .nvn-banner-track{aspect-ratio: 16/9}
}


/* =========================
   Foto de fondo (site-wide)
========================= */
body.nvn-has-bg{
  position:relative;
  background-size: cover;
  background-position: center;
  background-attachment: fixed;
}
body.nvn-has-bg::before{
  content:"";
  position:fixed;
  inset:0;
  background: rgba(0,0,0,var(--nvn-bg-overlay));
  pointer-events:none;
  z-index:-1;
}


/* =========================
   Iconos redes sociales
========================= */
.nvn-social{
  display:flex;
  gap:8px;
  align-items:center;
  flex-wrap:wrap;
}
.nvn-social a{
  width:36px;height:36px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:12px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  color: var(--nvn-text);
  transition: transform .12s ease, border-color .2s ease, background .2s ease, color .2s ease;
}
.nvn-social a:hover{
  border-color: rgba(255,122,0,.45);
  background: rgba(255,255,255,.04);
  color: var(--nvn-orange);
  transform: translateY(-1px);
}
.nvn-social a:focus{
  outline: 2px solid rgba(37,211,102,.45);
  outline-offset: 2px;
}
.nvn-social svg{
  width:18px;height:18px;
  display:block;
  fill: currentColor;
}
.nvn-topbar .nvn-toplinks{
  display:flex;
  gap:10px;
  align-items:center;
  justify-content:flex-end;
  flex-wrap:wrap;
}
.nvn-topbar .nvn-toplinks nav{display:inline-flex}
.nvn-topbar .nvn-toplinks a{margin-left:0}


/* =========================
   Banner estilo cover (similar al ejemplo)
========================= */
.nvn-banner{
  border-radius: 20px;
}
.nvn-banner::before{
  /* Base geométrica naranja/verde + diagonales blancas */
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg, var(--nvn-orange) 0 55%, var(--nvn-green) 55% 100%),
    linear-gradient(135deg, rgba(255,255,255,.92) 0 46%, rgba(255,255,255,0) 46% 100%),
    linear-gradient(315deg, rgba(255,255,255,.92) 0 24%, rgba(255,255,255,0) 24% 100%),
    linear-gradient(135deg, rgba(255,119,0,.95) 0 26%, rgba(255,119,0,0) 26% 100%);
  opacity:.38;
  z-index:0;
}
.nvn-banner::after{
  /* Overlay para legibilidad */
  opacity:.55;
  z-index:1;
}

.nvn-banner-track{z-index:0}
.nvn-banner-slide{z-index:0}
.nvn-banner-caption{z-index:2}

/* UI dentro del banner */
.nvn-banner-ui{
  position:absolute;
  inset:0;
  z-index:3;
  pointer-events:none;
}

.nvn-banner-brand{
  position:absolute;
  left:50%;
  transform: translateX(-50%);
  bottom:18px;
  display:flex;
  gap:16px;
  align-items:center;
  pointer-events:auto;
}

/* círculo grande con logo */
.nvn-banner-circle{
  width:200px;
  height:200px;
  border-radius:999px;
  background: rgba(255,255,255,.96);
  box-shadow: 0 18px 40px rgba(0,0,0,.35);
  border: 1px solid rgba(0,0,0,.08);
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
.nvn-banner-circle img.custom-logo{
  width: calc(var(--nvn-logo-size) * 1.35);
  height: calc(var(--nvn-logo-size) * 1.35);
  object-fit:contain;
  background: transparent;
  border:0;
  padding:0;
  border-radius:0;
}
.nvn-banner-circle .nvn-logo{display:block;
  width: calc(var(--nvn-logo-size) * 1.35);
  height: calc(var(--nvn-logo-size) * 1.35);
  border-radius: 18px;
}

.nvn-banner-brandtext{
  max-width: 520px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 12px 14px;
  backdrop-filter: blur(8px);
}
.nvn-banner-sitename{
  margin:0;
  font-size: clamp(18px, 2.2vw, 28px);
  font-weight: 1000;
  letter-spacing: -.2px;
}
.nvn-banner-tagline{
  margin-top:6px;
  font-size: 13px;
  color: rgba(255,255,255,.82);
}

/* Barra social inclinada (arriba-derecha) */
.nvn-banner-socialbar{
  position:absolute;
  top:18px;
  right:18px;
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding: 10px 14px;
  border-radius: 14px;
  background: var(--nvn-navy);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 14px 28px rgba(0,0,0,.35);
  transform: skewX(-16deg);
  pointer-events:auto;
}
.nvn-banner-socialbar > *{
  transform: skewX(16deg);
}

/* Ajustes de iconos dentro del banner */
.nvn-banner-socialbar .nvn-social a{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
}
.nvn-banner-socialbar .nvn-social a:hover{
  border-color: rgba(0,216,0,.55);
  color: var(--nvn-green);
}

/* Texto de banner (opcional) */
.nvn-banner-caption{
  position:absolute;
  left:18px;
  right:18px;
  top:18px;
  bottom:auto;
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:12px;
}
.nvn-banner-caption .nvn-banner-title{
  margin:0;
  padding: 8px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,.10);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(8px);
}
.nvn-banner-caption .nvn-banner-tag{display:none}

/* Mobile */
@media (max-width: 760px){
  .nvn-banner-circle{
    width:140px;height:140px;
  }
  .nvn-banner-brand{
    left:12px;bottom:12px;
    gap:12px;
  }
  .nvn-banner-socialbar{
    top:12px;right:12px;
    padding:8px 10px;
  }
  .nvn-banner-brandtext{
    max-width: calc(100vw - 190px);
    padding: 10px 12px;
  }
}


/* =========================
   PRO MAX (Noticias) UI
========================= */

/* Contenedor ancho configurable */
.nvn-container{max-width:var(--nvn-maxw)}

/* Ticker / Último minuto */
.nvn-ticker{
  display:flex;
  align-items:center;
  gap:12px;
  padding:10px 0;
}
.nvn-ticker-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:6px 10px;
  border-radius:999px;
  font-weight:1000;
  font-size:12px;
  letter-spacing:.2px;
  background: rgba(255,119,0,.18);
  border: 1px solid rgba(255,119,0,.45);
  color: var(--nvn-orange);
}
.nvn-ticker-track{
  position:relative;
  overflow:hidden;
  flex:1;
  border-radius: 14px;
  border: 1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
}
.nvn-ticker-inner{
  display:inline-flex;
  gap:22px;
  padding:8px 14px;
  white-space:nowrap;
  will-change: transform;
  animation: nvnMarquee var(--nvn-ticker-speed) linear infinite;
}
.nvn-ticker-inner a{
  color: rgba(255,255,255,.88);
  font-weight:800;
}
.nvn-ticker-inner a:hover{color: var(--nvn-green)}
@keyframes nvnMarquee{
  from{transform: translateX(0)}
  to{transform: translateX(-50%)}
}
.nvn-ticker-track:hover .nvn-ticker-inner{animation-play-state: paused}

/* Slots de publicidad */
.nvn-ad{
  border:1px dashed rgba(255,255,255,.16);
  background: rgba(255,255,255,.02);
  border-radius: 16px;
  padding: 12px;
  margin: var(--nvn-gap) 0;
}
.nvn-ad small{
  display:block;
  color: rgba(255,255,255,.55);
  font-weight:800;
  letter-spacing:.2px;
  text-transform: uppercase;
  font-size: 11px;
  margin-bottom: 8px;
}
.nvn-ad .nvn-ad-body{color: rgba(255,255,255,.9)}

/* Layouts */
.nvn-grid.left-sidebar{
  grid-template-columns: 340px 1fr;
}
.nvn-grid.left-sidebar .nvn-content{order:2}
.nvn-grid.left-sidebar .nvn-sidebar{order:1}

.nvn-grid.no-sidebar{
  grid-template-columns: 1fr;
}
.nvn-grid.no-sidebar .nvn-sidebar{display:none}

/* Subtítulo */
.nvn-subtitle{
  margin: 8px 0 0;
  color: rgba(255,255,255,.82);
  font-size: 16px;
}

/* Badges meta */
.nvn-meta-badges{
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  margin-top: 10px;
}
.nvn-badge{
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  font-size:12px;
  color: var(--nvn-muted);
  font-weight:900;
}
.nvn-badge strong{color: var(--nvn-text)}

/* Compartir */
.nvn-share{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin: 14px 0 0;
}
.nvn-share a{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 12px;
  border-radius:14px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  font-weight:900;
  font-size:13px;
}
.nvn-share a:hover{
  border-color: rgba(0,216,0,.55);
  color: var(--nvn-green);
}
.nvn-share svg{width:16px;height:16px;fill:currentColor}

/* Author box */
.nvn-authorbox{
  display:flex;
  gap:14px;
  padding:16px;
  border-radius:18px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
}
.nvn-authorbox img{
  width:64px;height:64px;border-radius:18px;
  border:1px solid var(--nvn-border);
}
.nvn-authorbox h3{margin:0;font-size:14px}
.nvn-authorbox p{margin:6px 0 0;color: var(--nvn-muted);font-size:13px}

/* Footer columnas */
.nvn-footer-grid{
  display:grid;
  grid-template-columns: repeat(var(--nvn-footer-cols), 1fr);
  gap: var(--nvn-gap);
  margin: 14px 0 18px;
}
@media (max-width: 980px){.nvn-footer-grid{grid-template-columns:1fr}}

/* =========================
   Directos (badges)
========================= */
.nvn-live-row{
  display:flex;gap:8px;align-items:center;flex-wrap:wrap;
  margin-top:10px;
}
.nvn-live-badge{
  display:inline-flex;align-items:center;gap:7px;
  padding:6px 10px;border-radius:999px;
  font-weight:1000;font-size:12px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
}
.nvn-live-dot{
  width:8px;height:8px;border-radius:999px;background: var(--nvn-green);
  box-shadow: 0 0 0 0 rgba(0,216,0,.55);
  animation: nvnPulse 1.4s infinite;
}
@keyframes nvnPulse{
  0%{box-shadow:0 0 0 0 rgba(0,216,0,.55)}
  70%{box-shadow:0 0 0 12px rgba(0,216,0,0)}
  100%{box-shadow:0 0 0 0 rgba(0,216,0,0)}
}
.nvn-pill{
  display:inline-flex;align-items:center;
  padding:6px 10px;border-radius:999px;
  font-weight:900;font-size:12px;
  border:1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  color: rgba(255,255,255,.85);
}
.nvn-pill--twitch{border-color:rgba(145,70,255,.45);color:#b89cff}
.nvn-pill--youtube{border-color:rgba(255,0,0,.40);color:#ff7a7a}
.nvn-pill--facebook{border-color:rgba(24,119,242,.40);color:#87b7ff}

/* Barra de progreso de lectura */
.nvn-progress{
  position:fixed;
  top:0;left:0;
  width:100%;
  height:4px;
  z-index: 2000;
  background: rgba(255,255,255,.06);
  backdrop-filter: blur(8px);
}
.nvn-progress > span{
  display:block;
  height:100%;
  width:0%;
  background: linear-gradient(90deg, var(--nvn-orange), var(--nvn-green));
}

/* Logo centrado (header) */
.nvn-brand{min-width:0;justify-content:center;text-align:center}

/* Logo centrado (banner/cover) */
.nvn-banner-brand{left:50% !important;transform:translateX(-50%) !important;}


/* =========================
   ULTRA PRO (Live Factor)
========================= */

/* Header premium: logo centrado en columna */
@media (min-width: 900px){
  .nvn-brand{flex-direction:column;gap:6px;min-width:260px;text-align:center}
  .nvn-brand > div{display:flex;flex-direction:column;align-items:center}
  .nvn-site-title{font-size:18px}
  .nvn-site-desc{font-size:12px}
}

/* Barra de progreso lectura */
.nvn-reading-progress{
  position:fixed;
  left:0; top:0;
  height:3px;
  width:0%;
  background: linear-gradient(90deg, var(--nvn-orange), var(--nvn-green));
  z-index:100000;
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
}

/* Módulo Directos (arriba en portada) */
.nvn-live{
  margin: 14px 0 8px;
}
.nvn-live-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  margin-bottom: 10px;
}
.nvn-live-title{
  display:flex;
  align-items:center;
  gap:10px;
}
.nvn-live-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 7px 12px;
  border-radius: 999px;
  background: rgba(0,230,118,.12);
  border: 1px solid rgba(0,230,118,.45);
  color: var(--nvn-green);
  font-weight: 1000;
  letter-spacing:.2px;
  text-transform: uppercase;
  font-size: 12px;
}
.nvn-live-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--nvn-gap);
}
@media (max-width: 980px){ .nvn-live-grid{grid-template-columns:1fr} }

.nvn-live-card{
  border-radius: var(--lf-radius-xl);
  border: 1px solid var(--nvn-border);
  background: rgba(255,255,255,.03);
  overflow:hidden;
  box-shadow: var(--lf-shadow);
}
.nvn-live-card .nvn-live-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
  padding: 12px 14px;
}
.nvn-live-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:1000;
  letter-spacing:.2px;
  background: rgba(255,122,0,.14);
  border: 1px solid rgba(255,122,0,.45);
  color: var(--nvn-orange);
}
.nvn-live-platform{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 6px 10px;
  border-radius:999px;
  font-size:12px;
  font-weight:1000;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.16);
  color: var(--lf-white-soft);
}
.nvn-live-embed{
  padding: 0 14px 14px;
}
.nvn-live-embed iframe,
.nvn-live-embed embed,
.nvn-live-embed object,
.nvn-live-embed video{
  width:100%;
  border:0;
  border-radius: var(--lf-radius-lg);
  background: #000;
  aspect-ratio: 16/9;
}
.nvn-live-meta{
  padding: 0 14px 14px;
}
.nvn-live-meta a{
  color: var(--lf-white);
  font-weight: 1000;
  display:inline-block;
}
.nvn-live-meta a:hover{ color: var(--nvn-green); }

/* Ticker mejorado (arriba, debajo de Directos) */
.nvn-ticker{margin: 10px 0 14px;}
.nvn-ticker-track{
  border-radius: var(--lf-radius-lg);
}

/* Banner: logo centrado */
.nvn-banner-brand{
  left: 50%;
  transform: translateX(-50%);
  bottom: 18px;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 12px;
}
.nvn-banner-brandtext{
  max-width: 760px;
  text-align:center;
  border-radius: var(--lf-radius-lg);
}
@media (max-width:760px){
  .nvn-banner-brand{bottom:12px}
  .nvn-banner-brandtext{max-width:92vw}
}

/* Controles del banner (prev/next + dots) */
.nvn-banner-controls{
  position:absolute;
  inset:0;
  z-index:4;
  pointer-events:none;
}
.nvn-banner-btn{
  pointer-events:auto;
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:44px;height:44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.45);
  color: var(--lf-white);
  font-weight: 1000;
  display:flex;
  align-items:center;
  justify-content:center;
  box-shadow: var(--lf-shadow);
}
.nvn-banner-btn:hover{border-color: rgba(0,230,118,.55); color: var(--nvn-green)}
.nvn-banner-btn.prev{left:14px}
.nvn-banner-btn.next{right:14px}

.nvn-banner-dots{
  pointer-events:auto;
  position:absolute;
  left:50%;
  transform: translateX(-50%);
  bottom: 14px;
  display:flex;
  gap:8px;
  padding: 8px 12px;
  border-radius: 999px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.12);
  backdrop-filter: blur(8px);
}
.nvn-banner-dot{
  width:10px;height:10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.30);
  background: rgba(255,255,255,.10);
  cursor:pointer;
}
.nvn-banner-dot.is-active{
  background: linear-gradient(90deg, var(--nvn-orange), var(--nvn-green));
  border-color: rgba(255,255,255,.38);
}

/* Sección Más Leídas */
.nvn-mostread{
  margin: 14px 0;
}
.nvn-mostread ol{
  margin: 0;
  padding-left: 18px;
}
.nvn-mostread li{
  margin: 10px 0;
}
.nvn-mostread a{
  font-weight: 950;
}


/* =========================
   MEGA MENU (Secciones)
========================= */
.nvn-nav .menu-item-has-children{
  position:relative;
}
.nvn-nav .sub-menu{
  position:absolute;
  left:0;
  top: calc(100% + 6px);
  min-width: 240px;
  padding: 10px;
  border-radius: var(--lf-radius-lg);
  background: rgba(0,0,0,.74);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--lf-shadow);
  backdrop-filter: blur(14px);
  display:block;

  opacity:0;
  visibility:hidden;
  pointer-events:none;
  transform: translateY(8px);
  transition: opacity .16s ease, transform .16s ease, visibility .16s ease;
  z-index: 9999;

.nvn-nav .sub-menu::before{
  content:"";
  position:absolute;
  left:0; right:0;
  top:-10px;
  height:10px;
  background: transparent;
}

}
.nvn-nav .menu-item-has-children:hover > .sub-menu,
.nvn-nav .menu-item-has-children:focus-within > .sub-menu{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform: translateY(0);
}
.nvn-nav .sub-menu li{margin:0}
.nvn-nav .sub-menu a{
  display:flex;
  padding: 10px 10px;
  border-radius: 12px;
  color: rgba(255,255,255,.90);
}
.nvn-nav .sub-menu a:hover{
  background: rgba(255,255,255,.06);
  color: var(--nvn-green);
}

/* Mega: cuando el padre es categoría (nvn-mega-parent) */
.nvn-nav .nvn-mega-parent > .sub-menu.nvn-mega-menu{
  width: min(1080px, 92vw);
  left: 50%;
  transform: translateX(-50%) translateY(10px);
  padding: 14px;
  opacity:0;
  visibility:hidden;
  pointer-events:none;
}
.nvn-nav .nvn-mega-parent:hover > .sub-menu.nvn-mega-menu,
.nvn-nav .nvn-mega-parent:focus-within > .sub-menu.nvn-mega-menu{
  opacity:1;
  visibility:visible;
  pointer-events:auto;
  transform: translateX(-50%) translateY(0);
}
/* Grid interno */
.nvn-mega-grid{
  display:grid;
  grid-template-columns: 1.25fr 1fr;
  gap: 14px;
  align-items: start;
}
@media (max-width: 980px){
  .nvn-nav .nvn-mega-parent > .sub-menu.nvn-mega-menu{
    width: min(96vw, 780px);
  }
  .nvn-mega-grid{grid-template-columns: 1fr;}
}

/* Bloque posts destacados dentro del mega menu */
.nvn-mega-posts{
  padding: 0;
  margin: 0;
  list-style:none;
}
.nvn-mega-posts .nvn-mega-title{
  font-weight: 1000;
  letter-spacing:.2px;
  text-transform: uppercase;
  font-size: 12px;
  color: rgba(255,255,255,.72);
  margin: 4px 0 10px;
}
.nvn-mega-cards{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
}
@media (max-width: 600px){
  .nvn-mega-cards{grid-template-columns:1fr;}
}
.nvn-mega-card{
  border-radius: var(--lf-radius-lg);
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
}
.nvn-mega-thumb{
  width:100%;
  aspect-ratio: 16/9;
  background: rgba(255,255,255,.06);
}
.nvn-mega-thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.nvn-mega-card .nvn-mega-cardbody{
  padding: 10px 10px 12px;
}
.nvn-mega-card a{
  padding:0;
  background: transparent;
  border-radius:0;
  color: rgba(255,255,255,.92);
  font-weight: 950;
  line-height: 1.2;
}
.nvn-mega-card a:hover{color: var(--nvn-orange);}

.nvn-mega-links{
  border-radius: var(--lf-radius-lg);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.28);
  padding: 10px;
}
.nvn-mega-links .nvn-mega-title{margin-top:0}


/* =========================
   TV MODULE (Videos/Directos)
========================= */
.nvn-tv{
  margin: 16px 0 10px;
}
.nvn-tv-wrap{
  border-radius: var(--lf-radius-xl);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  box-shadow: var(--lf-shadow);
  overflow:hidden;
}
.nvn-tv-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding: 12px 14px;
  background: linear-gradient(90deg, rgba(255,122,0,.12), rgba(0,230,118,.10));
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.nvn-tv-title{
  display:flex;
  align-items:center;
  gap:10px;
  font-weight: 1000;
}
.nvn-tv-pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 6px 10px;
  border-radius:999px;
  font-size: 12px;
  font-weight: 1000;
  letter-spacing: .2px;
  background: rgba(0,0,0,.35);
  border: 1px solid rgba(255,255,255,.14);
}
.nvn-tv-grid{
  display:grid;
  grid-template-columns: 2fr 1fr;
  gap: 0;
}
@media (max-width: 980px){
  .nvn-tv-grid{grid-template-columns:1fr;}
}
.nvn-tv-player{
  padding: 14px;
}
.nvn-tv-player .nvn-tv-embed{
  border-radius: var(--lf-radius-lg);
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.10);
  background: #000;
}
.nvn-tv-player .nvn-tv-embed iframe,
.nvn-tv-player .nvn-tv-embed video,
.nvn-tv-player .nvn-tv-embed embed,
.nvn-tv-player .nvn-tv-embed object{
  width:100%;
  border:0;
  aspect-ratio:16/9;
  display:block;
}
.nvn-tv-player h3{
  margin: 12px 0 0;
  font-size: 18px;
}
.nvn-tv-list{
  border-left: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
@media (max-width: 980px){
  .nvn-tv-list{border-left:0;border-top:1px solid rgba(255,255,255,.10);}
}
.nvn-tv-item{
  display:flex;
  gap:10px;
  padding: 12px 12px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  cursor:pointer;
}
.nvn-tv-item:hover{
  background: rgba(255,255,255,.04);
}
.nvn-tv-item.is-active{
  background: rgba(0,230,118,.08);
}
.nvn-tv-mini{
  width: 96px;
  aspect-ratio: 16/9;
  border-radius: 12px;
  overflow:hidden;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  flex: 0 0 auto;
}
.nvn-tv-mini img{width:100%;height:100%;object-fit:cover;display:block}
.nvn-tv-item strong{
  display:block;
  font-weight: 950;
  line-height: 1.15;
}
.nvn-tv-item small{color: rgba(255,255,255,.70)}

/* =========================
   EXTERNAL FEATURED IMAGE
========================= */
.nvn-thumb img,
.nvn-feature-image img,
.nvn-mini img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}


/* =========================
   HEADER BANNER (Logo + Banner)
========================= */
.nvn-header-banner{
  display:flex;
  align-items:center;
  justify-content:center;
  min-height: 54px;
}
.nvn-header-banner-link{display:inline-flex;align-items:center;justify-content:center}
.nvn-header-banner img{
  max-height: 90px;
  width:auto;
  max-width: min(720px, 58vw);
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.22);
  box-shadow: 0 12px 26px rgba(0,0,0,.35);
}
.nvn-header-banner-html{
  max-width: min(720px, 58vw);
}
.nvn-header-banner.is-hide-mobile{display:flex}

@media (max-width: 980px){
  .nvn-header-top{grid-template-columns:1fr}
  .nvn-actions{justify-self:center}
  .nvn-header-banner img,
  .nvn-header-banner-html{max-width: min(92vw, 728px)}
}
@media (max-width: 520px){
  .nvn-header-banner.is-hide-mobile{display:none}
  .nvn-brandrow{flex-direction:column}
  .nvn-header-banner img{max-height: 78px;}
}


/* =========================
   LF LIKE BUTTON
========================= */
.lf-like-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.30);
  color: #fff;
  font-weight: 800;
  cursor: pointer;
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
  box-shadow: 0 10px 22px rgba(0,0,0,.28);
}
.lf-like-btn:hover{ transform: translateY(-1px); box-shadow: 0 14px 28px rgba(0,0,0,.33); }
.lf-like-btn:active{ transform: translateY(0px) scale(.99); }
.lf-like-btn .lf-like-ico{ font-size: 16px; line-height:1; }
.lf-like-btn .lf-like-count{
  min-width: 28px;
  text-align:center;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.10);
  font-size: 12px;
}
.lf-like-btn.is-liked{
  background: linear-gradient(135deg, rgba(0,214,102,.22), rgba(255,136,0,.18));
  border-color: rgba(0,214,102,.30);
}
.lf-like-btn.is-liked .lf-like-ico{ filter: drop-shadow(0 8px 14px rgba(0,0,0,.28)); }
.lf-like-btn[disabled]{ opacity:.75; cursor:not-allowed; }


/* =========================
   PODCAST
========================= */
.lf-embed iframe{width:100%; max-width:100%;}


/* =========================
   VIDEO COVER OVERLAY
========================= */
.lf-embed{
  position: relative;
  overflow: hidden;
  border-radius: 16px;
}
.lf-embed iframe,
.lf-embed video{
  width:100%;
  max-width:100%;
}
.lf-embed[data-lf-cover] iframe{
  display:block;
  min-height: 340px;
  background: rgba(0,0,0,.35);
}

.lf-embed-cover{
  position:absolute;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  border:0;
  padding:0;
  background: linear-gradient(180deg, rgba(0,0,0,.10), rgba(0,0,0,.55));
}
.lf-embed-cover img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit: cover;
  filter: saturate(1.05) contrast(1.03);
}
.lf-embed-cover::before{
  content:'';
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 50% 55%, rgba(0,0,0,.12), rgba(0,0,0,.62));
}
.lf-embed-play{
  position:relative;
  z-index:2;
  width:74px;
  height:74px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.22);
  background: linear-gradient(135deg, rgba(0,214,102,.24), rgba(255,136,0,.22));
  box-shadow: 0 20px 40px rgba(0,0,0,.45);
  display:flex;
  align-items:center;
  justify-content:center;
  transform: translateY(2px);
}
.lf-embed-play span{
  font-size: 22px;
  margin-left: 3px;
}
.lf-embed.is-playing{border-radius:16px;}


/* =========================
   LF SOCIAL BAR (Article Header)
========================= */
.lf-social-bar{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:12px;
}
.lf-social-btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:9px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.26);
  color:#fff;
  font-weight: 900;
  text-decoration:none;
  box-shadow: 0 10px 22px rgba(0,0,0,.24);
  transition: transform .12s ease, box-shadow .12s ease, background .12s ease;
}
.lf-social-btn:hover{
  transform: translateY(-1px);
  box-shadow: 0 14px 28px rgba(0,0,0,.30);
  background: linear-gradient(135deg, rgba(0,214,102,.12), rgba(255,136,0,.10));
}
.lf-social-ico{
  width:18px;
  height:18px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
}
.lf-social-ico svg{
  width:18px;
  height:18px;
  fill: currentColor;
  opacity: .95;
}
.lf-social-text{
  font-size: 12px;
  letter-spacing: .2px;
  opacity:.95;
}
@media (max-width: 520px){
  .lf-social-text{display:none;}
  .lf-social-btn{padding:10px 12px;}
}


/* =========================
   ARTICLE MEDIA (Imagen + Video separados)
========================= */
.lf-article-media .nvn-thumb{
  border-radius: 16px;
  overflow:hidden;
}


/* =========================
   RESPONSIVE VIDEO IF RAME
========================= */
.lf-embed{
  position: relative;
  width:100%;
}
.lf-embed .lf-iframe{
  width:100%;
  aspect-ratio: 16/9;
  height:auto;
  border:0;
  border-radius:16px;
  overflow:hidden;
  background: rgba(0,0,0,.35);
}
.lf-embed iframe:not(.lf-iframe){
  width:100%;
  max-width:100%;
}


/* TV (portada) - hacer embeds responsivos */
.nvn-tv-embed .lf-iframe,
.nvn-tv-embed iframe{
  width:100%;
  aspect-ratio:16/9;
  height:auto;
  border:0;
  border-radius:16px;
  overflow:hidden;
  background: rgba(0,0,0,.35);
}


/* =========================
   TEXTURA COMPONENTES
========================= */
.nvn-card{
  background:
    linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01)),
    radial-gradient(800px 320px at 20% 0%, rgba(0,230,118,.06), transparent 55%),
    radial-gradient(700px 300px at 90% 0%, rgba(255,122,0,.06), transparent 55%),
    rgba(0,0,0,.22);
  border: 1px solid rgba(255,255,255,.10);
  box-shadow: 0 18px 46px rgba(0,0,0,.42);
  backdrop-filter: blur(10px);
}

.nvn-section-title .nvn-line{
  height: 2px;
  background:
    linear-gradient(90deg, rgba(0,230,118,.0), rgba(0,230,118,.7), rgba(255,122,0,.75), rgba(255,122,0,0));
  border-radius: 999px;
  opacity:.9;
}

.nvn-btn,
.lf-social-btn{
  position:relative;
  overflow:hidden;
}
.nvn-btn::before,
.lf-social-btn::before{
  content:"";
  position:absolute;
  inset:-2px;
  pointer-events:none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,var(--lf-stripe-opacity)) 0 1px, transparent 1px 10px),
    radial-gradient(220px 90px at 30% 0%, rgba(0,230,118,.22), transparent 60%),
    radial-gradient(220px 90px at 70% 0%, rgba(255,122,0,.18), transparent 60%);
  opacity:.35;
  mix-blend-mode: overlay;
}

.nvn-topbar,
.nvn-nav{
  background:
    linear-gradient(180deg, rgba(255,255,255,.04), rgba(255,255,255,.01)),
    repeating-linear-gradient(90deg, rgba(255,122,0,.10) 0 2px, transparent 2px 14px),
    rgba(0,0,0,.55);
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: blur(10px);
}

.nvn-badge,
.nvn-chip{
  background:
    linear-gradient(180deg, rgba(255,255,255,.10), rgba(255,255,255,.02)),
    radial-gradient(140px 60px at 20% 0%, rgba(0,230,118,.30), transparent 70%),
    radial-gradient(140px 60px at 90% 0%, rgba(255,122,0,.22), transparent 70%),
    rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.12);
}

.nvn-thumb img{
  filter: saturate(1.05) contrast(1.03);
}
.nvn-thumb{
  border: 1px solid rgba(255,255,255,.10);
}


/* =========================
   GRAPHIC PRO DECALS (toque gráfico premium)
========================= */

/* Brillo suave en hover de cards */
.nvn-card{
  position: relative;
}
.nvn-card::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: 18px;
  pointer-events:none;
  opacity: 0;
  transition: opacity .25s ease, transform .25s ease;
  background:
    radial-gradient(500px 180px at 20% 0%, rgba(0,230,118,.22), transparent 60%),
    radial-gradient(520px 200px at 90% 0%, rgba(255,122,0,.20), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,0));
  filter: blur(0.2px);
}
.nvn-card:hover::after{
  opacity: .85;
}
.nvn-card:hover{
  transform: translateY(-2px);
  transition: transform .22s ease;
}

/* Esquinas con acento diagonal */
.nvn-card::before{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width: 120px;
  height: 120px;
  border-top-right-radius: 18px;
  pointer-events:none;
  opacity:.22;
  background:
    linear-gradient(135deg, rgba(255,122,0,.55), rgba(0,230,118,.40), transparent 60%);
  clip-path: polygon(40% 0, 100% 0, 100% 60%, 60% 100%, 0 100%, 0 40%);
}

/* Subrayado degradado pro en links del menú */
.nvn-nav a{
  position:relative;
}
.nvn-nav a::after{
  content:"";
  position:absolute;
  left: 12px;
  right: 12px;
  bottom: 6px;
  height: 2px;
  border-radius: 999px;
  opacity: 0;
  transform: translateY(2px);
  transition: opacity .2s ease, transform .2s ease;
  background: linear-gradient(90deg, rgba(0,230,118,.0), rgba(0,230,118,.85), rgba(255,122,0,.85), rgba(255,122,0,0));
}
.nvn-nav a:hover::after,
.nvn-nav .current-menu-item > a::after,
.nvn-nav .current-menu-ancestor > a::after{
  opacity: .9;
  transform: translateY(0);
}

/* Separadores con patrón (listas/sidebars) */
.widget .nvn-card ol li,
.widget .nvn-card ul li{
  border-bottom: 1px dashed rgba(255,255,255,.10);
  padding-bottom: 10px;
  margin-bottom: 10px;
}
.widget .nvn-card ol li:last-child,
.widget .nvn-card ul li:last-child{
  border-bottom: 0;
  padding-bottom: 0;
  margin-bottom: 0;
}

/* Scrollbar (Chrome/Edge) */
*::-webkit-scrollbar{
  width: 12px;
}
*::-webkit-scrollbar-track{
  background: rgba(0,0,0,.35);
}
*::-webkit-scrollbar-thumb{
  background: linear-gradient(180deg, rgba(0,230,118,.55), rgba(255,122,0,.55));
  border-radius: 999px;
  border: 3px solid rgba(0,0,0,.35);
}

/* Header/Fondo: decals */
.nvn-header{
  position:relative;
}
.nvn-header::before{
  content:"";
  position:absolute;
  top:-80px;
  left:-120px;
  width: 420px;
  height: 420px;
  pointer-events:none;
  opacity:.35;
  background:
    radial-gradient(circle at 30% 30%, rgba(0,230,118,.25), transparent 60%),
    radial-gradient(circle at 70% 70%, rgba(255,122,0,.22), transparent 62%);
  filter: blur(0.2px);
}
.nvn-header::after{
  content:"";
  position:absolute;
  top:-90px;
  right:-140px;
  width: 520px;
  height: 520px;
  pointer-events:none;
  opacity:.22;
  background:
    radial-gradient(circle at 40% 40%, rgba(255,255,255,.08), transparent 62%),
    radial-gradient(circle at 70% 20%, rgba(255,122,0,.18), transparent 60%),
    radial-gradient(circle at 25% 75%, rgba(0,230,118,.16), transparent 60%);
}

/* Evitar que decals tapen clicks */
.nvn-header .nvn-topbar,
.nvn-header .nvn-nav,
.nvn-header .nvn-header-inner{
  position:relative;
  z-index:2;
}


/* =========================
   EVENTOS + UNBOXING (secciones especiales)
========================= */
.lf-eventpromo{
  position:relative;
  overflow:hidden;
  padding:0;
}
.lf-eventpromo-bg{
  position:absolute;
  inset:-20px;
  background-size: cover;
  background-position:center;
  filter: blur(6px) saturate(1.05) contrast(1.05);
  opacity:.28;
  transform: scale(1.06);
}
.lf-eventpromo-inner{
  position:relative;
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 18px;
  padding: 22px;
  align-items: stretch;
}
.lf-eventpromo-left{min-width:0}
.lf-eventpromo-right{
  position:relative;
  border-radius: 18px;
  background:
    radial-gradient(520px 240px at 20% 0%, rgba(0,230,118,.16), transparent 60%),
    radial-gradient(520px 240px at 90% 0%, rgba(255,122,0,.14), transparent 60%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,0)),
    rgba(0,0,0,.28);
  border: 1px solid rgba(255,255,255,.12);
}
.lf-eventpromo-sheen{
  position:absolute;
  inset:-2px;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.10) 0 1px, transparent 1px 11px),
    radial-gradient(260px 120px at 30% 0%, rgba(0,230,118,.22), transparent 60%),
    radial-gradient(260px 120px at 70% 0%, rgba(255,122,0,.18), transparent 60%);
  opacity:.25;
  mix-blend-mode: overlay;
}
.lf-eventpromo-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:8px 12px;
  border-radius: 999px;
  font-weight:800;
  letter-spacing:.6px;
  font-size:12px;
  background: linear-gradient(90deg, rgba(0,230,118,.35), rgba(255,122,0,.35));
  border: 1px solid rgba(255,255,255,.16);
  text-transform: uppercase;
}
.lf-eventpromo-title{
  margin: 12px 0 0;
  font-size: 28px;
  line-height: 1.12;
  letter-spacing: -0.3px;
}
.lf-eventpromo-desc{
  margin: 10px 0 0;
  color: rgba(255,255,255,.85);
  max-width: 65ch;
}
.lf-eventpromo-meta{
  display:flex;
  flex-wrap: wrap;
  gap: 10px 14px;
  margin: 14px 0 0;
}
.lf-meta-item{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 14px;
  background: rgba(0,0,0,.25);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.92);
  font-size: 14px;
}
.lf-eventpromo-actions{
  display:flex;
  flex-wrap: wrap;
  gap: 10px;
  margin-top: 16px;
}
.lf-events-grid{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 12px;
}

.lf-unboxing{ margin-top: 18px; }
.lf-unboxing-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.lf-unboxing-card{
  overflow:hidden;
  padding: 0;
}
.lf-unboxing-thumb{
  display:block;
  aspect-ratio: 16/9;
  background: rgba(0,0,0,.25);
  border-bottom: 1px solid rgba(255,255,255,.10);
}
.lf-unboxing-thumb img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.lf-unboxing-body{
  padding: 14px;
}
.lf-unboxing-title{
  margin: 8px 0 0;
  font-size: 16px;
  line-height: 1.25;
}
@media (max-width: 980px){
  .nvn-grid{grid-template-columns: 1fr;}
  .lf-eventpromo-inner{grid-template-columns: 1fr; }
  .lf-unboxing-grid{grid-template-columns: 1fr;}
}
@media (min-width: 981px) and (max-width: 1200px){
  .lf-unboxing-grid{grid-template-columns: repeat(2, 1fr);}
}


/* =========================
   HERO SIDE (Últimas + Evento + Más leídas)
========================= */
.lf-hero-side{
  display:flex;
  flex-direction:column;
  gap: var(--nvn-gap);
}
.lf-hero-side .nvn-card{margin:0}
.lf-hero-side .nvn-hero-list{padding: 16px}
.lf-hero-side .nvn-section-title h2{font-size: 18px}
.lf-hero-side .nvn-section-title .nvn-pill{font-size: 12px}

/* Evento compacto */
.lf-eventpromo--compact{
  position:relative;
  overflow:hidden;
  padding: 16px;
  border: 1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(520px 260px at 0% 0%, rgba(0,230,118,.14), transparent 62%),
    radial-gradient(520px 260px at 100% 0%, rgba(255,122,0,.12), transparent 62%),
    rgba(0,0,0,.28);
}
.lf-eventpromo--compact .lf-eventpromo-bg{
  opacity:.22;
  filter: blur(10px) saturate(1.12) contrast(1.08);
}
.lf-eventpromo-compact{
  position:relative;
  z-index:1;
}
.lf-eventpromo--compact .lf-eventpromo-title{
  margin: 10px 0 0;
  font-size: 18px;
  line-height: 1.2;
}
.lf-eventpromo--compact .lf-eventpromo-desc{
  margin: 10px 0 0;
  font-size: 14px;
  color: rgba(255,255,255,.86);
}
.lf-eventpromo--compact .lf-eventpromo-meta{
  margin: 10px 0 0;
}
.lf-eventpromo--compact .lf-meta-item{
  padding: 7px 10px;
  border-radius: 14px;
  font-size: 13px;
}
.lf-eventpromo-mini-list{
  margin: 10px 0 0;
  padding-left: 18px;
}
.lf-eventpromo-mini-list li{margin: 6px 0}
.lf-eventpromo-mini-list a{
  color: rgba(255,255,255,.92);
  text-decoration: none;
}
.lf-eventpromo-mini-list a:hover{ text-decoration: underline; }

/* Más leídas compacto (estilo ranking) */
.lf-mostread--compact ol{
  margin: 0;
  padding: 0;
  list-style: none;
  counter-reset: lf_mr;
}
.lf-mostread--compact li{
  counter-increment: lf_mr;
  position: relative;
  padding: 10px 10px 10px 44px;
  border-radius: 14px;
  background: rgba(0,0,0,.18);
  border: 1px solid rgba(255,255,255,.10);
  margin: 8px 0;
}
.lf-mostread--compact li::before{
  content: counter(lf_mr);
  position:absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-weight: 900;
  font-size: 12px;
  background: linear-gradient(90deg, rgba(0,230,118,.55), rgba(255,122,0,.55));
  color: rgba(0,0,0,.9);
}
.lf-mostread--compact a{
  color: rgba(255,255,255,.95);
  text-decoration: none;
}
.lf-mostread--compact a:hover{ text-decoration: underline; }

/* Secciones premium */
.lf-section{
  padding: 16px;
  margin-top: 14px;
  border: 1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(700px 280px at 10% 0%, rgba(0,230,118,.10), transparent 60%),
    radial-gradient(700px 280px at 90% 0%, rgba(255,122,0,.09), transparent 60%),
    rgba(0,0,0,.18);
}
.lf-section .nvn-section-title{margin-top: 0}
.lf-section:hover{
  transform: translateY(-1px);
  transition: transform .15s ease;
}

/* Unboxing dentro de sección premium */
.lf-unboxing.lf-section{overflow:hidden}
.lf-unboxing.lf-section .lf-unboxing-grid{margin-top: 12px}


/* =========================
   TRIO PRINCIPAL (FULL WIDTH)
   Últimas + Evento + Más leídas (mismo ancho)
========================= */
.lf-home-trio{
  position:relative;
  margin-top: 16px;
}
.lf-home-trio::before{
  content:"";
  position:absolute;
  inset:-10px;
  border-radius: 22px;
  background:
    radial-gradient(520px 220px at 10% 0%, rgba(0,230,118,.08), transparent 60%),
    radial-gradient(520px 220px at 90% 0%, rgba(255,122,0,.07), transparent 60%),
    repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 1px, transparent 1px 13px);
  opacity:.22;
  pointer-events:none;
}
.lf-home-trio-grid{
  position:relative;
  display:grid;
  grid-template-columns: 1fr;
  gap: var(--nvn-gap);
  align-items: stretch;
}
.lf-home-trio-col{
  min-width:0;
}
.lf-home-trio-col > .nvn-card,
.lf-home-trio-col > section.nvn-card{
  height: auto;
  display:flex;
  flex-direction: column;
}
.lf-home-latest .nvn-item:last-child{
  margin-bottom:0;
}
.lf-home-latest{
  overflow:hidden;
}


/* Ajuste: Trio en columna (uno arriba de otro) */
.lf-home-trio-col + .lf-home-trio-col{
  margin-top: 0;
}


/* =========================
   LATEST LIST (miniatura + titulo)
========================= */
.lf-home-latest .nvn-item{
  display:flex;
  gap: 12px;
  align-items:center;
  padding: 12px 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.lf-home-latest .nvn-item:last-child{border-bottom:0}
.lf-home-latest .nvn-mini{
  width: 78px;
  height: 78px;
  flex: 0 0 78px;
  border-radius: 16px;
  overflow:hidden;
  background: rgba(0,0,0,.22);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 26px rgba(0,0,0,.25);
}
.lf-home-latest .nvn-mini img{
  width:100%;
  height:100%;
  object-fit: cover;
  display:block;
}
.lf-home-latest .lf-latest-text{min-width:0}
.lf-home-latest h3{
  margin: 0;
  font-size: 14px;
  line-height: 1.25;
}
.lf-home-latest h3 a{
  color: rgba(255,255,255,.96);
  text-decoration:none;
}
.lf-home-latest h3 a:hover{text-decoration: underline;}
.lf-home-latest .nvn-small{
  font-size: 12px;
  color: var(--nvn-muted);
  margin-top: 6px;
}

/* MOBILE NAV POLISH */


/* DROPDOWN POLISH */
.nvn-nav .sub-menu{
  box-shadow: 0 22px 50px rgba(0,0,0,.40);
}
.nvn-nav .sub-menu a{
  border: 1px solid transparent;
}
.nvn-nav .sub-menu a:hover{
  border-color: rgba(0,230,118,.25);
  background: rgba(255,255,255,.07);
}


/* NAV CONTAINER OVERRIDES */
.nvn-header .nvn-nav{
  background: transparent !important;
  border-bottom: 0 !important;
  backdrop-filter: none !important;
}


/* =========================
   TV PRO (Videos/Directos)
========================= */
.nvn-tv-wrap.lf-tv-pro{
  position:relative;
  background:
    radial-gradient(900px 320px at 20% 0%, rgba(0,230,118,.12), transparent 60%),
    radial-gradient(900px 320px at 80% 0%, rgba(255,122,0,.12), transparent 60%),
    rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.12);
}
.nvn-tv-wrap.lf-tv-pro::before{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  pointer-events:none;
  background:
    linear-gradient(90deg, rgba(255,122,0,.20), rgba(0,230,118,.18));
  opacity:.20;
}
.nvn-tv-wrap.lf-tv-pro::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius: inherit;
  pointer-events:none;
  background:
    repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 1px, transparent 1px 14px);
  opacity:.10;
}
.nvn-tv-grid{
  grid-template-columns: 1.65fr 1fr;
}
.nvn-tv-player{
  position:relative;
}
.lf-tv-screen{
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background: #000;
  box-shadow: 0 30px 60px rgba(0,0,0,.38);
}
.lf-tv-screen .nvn-tv-embed{
  border:0;
  border-radius:0;
}
.lf-tv-overlay{
  position:absolute;
  inset:0;
  pointer-events:none;
  background:
    radial-gradient(900px 420px at 50% 0%, rgba(255,255,255,.08), transparent 55%),
    radial-gradient(720px 380px at 0% 100%, rgba(0,230,118,.10), transparent 55%),
    radial-gradient(720px 380px at 100% 100%, rgba(255,122,0,.10), transparent 55%),
    repeating-linear-gradient(0deg, rgba(255,255,255,.05) 0 1px, transparent 1px 4px);
  mix-blend-mode: overlay;
  opacity:.18;
}
.lf-tv-badges{
  position:absolute;
  left: 12px;
  top: 12px;
  display:flex;
  gap: 8px;
  align-items:center;
  z-index: 2;
}
.lf-tv-badge{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .4px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(12px);
}
.lf-tv-badge--live{
  border-color: rgba(255,72,72,.35);
  background: linear-gradient(90deg, rgba(255,72,72,.30), rgba(255,122,0,.18));
}
.lf-tv-badge--live::before{
  content:"";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,72,72,.95);
  box-shadow: 0 0 0 4px rgba(255,72,72,.18);
  animation: lfPulse 1.2s infinite ease-in-out;
}
.lf-tv-badge--video{
  border-color: rgba(0,230,118,.28);
  background: linear-gradient(90deg, rgba(0,230,118,.20), rgba(255,255,255,.06));
}
.lf-tv-badge--video::before{
  content:"▶";
  font-size: 11px;
  opacity:.9;
}
.lf-tv-badge--plat{
  border-color: rgba(255,255,255,.12);
  background: rgba(0,0,0,.35);
}

@keyframes lfPulse{
  0%{transform: scale(0.95); opacity:.85}
  50%{transform: scale(1.15); opacity:1}
  100%{transform: scale(0.95); opacity:.85}
}

.lf-tv-list-head{
  display:flex;
  justify-content:space-between;
  align-items:center;
  padding: 10px 12px;
  border-bottom: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.16);
}
.lf-tv-list-title{
  font-weight: 950;
  letter-spacing: .3px;
}
.lf-tv-list-hint{
  font-size: 12px;
  color: var(--nvn-muted);
}
.lf-tv-list-items{
  max-height: 520px;
  overflow:auto;
}
.lf-tv-list-items::-webkit-scrollbar{width:10px}
.lf-tv-list-items::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:999px}
.lf-tv-list-items::-webkit-scrollbar-track{background:rgba(0,0,0,.10)}

.nvn-tv-item{
  align-items:center;
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.nvn-tv-item:hover{
  background: rgba(255,255,255,.05);
  transform: translateY(-1px);
}
.nvn-tv-item.is-active{
  background:
    linear-gradient(90deg, rgba(0,230,118,.12), rgba(255,122,0,.10));
  border-left: 3px solid rgba(0,230,118,.55);
}
.nvn-tv-mini{
  position:relative;
  box-shadow: 0 18px 34px rgba(0,0,0,.30);
}
.lf-tv-play{
  position:absolute;
  right: 8px;
  bottom: 8px;
  width: 26px;
  height: 26px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 12px;
  font-weight: 950;
  color: rgba(255,255,255,.95);
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
}
.lf-tv-live{
  position:absolute;
  left: 8px;
  top: 8px;
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(255,72,72,.95);
  box-shadow: 0 0 0 4px rgba(255,72,72,.18);
  animation: lfPulse 1.2s infinite ease-in-out;
}
.nvn-tv-item-text{min-width:0}
.lf-tv-item-meta{
  display:flex;
  gap: 8px;
  flex-wrap:wrap;
  margin-top: 6px;
}
.lf-tv-tag{
  display:inline-flex;
  align-items:center;
  padding: 4px 8px;
  border-radius: 999px;
  font-weight: 950;
  font-size: 11px;
  letter-spacing: .3px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.04);
  color: rgba(255,255,255,.90);
}
.lf-tv-tag--live{
  border-color: rgba(255,72,72,.28);
  background: rgba(255,72,72,.16);
}
.lf-tv-tag--video{
  border-color: rgba(0,230,118,.22);
  background: rgba(0,230,118,.10);
}

@media (max-width: 980px){
  .lf-tv-list-items{max-height: 360px;}
}


/* =========================
   LIVE PRO (Directos)
========================= */
.nvn-live.lf-live-pro{
  position:relative;
  padding: 14px;
  border-radius: var(--lf-radius-xl);
  border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(820px 280px at 12% 0%, rgba(255,122,0,.10), transparent 60%),
    radial-gradient(820px 280px at 88% 0%, rgba(0,230,118,.10), transparent 60%),
    rgba(255,255,255,.02);
  box-shadow: var(--lf-shadow);
  overflow:hidden;
}
.nvn-live.lf-live-pro::after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background: repeating-linear-gradient(135deg, rgba(255,255,255,.06) 0 1px, transparent 1px 16px);
  opacity:.10;
}
.nvn-live.lf-live-pro .nvn-live-header{
  margin-bottom: 12px;
}
.nvn-live.lf-live-pro .nvn-live-pill{
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.16);
  background: linear-gradient(90deg, rgba(255,122,0,.22), rgba(0,230,118,.18));
  box-shadow: 0 14px 28px rgba(0,0,0,.22);
}
.nvn-live-grid{
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--nvn-gap);
  position:relative;
  z-index: 1;
}
@media (max-width: 980px){
  .nvn-live-grid{grid-template-columns: 1fr;}
}
.nvn-live-card{
  position:relative;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.18);
  overflow:hidden;
  box-shadow: 0 24px 50px rgba(0,0,0,.30);
}
.nvn-live-top{
  position:absolute;
  left: 10px;
  top: 10px;
  display:flex;
  gap: 8px;
  z-index: 2;
}
.nvn-live-badge{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 6px 10px;
  border-radius: 999px;
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .4px;
  border: 1px solid rgba(255,72,72,.35);
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(12px);
}
.nvn-live-badge::before{
  content:"";
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: rgba(255,72,72,.95);
  box-shadow: 0 0 0 4px rgba(255,72,72,.18);
  animation: lfPulse 1.2s infinite ease-in-out;
}
.nvn-live-platform{
  display:inline-flex;
  align-items:center;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.35);
  font-weight: 950;
  font-size: 12px;
  letter-spacing: .35px;
}
.nvn-live-embed{
  background:#000;
}
.nvn-live-embed iframe,
.nvn-live-embed video,
.nvn-live-embed embed,
.nvn-live-embed object{
  width:100%;
  border:0;
  aspect-ratio:16/9;
  display:block;
}
.nvn-live-meta{
  padding: 12px 12px 14px;
  border-top: 1px solid rgba(255,255,255,.10);
  background:
    linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.22));
}
.nvn-live-meta a{
  font-weight: 950;
  text-decoration:none;
}
.nvn-live-meta a:hover{text-decoration: underline;}


/* =========================
   FEATURED PRO (Destacados en portada)
========================= */
.lf-featured-wrap{
  margin-top: 16px;
}
.lf-featured-grid{
  display:grid;
  grid-template-columns: 1.65fr 1fr;
  gap: var(--nvn-gap);
  position:relative;
  z-index:1;
}
.lf-featured-main{
  display:flex;
  flex-direction:column;
  gap: 12px;
  min-width:0;
}
.lf-featured-screen{
  position:relative;
  border-radius: 18px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(900px 420px at 50% 0%, rgba(255,255,255,.08), transparent 55%),
    rgba(0,0,0,.55);
  box-shadow: 0 30px 60px rgba(0,0,0,.38);
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
}
.lf-featured-screen.is-empty{
  background-image:none !important;
}
.lf-featured-screen::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.0), rgba(0,0,0,.62));
  pointer-events:none;
}
.lf-featured-meta{
  padding: 4px 2px 0;
}
.lf-featured-kicker{
  display:flex;
  align-items:center;
  gap: 8px;
  color: var(--nvn-muted);
  font-size: 12px;
}
.lf-featured-title{
  margin: 8px 0 8px;
  font-size: 22px;
  line-height: 1.15;
}
.lf-featured-title a{
  color: rgba(255,255,255,.98);
  text-decoration:none;
}
.lf-featured-title a:hover{
  text-decoration: underline;
}
.lf-featured-excerpt{
  margin: 0;
  color: rgba(255,255,255,.82);
  font-size: 14px;
  line-height: 1.55;
}
.lf-featured-actions{
  margin-top: 12px;
}
.lf-featured-list{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.14);
  overflow:hidden;
}
.lf-featured-item{
  display:flex;
  gap: 12px;
  align-items:center;
  padding: 12px;
  cursor:pointer;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(255,255,255,.00);
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.lf-featured-item:last-child{border-bottom:0}
.lf-featured-item:hover{
  background: rgba(255,255,255,.05);
  transform: translateY(-1px);
}
.lf-featured-item.is-active{
  background: linear-gradient(90deg, rgba(0,230,118,.12), rgba(255,122,0,.10));
  border-left: 3px solid rgba(255,122,0,.55);
}
.lf-featured-item .nvn-tv-mini{
  width: 84px;
  height: 60px;
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.12);
  flex: 0 0 84px;
  position:relative;
  background: rgba(0,0,0,.22);
}
.lf-featured-item .nvn-tv-mini img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.lf-featured-item .lf-tv-play{
  right: 8px;
  bottom: 8px;
}
@media (max-width: 980px){
  .lf-featured-grid{grid-template-columns: 1fr;}
  .lf-featured-title{font-size: 18px;}
}


/* =========================
   ARTICLE SIDEBAR PRO (solo en single)
========================= */
.lf-article-sidebar{
  position: sticky;
  top: 16px;
}
.lf-sb-widget + .lf-sb-widget{
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,.10);
}
.lf-sb-widget h3{
  margin: 0 0 10px;
  font-size: 14px;
  letter-spacing: .4px;
  text-transform: uppercase;
  font-weight: 950;
  display:flex;
  align-items:center;
  gap: 10px;
}
.lf-sb-widget h3::before{
  content:"";
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(255,122,0,.95), rgba(0,230,118,.95));
  box-shadow: 0 0 0 4px rgba(255,255,255,.06);
}
.lf-sb-sub{
  margin: 12px 0 8px;
  font-size: 13px;
  font-weight: 950;
  letter-spacing: .2px;
  opacity: .95;
}
.lf-sb-list{
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.lf-sb-item{
  display:flex;
  gap: 10px;
  align-items:center;
  text-decoration:none;
  padding: 8px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  transition: transform .12s ease, background .12s ease, border-color .12s ease;
}
.lf-sb-item:hover{
  background: rgba(255,255,255,.06);
  transform: translateY(-1px);
  border-color: rgba(255,255,255,.18);
}
.lf-sb-thumb{
  width: 76px;
  height: 54px;
  flex: 0 0 76px;
  border-radius: 14px;
  overflow:hidden;
  border: 1px solid rgba(255,255,255,.12);
  position:relative;
  background: rgba(0,0,0,.18);
}
.lf-sb-thumb img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block;
}
.lf-sb-ic{
  position:absolute;
  right: 6px;
  bottom: 6px;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display:flex;
  align-items:center;
  justify-content:center;
  font-size: 12px;
  font-weight: 950;
  color: rgba(255,255,255,.95);
  background: rgba(0,0,0,.55);
  border: 1px solid rgba(255,255,255,.14);
  backdrop-filter: blur(10px);
}
.lf-sb-text{min-width:0; display:flex; flex-direction:column; gap:6px;}
.lf-sb-title{
  display:block;
  font-weight: 950;
  font-size: 13px;
  line-height: 1.15;
  color: rgba(255,255,255,.96);
}
.lf-sb-meta{
  font-size: 11px;
  color: var(--nvn-muted);
  letter-spacing: .2px;
}
.lf-sb-empty{
  padding: 10px 12px;
  border-radius: 14px;
  border: 1px dashed rgba(255,255,255,.16);
  color: var(--nvn-muted);
}
.lf-sb-cats ul{
  list-style:none;
  padding:0;
  margin:0;
  display:flex;
  flex-direction:column;
  gap: 6px;
}
.lf-sb-cats a{
  display:flex;
  justify-content:space-between;
  gap:10px;
  text-decoration:none;
  padding: 8px 10px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.02);
}
.lf-sb-cats a:hover{
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
}
@media (max-width: 980px){
  .lf-article-sidebar{position: static; top:auto;}
}


/* HEADER OVERFLOW FIX */
.nvn-header, .nvn-header .nvn-container, .nvn-header .nvn-brandrow{ overflow: visible; }
