/* ============================================================================
   GacetaSPIN — "Tarde de Cierre"
   Dirección aprobada por el comité (UI · Editorial · Motion · UX).
   Principios: gaceta de verdad (no blog) · la firma diaria es ritual ·
   UN gesto rojo audaz · masthead claro / Dojo oscuro (no dos zonas negras) ·
   bloque "Por qué importa / Qué hacer" como columna vertebral · sistema 4/8 ·
   tipografía Fraunces protagonista · micro-motion sobrio (150ms) · AA verificado.
   ========================================================================== */

:root {
    /* Superficie — crema cálida real, con cuerpo (no el #FAFAF8 cobarde) */
    --paper:   #ECE7DB;   /* fondo de la gaceta */
    --card:    #FBFAF5;   /* tarjetas: se elevan sobre la crema */
    --band:    #E3DDCD;   /* bandas / chips inactivos */
    --ink:     #16140F;   /* negro tinta, profundo */
    --ink2:    #5C5850;   /* texto secundario (AA sobre crema) */
    --ink3:    #908A7C;   /* metadatos, ligero */
    --rule:    #D4CDBB;   /* filetes finos */
    --rule2:   #16140F;   /* filete editorial grueso */

    /* El rojo — protagonista una vez, no diez veces tímido */
    --red:     #CE2F26;   /* gesto gráfico: filete de marca, números, play */
    --redt:    #B5241C;   /* texto/CTA rojo: pasa AA sobre crema */
    --red-ink: #6E1610;   /* rojo muy oscuro para detalles sobre claro */

    /* Zona oscura — reservada al Dojo (el único negro de la página) */
    --dark:    #16140F;
    --dark2:   #211E17;
    --cream:   #F4F0E6;   /* CTA de patrocinador sobre oscuro */
    --salmon:  #F09A8E;   /* acento cálido sobre oscuro */

    /* Sistema de espaciado 4 / 8 */
    --s1: 4px;  --s2: 8px;  --s3: 12px; --s4: 16px;
    --s5: 24px; --s6: 32px; --s7: 48px; --s8: 64px;

    --maxw: 1120px;
    --r-sm: 6px; --r-md: 10px; --r-lg: 16px;

    --font-sans:  'Poppins', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --font-serif: 'Fraunces', Georgia, 'Times New Roman', serif;

    --t-fast: 130ms cubic-bezier(.2, .6, .2, 1);
    --t-base: 180ms cubic-bezier(.2, .6, .2, 1);
}

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }

body {
    margin: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.55;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
h1, h2, h3, h4 { margin: 0; }
img { max-width: 100%; }

.container { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--s5); }

.skip {
    position: absolute; left: -9999px; top: 0;
    background: var(--ink); color: #fff;
    padding: var(--s2) var(--s4); border-radius: var(--r-sm); z-index: 20;
}
.skip:focus { left: 12px; top: 12px; }

a:focus-visible, button:focus-visible, input:focus-visible, textarea:focus-visible {
    outline: 2px solid var(--redt);
    outline-offset: 2px;
    border-radius: 2px;
}

/* ── Utilidades tipográficas ──────────────────────────────────────────────── */
.serif { font-family: var(--font-serif); }
.lede  { color: var(--ink2); }
.ql    { color: var(--ink); font-weight: 600; }
.num   { font-family: var(--font-serif); font-weight: 600; color: var(--ink); font-feature-settings: "tnum" 1; }
.meta  { font-size: 13px; color: var(--ink2); font-weight: 500; }

.kick {
    font-size: 11.5px; text-transform: uppercase; letter-spacing: .16em;
    font-weight: 700; color: var(--redt); margin: 0;
    display: inline-flex; align-items: center; gap: 8px;
}
.kick::before {
    content: ""; width: 18px; height: 2px; background: var(--red);
    display: inline-block; flex: 0 0 auto;
}
.kick-link { color: inherit; text-decoration: none; transition: color var(--t-fast); }
.kick-link:hover { color: var(--ink); }

/* ── Navegación del artículo (serie + más de la categoría) ─────────────────── */
.series-nav { margin-top: var(--s6); padding-top: var(--s4); border-top: 1px solid var(--rule); }
.series-nav-links { display: flex; justify-content: space-between; gap: var(--s4); margin-top: var(--s2); flex-wrap: wrap; }
.more-cat { margin-top: var(--s5); }
.more-cat-list { list-style: none; padding: 0; margin: var(--s2) 0 0; }
.more-cat-list li {
    display: flex; align-items: baseline; justify-content: space-between; gap: var(--s3);
    padding: var(--s2) 0; border-bottom: 1px solid var(--rule);
}
.more-cat-list a { color: var(--ink); text-decoration: none; font-weight: 600; transition: color var(--t-fast); }
.more-cat-list a:hover { color: var(--redt); }
.label {
    font-size: 11px; text-transform: uppercase; letter-spacing: .15em;
    font-weight: 600; color: var(--ink2);
}

/* ── Botones ──────────────────────────────────────────────────────────────── */
.btn {
    font-family: var(--font-sans); font-size: 14px; font-weight: 600;
    border-radius: var(--r-sm); padding: 10px 18px; cursor: pointer;
    border: 1px solid transparent; display: inline-flex; align-items: center;
    gap: 8px; transition: transform var(--t-fast), filter var(--t-fast), background var(--t-fast);
}
.btn:active { transform: translateY(1px); }
.btn-red   { background: var(--redt); color: #fff; }
.btn-red:hover { filter: brightness(1.07); }
.btn-cream { background: var(--cream); color: var(--ink); }
.btn-cream:hover { filter: brightness(.96); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--ink); }
.btn-ghost:hover { background: var(--ink); color: var(--paper); }

.link {
    font-size: 14px; font-weight: 600; color: var(--redt);
    border-bottom: 1.5px solid var(--redt); padding-bottom: 1px;
    transition: color var(--t-fast), border-color var(--t-fast);
}
.link:hover { color: var(--red-ink); border-color: var(--red-ink); }
.linkn {
    font-size: 14px; font-weight: 500; color: var(--ink);
    border-bottom: 1px solid var(--ink); padding-bottom: 1px;
    transition: opacity var(--t-fast);
}
.linkn:hover { opacity: .6; }

/* ════════════════════════════════════════════════════════════════════════════
   MASTHEAD — claro, con el gesto rojo de marca. El negro se reserva al Dojo.
   ════════════════════════════════════════════════════════════════════════════ */
.site-masthead {
    border-top: 3px solid var(--red);     /* el gesto rojo, una vez, arriba */
    background: var(--paper);
    position: sticky; top: 0; z-index: 10;
    border-bottom: 1px solid var(--rule);
}
.masthead-inner {
    max-width: var(--maxw); margin: 0 auto; padding: var(--s3) var(--s5);
    display: flex; align-items: center; justify-content: space-between; gap: var(--s4);
    position: relative;
}
.brand {
    display: flex; align-items: center; gap: 10px;
    font-weight: 700; letter-spacing: .22em; font-size: 15px; color: var(--ink);
}
.brand svg { display: block; }

.main-nav { display: flex; align-items: center; gap: var(--s5); }
.main-nav a:not(.btn-sub) {
    font-size: 14px; font-weight: 500; color: var(--ink2);
    transition: color var(--t-fast); position: relative; padding: 2px 0;
}
.main-nav a:not(.btn-sub):hover { color: var(--ink); }
.main-nav a:not(.btn-sub)[aria-current="page"] { color: var(--ink); font-weight: 600; }
.main-nav a:not(.btn-sub)[aria-current="page"]::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: -4px;
    height: 2px; background: var(--red);
}
.nav-sep { width: 1px; height: 18px; background: var(--rule); }
.nav-user { font-weight: 600 !important; color: var(--ink) !important; }
.nav-entrar { color: var(--ink2) !important; }
.btn-sub {
    font-size: 13px; font-weight: 600; color: #fff !important;
    background: var(--redt); padding: 9px 16px; border-radius: var(--r-sm);
    transition: filter var(--t-fast);
}
.btn-sub:hover { filter: brightness(1.07); }
.nav-toggle { display: none; background: none; border: 0; color: var(--ink); cursor: pointer; padding: 4px; line-height: 0; }

/* ── Cabecera de edición — LA FIRMA DIARIA (ritual tipográfico) ───────────── */
.dateline {
    display: flex; align-items: flex-end; justify-content: space-between;
    gap: var(--s4); border-bottom: 2px solid var(--ink);
    padding: var(--s5) 0 var(--s3); margin-bottom: var(--s2);
}
.dateline-edition { display: flex; align-items: baseline; gap: var(--s3); }
.dateline-edition .ed-no {
    font-family: var(--font-serif); font-weight: 700; font-size: 40px;
    line-height: .9; color: var(--ink); letter-spacing: -.02em;
    font-feature-settings: "tnum" 1;
}
.dateline-edition .ed-no small {
    font-size: 15px; color: var(--redt); font-weight: 600; vertical-align: top;
}
.dateline-edition .ed-day {
    font-family: var(--font-serif); font-style: italic; font-weight: 500;
    font-size: 18px; color: var(--ink2);
}
.dateline-tag {
    font-size: 11px; text-transform: uppercase; letter-spacing: .15em;
    font-weight: 600; color: var(--ink2); text-align: right; max-width: 240px;
}
.tldr {
    font-size: 13px; color: var(--ink2); margin: var(--s3) 0 0; line-height: 1.6;
    display: flex; align-items: baseline; gap: var(--s3);
}
.tldr strong {
    font-size: 10px; text-transform: uppercase; letter-spacing: .16em;
    color: var(--ink); font-weight: 700; flex-shrink: 0;
    background: var(--band); padding: 2px 8px; border-radius: 3px;
}

/* Masthead simple (páginas internas con dateline corto) */
.masthead {
    display: flex; justify-content: space-between; align-items: baseline;
    border-top: 2px solid var(--ink); border-bottom: 1px solid var(--rule);
    padding: var(--s3) 0; gap: var(--s4); flex-wrap: wrap;
}

/* ════════════════════════════════════════════════════════════════════════════
   HERO — la señal del día. Headline Fraunces protagonista, escalado con clamp.
   ════════════════════════════════════════════════════════════════════════════ */
.hero {
    display: grid; grid-template-columns: 1.7fr 1fr; gap: var(--s7);
    align-items: start; padding: var(--s7) 0 var(--s6);
}
.hero h1 {
    font-family: var(--font-serif); font-weight: 600;
    font-size: clamp(34px, 5.2vw, 56px); line-height: 1.04;
    letter-spacing: -.02em; margin-top: var(--s3);
}
.hero h1 a { transition: color var(--t-fast); }
.hero h1 a:hover { color: var(--redt); }
.hero .lede { font-size: 17px; line-height: 1.5; margin: var(--s4) 0 0; max-width: 40ch; }

/* Bloque firma "Por qué importa / Qué hacer hoy" — la columna vertebral */
.signal-points {
    display: flex; flex-direction: column; gap: 0;
    margin-top: var(--s5); border-top: 1px solid var(--rule);
}
.signal-points p {
    margin: 0; font-size: 14.5px; line-height: 1.5;
    padding: var(--s3) 0; border-bottom: 1px solid var(--rule);
    display: grid; grid-template-columns: 158px 1fr; gap: var(--s3);
}
.signal-points .ql {
    font-size: 11px; text-transform: uppercase; letter-spacing: .1em;
    color: var(--redt); font-weight: 700; padding-top: 2px; white-space: nowrap;
}
.actions {
    display: flex; align-items: center; gap: var(--s5);
    margin-top: var(--s5); flex-wrap: wrap;
}

/* ── Tarjeta Spin Daily (aside del hero) ──────────────────────────────────── */
.card {
    border: 1px solid var(--rule); border-radius: var(--r-md);
    background: var(--card); padding: var(--s5);
    transition: border-color var(--t-fast), transform var(--t-fast);
}
.player { display: flex; align-items: center; gap: var(--s3); }
.play {
    width: 52px; height: 52px; border-radius: 50%;
    background: var(--red); border: none; color: #fff;
    display: inline-flex; align-items: center; justify-content: center;
    flex: 0 0 auto; cursor: pointer; transition: transform var(--t-fast), filter var(--t-fast);
    box-shadow: 0 4px 14px rgba(206, 47, 38, .28);
}
.play:hover { transform: scale(1.06); filter: brightness(1.05); }
.wave { display: flex; align-items: flex-end; gap: 3px; height: 36px; margin-top: var(--s4); }
.wave span { width: 3px; border-radius: 2px; background: #C9C1AE; transition: background var(--t-base); }
.wave span.on { background: var(--red); }
.wave.is-playing span { background: var(--red); animation: wavepulse .9s ease-in-out infinite; }
.wave.is-playing span:nth-child(2n) { animation-delay: .15s; }
.wave.is-playing span:nth-child(3n) { animation-delay: .3s; }
.wave.is-playing span:nth-child(4n) { animation-delay: .45s; }
@keyframes wavepulse { 0%, 100% { transform: scaleY(.5); } 50% { transform: scaleY(1); } }

/* ── Tarjeta Spin Daily — presencia de audio (comité ronda 2) ─────────────── */
.spin-card {
    border: 1px solid var(--rule); border-radius: var(--r-md);
    overflow: hidden; transition: border-color var(--t-fast);
    display: flex; flex-direction: column;
}
.hero > aside { align-self: stretch; }
.hero > aside .spin-card { height: 100%; }
.spin-card:hover { border-color: var(--ink); }
.spin-card-head { background: var(--dark); padding: var(--s3) var(--s5); flex-shrink: 0; }
.spin-card-head .kick { color: var(--salmon); }
.spin-card-head .kick::before { background: var(--salmon); }
.spin-card-body { background: var(--card); padding: var(--s5); flex: 1; display: flex; flex-direction: column; }
.spin-card-body > div:last-child { margin-top: auto; }
.spin-card-title {
    font-family: var(--font-serif); font-size: 18px; font-weight: 600;
    line-height: 1.2; display: block; margin-top: var(--s3);
}

/* ════════════════════════════════════════════════════════════════════════════
   BANDA DE SUSCRIPCIÓN — prominente, no enterrada (fix UX).
   ════════════════════════════════════════════════════════════════════════════ */
/* Banda editorial de suscripción — prominente vía reglas gruesas y rojo,
   NO oscura: el negro pertenece al módulo ZonaSPIN/Dojo. */
.subscribe {
    background: var(--card); color: var(--ink);
    border-top: 3px solid var(--ink); border-bottom: 3px solid var(--ink);
    padding: var(--s6) var(--s5);
    display: flex; align-items: center; justify-content: space-between;
    gap: var(--s6); flex-wrap: wrap; margin: var(--s5) 0 var(--s7);
    position: relative;
}
.subscribe h2 {
    font-family: var(--font-serif); font-size: clamp(20px, 2.6vw, 27px);
    font-weight: 600; letter-spacing: -.01em; line-height: 1.15; color: var(--ink);
}
.subscribe h2 .accent { color: var(--redt); }
.subscribe .lede { color: var(--ink2); font-size: 13.5px; }
.subscribe form { display: flex; align-items: center; gap: var(--s3); flex: 1; min-width: 280px; }
.email {
    flex: 1; min-width: 160px; border: none;
    border-bottom: 1.5px solid var(--ink); background: transparent;
    padding: 11px 2px; font-size: 15px; color: var(--ink); font-family: var(--font-sans);
    transition: border-color var(--t-fast);
}
.email::placeholder { color: var(--ink3); }
.email:focus { border-bottom-color: var(--redt); outline: none; }

.sec-head {
    display: flex; align-items: baseline; justify-content: space-between;
    margin-bottom: var(--s5); border-top: 2px solid var(--ink); padding-top: var(--s3);
}

/* Zona señales — fondo --card crea contraste leve con --paper (comité ronda 2) */
.sec-signals {
    background: var(--card);
    margin: 0 calc(-1 * var(--s5)) var(--s7);
    padding: var(--s6) var(--s5);
    border-top: 1px solid var(--rule);
    border-bottom: 1px solid var(--rule);
}

/* ── Rejilla de señales — filete de columna periodístico (comité ronda 2) ─── */
.signals {
    display: grid; grid-template-columns: repeat(3, 1fr);
    gap: 1px; background: var(--rule);
    border: 1px solid var(--rule); border-radius: var(--r-md); overflow: hidden;
}
.signals .card { border: none; border-radius: 0; padding: var(--s5); display: flex; flex-direction: column; }
.signals .card:hover { background: var(--band); }
.signals h3 {
    font-family: var(--font-serif); font-size: 20px; font-weight: 600;
    line-height: 1.18; margin-top: var(--s2);
}
.signals h3 a { transition: color var(--t-fast); }
.signals h3 a:hover { color: var(--redt); }
.why { font-size: 13.5px; margin: var(--s3) 0 0; color: var(--ink2); line-height: 1.5; }
.why .ql { color: var(--redt); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; }
.signal-foot {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: auto; padding-top: var(--s4);
}

/* ════════════════════════════════════════════════════════════════════════════
   EL DOJO — la ÚNICA zona oscura. Por eso destaca (fix Motion/UI).
   ════════════════════════════════════════════════════════════════════════════ */
.dojo {
    background: var(--dark); border-radius: var(--r-lg);
    padding: var(--s7) var(--s6); color: var(--cream); margin: var(--s7) 0;
    position: relative; overflow: hidden;
}
.dojo::before {
    content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--red);
}
.dojo-top {
    display: flex; align-items: center; justify-content: space-between;
    gap: var(--s3); flex-wrap: wrap;
}
.dojo .kick { color: var(--salmon); }
.dojo .kick::before { background: var(--salmon); }
.dojo h2 {
    font-family: var(--font-serif); font-size: clamp(28px, 4vw, 42px);
    font-weight: 600; line-height: 1.08; margin-top: var(--s4); color: #fff;
}
.dojo h2::first-letter { color: var(--salmon); }
.dojo .reto { font-size: 15px; margin: var(--s4) 0 0; color: #C7C1B3; max-width: 64ch; line-height: 1.6; }
.dojo .reto b { color: var(--salmon); font-weight: 600; }
.dojo .trainable {
    font-family: var(--font-serif); font-style: italic; font-size: 17px;
    color: #A39E90; margin: var(--s3) 0 0; line-height: 1.45;
}
.dojo-foot { display: flex; align-items: center; gap: var(--s5); margin-top: var(--s6); flex-wrap: wrap; }
.dojo-foot .proof { font-size: 14px; color: #948F82; font-weight: 500; }
.dojo-foot .proof .num { color: var(--cream); }

/* ════════════════════════════════════════════════════════════════════════════
   OBJECIÓN DE LA SEMANA — antes sin estilo. Bloque editorial con filete rojo.
   ════════════════════════════════════════════════════════════════════════════ */
.objecion {
    border: 1px solid var(--rule); border-left: 4px solid var(--red);
    border-radius: var(--r-md); background: var(--card);
    padding: var(--s6); margin: var(--s7) 0;
}
.objecion h2 {
    font-family: var(--font-serif); font-size: clamp(20px, 2.6vw, 26px);
    font-weight: 600; line-height: 1.2; margin-top: var(--s4); letter-spacing: -.01em;
}
.objecion .lede { font-size: 15px; margin: var(--s3) 0 0; max-width: 62ch; }
.objecion-form { margin-top: var(--s5); }

/* ════════════════════════════════════════════════════════════════════════════
   PIE
   ════════════════════════════════════════════════════════════════════════════ */
.site-footer {
    border-top: 2px solid var(--ink); margin-top: var(--s7);
    padding: var(--s5) 0 var(--s7);
}
.site-footer .label { letter-spacing: .12em; }
.footer-map { display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: var(--s5); }
.footer-col { display: flex; flex-direction: column; gap: 7px; }
.footer-h {
    font-size: 11px; font-weight: 700; text-transform: uppercase;
    letter-spacing: .12em; color: var(--ink2); margin-bottom: 4px;
}
.footer-col a { font-size: 13.5px; color: var(--ink); text-decoration: none; transition: color var(--t-fast); }
.footer-col a:hover { color: var(--redt); }
.footer-base { margin-top: var(--s5); padding-top: var(--s4); border-top: 1px solid var(--rule); }

/* ════════════════════════════════════════════════════════════════════════════
   PÁGINA DE ARTÍCULO
   ════════════════════════════════════════════════════════════════════════════ */
.article { max-width: 760px; margin: 0 auto; padding-top: var(--s5); }
.article .kick { margin-top: var(--s6); }
.article h1 {
    font-family: var(--font-serif); font-size: clamp(30px, 4.6vw, 50px);
    font-weight: 600; line-height: 1.06; letter-spacing: -.02em; margin-top: var(--s3);
}
.article-dek {
    font-size: 19px; color: var(--ink2); line-height: 1.5;
    margin: var(--s4) 0 0; max-width: 60ch;
}
.article .meta { margin-top: var(--s4); padding-bottom: var(--s4); border-bottom: 1px solid var(--rule); }
.article-body { margin-top: var(--s5); max-width: 64ch; }
.article-body p { font-size: 17px; line-height: 1.72; margin: var(--s2) 0 0; }
.blk {
    font-size: 12px; text-transform: uppercase; letter-spacing: .14em;
    color: var(--redt); font-weight: 700; margin: var(--s6) 0 0;
    display: flex; align-items: center; gap: 8px;
}
.blk::before { content: ""; width: 16px; height: 2px; background: var(--red); display: inline-block; }

.rt {
    font-size: 12px; font-weight: 600; color: var(--ink2);
    background: var(--band); border-radius: 20px; padding: 3px 11px;
}

/* ── Guion del día (copy-paste por canal) ─────────────────────────────────── */
.guion { margin-top: var(--s6); }
.guion-top { display: flex; align-items: center; justify-content: space-between; gap: var(--s3); flex-wrap: wrap; }
.guion-controls { display: inline-flex; align-items: center; gap: var(--s3); flex-wrap: wrap; }
.loc-tag {
    font-size: 11px; font-weight: 700; letter-spacing: .04em; color: #2C5E3F;
    background: #E6EEE7; border-radius: 20px; padding: 2px 10px;
}
.lang-toggle { display: inline-flex; border: 1px solid var(--rule); border-radius: var(--r-sm); overflow: hidden; }
.lang-btn {
    font-family: var(--font-sans); font-size: 12px; font-weight: 700; letter-spacing: .04em;
    color: var(--ink2); background: var(--card); border: 0; padding: 4px 12px; cursor: pointer;
    transition: background var(--t-fast), color var(--t-fast);
}
.lang-btn + .lang-btn { border-left: 1px solid var(--rule); }
.lang-btn.on { background: var(--redt); color: #fff; }
.guion-block {
    border: 1px solid var(--rule); border-radius: var(--r-md);
    padding: var(--s3) var(--s4); margin-top: var(--s3); background: var(--card);
    transition: border-color var(--t-fast);
}
.guion-block:hover { border-color: var(--ink3); }
.guion-head { display: flex; align-items: center; justify-content: space-between; gap: var(--s3); margin-bottom: var(--s2); }
.guion-canal { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .12em; color: var(--ink2); }
.guion-text { font-size: 14.5px; line-height: 1.6; margin: 0; white-space: pre-wrap; }
.copy-btn {
    font-family: var(--font-sans); font-size: 12px; font-weight: 600; color: var(--redt);
    background: transparent; border: 1px solid var(--rule); border-radius: var(--r-sm);
    padding: 5px 12px; cursor: pointer; transition: border-color var(--t-fast), color var(--t-fast);
}
.copy-btn:hover { border-color: var(--redt); }
.copy-btn.is-copied { color: #0F6E56; border-color: #9FE1CB; }

/* ── Guiones editables (merge-fields) ─────────────────────────────────────── */
.mf-panel {
    margin-top: var(--s3); padding: var(--s3) var(--s4);
    border: 1px solid var(--rule); border-radius: var(--r-md);
    background: var(--paper);
}
.mf-panel-head {
    margin: 0 0 var(--s3); font-size: 12px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .08em; color: var(--ink2);
}
.mf-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); gap: var(--s3); }
.mf-field { display: flex; flex-direction: column; gap: 4px; }
.mf-field span { font-size: 12px; font-weight: 600; color: var(--ink2); }
.mf-field input {
    font-family: var(--font-sans); font-size: 14px; color: var(--ink);
    background: var(--card); border: 1px solid var(--rule); border-radius: var(--r-sm);
    padding: 7px 10px; transition: border-color var(--t-fast);
}
.mf-field input:focus { outline: none; border-color: var(--redt); }
.mf {
    background: #FBEAD0; border-radius: 3px; padding: 0 2px;
    box-shadow: inset 0 -1px 0 rgba(180, 120, 30, .35);
}
.mf--filled { background: #D8EFE3; box-shadow: inset 0 -1px 0 rgba(15, 110, 86, .35); color: var(--ink); }

/* ── Para tu equipo ───────────────────────────────────────────────────────── */
.team-block { margin-top: var(--s5); border-left: 3px solid var(--redt); padding: var(--s1) 0 var(--s1) var(--s4); }
.team-text { font-size: 14.5px; line-height: 1.65; margin: var(--s2) 0 0; white-space: pre-wrap; color: var(--ink); }

.practice-cta {
    margin-top: var(--s6); padding: var(--s4) var(--s5);
    border: 1px solid var(--rule); border-radius: var(--r-md); background: var(--card);
}
.share { margin-top: var(--s7); padding-top: var(--s1); border-top: 1px solid var(--rule); }
.share .blk { margin-top: var(--s5); }

/* ════════════════════════════════════════════════════════════════════════════
   PÁGINA DOJO
   ════════════════════════════════════════════════════════════════════════════ */
.dojo-page { max-width: 760px; margin: 0 auto; padding-top: var(--s5); }
.dojo-meta { display: flex; align-items: center; gap: var(--s3); }
.kicker-tag { font-size: 11px; text-transform: uppercase; letter-spacing: .12em; font-weight: 700; color: var(--redt); }
.level-badge {
    font-size: 11px; font-weight: 600; color: var(--ink2); background: var(--band);
    border-radius: 20px; padding: 3px 11px; text-transform: capitalize;
}
.dojo-page h1 {
    font-family: var(--font-serif); font-size: clamp(26px, 4vw, 42px);
    font-weight: 600; line-height: 1.1; letter-spacing: -.02em; margin: var(--s4) 0 0;
}
.reto2 { font-size: 15.5px; margin: var(--s4) 0 0; line-height: 1.6; }
.reto2 b { color: var(--redt); font-weight: 600; }
.answers { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s4); margin-top: var(--s6); }
.ans { border: 1px solid var(--rule); border-radius: var(--r-md); padding: var(--s4) var(--s5); background: var(--card); }
.ans p { font-size: 14px; line-height: 1.6; margin: var(--s2) 0 0; }
.ans-label { font-size: 11px; text-transform: uppercase; letter-spacing: .1em; font-weight: 700; color: #A32D2D; }
.ans-bad p { color: var(--ink2); }
.ans-good { border-color: #9FE1CB; background: #F1FBF7; }
.ans-label-good { color: #0F6E56; }
.spin { margin-top: var(--s6); border-left: 3px solid var(--redt); padding-left: var(--s4); }
.spin p { font-size: 19px; font-family: var(--font-serif); font-style: italic; line-height: 1.4; margin: var(--s2) 0 0; }
.dojo-cta {
    margin-top: var(--s7); display: flex; align-items: center; gap: var(--s5);
    flex-wrap: wrap; background: var(--ink); color: var(--cream);
    border-radius: var(--r-lg); padding: var(--s5) var(--s6);
    position: relative; overflow: hidden;
}
.dojo-cta::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--red); }
.proof2 { font-size: 13px; color: #948F82; }
.proof2 strong { color: var(--cream); font-family: var(--font-serif); font-size: 17px; }

/* ════════════════════════════════════════════════════════════════════════════
   FILTROS (chips) — con micro-motion
   ════════════════════════════════════════════════════════════════════════════ */
.search { display: flex; gap: var(--s2); align-items: center; margin-top: var(--s4); flex-wrap: wrap; }
.search input {
    flex: 1 1 240px; font-family: var(--font-sans); font-size: 14.5px; color: var(--ink);
    background: var(--card); border: 1px solid var(--rule); border-radius: var(--r-sm);
    padding: 9px 12px; transition: border-color var(--t-fast);
}
.search input:focus { outline: none; border-color: var(--redt); }
.chips { display: flex; flex-wrap: wrap; gap: var(--s2); margin-top: var(--s4); }
.chips-moments { margin-top: var(--s2); }

/* ── Hemeroteca ───────────────────────────────────────────────────────────── */
.edition { margin-top: var(--s6); }
.edition + .edition { border-top: 1px solid var(--rule); padding-top: var(--s5); }
.edition-head { display: flex; align-items: baseline; gap: var(--s3); margin-bottom: var(--s3); }
.edition-no { font-family: var(--font-serif); font-size: 22px; font-weight: 700; color: var(--red); }
.chip {
    font-size: 13px; color: var(--ink2); border: 1px solid var(--rule);
    border-radius: 20px; padding: 5px 14px; white-space: nowrap;
    transition: border-color var(--t-fast), color var(--t-fast), background var(--t-fast);
}
.chip:hover { border-color: var(--ink); color: var(--ink); }
.chip.on { background: var(--ink); color: var(--paper); border-color: var(--ink); }
.chip-moment { font-size: 12.5px; color: var(--redt); border-color: #E2B6B1; }
.chip-moment.on { background: var(--redt); color: #fff; border-color: var(--redt); }
.card-tags { display: flex; align-items: center; gap: var(--s2); flex-wrap: wrap; }
.moment-badge {
    font-size: 10.5px; font-weight: 600; text-transform: uppercase; letter-spacing: .08em;
    color: var(--redt); background: #F6E2DF; border-radius: 20px; padding: 2px 9px;
}
/* Método de venta (SPIN · Implicación). Pill con filete, sobrio. */
.method-badge {
    display: inline-block; font-size: 10.5px; font-weight: 700; letter-spacing: .04em;
    color: var(--ink); background: transparent; border: 1px solid var(--rule);
    border-radius: 20px; padding: 1px 9px; text-transform: none; vertical-align: middle;
}
.method-badge--dark { color: var(--cream); border-color: rgba(244, 240, 230, .35); }
.dojo-same-method { font-size: 12.5px; color: var(--salmon); margin: -2px 0 var(--s2); }

/* ════════════════════════════════════════════════════════════════════════════
   FORMULARIOS (comentarios + objeción) — antes sin estilo.
   ════════════════════════════════════════════════════════════════════════════ */
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s3); }
.field { display: flex; flex-direction: column; gap: 6px; margin-top: var(--s3); }
.field label {
    font-size: 11px; text-transform: uppercase; letter-spacing: .1em;
    font-weight: 600; color: var(--ink2);
}
.field .hint { text-transform: none; letter-spacing: 0; font-weight: 500; color: var(--ink3); }
.field input, .field textarea, .comment-form input, .comment-form textarea, .objecion-form input, .objecion-form textarea {
    font-family: var(--font-sans); font-size: 14.5px; color: var(--ink);
    background: var(--paper); border: 1px solid var(--rule); border-radius: var(--r-sm);
    padding: 10px 12px; transition: border-color var(--t-fast);
}
.field input:focus, .field textarea:focus { border-color: var(--ink); outline: none; }
.field textarea { resize: vertical; line-height: 1.55; }

.flash { border-radius: var(--r-md); padding: var(--s3) var(--s4); font-size: 14px; margin: var(--s4) 0; }
.flash-ok { background: #F1FBF7; border: 1px solid #9FE1CB; color: #0F6E56; }

.comments { margin-top: var(--s7); padding-top: var(--s5); border-top: 2px solid var(--ink); }
.comment-list { display: flex; flex-direction: column; gap: var(--s4); margin-top: var(--s5); }
.comment { border: 1px solid var(--rule); border-radius: var(--r-md); padding: var(--s4) var(--s5); background: var(--card); }
.comment-meta { display: flex; align-items: baseline; gap: var(--s3); margin-bottom: 6px; }
.comment-meta strong { font-size: 14px; font-weight: 600; }
.comment-meta time { font-size: 12px; color: var(--ink3); }
.comment p { font-size: 14.5px; line-height: 1.6; margin: 0; }
.empty-comments { color: var(--ink2); font-size: 14.5px; margin-top: var(--s4); }
.comment-form { margin-top: var(--s6); }
.hint { font-size: 12px; color: var(--ink3); }

/* ════════════════════════════════════════════════════════════════════════════
   RESPONSIVE
   ════════════════════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
    .hero { grid-template-columns: 1fr; gap: var(--s5); padding: var(--s6) 0; }
    .signals { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 680px) {
    .container { padding: 0 var(--s4); }
    .masthead-inner { padding: var(--s3) var(--s4); }
    .nav-toggle { display: inline-flex; align-items: center; }
    .main-nav {
        display: none; position: absolute; top: 100%; left: 0; right: 0;
        flex-direction: column; align-items: stretch; gap: var(--s4);
        background: var(--paper); border-bottom: 1px solid var(--rule);
        padding: var(--s4) var(--s4) var(--s5); box-shadow: 0 8px 18px rgba(0, 0, 0, .07);
    }
    .main-nav.is-open { display: flex; }
    .main-nav a { display: block; }
    .nav-sep { display: none; }
    .btn-sub { text-align: center; }
    .signals { grid-template-columns: 1fr; }
    .answers { grid-template-columns: 1fr; }
    .field-row { grid-template-columns: 1fr; }
    .dateline { flex-direction: column; align-items: flex-start; gap: var(--s2); }
    .dateline-tag { text-align: left; }
    .signal-points p { grid-template-columns: 1fr; gap: 2px; }
    .subscribe { padding: var(--s5); }
    .subscribe form { flex-direction: column; align-items: stretch; }
    .subscribe .btn { justify-content: center; }
    .sec-signals { margin-left: calc(-1 * var(--s4)); margin-right: calc(-1 * var(--s4)); padding-left: var(--s4); padding-right: var(--s4); }
}

@media (prefers-reduced-motion: reduce) {
    * { transition: none !important; animation: none !important; }
}

/* ════════════════════════════════════════════════════════════════════════════
   COMPATIBILIDAD — cabeceras de auth/cuenta (login, registro, mi-cuenta).
   Mantienen .site-header / .nav y heredan el lenguaje del nuevo masthead.
   ════════════════════════════════════════════════════════════════════════════ */
.site-header {
    display: flex; align-items: center; justify-content: space-between;
    gap: var(--s4); padding: var(--s4) 0 var(--s3);
    border-top: 3px solid var(--red); border-bottom: 1px solid var(--rule);
    margin-bottom: var(--s5);
}
.nav { display: flex; align-items: center; gap: var(--s5); }
.nav a:not(.btn) { color: var(--ink2); font-size: 14px; font-weight: 500; transition: color var(--t-fast); }
.nav a:not(.btn):hover, .nav a[aria-current="page"] { color: var(--ink); }

.flash-err { background: #FCEEED; border: 1px solid #E9B3AF; color: var(--redt); }

.stat-card .num, .stat-card strong { font-family: var(--font-serif); }
