/* ==========================================================================
   OLPA — Blog (listing + single post + search)
   Cargado solo en is_home(), is_archive(), is_single() (de post), is_search()
   o el template-blog.php.
   ========================================================================== */

/* ===== Hero search input ===== */
.search-wrap {
    position: relative;
    max-width: 560px;
    margin-top: 24px;
}
.search-wrap input[type="search"] {
    width: 100%;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 16px 20px 16px 50px;
    border-radius: 14px;
    font-family: inherit;
    font-size: 15px;
    transition: all 0.4s ease;
}
.search-wrap input[type="search"]:focus {
    outline: none;
    border-color: var(--olpa);
    background: rgba(255, 214, 10, 0.04);
    box-shadow: 0 0 0 4px rgba(255, 214, 10, 0.08);
}
.search-wrap input[type="search"]::placeholder { color: var(--muted); }
.search-wrap > svg,
.search-wrap > i[data-lucide] {
    position: absolute;
    left: 18px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--muted);
    width: 20px;
    height: 20px;
}

/* ===== Filter pills ===== */
.fpill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 10px 18px;
    border: 1px solid var(--border);
    border-radius: 999px;
    font-size: 12px;
    font-weight: 500;
    color: var(--muted);
    background: rgba(255, 255, 255, 0.02);
    backdrop-filter: blur(10px);
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
    font-family: inherit;
}
.fpill:hover {
    color: var(--text);
    border-color: rgba(255, 214, 10, 0.3);
}
.fpill.active {
    background: var(--olpa);
    color: #000;
    border-color: var(--olpa);
    box-shadow: 0 8px 25px rgba(255, 214, 10, 0.3);
}
.fpill .count {
    font-family: var(--font-mono);
    font-size: 10px;
    opacity: 0.7;
}

/* ===== Sort dropdown ===== */
.sort-select {
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 10px 16px;
    border-radius: 10px;
    font-family: inherit;
    font-size: 13px;
    max-width: 200px;
    cursor: pointer;
}
.sort-select:focus {
    outline: none;
    border-color: var(--olpa);
}

/* ===== Featured post (60/40) ===== */
.feat-card {
    position: relative;
    overflow: hidden;
    border-radius: 28px;
    border: 1px solid var(--border);
    background: rgba(18, 18, 28, 0.6);
    backdrop-filter: blur(20px);
    display: grid;
    grid-template-columns: 1fr;
    min-height: 400px;
    text-decoration: none;
    color: var(--text);
    transition: all 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}
@media (min-width: 1024px) {
    .feat-card {
        grid-template-columns: 1.1fr 1fr;
        min-height: 500px;
    }
}
.feat-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 40px 80px rgba(0, 0, 0, 0.6), 0 0 60px rgba(255, 214, 10, 0.12);
}
.feat-img {
    position: relative;
    overflow: hidden;
    min-height: 300px;
}
.feat-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.8s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.feat-card:hover .feat-img img {
    transform: scale(1.05);
}
.feat-img::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, transparent, rgba(7, 7, 12, 0.4));
}
@media (max-width: 1023px) {
    .feat-img::after {
        background: linear-gradient(180deg, transparent 50%, rgba(7, 7, 12, 0.6));
    }
}
.feat-content {
    padding: 40px 36px;
    display: flex;
    flex-direction: column;
    justify-content: center;
}
.feat-cat {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-mono);
    font-size: 10px;
    padding: 6px 12px;
    border-radius: 8px;
    background: rgba(255, 214, 10, 0.12);
    border: 1px solid rgba(255, 214, 10, 0.35);
    color: var(--olpa);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 16px;
    align-self: flex-start;
}
.feat-cat i[data-lucide], .feat-cat svg {
    width: 11px;
    height: 11px;
}
.feat-content h2 {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 32px;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin-bottom: 14px;
    color: var(--text);
}
@media (min-width: 768px) {
    .feat-content h2 { font-size: 40px; }
}
.feat-content p {
    font-size: 15px;
    color: var(--muted);
    line-height: 1.6;
    margin-bottom: 24px;
}
.feat-meta {
    display: flex;
    gap: 16px;
    font-size: 11px;
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--muted);
    margin-bottom: 20px;
    flex-wrap: wrap;
}
.feat-meta span {
    display: flex;
    align-items: center;
    gap: 6px;
}
.feat-meta i[data-lucide], .feat-meta svg {
    width: 12px;
    height: 12px;
}

/* ===== Post cards (grid) ===== */
.post-card {
    position: relative;
    display: flex;
    flex-direction: column;
    overflow: hidden;
    background: rgba(18, 18, 28, 0.6);
    border: 1px solid var(--border);
    border-radius: 20px;
    color: var(--text);
    text-decoration: none;
    transition: all 0.5s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.post-card:hover {
    transform: translateY(-6px);
    box-shadow: 0 30px 60px rgba(0, 0, 0, 0.45), 0 0 40px rgba(255, 214, 10, 0.08);
    border-color: rgba(255, 214, 10, 0.2);
}
.post-img {
    position: relative;
    overflow: hidden;
    aspect-ratio: 16 / 10;
    border-radius: 20px 20px 0 0;
}
.post-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.post-card:hover .post-img img {
    transform: scale(1.08);
}
.post-cat {
    position: absolute;
    top: 14px;
    left: 14px;
    z-index: 2;
    font-family: var(--font-mono);
    font-size: 9px;
    padding: 5px 10px;
    border-radius: 6px;
    background: rgba(7, 7, 12, 0.8);
    backdrop-filter: blur(12px);
    border: 1px solid var(--border);
    text-transform: uppercase;
    letter-spacing: 0.15em;
}
.post-cat.olpa {
    color: var(--olpa);
    border-color: rgba(255, 214, 10, 0.35);
}
.post-cat.accent {
    color: var(--accent);
    border-color: rgba(0, 229, 255, 0.35);
}
.post-body {
    padding: 22px 24px 24px;
    flex: 1;
    display: flex;
    flex-direction: column;
}
.post-meta {
    display: flex;
    gap: 12px;
    font-size: 10px;
    font-family: var(--font-mono);
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    margin-bottom: 10px;
    flex-wrap: wrap;
}
.post-meta span {
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.post-meta i[data-lucide], .post-meta svg {
    width: 11px;
    height: 11px;
}
.post-body h3 {
    font-family: var(--font-display);
    font-weight: 600;
    font-size: 17px;
    line-height: 1.3;
    margin: 0 0 8px;
    letter-spacing: -0.01em;
    transition: color 0.3s ease;
    color: var(--text);
}
.post-card:hover .post-body h3 {
    color: var(--olpa);
}
.post-body p {
    font-size: 13px;
    color: var(--muted);
    line-height: 1.55;
    margin: 0 0 16px;
    flex: 1;
}
.post-body .read-more {
    font-size: 11px;
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: 0.15em;
    color: var(--olpa);
    display: inline-flex;
    align-items: center;
    gap: 6px;
    transition: gap 0.3s ease;
}
.post-card:hover .post-body .read-more {
    gap: 10px;
}
.post-body .read-more i[data-lucide], .post-body .read-more svg {
    width: 12px;
    height: 12px;
}

/* ===== Filter bar layout ===== */
.filter-bar {
    display: flex;
    flex-direction: column;
    gap: 20px;
    margin-bottom: 40px;
}
@media (min-width: 640px) {
    .filter-bar {
        flex-direction: row;
        align-items: center;
        justify-content: space-between;
    }
}
.filter-bar .pills-group {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
}

/* ===== Load more button ===== */
.load-more-wrap {
    text-align: center;
    margin-top: 56px;
}
.load-more-wrap .load-more-info {
    font-size: 12px;
    color: var(--muted);
    font-family: var(--font-mono);
    margin-top: 16px;
}

/* ===== Grid responsive ===== */
.blog-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 24px;
}
@media (min-width: 640px) {
    .blog-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1024px) {
    .blog-grid { grid-template-columns: repeat(3, 1fr); }
}

/* Estado filtrado — posts fuera del filtro */
.post-card.is-filtered-out {
    opacity: 0.1;
    transform: scale(0.95);
    pointer-events: none;
    transition: opacity 0.4s ease, transform 0.4s ease;
}
.post-card.is-filtered-in {
    opacity: 1;
    transform: scale(1);
    transition: opacity 0.4s ease, transform 0.4s ease;
}

/* ==========================================================================
   Blog con sidebar (layout 2-col) — listing
   ========================================================================== */
.blog-with-sidebar {
    display: grid;
    grid-template-columns: 1fr;
    gap: 40px;
}
@media (min-width: 1024px) {
    .blog-with-sidebar {
        grid-template-columns: minmax(0, 2.2fr) minmax(300px, 1fr);
        gap: 48px;
    }
}
.blog-with-sidebar__main { min-width: 0; }

/* Aside (común listing + single) */
.blog-with-sidebar__aside { min-width: 0; }
.blog-with-sidebar__aside .blog-sidebar-content {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

/* Desktop: el sidebar queda sticky mientras se scrollea dentro del grid.
   Requisito: html/body NO debe tener overflow-x: hidden (rompe sticky) —
   usamos overflow-x: clip en olpa.css.

   Si el contenido de las widgets excede la altura del viewport, aparece un
   scrollbar amarillo para scrollear internamente. blog-filters.js asegura
   que Lenis no hijack el wheel cuando el cursor está dentro del aside. */
@media (min-width: 1024px) {
    .blog-with-sidebar__aside {
        position: sticky;
        top: 100px;
        align-self: start;
        max-height: calc(100vh - 140px);
        overflow-y: auto;
        overscroll-behavior: contain;  /* evita que el scroll "salte" al window cuando llegás al fin */
        scrollbar-width: thin;
        scrollbar-color: rgba(255, 214, 10, 0.4) transparent;
        padding-right: 8px;
    }
    .blog-with-sidebar__aside::-webkit-scrollbar { width: 8px; }
    .blog-with-sidebar__aside::-webkit-scrollbar-track {
        background: rgba(255, 255, 255, 0.02);
        border-radius: 4px;
    }
    .blog-with-sidebar__aside::-webkit-scrollbar-thumb {
        background: rgba(255, 214, 10, 0.35);
        border-radius: 4px;
    }
    .blog-with-sidebar__aside::-webkit-scrollbar-thumb:hover {
        background: rgba(255, 214, 10, 0.6);
    }
    /* Botón toggle mobile: oculto en desktop */
    .blog-sidebar-toggle { display: none !important; }
}

/* Slot wrapper (inyectado por JS) que reserva el espacio del grid cuando el
   aside pasa a position:fixed. En mobile es transparente para layout. */
.blog-aside-slot { display: contents; }
@media (min-width: 1024px) {
    .blog-aside-slot {
        display: block;
        position: relative;
        min-width: 0;
    }
}

/* ==========================================================================
   Sidebar collapsible — usado en single.php (mobile-first accordion)
   ========================================================================== */
.blog-sidebar-toggle {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    width: 100%;
    padding: 14px 18px;
    background: rgba(18, 18, 28, 0.7);
    backdrop-filter: blur(14px);
    border: 1px solid var(--border);
    border-radius: 16px;
    color: var(--text);
    font-family: var(--font-mono);
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.15em;
    cursor: pointer;
    transition: all 0.3s ease;
}
.blog-sidebar-toggle:hover {
    border-color: rgba(255, 214, 10, 0.3);
    color: var(--olpa);
}
.blog-sidebar-toggle__label {
    display: inline-flex;
    align-items: center;
    gap: 10px;
}
.blog-sidebar-toggle__label i[data-lucide],
.blog-sidebar-toggle__label svg {
    width: 16px;
    height: 16px;
    color: var(--olpa);
}
.blog-sidebar-toggle__chevron {
    width: 16px;
    height: 16px;
    transition: transform 0.35s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.blog-sidebar-toggle[aria-expanded="true"] .blog-sidebar-toggle__chevron {
    transform: rotate(180deg);
}

/* Mobile (< 1024px) + collapsible: contenido oculto por defecto, expandible */
@media (max-width: 1023px) {
    .blog-with-sidebar__aside--collapsible .blog-sidebar-content {
        max-height: 0;
        overflow: hidden;
        opacity: 0;
        margin-top: 0;
        pointer-events: none;
        transition: max-height 0.45s cubic-bezier(0.2, 0.8, 0.2, 1),
                    opacity 0.3s ease,
                    margin-top 0.3s ease;
    }
    .blog-with-sidebar__aside--collapsible.is-open .blog-sidebar-content {
        max-height: 4000px;  /* alto suficiente para que no cortee contenido */
        opacity: 1;
        margin-top: 14px;
        pointer-events: auto;
    }
    /* En single.php: aside collapsible aparece ARRIBA del contenido en mobile.
       El usuario pidió explícitamente: "en responsive debe aparecer primero
       lo que sera la barra lateral". */
    .single-with-sidebar .blog-with-sidebar__aside--collapsible {
        order: -1;
    }
}

/* ==========================================================================
   Single post — layout 2-col
   ========================================================================== */
.single-with-sidebar {
    display: grid;
    grid-template-columns: 1fr;
    gap: 28px;
}
@media (min-width: 1024px) {
    .single-with-sidebar {
        /* Auto-placement: main ocupa col 1, el slot (o aside directa) col 2. */
        grid-template-columns: minmax(0, 2.4fr) minmax(300px, 1fr);
        gap: 56px;
    }
}
.single-with-sidebar__main {
    min-width: 0;
    max-width: 100%;
}
/* En single el contenido prose tiene su propio max-width; limitamos a 56rem
   dentro del main para legibilidad óptima. */
@media (min-width: 1024px) {
    .single-with-sidebar__main .entry-content {
        max-width: 56rem;
    }
}

/* Tag pills del post */
.single-post-tags {
    padding-top: 24px;
    border-top: 1px solid var(--border);
}

/* ==========================================================================
   CTA dinámico al final del single post
   ========================================================================== */
.single-cta {
    margin-top: 56px;
    position: relative;
}
.single-cta::before {
    content: '';
    position: absolute;
    inset: -40px -20px auto -20px;
    height: 260px;
    background: radial-gradient(ellipse at center top, rgba(255, 214, 10, 0.12), transparent 70%);
    pointer-events: none;
    z-index: 0;
}
.single-cta__inner {
    position: relative;
    z-index: 1;
    background: linear-gradient(135deg, rgba(255, 214, 10, 0.06), rgba(0, 229, 255, 0.04));
    border: 1px solid rgba(255, 214, 10, 0.25);
    border-radius: 28px;
    padding: 40px 28px;
    text-align: center;
    overflow: hidden;
}
@media (min-width: 640px) {
    .single-cta__inner {
        padding: 48px 40px;
    }
}
.single-cta__inner::after {
    content: '';
    position: absolute;
    top: -100px;
    right: -100px;
    width: 280px;
    height: 280px;
    border-radius: 50%;
    background: radial-gradient(circle, rgba(255, 214, 10, 0.15), transparent 70%);
    pointer-events: none;
}
.single-cta__tag {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-mono);
    font-size: 10px;
    padding: 6px 14px;
    border-radius: 999px;
    background: rgba(255, 214, 10, 0.12);
    border: 1px solid rgba(255, 214, 10, 0.35);
    color: var(--olpa);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    margin-bottom: 20px;
}
.single-cta__tag .dot {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--olpa);
    box-shadow: 0 0 10px rgba(255, 214, 10, 0.6);
}
.single-cta__title {
    font-family: var(--font-display);
    font-weight: 700;
    font-size: 26px;
    line-height: 1.15;
    letter-spacing: -0.02em;
    color: var(--text);
    margin: 0 0 16px;
    max-width: 640px;
    margin-inline: auto;
}
@media (min-width: 640px) {
    .single-cta__title { font-size: 34px; }
}
@media (min-width: 1024px) {
    .single-cta__title { font-size: 38px; }
}
.single-cta__subtitle {
    font-size: 15px;
    line-height: 1.6;
    color: var(--muted);
    max-width: 560px;
    margin: 0 auto 28px;
}
.single-cta__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
}
.single-cta__actions .btn-primary,
.single-cta__actions .btn-ghost {
    padding: 14px 22px;
    font-size: 13px;
}

/* Grid con sidebar: 1 col mobile, 2 col tablet/desktop (nunca 3 porque el ancho es menor) */
.blog-grid--sidebar {
    grid-template-columns: 1fr !important;
}
@media (min-width: 640px) {
    .blog-grid--sidebar {
        grid-template-columns: repeat(2, 1fr) !important;
    }
}

/* ===== Widget base ===== */
.blog-widget {
    background: rgba(18, 18, 28, 0.6);
    backdrop-filter: blur(14px);
    border: 1px solid var(--border);
    border-radius: 16px;
    padding: 14px 16px 16px;
    transition: border-color 0.3s ease;
}
.blog-widget:hover {
    border-color: rgba(255, 214, 10, 0.18);
}
.blog-widget__title {
    display: flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-mono);
    font-size: 10px;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--text);
    margin: 0 0 10px;
    padding-bottom: 8px;
    border-bottom: 1px solid var(--border);
}
.blog-widget__title i[data-lucide],
.blog-widget__title svg {
    width: 13px;
    height: 13px;
    color: var(--olpa);
}
.blog-widget__text {
    font-size: 12px;
    color: var(--muted);
    line-height: 1.5;
    margin: 0 0 10px;
}

/* ===== Widget: Search ===== */
.blog-widget__search {
    position: relative;
    display: flex;
}
.blog-widget__search input[type="search"] {
    flex: 1;
    background: rgba(255, 255, 255, 0.03);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 9px 42px 9px 12px;
    border-radius: 10px;
    font-family: inherit;
    font-size: 12.5px;
    transition: all 0.3s ease;
}
.blog-widget__search input[type="search"]:focus {
    outline: none;
    border-color: var(--olpa);
    background: rgba(255, 214, 10, 0.04);
    box-shadow: 0 0 0 3px rgba(255, 214, 10, 0.08);
}
.blog-widget__search button {
    position: absolute;
    right: 5px;
    top: 50%;
    transform: translateY(-50%);
    background: var(--olpa);
    color: #000;
    border: 0;
    width: 30px;
    height: 30px;
    border-radius: 8px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    transition: all 0.25s ease;
}
.blog-widget__search button:hover {
    transform: translateY(-50%) scale(1.05);
    box-shadow: 0 6px 18px rgba(255, 214, 10, 0.3);
}
.blog-widget__search button i[data-lucide],
.blog-widget__search button svg {
    width: 14px;
    height: 14px;
}

/* ===== Widget: Lista (categorías) ===== */
.blog-widget__list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.blog-widget__list li a {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    padding: 7px 10px;
    border-radius: 8px;
    color: var(--text);
    font-size: 12.5px;
    text-decoration: none;
    transition: all 0.25s ease;
}
.blog-widget__list li a:hover {
    background: rgba(255, 214, 10, 0.06);
    color: var(--olpa);
    transform: translateX(3px);
}
.blog-widget__count {
    font-family: var(--font-mono);
    font-size: 10px;
    background: rgba(255, 255, 255, 0.04);
    border: 1px solid var(--border);
    color: var(--muted);
    padding: 3px 8px;
    border-radius: 6px;
    min-width: 28px;
    text-align: center;
}
.blog-widget__more {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 10px;
    padding: 6px 0;
    font-family: var(--font-mono);
    font-size: 10.5px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--olpa);
    text-decoration: none;
    transition: gap 0.3s ease;
}
.blog-widget__more:hover { gap: 10px; }
.blog-widget__more i[data-lucide],
.blog-widget__more svg { width: 12px; height: 12px; }

/* ===== Widget: Tags ===== */
.blog-widget__tags {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
}
.blog-tag-pill {
    display: inline-flex;
    align-items: center;
    padding: 6px 12px;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.02);
    color: var(--muted);
    font-size: 11px;
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    text-decoration: none;
    transition: all 0.25s ease;
}
.blog-tag-pill:hover {
    color: #000;
    background: var(--olpa);
    border-color: var(--olpa);
    transform: translateY(-2px);
}

/* ===== Widget: Últimos posts ===== */
.blog-widget__recent {
    list-style: none;
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.blog-widget__recent li a {
    display: grid;
    grid-template-columns: 50px 1fr;
    gap: 10px;
    align-items: center;
    text-decoration: none;
    color: var(--text);
    transition: transform 0.25s ease;
}
.blog-widget__recent li a:hover {
    transform: translateX(3px);
}
.blog-widget__recent li a:hover .blog-widget__recent-title {
    color: var(--olpa);
}
.blog-widget__recent img,
.blog-widget__recent-placeholder {
    width: 50px;
    height: 50px;
    border-radius: 10px;
    object-fit: cover;
    border: 1px solid var(--border);
}
.blog-widget__recent-placeholder {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: rgba(255, 214, 10, 0.06);
    color: var(--olpa);
}
.blog-widget__recent-placeholder i[data-lucide],
.blog-widget__recent-placeholder svg {
    width: 18px;
    height: 18px;
}
.blog-widget__recent-date {
    display: block;
    font-family: var(--font-mono);
    font-size: 9px;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--muted);
    margin-bottom: 2px;
}
.blog-widget__recent-title {
    display: block;
    font-size: 12px;
    font-weight: 500;
    line-height: 1.35;
    transition: color 0.25s ease;
}

/* ===== Widget: Newsletter (accent) ===== */
.blog-widget--accent {
    background: linear-gradient(135deg, rgba(255, 214, 10, 0.08), rgba(0, 229, 255, 0.05));
    border-color: rgba(255, 214, 10, 0.25);
}
.blog-widget--accent .blog-widget__title {
    border-bottom-color: rgba(255, 214, 10, 0.2);
}
.blog-widget__newsletter {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.blog-widget__newsletter input[type="email"] {
    background: rgba(7, 7, 12, 0.6);
    border: 1px solid var(--border);
    color: var(--text);
    padding: 9px 12px;
    border-radius: 10px;
    font-family: inherit;
    font-size: 12.5px;
    transition: all 0.3s ease;
}
.blog-widget__newsletter input[type="email"]:focus {
    outline: none;
    border-color: var(--olpa);
    box-shadow: 0 0 0 3px rgba(255, 214, 10, 0.08);
}
.blog-widget__newsletter .btn-primary {
    justify-content: center;
    padding: 9px 14px;
    font-size: 11px;
}

/* ===== Widget: Contacto ===== */
.blog-widget--contact {
    background: linear-gradient(135deg, rgba(0, 229, 255, 0.05), rgba(18, 18, 28, 0.6));
}
.blog-widget__contact-actions {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.blog-widget__contact-actions .btn-primary {
    justify-content: center;
    padding: 9px 14px;
    font-size: 11px;
}
.blog-widget__wa,
.blog-widget__email {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 7px;
    padding: 8px 12px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: rgba(255, 255, 255, 0.02);
    color: var(--text);
    font-size: 11px;
    font-family: var(--font-mono);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    text-decoration: none;
    transition: all 0.25s ease;
}
.blog-widget__wa:hover {
    color: #25d366;
    border-color: rgba(37, 211, 102, 0.35);
    background: rgba(37, 211, 102, 0.08);
}
.blog-widget__email:hover {
    color: var(--olpa);
    border-color: rgba(255, 214, 10, 0.35);
    background: rgba(255, 214, 10, 0.06);
}
.blog-widget__wa i[data-lucide],
.blog-widget__wa svg,
.blog-widget__email i[data-lucide],
.blog-widget__email svg {
    width: 14px;
    height: 14px;
}
