/* ==================================================
   FRONT-BASE.CSS
   Tipo: Base global
   Ámbito: Todas las páginas (se carga siempre)
   Define: Design tokens (:root), reset, tipografía
           transversal (títulos, subtítulos, autor),
           clases de imagen (.lavoz-img, .lavoz-card-link)
   Depende de: style.css (cabecera WordPress)
   ================================================== */

/* --------------------------------------------------
   1.1 Design Tokens
   -------------------------------------------------- */
:root {
    /* Tipografía — Familias */
    --lavoz-font-heading: 'Playfair Display', serif;
    --lavoz-font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;

    /* Tipografía — Títulos */
    --lavoz-title-size: clamp(1.1rem, 2vw, 1.5rem);
    --lavoz-title-size-lg: clamp(2rem, 4vw, 3.5rem);
    --lavoz-title-weight: 400;
    --lavoz-title-lh: 1;
    --lavoz-title-color: #1a1a1a;
    --lavoz-title-mb: 3px;

    /* Tipografía — Subtítulos */
    --lavoz-subtitle-size: clamp(1rem, 1.5vw, 1.2rem);
    --lavoz-subtitle-weight: 400;
    --lavoz-subtitle-lh: 1.5;
    --lavoz-subtitle-color: #444;

    /* Tipografía — Texto */
    --lavoz-color-meta: #666;
    --lavoz-color-muted: #999;
    --lavoz-color-text-light: #555;
    --lavoz-lh-base: 1.6;
    --lavoz-lh-body: 1.5;
    --lavoz-lh-heading: 1.2;

    /* Colores */
    --lavoz-color-bg: #ffffff;
    --lavoz-color-bg-light: #f3f3f3;
    --lavoz-color-text: #1a1a1a;
    --lavoz-color-accent: #0f5274;
    --lavoz-color-accent-hover: #1a3f5a;
    --lavoz-color-border: #e0e0e0;
    --lavoz-color-border-light: #eee;
    --lavoz-color-border-dark: #aaa;

    /* Espaciado uniforme */
    --lavoz-card-gap: 20px;
    --lavoz-titulo-margin-top: 10px;
    --lavoz-content-pad: 15px;
    --lavoz-gap-xs: 10px;
    --lavoz-gap-sm: 15px;
    --lavoz-gap-md: 20px;
    --lavoz-gap-lg: 30px;
    --lavoz-gap-xl: 40px;

    /* Imágenes */
    --lavoz-img-radius: 6px;
    --lavoz-img-ratio-landscape: 16 / 9;
    --lavoz-img-ratio-portrait: 9 / 16;
    --lavoz-img-ratio-cierre: 9 / 12;
    --lavoz-img-transition: transform 0.6s ease;
    --lavoz-img-hover-scale: scale(1.05);

    /* Overlay / Sombras */
    --lavoz-overlay-bg: rgba(0, 0, 0, 0.75);
    --lavoz-video-caption-bg: #222;
    --lavoz-shadow-card: 0 8px 20px rgba(0, 0, 0, 0.12);
}

/* --------------------------------------------------
   1.2 Fuentes
   -------------------------------------------------- */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600&display=swap');

/* --------------------------------------------------
   1.3 Reset
   -------------------------------------------------- */
* {
    margin: 0;
    padding: 0;
    box-sizing: border-box;
}

body {
    font-family: var(--lavoz-font-body);
    background: var(--lavoz-color-bg);
    color: var(--lavoz-color-text);
    line-height: var(--lavoz-lh-base);
}

/* --------------------------------------------------
   1.4 Títulos — Transversal
   Todos: Playfair Display, peso variable según token --lavoz-title-weight.
   -------------------------------------------------- */
.lavoz-portada-titulo,
.lavoz-apertura1-titulo,
.lavoz-apertura1-titulo-sec,
.lavoz-apertura2-titulo,
.lavoz-apertura2-titulo-sec,
.lavoz-apertura3-titulo,
.lavoz-apertura3-titulo-sec,
.lavoz-destacada1-titulo,
.lavoz-destacada1-titulo-principal,
.lavoz-destacada2-titulo,
.lavoz-destacada2-titulo-solapada,
.lavoz-destacada2-titulo-lista,
.lavoz-mosaico-titulo,
.lavoz-mosaico-titulo-destacada,
.lavoz-friso-titulo,
.lavoz-cierre-titulo,
.lavoz-barralateral-titulo {
    margin-top: var(--lavoz-titulo-margin-top);
}

/* Títulos que van ANTES de la imagen (sin imagen encima) → margin-top 0 */
.lavoz-apertura1-principal .lavoz-apertura1-titulo,
.lavoz-apertura2-principal .lavoz-apertura2-titulo,
.lavoz-apertura3-principal .lavoz-apertura3-titulo,
.lavoz-destacada1-titulo-principal,
.lavoz-destacada2-titulo-solapada {
    margin-top: 0;
}

/* Font, tamaño y estilos compartidos de todos los títulos */
.lavoz-portada-titulo,
.lavoz-apertura1-titulo,
.lavoz-apertura1-titulo-sec,
.lavoz-apertura2-titulo,
.lavoz-apertura2-titulo-sec,
.lavoz-apertura3-titulo,
.lavoz-apertura3-titulo-sec,
.lavoz-destacada1-titulo,
.lavoz-destacada1-titulo-principal,
.lavoz-destacada2-titulo,
.lavoz-destacada2-titulo-solapada,
.lavoz-destacada2-titulo-lista,
.lavoz-mosaico-titulo,
.lavoz-mosaico-titulo-destacada,
.lavoz-friso-titulo,
.lavoz-cierre-titulo,
.lavoz-barralateral-titulo,
.lavoz-video-lateral-caption,
.lavoz-post-titulo,
.lavoz-otras-noticias-titulo,
.lavoz-sidebar-titulo,
.lavoz-sidebar-noticia-titulo,
.lavoz-otra-noticia-titulo {
    font-family: var(--lavoz-font-heading);
    font-size: var(--lavoz-title-size);
    font-weight: var(--lavoz-title-weight);
    line-height: var(--lavoz-title-lh);
    color: var(--lavoz-title-color);
    margin-bottom: var(--lavoz-title-mb);
    padding: 0 var(--lavoz-gap-xs);
}
/* Ningún título lleva underline en hover — NUNCA */
[class*="titulo"]:hover,
a:hover [class*="titulo"] {
    text-decoration: none !important;
}

/* Caption vídeo lateral — enlace hereda estilo del texto */
.lavoz-video-lateral-caption a {
    font-family: var(--lavoz-font-heading);
    font-size: 19px;
    font-weight: var(--lavoz-title-weight);
    line-height: var(--lavoz-title-lh);
    color: var(--lavoz-title-color);
    text-decoration: none;
    cursor: pointer;
}

/* --------------------------------------------------
   1.5 Subtítulos — Transversal
   Todos: fuente body (Inter).
   Todos: Inter. Sin excepciones de fuente.
   -------------------------------------------------- */
.lavoz-apertura1-subtitulo,
.lavoz-apertura2-subtitulo,
.lavoz-apertura3-subtitulo,
.lavoz-destacada1-subtitulo,
.lavoz-destacada2-subtitulo,
.lavoz-mosaico-subtitulo,
.lavoz-post-subtitulo {
    font-family: var(--lavoz-font-body);
    font-size: var(--lavoz-subtitle-size);
    font-weight: var(--lavoz-subtitle-weight);
    line-height: var(--lavoz-subtitle-lh);
    color: var(--lavoz-subtitle-color);
    margin: 0;
    padding: 0 var(--lavoz-gap-xs);
}

/* --------------------------------------------------
   1.5b Autor — Transversal
   -------------------------------------------------- */
.lavoz-autor {
    font-family: var(--lavoz-font-body);
    font-size: 0.85rem;
    font-weight: 400;
    color: var(--lavoz-color-meta);
    margin: 0;
    padding: 0 var(--lavoz-gap-xs);
    display: block;
    text-align: left;
}

/* --------------------------------------------------
   1.6 Card Links — Transversal
   -------------------------------------------------- */
.lavoz-card-link {
    text-decoration: none;
    color: inherit;
    display: block;
    height: 100%;
    position: relative;
    overflow: hidden;
}

.lavoz-card-link:hover {
    text-decoration: none;
}

.lavoz-card-link:hover .lavoz-img {
    transform: var(--lavoz-img-hover-scale);
}

.lavoz-img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: var(--lavoz-img-transition);
    display: block;
}

/* --------------------------------------------------
   1.7 Contenedores de Imagen — Transversal
   -------------------------------------------------- */
.lavoz-apertura1-imagen,
.lavoz-apertura2-imagen,
.lavoz-apertura3-imagen,
.lavoz-destacada1-imagen,
.lavoz-destacada1-imagen-principal,
.lavoz-destacada2-imagen,
.lavoz-destacada2-imagen-solapada,
.lavoz-mosaico-imagen,
.lavoz-mosaico-imagen-destacada,
.lavoz-barralateral-imagen,
.lavoz-friso-imagen {
    width: 100%;
    height: auto;
    aspect-ratio: var(--lavoz-img-ratio-landscape);
    position: relative;
    overflow: hidden;
    border-radius: var(--lavoz-img-radius);
    border: 1px solid var(--lavoz-color-border-light);
}

/* --------------------------------------------------
   1.8 Ocultación de Subtítulos en Portada
   -------------------------------------------------- */




a {
    color: inherit;
    text-decoration: none;
}

img {
    max-width: 100%;
    height: auto;
}

/* Contenedor genérico de ancho máximo */
.lavoz-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 0 20px;
}

/* Wrapper del contenido principal de cada página */
.lavoz-main-content {
    min-height: 60vh;
    padding: var(--lavoz-gap-lg) 0 0;
}

/* --------------------------------------------------
   Publicidad — común a todas las páginas
   -------------------------------------------------- */
.lavoz-publicidad {
    display: block;
    text-align: center;
}

.lavoz-publicidad-label {
    font-family: var(--lavoz-font-body);
    font-size: 0.68rem;
    font-weight: 400;
    color: #bbb;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    margin: 0;
    padding: 0 0 2px 0;
    text-align: center;
    display: block;
}

.lavoz-publicidad img {
    display: block;
    margin: 0 auto;
    width: 100%;
    height: auto;
    border: 1px solid var(--lavoz-color-border-light);
    border-radius: 2px;
}

.lavoz-publicidad-vertical img {
    max-width: 300px;
}

.lavoz-publicidad-horizontal img {
    max-width: 100%;
}

/* --------------------------------------------------
   Mobile — títulos sin margin-top
   -------------------------------------------------- */
@media (max-width: 480px) {
    h1, h2, h3, h4,
    .lavoz-apertura1-titulo, .lavoz-apertura1-titulo-sec,
    .lavoz-apertura2-titulo,
    .lavoz-apertura3-titulo,
    .lavoz-destacada1-titulo, .lavoz-destacada1-titulo-principal,
    .lavoz-destacada2-titulo, .lavoz-destacada2-titulo-solapada, .lavoz-destacada2-titulo-lista,
    .lavoz-mosaico-titulo, .lavoz-mosaico-titulo-destacada,
    .lavoz-friso-titulo,
    .lavoz-cierre-titulo,
    .lavoz-barralateral-titulo {
        margin-top: 0;
    }
}
