/* ═══════════════════════════════════════════════════════════
   DUA NETZERO BLOG — main.css
   Fiel al diseño Figma: verde corporativo + cards editoriales
   ═══════════════════════════════════════════════════════════ */

/* ─── VARIABLES ─────────────────────────────────────────── */
@font-face {
    font-family: 'Proxima Nova';
    src: url('../fonts/proxima nova/Mark Simonson - Proxima Nova Regular.otf') format('opentype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Proxima Nova';
    src: url('../fonts/proxima nova/Mark Simonson - Proxima Nova Semibold.otf') format('opentype');
    font-weight: 600;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Proxima Nova';
    src: url('../fonts/proxima nova/Mark Simonson - Proxima Nova Bold.otf') format('opentype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {
    /* Colores Personalizados */
    --green-dark:    #091717; /* Texto oscuro / Color base */
    --green-mid:     #122a2a; /* Variación para hovers */
    --green-accent:  #98C836; /* Resaltado */
    --green-light:   #f4f8e6; /* Fondo muy claro basado en el acento */
    --white:         #FFFFFF;
    --gray-50:       #F8F9F5;
    --gray-100:      #E9ECE5;
    --gray-200:      #C2CDBA; /* Gris principal */
    --gray-400:      #9AA692; /* Gris medio */
    --gray-600:      #5C6658; /* Gris oscuro */
    --gray-900:      #091717; /* Texto normal */

    /* Tipografía */
    --font-sans:  'Proxima Nova', sans-serif;
    --font-serif: 'Proxima Nova', serif;

    /* Layout */
    --container-max:  1240px;
    --container-pad:  clamp(16px, 4vw, 40px);
    --radius-sm:      6px;
    --radius-md:      10px;
    --radius-lg:      16px;
    --radius-xl:      20px;

    /* Sombras */
    --shadow-card: 0 1px 3px rgba(0,0,0,.06), 0 4px 16px rgba(0,0,0,.06);
    --shadow-card-hover: 0 4px 8px rgba(0,0,0,.08), 0 12px 32px rgba(0,0,0,.10);

    /* Transiciones */
    --ease: cubic-bezier(.25,.46,.45,.94);
    --transition: 220ms var(--ease);
}

/* ─── RESET / BASE ──────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { font-size: 16px; scroll-behavior: smooth; height: 100%; }

body {
    font-family: var(--font-sans);
    color: var(--gray-900);
    background: var(--white);
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    min-height: 100vh;
}

img, svg { display: block; max-width: 100%; height: auto; }

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

ul, ol { list-style: none; }

/* ─── CONTAINER ─────────────────────────────────────────── */
.site{
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
}
.site-main {
    max-width: var(--container-max);
    margin-inline: auto;
}
.site-content{
    padding:30px 0px;
}

.container {
    width: 100%;
    max-width: var(--container-max);
    margin-inline: auto;
    padding-inline: var(--container-pad);
}

.container--narrow {
    max-width: 820px;
}

/* ─── BOTONES ───────────────────────────────────────────── */
.btn, .comment-form .submit {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 9.6px 20px;
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    cursor: pointer;
    transition: background var(--transition), color var(--transition), border-color var(--transition);
    border: 1.5px solid transparent;
    white-space: nowrap;
}

.btn--primary, .comment-form .submit {
    background: var(--green-accent);
    color: var(--green-dark);
    border-color: var(--green-accent);
}
.btn--primary:hover, .comment-form .submit:hover { background: #6cb535; border-color: #6cb535; }

.btn--outline {
    background: transparent;
    color: var(--green-accent);
    border-color: var(--green-accent);
}
.btn--outline:hover { background: var(--green-accent); color: var(--green-dark); }

/* ─── HEADER TOP ────────────────────────────────────────── */
.site-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: var(--white);
}

.site-header .container {
    padding-inline: 0;
}

.header-top {
    border-bottom: 1px solid var(--gray-200);
}

.header-top__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 24px;
    padding-block: 14px;
}

/* Logo */
.site-branding { flex-shrink: 0;  }
.site-branding img { height: 56px; width: auto; }
.site-branding__name {
    font-size: 20px;
    font-weight: 700;
    color: var(--green-dark);
}

/* Acciones top */
.header-top__actions {
    display: flex;
    align-items: center;
    gap: 24px;
    padding-right: 15px;
}

.header-action {
    font-size: 14px;
    color: var(--gray-600);
    display: flex;
    align-items: center;
    gap: 6px;
    transition: color var(--transition);
    background: none;
    border: none;
    cursor: pointer;
    font-family: var(--font-sans);
    padding: 0;
}
.header-action:hover { color: var(--green-dark); }

.header-action--search svg { flex-shrink: 0; }

/* ─── HEADER NAV (barra secundaria) ─────────────────────── */
.header-nav {
    border-bottom: 1px solid var(--gray-200);
}

.header-nav__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding-block: 8px;
}

/* Menú principal */
.primary-nav__list {
    display: flex;
    align-items: center;
    gap: 2px;
    flex-wrap: wrap;
    
}

.primary-nav__list li a {
    font-size: 14.4px;
    font-weight: 400;
    color: var(--gray-900);
    padding: 8px 14px;
    border-radius: var(--radius-sm);
    transition: background var(--transition), color var(--transition);
    display: block;
}
.primary-nav__list li a:hover,
.primary-nav__list li.current-menu-item > a { color: var(--green-dark); background: var(--gray-50); }

/* Link de acento (Suscribe) */
.primary-nav__list li.menu-highlight > a { color: var(--green-accent); font-weight: 500; }

/* Acciones derecha del nav */
.header-nav__right {
    display: flex;
    align-items: center;
    gap: 20px;
}

.nav-action {
    font-size: 14px;
    color: var(--gray-600);
    transition: color var(--transition);
}
.nav-action:hover { color: var(--green-dark); }
.nav-action--accent { color: var(--green-accent); font-weight: 500; }
.nav-action--accent:hover { color: var(--green-mid); }

/* ─── SEARCH BAR ────────────────────────────────────────── */
.search-bar {
    background: var(--gray-50);
    border-bottom: 1px solid var(--gray-200);
    max-height: 0;
    overflow: hidden;
    transition: max-height .3s var(--ease), padding .3s var(--ease);
}
.search-bar.is-open {
    max-height: 80px;
    padding-block: 12px;
}
.search-bar[aria-hidden="true"] { display: none; } /* fallback sin JS */

.search-form { display: flex; gap: 8px; }
.search-field {
    flex: 1;
    padding: 9.6px 16px;
    border: 1.5px solid var(--gray-200);
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: 14.4px;
    outline: none;
    transition: border-color var(--transition);
}
.search-field:focus { border-color: var(--green-accent); }
.search-submit {
    padding: 9.6px 20px;
    background: var(--green-dark);
    color: var(--white);
    border: none;
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: 14px;
    cursor: pointer;
    transition: background var(--transition);
}
.search-submit:hover { background: var(--green-mid); }

/* ─── HERO BANNER ───────────────────────────────────────── */
.first-word{
    color: var(--green-accent);
}
.hero-banner {
    position: relative;
    margin-block: 32px;
    border-radius: var(--radius-xl);
    overflow: hidden;
    height: 480px;
}

.hero-banner__link {
    display: flex;
    flex-direction: column;
    justify-content: center;
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    text-decoration: none;
    position: relative;
}

.hero-banner__overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to right,
        rgba(0, 0, 0, 0.8) 0%,
        rgba(0, 0, 0, 0.4) 60%,
        rgba(0, 0, 0, 0.2) 100%
    );
    z-index: 1;
}

.hero-banner__overlay::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0, 0, 0, 0.3);
    z-index: -1;
}

.hero-banner__content-wrapper {
    position: absolute;
    inset: 0;
    z-index: 10;
    display: flex;
    align-items: center;
    justify-content: flex-start;
    pointer-events: none;
}

.hero-banner__content {
    width: 100%;
    max-width: 1240px;
    margin-inline: auto;
    padding-inline: 40px;
    color: #FFFFFF;
    pointer-events: auto;
    text-align: left;
}

.hero-banner__content > * {
    max-width: 620px;
}

.hero-banner__title {
    font-size: 40px;
    font-weight: 400;
    line-height: 1.15;
    margin-block: 16px;
    color: #FFFFFF;
}

.hero-banner__excerpt {
    font-size: 16px;
    color: rgba(255, 255, 255, 0.9);
    line-height: 1.6;
}

/* Empty State */
.hero-empty {
    margin-block: 32px;
    background-color: #000000 !important;
    height: 300px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    border-radius: var(--radius-xl);
}

.hero-empty__content {
    width: 100%;
}

.hero-empty p {
    color: #FFFFFF !important;
    font-size: 24px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 2px;
    margin: 0;
}

/* ─── BLOG SECTION ──────────────────────────────────────── */
.blog-section {
    padding-block: 32px 64px;
}

/* ─── GRILLA DE POSTS ───────────────────────────────────── */
.posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 28px;
}

/* ─── POST CARD ─────────────────────────────────────────── */
.post-card {
    background: var(--white);
    border-radius: 20px;
    border: 1px solid var(--gray-200);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: box-shadow var(--transition), transform var(--transition);
}
.post-card:hover {
    box-shadow: var(--shadow-card-hover);
    transform: translateY(-3px);
}

.post-card__image-wrap {
    display: block;
    aspect-ratio: 3 / 2;
    overflow: hidden;
}
.post-card__image {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .5s var(--ease);
}
.post-card:hover .post-card__image { transform: scale(1.05); }

.post-card__body {
    padding: 20px 20px 16px;
    display: flex;
    flex-direction: column;
    gap: 12px;
    flex: 1;
}

.post-card__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--green-dark);
    line-height: 1.35;
}
.post-card__title a { transition: color var(--transition); }
.post-card__title a:hover { color: var(--green-accent); }

.post-card__excerpt {
    font-size: 14px;
    color: var(--gray-600);
    line-height: 1.6;
    flex: 1;
}

/* Footer de la card */
.post-card__footer {
    border-top: 1px solid var(--gray-100);
    padding-top: 12px;
    margin-top: 4px;
    display: flex;
    flex-direction: column;
    gap: 6.4px;
}

.post-card__author {
    font-size: 12.8px;
    color: var(--green-accent);
    font-weight: 500;
}

.post-card__meta {
    display: flex;
    align-items: center;
    gap: 9.6px;
    
}

.post-card__date {
    font-size: 12.48px;
    color: var(--gray-400);
}

/* ─── BADGES DE CATEGORÍA ───────────────────────────────── */
.badge {
    display: inline-block;
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 10px;
    font-weight: 500;
    line-height: 1;
    transition: opacity var(--transition);
    color: var(--green-accent) !important; /* Forzamos color verde */
}
.badge:hover { opacity: .85; }

/* Colores por slug de categoría (solo fondo ahora) */
.badge--tecnologia, .badge--technology   { background: #D6F0C1; }
.badge--normativo,  .badge--normativa    { background: #FFE7CC; }
.badge--liderazgo,  .badge--leadership   { background: #FFF3CC; }
.badge--sostenibilidad, .badge--sustainability { background: #CCF0E8; }
.badge--innovacion, .badge--innovation   { background: #E3DAFC; }
/* Fallback para cualquier otra categoría */
.badge { background: #f5faeb; }

/* ─── PAGINACIÓN ────────────────────────────────────────── */
.pagination-wrap {
    margin-top: 48px;
    display: flex;
    justify-content: center;
}
.nav-links {
    display: flex;
    align-items: center;
    gap: 6px;
}
.nav-links a,
.nav-links .current {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 36px;
    height: 36px;
    padding-inline: 10px;
    border-radius: var(--radius-sm);
    font-size: 14px;
    font-weight: 500;
    border: 1.5px solid var(--gray-200);
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}
.nav-links a:hover { background: var(--gray-50); border-color: var(--gray-400); }
.nav-links .current { background: var(--green-dark); color: var(--white); border-color: var(--green-dark); }
.nav-links .prev, .nav-links .next { font-size: 12.8px; color: var(--gray-600); }

/* ─── SINGLE POST ───────────────────────────────────────── */

.single-post__header { margin-bottom: 32px; }

.single-post__meta-top {
    display: flex;
    align-items: center;
    gap: 12px;
    margin-bottom: 16px;
}

.single-post__date { font-size: 13.6px; color: var(--gray-400); }

.single-post__title {
    font-size: clamp(28px, 4vw, 40px);
    font-weight: 700;
    color: var(--green-dark);
    line-height: 1.2;
    margin-bottom: 16px;
}

.single-post__byline {
    font-size: 14px;
    color: var(--gray-600);
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
}
.single-post__author { color: var(--green-accent); font-weight: 500; }

.single-post__thumbnail {
    margin-bottom: 32px;
    border-radius: var(--radius-lg);
    overflow: hidden;
}
.single-post__thumbnail img { width: 100%; object-fit: cover; }

/* Contenido del post */
.entry-content {
    font-size: 17px;
    line-height: 1.75;
    color: var(--gray-900);
}
.entry-content h2 { font-size: 24px; font-weight: 700; color: var(--green-dark); margin: 32px 0 12px; }
.entry-content h3 { font-size: 20px; font-weight: 700; color: var(--green-dark); margin: 24px 0 8px; }
.entry-content p  { margin-bottom: 20px; }
.entry-content a  { color: var(--green-accent); text-decoration: underline; text-underline-offset: 3px; }
.entry-content ul, .entry-content ol { padding-left: 24px; margin-bottom: 20px; }
.entry-content ul { list-style: disc; }
.entry-content ol { list-style: decimal; }
.entry-content li { margin-bottom: 6px; }
.entry-content blockquote {
    border-left: 4px solid var(--green-accent);
    padding: 16px 24px;
    margin: 24px 0;
    background: var(--green-light);
    border-radius: 0 var(--radius-sm) var(--radius-sm) 0;
    font-style: italic;
    color: var(--green-dark);
}
.entry-content img { border-radius: var(--radius-md); margin-block: 24px; }
.entry-content code {
    font-family: 'Courier New', monospace;
    background: var(--gray-100);
    padding: 2.4px 6.4px;
    border-radius: 3px;
    font-size: 14.4px;
}
.entry-content pre {
    background: var(--gray-900);
    color: var(--white);
    padding: 20px;
    border-radius: var(--radius-md);
    overflow-x: auto;
    margin-block: 24px;
}
.entry-content pre code { background: none; padding: 0; color: inherit; }

/* Post footer: etiquetas */
.single-post__footer { margin-top: 32px; padding-top: 24px; border-top: 1px solid var(--gray-200); }
.entry-tags { display: flex; flex-wrap: wrap; gap: 8px; font-size: 14px; }
.entry-tags span { color: var(--gray-400); }
.entry-tags a {
    background: var(--gray-100);
    color: var(--gray-600);
    padding: 4px 12px;
    border-radius: 999px;
    font-size: 12.8px;
    transition: background var(--transition);
}
.entry-tags a:hover { background: var(--gray-200); }

/* ─── NAVEGACIÓN POST ANTERIOR / SIGUIENTE ──────────────── */
.post-navigation {
    margin-top: 48px;
    padding-top: 32px;
    border-top: 1px solid var(--gray-200);
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
.nav-previous, .nav-next { display: flex; flex-direction: column; gap: 4px; }
.nav-next { text-align: right; align-items: flex-end; }
.post-nav__label { font-size: 12px; color: var(--gray-400); text-transform: uppercase; letter-spacing: 0.8px; }
.post-nav__title { font-size: 15px; font-weight: 600; color: var(--green-dark); line-height: 1.35; transition: color var(--transition); }
.post-navigation a:hover .post-nav__title { color: var(--green-accent); }

/* ─── ARCHIVOS / SEARCH HEADER ──────────────────────────── */
.archive-header {
    padding-block: 40px 24px;
    border-bottom: 1px solid var(--gray-200);
    margin-bottom: 32px;
}
.archive-header__title {
    font-size: 32px;
    font-weight: 700;
    color: var(--green-dark);
}
.archive-header__desc { margin-top: 8px; color: var(--gray-600); font-size: 15px; }
.search-term { color: var(--green-accent); }

/* ─── PÁGINA ESTÁTICA ───────────────────────────────────── */
.page-content { padding-block: 40px 64px; }
.page-content__header { margin-bottom: 32px; }
.page-content__title { font-size: 32px; font-weight: 700; color: var(--green-dark); }
.page-content__thumbnail { margin-bottom: 32px; border-radius: var(--radius-lg); overflow: hidden; }

/* ─── ERROR 404 ─────────────────────────────────────────── */
.error-404 {
    padding-block: 80px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 16px;
}
.error-404__code { font-size: 96px; font-weight: 700; color: var(--gray-200); line-height: 1; }
.error-404__title { font-size: 28px; font-weight: 700; color: var(--green-dark); }
.error-404__msg { color: var(--gray-600); max-width: 380px; }

/* ─── SIDEBAR / WIDGETS ─────────────────────────────────── */
.sidebar { display: flex; flex-direction: column; gap: 32px; }
.widget__title {
    font-size: 16px;
    font-weight: 700;
    color: var(--green-dark);
    margin-bottom: 14px;
    padding-bottom: 8px;
    border-bottom: 2px solid var(--green-accent);
}

/* ─── COMMENTS ──────────────────────────────────────────── */
.comments-wrap { margin-top: 48px; }
.comment-list { list-style: none; margin-bottom: 32px; }
.comment-body { padding: 16px 0; border-bottom: 1px solid var(--gray-100); }
.comment-author { font-weight: 600; color: var(--green-dark); }
.comment-metadata { font-size: 12.8px; color: var(--gray-400); margin-top: 2px; }
.comment-content { margin-top: 12px; font-size: 15px; }
.comment-reply-link {
    font-size: 12.8px;
    color: var(--green-accent);
    font-weight: 500;
    transition: color var(--transition);
}
.comment-reply-link:hover { color: var(--green-mid); }
.comment-respond .comment-reply-title { font-size: 20px; font-weight: 700; color: var(--green-dark); margin-bottom: 16px; }
.comment-form label { display: block; font-size: 14px; font-weight: 500; margin-bottom: 6px; color: var(--gray-600); }
.comment-form input[type="text"],
.comment-form input[type="email"],
.comment-form input[type="url"],
.comment-form textarea {
    width: 100%;
    padding: 9.6px 14px;
    border: 1.5px solid var(--gray-200);
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: 14.4px;
    outline: none;
    transition: border-color var(--transition);
    margin-bottom: 16px;
}
.comment-form input:focus, .comment-form textarea:focus { border-color: var(--green-accent); }
.comment-form textarea { min-height: 140px; resize: vertical; }
#submit {
    padding: 10.4px 24px;
    background: var(--green-dark);
    color: var(--white);
    border: none;
    border-radius: var(--radius-sm);
    font-family: var(--font-sans);
    font-size: 14.4px;
    font-weight: 500;
    cursor: pointer;
    transition: background var(--transition);
}
#submit:hover { background: var(--green-mid); }

/* ─── FOOTER ────────────────────────────────────────────── */
.site-footer {
    background: var(--green-dark);
    color: rgba(255,255,255,.75);

}

.footer-top {
    padding-block: 48px;
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 32px;
    flex-wrap: wrap;
    border-bottom: 1px solid rgba(255,255,255,.1);
}

.footer-brand__name { font-size: 20px; font-weight: 700; color: var(--white); }
.footer-brand img { filter: brightness(0) invert(1); height: 52px; width: auto; }
.footer-brand__tagline { font-size: 14px; margin-top: 8px; }

.footer-nav__list { display: flex; gap: 24px; flex-wrap: wrap; }
.footer-nav__list a {
    font-size: 14px;
    color: rgba(255,255,255,.65);
    transition: color var(--transition);
}
.footer-nav__list a:hover { color: var(--white); }

.footer-bottom {
    padding-block: 20px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}

.footer-copy { font-size: 12.8px; color: rgba(255,255,255,.45); }
.footer-copy a { color: rgba(255,255,255,.65); transition: color var(--transition); }
.footer-copy a:hover { color: var(--white); }

/* ═══════════════════════════════════════════════════════════
   RESPONSIVE
   1024px  Tablet landscape
    768px  Tablet portrait
    480px  Mobile grande
    360px  Mobile pequeño
   ═══════════════════════════════════════════════════════════ */

/* ─── HAMBURGER (oculto en desktop) ─────────────────────── */
.menu-toggle {
    display: none;
    width: 32px;
    height: 32px;
    position: relative;
    background: none;
    border: none;
    cursor: pointer;
    padding: 0 15px 0 0;
    z-index: 1000;
}

.menu-toggle__box {
    display: block;
    width: 24px;
    height: 18px;
    margin: 7px 4px;
    position: relative;
}

.menu-toggle__inner,
.menu-toggle__inner::before,
.menu-toggle__inner::after {
    display: block;
    width: 24px;
    height: 2px;
    background-color: var(--green-dark);
    position: absolute;
    transition: transform 0.2s ease, background-color 0.2s ease;
    border-radius: 4px;
}

.menu-toggle__inner {
    top: 50%;
    margin-top: -1px;
}

.menu-toggle__inner::before,
.menu-toggle__inner::after {
    content: "";
}

.menu-toggle__inner::before { top: -8px; }
.menu-toggle__inner::after  { bottom: -8px; }

/* Animación al abrir */
.js-menu-toggle[aria-expanded="true"] .menu-toggle__inner {
    background-color: transparent;
}
.js-menu-toggle[aria-expanded="true"] .menu-toggle__inner::before {
    transform: translateY(8px) rotate(45deg);
}
.js-menu-toggle[aria-expanded="true"] .menu-toggle__inner::after {
    transform: translateY(-8px) rotate(-45deg);
}

/* Sombra al hacer scroll */
.site-header.is-scrolled { box-shadow: 0 2px 12px rgba(0,0,0,.08); }

/* ─── TABLET LANDSCAPE (≤1024px) ────────────────────────── */
@media (max-width: 1024px) {
    /* Nav secundario: ocultar textos largos */
    .nav-action:not(.nav-action--accent) { display: none; }

    /* Grilla: 3 columnas máx en tablet grande */
    .posts-grid { grid-template-columns: repeat(3, 1fr); gap: 20px; }

    /* Hero un poco más bajo */
    .hero-banner { height: 380px; width: 90%; margin: 20px auto;}
}

/* ─── TABLET PORTRAIT (≤768px) ──────────────────────────── */
@media (max-width: 767px) {

    /* Mostrar hamburger */
    .menu-toggle { display: block; }

    /* ── Header top ── */
    .header-top__inner { gap: 12px; padding-inline: 16px; }
    /* Ocultar "Search" text en mobile para dejar espacio */
    .header-action--search { font-size: 0; }
    .header-action--search svg { width: 20px; height: 20px; }

    /* ── Header nav ── */
    .header-nav { 
        position: static; 
        border: none;
    }
    .header-nav__inner { padding: 0; }

    /* Nav principal → Menú Vertical Overlay */
    .primary-nav {
        position: fixed;
        top: 0;
        right: -100%;
        width: 85%;
        max-width: 320px;
        height: 100vh;
        background: var(--white);
        box-shadow: -10px 0 30px rgba(0,0,0,0.1);
        z-index: 999;
        transition: right 0.3s ease;
        padding: 80px 24px 40px;
        overflow-y: auto;
    }

    .primary-nav.is-open {
        right: 0;
    }

    .primary-nav__list {
        flex-direction: column;
        align-items: flex-start;
        gap: 8px;
        padding: 0;
    }

    .primary-nav__list li { width: 100%; }

    .primary-nav__list li a {
        font-size: 18px;
        font-weight: 600;
        padding: 12px 16px;
        background: var(--gray-50);
        border-radius: var(--radius-md);
        display: flex;
        justify-content: space-between;
        align-items: center;
    }

    .primary-nav__list li a::after {
        content: "→";
        opacity: 0.3;
    }

    .primary-nav__list li.current-menu-item > a {
        background: var(--green-light);
        color: var(--green-dark);
        border: 1px solid var(--green-accent);
    }

    /* Título para el menú mobile */
    .primary-nav::before {
        content: "Categorías";
        display: block;
        font-size: 14px;
        font-weight: 700;
        text-transform: uppercase;
        letter-spacing: 1px;
        color: var(--gray-400);
        margin-bottom: 24px;
        padding-left: 16px;
    }

    /* Overlay oscuro cuando el menú está abierto */
    body.menu-open {
        overflow: hidden;
    }

    body.menu-open::after {
        content: "";
        position: fixed;
        inset: 0;
        background: rgba(0,0,0,0.5);
        z-index: 998;
    }

    /* Acciones nav derecha */
    .header-nav__right { display: none; }

    /* ── Grilla: 2 columnas ── */
    .posts-grid { grid-template-columns: repeat(2, 1fr); gap: 24px; }

    /* ── Hero ── */
    .hero-banner { height: 320px; margin-block: 24px; border-radius: 20px; }
    .hero-banner__title { font-size: 32px; line-height: 1.1; }
    .hero-banner__excerpt { font-size: 15px; max-width: 90%; }
    .hero-banner__content { padding-inline: 24px; }
    .hero-banner__overlay {
        background: linear-gradient(
            to right,
            rgba(0,0,0,.9) 0%,
            rgba(0,0,0,.5) 100%
        );
    }
    .site-branding{
        padding: 15px;
    }
    .primary-nav__list{
        padding-left:15px;
    }
    /* ── Single post ── */
    .single-post__title { font-size: 32px; }
    .entry-content { font-size: 16px; }

    /* ── Footer ── */
    .footer-top { flex-direction: column; gap: 32px; padding-inline: 24px; }
    .footer-nav__list { gap: 16px; }
    .footer-bottom { padding-inline: 24px; }
}

/* ─── MOBILE GRANDE (≤480px) ────────────────────────────── */
@media (max-width: 480px) {

    /* ── Header ── */
    .header-top__inner { padding-block: 10px; }
    .site-branding img { height: 40px; }

    /* ── Grilla: 1 columna ── */
    .posts-grid { grid-template-columns: 1fr; gap: 20px; }

    /* ── Post card ── */
    .post-card { border-radius: 32px; }
    .post-card__body { padding: 20px; }
    .post-card__title { font-size: 18px; }

    /* ── Hero ── */
    .hero-banner { margin-block: 16px; height: 300px; border-radius: 35px; }
    .hero-banner__title { font-size: 26px; }
    .hero-banner__excerpt { -webkit-line-clamp: 2; display: -webkit-box; -webkit-box-orient: vertical; overflow: hidden; }
    .hero-banner__content { padding-inline: 20px; }

    /* ── Single post ── */
    .single-post { padding-block: 24px 40px; }
    .single-post__title { font-size: 28px; }
}

/* ─── MOBILE PEQUEÑO (≤360px) ───────────────────────────── */
@media (max-width: 360px) {
    :root { --container-pad: 16px; }

    .hero-banner { height: 280px; }
    .hero-banner__title { font-size: 22px; }
    .hero-banner__excerpt { display: none; }

    .post-card__title { font-size: 16px; }
    .post-card__excerpt { font-size: 14px; }

    .primary-nav__list li a { font-size: 13px; padding: 6px 10px; }
}
