/* ===================================================================
   Blog Arletex — Arletex Design System v3.3
   ATREVIDO · TEXTIL · EDITORIAL · VARIADO
   Registros: Manifiesto · Periódico · Dossier
   Aperturas: ManifestoClaim+MegaText · RunInHeadline · Dossier
   Marcos:    Bleed-edge · Double-rule · Top-rule
   Hovers:    press-chunky (CTAs) · lift-orange (cards) · side-shift (links)
   Tokens --ax-* scoped en .blog-page para no filtrar al resto del sitio.
   =================================================================== */

.blog-page {
    --ax-ink:          #1F2530;
    --ax-ink-deep:     #141821;
    --ax-paper:        #FAF6EE;
    --ax-cream:        #F2EDE4;
    --ax-white:        #FFFFFF;
    --ax-orange:       #F15A29;
    --ax-orange-deep:  #B0401A;
    --ax-purple:       #6A52A2;
    --ax-yellow:       #FFEB3B;
    --ax-muted:        #6E6A60;
    --ax-muted-dark:   #A8A39A;
    --ax-rule:         rgba(14, 14, 14, 0.18);
    --ax-rule-on-dark: rgba(250, 246, 238, 0.18);
    --ax-whatsapp:     #25D366;

    --ax-font-display: 'Anton', 'Arial Narrow', sans-serif;
    --ax-font-accent:  'Fraunces', Georgia, serif;
    --ax-font-body:    'Lato', system-ui, sans-serif;
    --ax-font-mono:    'JetBrains Mono', 'SF Mono', ui-monospace, monospace;

    --ax-motion-fast: 120ms;
    --ax-motion-base: 200ms;
    --ax-ease-out:    cubic-bezier(0.16, 1, 0.3, 1);

    font-family: var(--ax-font-body);
    color: var(--ax-ink);
    background: var(--ax-white);
    line-height: 1.6;
    overflow-x: clip;
    -webkit-font-smoothing: antialiased;
}

.blog-page *,
.blog-page *::before,
.blog-page *::after { box-sizing: border-box; }

/* ── Container ───────────────────────────────────────────────────── */
.blog-container {
    position: relative;
    width: 100%;
    max-width: 1440px;
    margin: 0 auto;
    padding: 0 clamp(20px, 4vw, 56px);
    z-index: 2;
}
.blog-container--narrow { max-width: 980px; }

/* ── Section base + marcos editoriales ───────────────────────────── */
/* min-height neutraliza reglas globales que pudieran filtrarse por nombre. */
.blog-section { position: relative; min-height: 0; padding: clamp(56px, 8vw, 96px) 0; background: var(--ax-white); }
.blog-section--paper { background: var(--ax-paper); }
.blog-section--cream { background: var(--ax-cream); }
.blog-section--ink   { background: var(--ax-ink); color: var(--ax-paper); }

/* Top-rule (Dossier) */
.blog-section--top-rule { border-top: 2px solid var(--ax-orange); }
/* Double-rule (Periódico) */
.blog-section--double-rule {
    border-top: 1px solid var(--ax-ink);
    box-shadow: inset 0 5px 0 var(--ax-white), inset 0 6px 0 var(--ax-ink);
}
.blog-section--double-rule.blog-section--paper {
    box-shadow: inset 0 5px 0 var(--ax-paper), inset 0 6px 0 var(--ax-ink);
}

/* ── Breadcrumb ──────────────────────────────────────────────────── */
.blog-breadcrumb ol {
    display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
    margin: 0 0 clamp(20px, 3vw, 32px); padding: 0; list-style: none;
}
.blog-breadcrumb li {
    font-family: var(--ax-font-mono);
    font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--ax-muted-dark);
}
.blog-breadcrumb li::after { content: '/'; margin-left: 10px; color: var(--ax-orange); }
.blog-breadcrumb li:last-child::after { content: ''; }
.blog-breadcrumb a { color: var(--ax-muted-dark); text-decoration: none; }
.blog-breadcrumb a:hover { color: var(--ax-orange); }
.blog-breadcrumb li[aria-current="page"] { color: var(--ax-orange); }

/* ════════════════════════════════════════════════════════════════
   00 · HERO — Manifiesto + ManifestoClaim + MegaTextBg · ink · Bleed
   ════════════════════════════════════════════════════════════════ */
.blog-hero {
    position: relative;
    background: var(--ax-ink); color: var(--ax-paper);
    padding: clamp(72px, 12vw, 150px) 0;
    overflow: hidden;
}
.blog-hero__mega {
    position: absolute;
    left: 50%; top: 54%;
    transform: translate(-50%, -50%);
    font-family: var(--ax-font-display);
    text-transform: uppercase;
    font-size: clamp(7rem, 30vw, 26rem);
    line-height: .8; letter-spacing: -0.02em;
    color: var(--ax-rule-on-dark);
    z-index: 1; pointer-events: none; user-select: none;
    white-space: nowrap;
}
.blog-hero .blog-container { z-index: 2; }
.blog-hero__eyebrow {
    display: inline-block;
    font-family: var(--ax-font-display); text-transform: uppercase;
    background: var(--ax-orange); color: var(--ax-paper);
    font-size: clamp(.8rem, 1.1vw, 1rem); letter-spacing: 0.14em;
    padding: 8px 16px 6px; margin-bottom: clamp(16px, 2.5vw, 28px);
}
.blog-hero__title {
    font-family: var(--ax-font-display); text-transform: uppercase;
    font-size: clamp(3rem, 12vw, 9rem) !important;
    line-height: .82; letter-spacing: -0.02em;
    margin: 0; color: var(--ax-paper);
}
.blog-hero__title em {
    font-family: var(--ax-font-accent); font-style: italic; font-weight: 400;
    text-transform: lowercase; letter-spacing: -0.03em; color: var(--ax-orange);
}
.blog-hero__lede {
    font-family: var(--ax-font-accent); font-style: italic;
    font-size: clamp(1.1rem, 1.8vw, 1.5rem); color: var(--ax-muted-dark);
    margin: clamp(1.2rem, 2.5vw, 2rem) 0 0; max-width: 54ch;
}
.blog-hero__counts {
    display: flex; flex-wrap: wrap; gap: clamp(24px, 5vw, 64px);
    margin: clamp(2rem, 5vw, 3.5rem) 0 0;
    border-top: 1px solid var(--ax-rule-on-dark); padding-top: clamp(1.5rem, 3vw, 2.5rem);
}
.blog-hero__num {
    font-family: var(--ax-font-display);
    font-size: clamp(2.6rem, 6vw, 4.5rem); line-height: .85;
    color: var(--ax-orange); font-variant-numeric: tabular-nums;
}
.blog-hero__lbl {
    font-family: var(--ax-font-mono);
    font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--ax-muted-dark); margin-top: 8px;
}

/* ── MARQUEE ─────────────────────────────────────────────────────── */
.blog-marquee {
    background: var(--ax-ink); overflow: hidden; position: relative;
    border-top: 3px solid var(--ax-orange); border-bottom: 3px solid var(--ax-orange);
    padding: 16px 0;
}
.blog-marquee__track {
    display: inline-flex; gap: clamp(1.5rem, 3vw, 3rem); white-space: nowrap;
    font-family: var(--ax-font-display); text-transform: uppercase;
    font-size: clamp(1.4rem, 2.6vw, 2.3rem); line-height: 1;
    animation: blog-scroll 34s linear infinite; will-change: transform;
}
.blog-marquee__track > span:nth-of-type(odd)  { color: var(--ax-paper); }
.blog-marquee__track > span:nth-of-type(even) { color: var(--ax-orange); }
.blog-marquee:hover .blog-marquee__track { animation-play-state: paused; }
@keyframes blog-scroll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

/* ════════════════════════════════════════════════════════════════
   Section headers — aperturas (RunInHeadline · Dossier)
   ════════════════════════════════════════════════════════════════ */
/* RunInHeadline (Periódico) */
.blog-head--runin {
    display: flex; align-items: center; flex-wrap: wrap;
    gap: clamp(.5rem, 1.5vw, 1rem);
    margin-bottom: clamp(2rem, 4vw, 3.5rem);
    padding-bottom: clamp(.75rem, 1.5vw, 1.2rem);
    border-bottom: 1px solid var(--ax-rule);
}
.blog-head--runin .blog-head__stamp {
    font-family: var(--ax-font-display); text-transform: uppercase;
    font-size: .78rem; letter-spacing: 0.06em;
    padding: 5px 10px; line-height: 1;
    border: 1px solid var(--ax-orange); color: var(--ax-orange);
    flex-shrink: 0;
}
.blog-head--runin .blog-head__divider {
    font-family: var(--ax-font-accent); font-style: italic;
    color: var(--ax-orange); font-size: 1.6em; flex-shrink: 0;
}

/* Dossier */
.blog-head--dossier {
    margin-bottom: clamp(2rem, 4vw, 3.5rem);
    padding-bottom: clamp(1rem, 2vw, 1.5rem);
    border-bottom: 2px solid var(--ax-ink);
}
.blog-head__eyebrow {
    display: block;
    font-family: var(--ax-font-mono);
    font-size: 12px; letter-spacing: 0.18em; text-transform: uppercase;
    color: var(--ax-muted); margin-bottom: 10px;
}
.blog-head__title {
    font-family: var(--ax-font-display); text-transform: uppercase;
    font-size: clamp(1.9rem, 4.5vw, 3.4rem) !important; line-height: .95;
    letter-spacing: 0.005em; margin: 0; color: var(--ax-ink);
}
.blog-head__title em {
    font-family: var(--ax-font-accent); font-style: italic; font-weight: 400;
    text-transform: lowercase; letter-spacing: -0.03em; color: var(--ax-orange);
}

/* ════════════════════════════════════════════════════════════════
   01 · DESTACADO — Card horizontal (media-16-9) · lift-orange
   ════════════════════════════════════════════════════════════════ */
.blog-feature {
    display: grid;
    grid-template-columns: 1fr;
    background: var(--ax-white);
    border: 2px solid var(--ax-ink);
    border-top: 4px solid var(--ax-orange);
    box-shadow: 12px 12px 0 var(--ax-ink);
    transition: transform var(--ax-motion-base) var(--ax-ease-out),
                box-shadow var(--ax-motion-base) var(--ax-ease-out);
}
@media (min-width: 860px) {
    /* Columna de imagen de ancho acotado: con la imagen vertical 1080×1549,
       un ancho ~340-400px deja una altura ~490-575px, evitando el retrato gigante. */
    .blog-feature { grid-template-columns: clamp(300px, 30vw, 400px) 1fr; align-items: stretch; }
}
.blog-feature:hover {
    transform: translate(-4px, -4px);
    box-shadow: 16px 16px 0 var(--ax-orange);
}
/* Imagen vertical 1080×1549: respeta su proporción (sin recortar el mockup). */
.blog-feature__media { position: relative; overflow: hidden; aspect-ratio: 1080 / 1549; }
.blog-feature__media img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }
.blog-feature__badge {
    position: absolute; top: 0; left: 0;
    font-family: var(--ax-font-display); text-transform: uppercase;
    background: var(--ax-orange); color: var(--ax-paper);
    font-size: .8rem; letter-spacing: 0.1em; padding: 8px 14px 6px;
}
.blog-feature__body {
    display: flex; flex-direction: column; align-items: flex-start;
    justify-content: center;                 /* centra el texto en la altura de la imagen */
    gap: clamp(12px, 1.6vw, 18px);
    padding: clamp(24px, 3.5vw, 44px);
}
.blog-feature__meta {
    font-family: var(--ax-font-mono);
    font-size: 11px; letter-spacing: 0.16em; text-transform: uppercase;
    color: var(--ax-muted);
}
.blog-feature__meta b { color: var(--ax-orange); font-weight: 700; }
.blog-feature__title {
    font-family: var(--ax-font-display); text-transform: uppercase;
    font-size: clamp(1.7rem, 3.4vw, 2.8rem); line-height: .98;
    letter-spacing: 0.005em; margin: 0; color: var(--ax-ink);
}
.blog-feature__title a { color: inherit; text-decoration: none; }
.blog-feature__excerpt {
    font-size: clamp(1rem, 1.3vw, 1.12rem); line-height: 1.6;
    color: #3A4150; margin: 0;
}
.blog-feature__excerpt a { color: var(--ax-ink); font-weight: 700; }

/* ── Botón chunky press (CTAs) ───────────────────────────────────── */
.blog-btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 14px 28px; min-height: 44px;
    font-family: var(--ax-font-body); font-weight: 700;
    text-transform: uppercase; letter-spacing: 0.05em;
    border: none; border-radius: 0; cursor: pointer; text-decoration: none;
    transition: transform var(--ax-motion-fast) var(--ax-ease-out),
                box-shadow var(--ax-motion-fast) var(--ax-ease-out);
}
/* anula el underline global de a:hover en todos los estados del botón */
.blog-page a.blog-btn,
.blog-page a.blog-btn:hover,
.blog-page a.blog-btn:focus { text-decoration: none; }
.blog-btn--primary { background: var(--ax-orange); color: var(--ax-paper); box-shadow: 0 6px 0 var(--ax-orange-deep); }
.blog-btn--primary:hover  { transform: translateY(-2px); color: var(--ax-paper); }
.blog-btn--primary:active { transform: translateY(2px); box-shadow: 0 0 0 var(--ax-orange-deep); }
.blog-btn--ghost { background: transparent; color: var(--ax-paper); border: 1.5px solid var(--ax-paper); }
.blog-btn--ghost:hover { background: var(--ax-paper); color: var(--ax-ink); }
.blog-btn .fas, .blog-btn .fab { transition: transform var(--ax-motion-base) var(--ax-ease-out); }
.blog-btn:hover .fa-arrow-right { transform: translateX(4px); }

/* ════════════════════════════════════════════════════════════════
   02 · GRID — Cards (top-border + media-16-9) · lift-orange
   ════════════════════════════════════════════════════════════════ */
.blog-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: clamp(20px, 2.6vw, 36px);
}
@media (max-width: 1024px) { .blog-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 620px)  { .blog-grid { grid-template-columns: 1fr; } }

.blog-card {
    display: flex; flex-direction: column;
    background: var(--ax-white);
    border: 1px solid var(--ax-rule);
    border-top: 2px solid var(--ax-orange);
    transition: transform var(--ax-motion-base) var(--ax-ease-out),
                box-shadow var(--ax-motion-base) var(--ax-ease-out);
}
.blog-card:hover {
    transform: translate(-3px, -3px);
    box-shadow: 5px 5px 0 var(--ax-orange);
}
.blog-card__media { aspect-ratio: 1 / 1; overflow: hidden; }   /* imágenes 1080×1080 */
.blog-card__media img { width: 100%; height: 100%; object-fit: cover; display: block; }
.blog-card__body {
    display: flex; flex-direction: column; gap: 10px;
    padding: clamp(16px, 1.6vw, 22px);
    flex: 1 1 auto;
}
.blog-card__meta {
    font-family: var(--ax-font-mono);
    font-size: 10.5px; letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--ax-muted);
}
.blog-card__meta b { color: var(--ax-orange); font-weight: 700; }
.blog-card__title {
    font-family: var(--ax-font-display); text-transform: uppercase;
    font-size: clamp(1.15rem, 1.7vw, 1.45rem); line-height: 1.04;
    letter-spacing: 0.01em; margin: 0; color: var(--ax-ink);
}
.blog-card__title a { color: inherit; text-decoration: none; }
.blog-card__title a:hover { color: var(--ax-orange); }
.blog-card__excerpt {
    font-size: .95rem; line-height: 1.55; color: #4A5160; margin: 0;
}
.blog-card__excerpt a { color: var(--ax-ink); font-weight: 700; }
/* link "Leer más" — hover side-shift */
.blog-card__link {
    margin-top: auto; padding-top: 6px;
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--ax-font-body); font-weight: 700;
    font-size: .78rem; letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--ax-ink); text-decoration: none;
    align-self: flex-start;
}
.blog-card__link::after {
    content: '→'; color: var(--ax-orange);
    transition: transform var(--ax-motion-base) var(--ax-ease-out);
}
.blog-card__link:hover { color: var(--ax-orange); }
.blog-card__link:hover::after { transform: translateX(5px); }

/* ════════════════════════════════════════════════════════════════
   03 · CTA cierre — Manifiesto · ink (→ footer) · Bleed
   ════════════════════════════════════════════════════════════════ */
.blog-cta { background: var(--ax-ink); color: var(--ax-paper); padding: clamp(56px, 9vw, 110px) 0; }
.blog-cta__title {
    font-family: var(--ax-font-display); text-transform: uppercase;
    font-size: clamp(2.2rem, 6vw, 5rem) !important; line-height: .9; letter-spacing: -0.01em;
    margin: 0 0 clamp(1rem, 2vw, 1.5rem); color: var(--ax-paper); max-width: 18ch;
}
.blog-cta__title em {
    font-family: var(--ax-font-accent); font-style: italic; font-weight: 400;
    text-transform: lowercase; letter-spacing: -0.03em; color: var(--ax-orange);
}
.blog-cta__lede {
    font-family: var(--ax-font-accent); font-style: italic;
    font-size: clamp(1.05rem, 1.6vw, 1.35rem); color: var(--ax-muted-dark);
    margin: 0 0 clamp(1.8rem, 3vw, 2.6rem); max-width: 46ch;
}
.blog-cta__actions { display: flex; flex-wrap: wrap; gap: 16px; }

/* ── Focus visible (a11y) ────────────────────────────────────────── */
.blog-page a:focus-visible,
.blog-page button:focus-visible {
    outline: 3px solid var(--ax-orange); outline-offset: 3px;
}
.blog-section--ink a:focus-visible { outline-color: var(--ax-paper); }

/* ── Motion safe ─────────────────────────────────────────────────── */
@media (prefers-reduced-motion: reduce) {
    .blog-marquee__track { animation: none; }
    .blog-feature, .blog-card, .blog-btn,
    .blog-card__link::after, .blog-btn .fa-arrow-right { transition: none; }
    .blog-feature:hover, .blog-card:hover { transform: none; }
    .blog-btn--primary:hover, .blog-btn--primary:active { transform: none; }
    .blog-card__link:hover::after, .blog-btn:hover .fa-arrow-right { transform: none; }
}
