/*
============================================================
JUEGALIA — DESIGN SYSTEM v2
Editorial cálido · Biblioteca-club de juegos
============================================================
*/

/* ---------- FONTS ---------- */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,400;1,9..144,600;1,9..144,700&family=Manrope:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;500;600&display=swap');

/* ---------- DESIGN TOKENS ---------- */
:root {
    /* Brand — paleta cálida */
    --jg-burgundy:        #8B2635;
    --jg-burgundy-deep:   #6E1E2A;
    --jg-burgundy-soft:   #f4e6e8;
    --jg-mustard:         #D4A24C;
    --jg-mustard-deep:    #B0823A;
    --jg-mustard-soft:    #faf2e0;
    --jg-green:           #4A6B47;
    --jg-green-soft:      #e8efe6;

    /* Neutros cálidos */
    --jg-cream:           #F5EFE0;
    --jg-cream-deep:      #ECE3CD;
    --jg-paper:           #FAF6EC;
    --jg-white:           #FFFFFF;

    /* Texto */
    --jg-ink:             #2A201E;
    --jg-text:            #3A2F2C;
    --jg-text-soft:       rgba(58, 47, 44, 0.78);
    --jg-text-mute:       rgba(58, 47, 44, 0.55);
    --jg-line:            rgba(58, 47, 44, 0.10);
    --jg-line-soft:       rgba(58, 47, 44, 0.06);

    /* Tipografía */
    --jg-serif: 'Fraunces', 'Iowan Old Style', Georgia, serif;
    --jg-sans:  'Manrope', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
    --jg-mono:  'JetBrains Mono', 'IBM Plex Mono', 'Courier New', monospace;

    /* Espaciado */
    --jg-space-1: 0.25rem;
    --jg-space-2: 0.5rem;
    --jg-space-3: 0.75rem;
    --jg-space-4: 1rem;
    --jg-space-5: 1.5rem;
    --jg-space-6: 2rem;
    --jg-space-7: 3rem;
    --jg-space-8: 4rem;
    --jg-space-9: 6rem;
    --jg-space-10: 8rem;

    /* Radios */
    --jg-radius-sm: 4px;
    --jg-radius:    8px;
    --jg-radius-lg: 14px;
    --jg-radius-xl: 20px;

    /* Sombras (capas suaves) */
    --jg-shadow-sm: 0 1px 2px rgba(58, 47, 44, 0.04), 0 2px 4px rgba(58, 47, 44, 0.04);
    --jg-shadow:    0 2px 4px rgba(58, 47, 44, 0.06), 0 8px 24px rgba(58, 47, 44, 0.08);
    --jg-shadow-lg: 0 4px 12px rgba(58, 47, 44, 0.08), 0 16px 48px rgba(58, 47, 44, 0.12);
    --jg-shadow-burgundy: 0 6px 20px rgba(139, 38, 53, 0.18);

    /* Transiciones */
    --jg-trans-fast: 150ms cubic-bezier(0.4, 0, 0.2, 1);
    --jg-trans:      280ms cubic-bezier(0.4, 0, 0.2, 1);
    --jg-trans-slow: 480ms cubic-bezier(0.4, 0, 0.2, 1);

    /* Layout */
    --jg-max:       1200px;
    --jg-max-prose: 720px;
    --jg-max-wide:  1320px;
}

/* ---------- RESET LIGERO ---------- */
*, *::before, *::after { box-sizing: border-box; }

html {
    scroll-behavior: smooth;
    -webkit-text-size-adjust: 100%;
}

body {
    margin: 0;
    background: var(--jg-cream);
    color: var(--jg-text);
    font-family: var(--jg-sans);
    font-size: 17px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    background-image:
        radial-gradient(ellipse at 25% 0%, rgba(212, 162, 76, 0.06), transparent 60%),
        radial-gradient(ellipse at 75% 100%, rgba(139, 38, 53, 0.05), transparent 50%);
    background-attachment: fixed;
    min-height: 100vh;
}

/* Patrón sutil hexagonal de fondo */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image:
        url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='60' height='52' viewBox='0 0 60 52'><path d='M30 0 L60 17 L60 35 L30 52 L0 35 L0 17 Z' fill='none' stroke='%233A2F2C' stroke-width='0.5' opacity='0.04'/></svg>");
    background-size: 60px 52px;
    pointer-events: none;
    z-index: 0;
    opacity: 0.6;
}

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

a {
    color: var(--jg-burgundy);
    text-decoration: none;
    transition: color var(--jg-trans-fast);
}

a:hover {
    color: var(--jg-burgundy-deep);
}

button {
    font: inherit;
    cursor: pointer;
}

/* ---------- TIPOGRAFÍA ---------- */
h1, h2, h3, h4, h5, h6 {
    font-family: var(--jg-serif);
    font-weight: 600;
    color: var(--jg-ink);
    line-height: 1.15;
    letter-spacing: -0.022em;
    margin: 0 0 var(--jg-space-4);
    font-variation-settings: "opsz" 144;
}

h1 { font-size: clamp(2.4rem, 5vw, 4rem); font-weight: 700; }
h2 { font-size: clamp(1.85rem, 3.5vw, 2.6rem); font-weight: 600; }
h3 { font-size: clamp(1.3rem, 2.4vw, 1.65rem); font-weight: 600; }
h4 { font-size: 1.2rem; font-weight: 600; }

p {
    margin: 0 0 var(--jg-space-4);
}

::selection {
    background: var(--jg-burgundy);
    color: var(--jg-cream);
}

/* ---------- ELEMENTOS REUTILIZABLES ---------- */

/* Container responsive */
.jg-container {
    width: 100%;
    max-width: var(--jg-max);
    margin: 0 auto;
    padding: 0 var(--jg-space-5);
    position: relative;
    z-index: 1;
}

.jg-container--prose {
    max-width: var(--jg-max-prose);
}

.jg-container--wide {
    max-width: var(--jg-max-wide);
}

/* Section base */
.jg-section {
    padding: var(--jg-space-9) 0;
    position: relative;
    z-index: 1;
}

.jg-section--tight {
    padding: var(--jg-space-7) 0;
}

.jg-section--cream-deep { background: var(--jg-cream-deep); }
.jg-section--paper { background: var(--jg-paper); }
.jg-section--ink { background: var(--jg-ink); color: var(--jg-cream); }
.jg-section--ink h1, .jg-section--ink h2, .jg-section--ink h3 { color: var(--jg-cream); }

/* Kicker (etiqueta superior tipo magazine) */
.jg-kicker {
    display: inline-flex;
    align-items: center;
    gap: var(--jg-space-2);
    font-family: var(--jg-mono);
    font-size: 0.72rem;
    letter-spacing: 0.18em;
    color: var(--jg-burgundy);
    text-transform: uppercase;
    font-weight: 500;
    margin-bottom: var(--jg-space-4);
}

.jg-kicker::before {
    content: '';
    width: 24px;
    height: 1px;
    background: var(--jg-burgundy);
}

.jg-kicker--mustard {
    color: var(--jg-mustard-deep);
}
.jg-kicker--mustard::before {
    background: var(--jg-mustard-deep);
}

.jg-kicker--cream {
    color: var(--jg-mustard);
}
.jg-kicker--cream::before {
    background: var(--jg-mustard);
}

/* Botones */
.jg-btn {
    display: inline-flex;
    align-items: center;
    gap: var(--jg-space-2);
    padding: 0.95rem 1.6rem;
    border-radius: var(--jg-radius);
    font-family: var(--jg-sans);
    font-weight: 600;
    font-size: 0.95rem;
    letter-spacing: 0.005em;
    transition: all var(--jg-trans);
    cursor: pointer;
    text-decoration: none !important;
    border: 1.5px solid transparent;
    line-height: 1;
    white-space: nowrap;
}

.jg-btn:hover {
    transform: translateY(-1px);
}

.jg-btn--primary {
    background: var(--jg-burgundy);
    color: var(--jg-cream);
    border-color: var(--jg-burgundy);
}
.jg-btn--primary:hover {
    background: var(--jg-burgundy-deep);
    border-color: var(--jg-burgundy-deep);
    color: var(--jg-cream);
    box-shadow: var(--jg-shadow-burgundy);
}

.jg-btn--secondary {
    background: var(--jg-mustard);
    color: var(--jg-ink);
    border-color: var(--jg-mustard);
    margin-top: 0.5rem;
}
.jg-btn--secondary:hover {
    background: var(--jg-mustard-deep);
    border-color: var(--jg-mustard-deep);
    color: var(--jg-ink);
}

.jg-btn--ghost {
    background: transparent;
    color: var(--jg-ink);
    border-color: var(--jg-ink);
}
.jg-btn--ghost:hover {
    background: var(--jg-ink);
    color: var(--jg-cream);
}

.jg-btn--mustard {
    background: var(--jg-mustard);
    color: var(--jg-ink);
    border-color: var(--jg-mustard);
}
.jg-btn--mustard:hover {
    background: var(--jg-mustard-deep);
    border-color: var(--jg-mustard-deep);
    color: var(--jg-cream);
}

.jg-btn__arrow {
    transition: transform var(--jg-trans);
    display: inline-block;
}
.jg-btn:hover .jg-btn__arrow {
    transform: translateX(3px);
}

/* ---------- HEADER / NAV ---------- */
.jg-header {
    position: sticky;
    top: 0;
    z-index: 100;
    background: rgba(245, 239, 224, 0.85);
    backdrop-filter: blur(16px) saturate(1.4);
    -webkit-backdrop-filter: blur(16px) saturate(1.4);
    border-bottom: 1px solid var(--jg-line);
}

.jg-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: var(--jg-space-4) 0;
    gap: var(--jg-space-6);
}

.jg-logo {
    display: inline-flex;
    align-items: baseline;
    gap: 2px;
    font-family: var(--jg-serif);
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--jg-ink);
    letter-spacing: -0.025em;
    text-decoration: none !important;
    transition: color var(--jg-trans-fast);
    line-height: 1;
}

.jg-logo:hover {
    color: var(--jg-burgundy);
}

.jg-logo__dot {
    color: var(--jg-burgundy);
    font-weight: 800;
}

.jg-nav {
    display: flex;
    align-items: center;
    gap: var(--jg-space-6);
}

.jg-nav__link {
    font-family: var(--jg-sans);
    font-size: 0.92rem;
    font-weight: 500;
    color: var(--jg-text);
    text-decoration: none;
    letter-spacing: 0.005em;
    position: relative;
    transition: color var(--jg-trans-fast);
    padding: 0.4rem 0;
}

.jg-nav__link:hover,
.jg-nav__link--active {
    color: var(--jg-burgundy);
}

.jg-nav__link--active::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--jg-burgundy);
    border-radius: 2px;
}

.jg-nav__cta {
    margin-left: var(--jg-space-2);
}

/* Mobile menu toggle */
.jg-nav__toggle {
    display: none;
    background: none;
    border: none;
    color: var(--jg-ink);
    width: 40px;
    height: 40px;
    align-items: center;
    justify-content: center;
}

@media (max-width: 880px) {
    .jg-nav { display: none; }
    .jg-nav__toggle { display: inline-flex; }
}

/* ---------- HERO HOME ---------- */
.jg-hero {
    position: relative;
    padding: var(--jg-space-10) 0 var(--jg-space-9);
    overflow: hidden;
}

.jg-hero__decoration {
    position: absolute;
    inset: 0;
    pointer-events: none;
    overflow: hidden;
}

.jg-hero__decoration::before,
.jg-hero__decoration::after {
    content: '';
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.5;
}

.jg-hero__decoration::before {
    top: -20%;
    left: -10%;
    width: 50%;
    height: 60%;
    background: radial-gradient(circle, var(--jg-mustard-soft), transparent 70%);
}

.jg-hero__decoration::after {
    bottom: -30%;
    right: -10%;
    width: 50%;
    height: 60%;
    background: radial-gradient(circle, var(--jg-burgundy-soft), transparent 70%);
}

.jg-hero__content {
    position: relative;
    z-index: 2;
    max-width: 820px;
    margin: 0 auto;
    text-align: center;
}

.jg-hero__title {
    font-family: var(--jg-serif);
    font-size: clamp(2.6rem, 6vw, 4.8rem);
    font-weight: 700;
    line-height: 1.05;
    letter-spacing: -0.035em;
    margin-bottom: var(--jg-space-5);
    font-variation-settings: "opsz" 144;
}

.jg-hero__title em {
    font-style: italic;
    color: var(--jg-burgundy);
    font-weight: 700;
    font-variation-settings: "opsz" 144;
}

.jg-hero__lead {
    font-size: clamp(1.05rem, 1.6vw, 1.2rem);
    line-height: 1.6;
    color: var(--jg-text-soft);
    max-width: 600px;
    margin: 0 auto var(--jg-space-7);
}

.jg-hero__ctas {
    display: inline-flex;
    gap: var(--jg-space-3);
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: var(--jg-space-8);
}

/* Animaciones de entrada */
.jg-hero .jg-kicker      { animation: jg-rise 700ms 100ms both; }
.jg-hero__title          { animation: jg-rise 800ms 200ms both; }
.jg-hero__lead           { animation: jg-rise 800ms 350ms both; }
.jg-hero__ctas           { animation: jg-rise 800ms 500ms both; }
.jg-hero__strip          { animation: jg-fade 800ms 700ms both; }

@keyframes jg-rise {
    from { opacity: 0; transform: translateY(16px); }
    to   { opacity: 1; transform: translateY(0); }
}

@keyframes jg-fade {
    from { opacity: 0; }
    to   { opacity: 1; }
}

/* Strip de confianza */
.jg-hero__strip {
    border-top: 1px solid var(--jg-line);
    border-bottom: 1px solid var(--jg-line);
    padding: var(--jg-space-5) var(--jg-space-4);
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    align-items: center;
    gap: var(--jg-space-4) var(--jg-space-7);
    background: rgba(255, 255, 255, 0.4);
    border-radius: var(--jg-radius);
    max-width: 920px;
    margin: 0 auto;
}

.jg-trust-item {
    display: inline-flex;
    align-items: center;
    gap: var(--jg-space-2);
    font-family: var(--jg-mono);
    font-size: 0.78rem;
    letter-spacing: 0.08em;
    color: var(--jg-text);
    text-transform: uppercase;
    font-weight: 500;
}

.jg-trust-item__dice {
    width: 14px;
    height: 14px;
    background: var(--jg-burgundy);
    border-radius: 3px;
    position: relative;
    flex-shrink: 0;
}

.jg-trust-item__dice::after {
    content: '';
    position: absolute;
    top: 50%;
    left: 50%;
    width: 4px;
    height: 4px;
    background: var(--jg-cream);
    border-radius: 50%;
    transform: translate(-50%, -50%);
}

.jg-trust-item:nth-child(2) .jg-trust-item__dice { background: var(--jg-mustard); }
.jg-trust-item:nth-child(2) .jg-trust-item__dice::after { background: var(--jg-ink); }
.jg-trust-item:nth-child(3) .jg-trust-item__dice { background: var(--jg-green); }
.jg-trust-item:nth-child(4) .jg-trust-item__dice { background: var(--jg-ink); }

/* ---------- SECCIÓN: HEADER ---------- */
.jg-section-head {
    text-align: center;
    max-width: 720px;
    margin: 0 auto var(--jg-space-8);
}

.jg-section-head__title {
    font-size: clamp(1.9rem, 3.6vw, 2.8rem);
    margin-bottom: var(--jg-space-4);
}

.jg-section-head__title em {
    font-style: italic;
    color: var(--jg-burgundy);
}

.jg-section-head__intro {
    font-size: 1.05rem;
    line-height: 1.65;
    color: var(--jg-text-soft);
}

/* ---------- CARDS DE JUEGOS DESTACADOS ---------- */
.jg-games-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--jg-space-5);
    margin-bottom: var(--jg-space-7);
}

.jg-game {
    background: var(--jg-paper);
    border: 1px solid var(--jg-line);
    border-radius: var(--jg-radius-lg);
    overflow: hidden;
    box-shadow: var(--jg-shadow-sm);
    transition: transform var(--jg-trans), box-shadow var(--jg-trans);
    text-decoration: none !important;
    color: var(--jg-ink);
    display: flex;
    flex-direction: column;
}

.jg-game:hover {
    transform: translateY(-4px);
    box-shadow: var(--jg-shadow-lg);
}

.jg-game__cover {
    height: 200px;
    position: relative;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}

.jg-game__cover-pattern {
    position: absolute;
    inset: 0;
    opacity: 0.15;
}

.jg-game:nth-child(1) .jg-game__cover {
    background: linear-gradient(135deg, #9a2d3e, var(--jg-burgundy-deep));
}
.jg-game:nth-child(2) .jg-game__cover {
    background: linear-gradient(135deg, #d8a850, var(--jg-mustard-deep));
}
.jg-game:nth-child(3) .jg-game__cover {
    background: linear-gradient(135deg, #517a4f, #38513a);
}

.jg-game__name {
    font-family: var(--jg-serif);
    font-size: 2rem;
    font-weight: 700;
    color: var(--jg-cream);
    text-align: center;
    padding: 0 var(--jg-space-4);
    letter-spacing: -0.02em;
    line-height: 1;
    z-index: 1;
}

.jg-game__rating {
    position: absolute;
    top: var(--jg-space-3);
    right: var(--jg-space-3);
    background: rgba(0, 0, 0, 0.4);
    backdrop-filter: blur(8px);
    color: var(--jg-cream);
    padding: 0.3rem 0.6rem;
    border-radius: var(--jg-radius-sm);
    font-family: var(--jg-mono);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.05em;
}

.jg-game__body {
    padding: var(--jg-space-5);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.jg-game__tag {
    display: inline-block;
    font-family: var(--jg-mono);
    font-size: 0.68rem;
    color: var(--jg-burgundy);
    background: var(--jg-burgundy-soft);
    padding: 0.25rem 0.6rem;
    border-radius: 100px;
    margin-bottom: var(--jg-space-3);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-weight: 500;
    align-self: flex-start;
}

.jg-game__title {
    font-size: 1.3rem;
    margin-bottom: var(--jg-space-3);
}

.jg-game__desc {
    font-size: 0.95rem;
    color: var(--jg-text-soft);
    line-height: 1.55;
    margin-bottom: var(--jg-space-4);
    flex: 1;
}

.jg-game__meta {
    display: flex;
    flex-wrap: wrap;
    gap: var(--jg-space-3);
    padding-top: var(--jg-space-4);
    border-top: 1px solid var(--jg-line);
}

.jg-meta-item {
    display: inline-flex;
    align-items: center;
    gap: var(--jg-space-2);
    font-family: var(--jg-mono);
    font-size: 0.72rem;
    color: var(--jg-text-mute);
    letter-spacing: 0.04em;
    text-transform: uppercase;
    font-weight: 500;
}

.jg-meta-item__icon {
    width: 14px;
    height: 14px;
    flex-shrink: 0;
    opacity: 0.7;
}

/* ---------- CATEGORÍAS — TARJETAS GRANDES ---------- */
.jg-categories {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--jg-space-5);
}

.jg-category {
    background: var(--jg-paper);
    border: 1px solid var(--jg-line);
    border-radius: var(--jg-radius-lg);
    padding: var(--jg-space-7) var(--jg-space-6) var(--jg-space-6);
    text-decoration: none !important;
    color: var(--jg-ink);
    transition: transform var(--jg-trans), box-shadow var(--jg-trans), border-color var(--jg-trans);
    box-shadow: var(--jg-shadow-sm);
    display: block;
    position: relative;
    overflow: hidden;
}

.jg-category:hover {
    transform: translateY(-3px);
    box-shadow: var(--jg-shadow-lg);
    border-color: var(--jg-burgundy);
}

.jg-category::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 4px;
}

.jg-category:nth-child(1)::before { background: var(--jg-burgundy); }
.jg-category:nth-child(2)::before { background: var(--jg-mustard); }
.jg-category:nth-child(3)::before { background: var(--jg-green); }

.jg-category__icon {
    width: 56px;
    height: 56px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: var(--jg-cream);
    border-radius: var(--jg-radius);
    margin-bottom: var(--jg-space-5);
    border: 1px solid var(--jg-line);
}

.jg-category__icon svg {
    width: 28px;
    height: 28px;
}

.jg-category:nth-child(1) .jg-category__icon svg { color: var(--jg-burgundy); }
.jg-category:nth-child(2) .jg-category__icon svg { color: var(--jg-mustard-deep); }
.jg-category:nth-child(3) .jg-category__icon svg { color: var(--jg-green); }

.jg-category__title {
    font-size: 1.45rem;
    margin-bottom: var(--jg-space-3);
}

.jg-category__desc {
    color: var(--jg-text-soft);
    font-size: 0.96rem;
    line-height: 1.55;
    margin-bottom: var(--jg-space-5);
}

.jg-category__count {
    font-family: var(--jg-mono);
    font-size: 0.72rem;
    color: var(--jg-burgundy);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 600;
    display: inline-flex;
    align-items: center;
    gap: var(--jg-space-2);
}

/* ---------- BLOQUE EDITORIAL "SOBRE JUEGALIA" ---------- */
.jg-editorial {
    background: var(--jg-ink);
    color: var(--jg-cream);
    padding: var(--jg-space-9) var(--jg-space-5);
    position: relative;
    overflow: hidden;
}

.jg-editorial::before {
    content: '';
    position: absolute;
    top: -50%;
    right: -10%;
    width: 50%;
    height: 200%;
    background: radial-gradient(circle, rgba(212, 162, 76, 0.15), transparent 60%);
    pointer-events: none;
}

.jg-editorial__inner {
    max-width: 880px;
    margin: 0 auto;
    text-align: center;
    position: relative;
    z-index: 1;
}

.jg-editorial h2 {
    color: var(--jg-cream);
    font-size: clamp(1.9rem, 3.6vw, 2.6rem);
    margin-bottom: var(--jg-space-5);
}

.jg-editorial h2 em {
    font-style: italic;
    color: var(--jg-mustard);
}

.jg-editorial__text {
    font-family: var(--jg-serif);
    font-size: clamp(1.1rem, 1.7vw, 1.3rem);
    line-height: 1.6;
    color: rgba(245, 239, 224, 0.92);
    max-width: 680px;
    margin: 0 auto var(--jg-space-6);
    font-weight: 400;
    font-style: italic;
}

.jg-editorial__author {
    font-family: var(--jg-mono);
    font-size: 0.78rem;
    color: var(--jg-mustard);
    letter-spacing: 0.18em;
    text-transform: uppercase;
    margin-bottom: var(--jg-space-7);
    font-weight: 500;
}

/* ---------- ARTÍCULO INDIVIDUAL ---------- */
.jg-article {
    padding: var(--jg-space-8) 0 var(--jg-space-9);
}

.jg-article__header {
    max-width: var(--jg-max-prose);
    margin: 0 auto var(--jg-space-7);
    text-align: center;
}

.jg-article__category {
    font-family: var(--jg-mono);
    font-size: 0.78rem;
    letter-spacing: 0.18em;
    color: var(--jg-burgundy);
    text-transform: uppercase;
    font-weight: 500;
    margin-bottom: var(--jg-space-4);
    display: inline-block;
}

.jg-article__title {
    font-family: var(--jg-serif);
    font-size: clamp(2.2rem, 4.5vw, 3.4rem);
    line-height: 1.1;
    letter-spacing: -0.03em;
    margin-bottom: var(--jg-space-5);
    font-weight: 700;
}

.jg-article__deck {
    font-family: var(--jg-serif);
    font-size: 1.3rem;
    line-height: 1.5;
    color: var(--jg-text-soft);
    font-style: italic;
    margin-bottom: var(--jg-space-6);
}

.jg-article__meta {
    display: inline-flex;
    align-items: center;
    gap: var(--jg-space-5);
    font-family: var(--jg-mono);
    font-size: 0.78rem;
    color: var(--jg-text-mute);
    letter-spacing: 0.06em;
    text-transform: uppercase;
}

.jg-article__meta-divider {
    width: 4px;
    height: 4px;
    background: var(--jg-text-mute);
    border-radius: 50%;
}

.jg-article__body {
    max-width: var(--jg-max-prose);
    margin: 0 auto;
    font-size: 1.1rem;
    line-height: 1.75;
    color: var(--jg-text);
}

.jg-article__body > * + * {
    margin-top: var(--jg-space-5);
}

.jg-article__body h2 {
    font-size: clamp(1.5rem, 2.6vw, 1.95rem);
    margin-top: var(--jg-space-8);
    margin-bottom: var(--jg-space-4);
    color: var(--jg-burgundy);
    line-height: 1.2;
}

.jg-article__body h2::first-letter {
    color: var(--jg-burgundy);
}

.jg-article__body h3 {
    font-size: 1.4rem;
    margin-top: var(--jg-space-6);
    margin-bottom: var(--jg-space-3);
    color: var(--jg-ink);
}

.jg-article__body p {
    color: var(--jg-text);
}

.jg-article__body a {
    color: var(--jg-burgundy);
    border-bottom: 1px solid rgba(139, 38, 53, 0.3);
    transition: all var(--jg-trans-fast);
}

.jg-article__body a:hover {
    background: var(--jg-burgundy-soft);
    border-bottom-color: var(--jg-burgundy);
}

/* Excepción: enlaces que son botones NO heredan estilos de enlace */
.jg-article__body a.jg-btn,
.jg-article__body a.jg-btn:hover {
    border-bottom: none;
}

.jg-article__body a.jg-btn--primary {
    color: var(--jg-cream);
}
.jg-article__body a.jg-btn--primary:hover {
    color: var(--jg-cream);
    background: var(--jg-burgundy-deep);
}

.jg-article__body a.jg-btn--secondary {
    color: var(--jg-ink);
}
.jg-article__body a.jg-btn--secondary:hover {
    color: var(--jg-ink);
    background: var(--jg-mustard-deep);
}

/* Pull-quote estilo magazine */
.jg-pullquote {
    margin: var(--jg-space-7) 0;
    padding: var(--jg-space-6) var(--jg-space-6);
    border-left: 4px solid var(--jg-mustard);
    background: var(--jg-mustard-soft);
    border-radius: 0 var(--jg-radius) var(--jg-radius) 0;
    font-family: var(--jg-serif);
    font-size: 1.4rem;
    line-height: 1.5;
    color: var(--jg-ink);
    font-style: italic;
    position: relative;
}

.jg-pullquote::before {
    content: '"';
    position: absolute;
    top: -10px;
    left: 12px;
    font-size: 4rem;
    color: var(--jg-mustard);
    line-height: 1;
    font-family: var(--jg-serif);
    font-weight: 700;
}

/* Cuadro de datos rápidos */
.jg-quickdata {
    background: var(--jg-paper);
    border: 1px solid var(--jg-line);
    border-radius: var(--jg-radius-lg);
    padding: var(--jg-space-5) var(--jg-space-6);
    margin: var(--jg-space-6) 0;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: var(--jg-space-4) var(--jg-space-5);
}

.jg-quickdata__item {
    display: flex;
    flex-direction: column;
    gap: 2px;
}

.jg-quickdata__label {
    font-family: var(--jg-mono);
    font-size: 0.7rem;
    color: var(--jg-text-mute);
    letter-spacing: 0.1em;
    text-transform: uppercase;
    font-weight: 500;
}

.jg-quickdata__value {
    font-family: var(--jg-sans);
    font-size: 1rem;
    color: var(--jg-ink);
    font-weight: 600;
}

/* Lista numerada estilo editorial */
.jg-numbered-list {
    list-style: none;
    counter-reset: jg-counter;
    padding: 0;
    margin: var(--jg-space-6) 0;
}

.jg-numbered-list li {
    counter-increment: jg-counter;
    padding: var(--jg-space-4) 0 var(--jg-space-4) var(--jg-space-7);
    border-bottom: 1px solid var(--jg-line-soft);
    position: relative;
}

.jg-numbered-list li:last-child {
    border-bottom: none;
}

.jg-numbered-list li::before {
    content: counter(jg-counter);
    position: absolute;
    left: 0;
    top: var(--jg-space-4);
    font-family: var(--jg-serif);
    font-size: 1.6rem;
    font-weight: 700;
    color: var(--jg-burgundy);
    line-height: 1;
}

/* Box de marcador editorial (para [TU EXPERIENCIA AQUÍ]) */
.jg-todo {
    background: rgba(212, 162, 76, 0.12);
    border: 1px dashed var(--jg-mustard-deep);
    border-radius: var(--jg-radius);
    padding: var(--jg-space-5) var(--jg-space-5);
    margin: var(--jg-space-5) 0;
    font-family: var(--jg-mono);
    font-size: 0.92rem;
    color: var(--jg-text);
    line-height: 1.5;
}

.jg-todo strong {
    color: var(--jg-mustard-deep);
    text-transform: uppercase;
    letter-spacing: 0.08em;
    font-size: 0.78rem;
    display: block;
    margin-bottom: var(--jg-space-2);
}

/* Disclaimer afiliados */
.jg-disclaimer {
    background: var(--jg-cream-deep);
    border-left: 3px solid var(--jg-mustard);
    padding: var(--jg-space-4) var(--jg-space-5);
    margin: var(--jg-space-6) 0;
    font-size: 0.92rem;
    color: var(--jg-text-soft);
    border-radius: 0 var(--jg-radius) var(--jg-radius) 0;
    font-style: italic;
}

/* CTA final del artículo */
.jg-end-cta {
    background: var(--jg-paper);
    border: 1px solid var(--jg-line);
    border-radius: var(--jg-radius-lg);
    padding: var(--jg-space-7) var(--jg-space-6);
    margin: var(--jg-space-8) 0;
    text-align: center;
    box-shadow: var(--jg-shadow-sm);
}

.jg-end-cta h3 {
    font-size: 1.6rem;
    margin-bottom: var(--jg-space-3);
}

.jg-end-cta p {
    color: var(--jg-text-soft);
    margin-bottom: var(--jg-space-5);
    max-width: 540px;
    margin-left: auto;
    margin-right: auto;
}

/* ---------- FOOTER ---------- */
.jg-footer {
    background: var(--jg-ink);
    color: var(--jg-cream);
    padding: var(--jg-space-9) 0 var(--jg-space-5);
    position: relative;
    z-index: 1;
}

.jg-footer__grid {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: var(--jg-space-7);
    margin-bottom: var(--jg-space-8);
}

.jg-footer__brand .jg-logo {
    color: var(--jg-cream);
    font-size: 1.55rem;
    margin-bottom: var(--jg-space-3);
}

.jg-footer__brand .jg-logo:hover {
    color: var(--jg-mustard);
}

.jg-footer__brand-text {
    font-size: 0.95rem;
    line-height: 1.6;
    color: rgba(245, 239, 224, 0.7);
    max-width: 320px;
    margin-bottom: var(--jg-space-4);
}

.jg-footer__email {
    font-family: var(--jg-mono);
    font-size: 0.85rem;
    color: var(--jg-mustard);
    letter-spacing: 0.04em;
    text-decoration: none;
    border-bottom: 1px solid rgba(212, 162, 76, 0.3);
    padding-bottom: 1px;
    transition: color var(--jg-trans-fast);
}

.jg-footer__email:hover {
    color: var(--jg-cream);
}

.jg-footer__col h4 {
    font-family: var(--jg-mono);
    font-size: 0.75rem;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    color: var(--jg-mustard);
    font-weight: 600;
    margin-bottom: var(--jg-space-4);
    padding-bottom: var(--jg-space-3);
    border-bottom: 1px solid rgba(245, 239, 224, 0.12);
}

.jg-footer__col ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: var(--jg-space-3);
}

.jg-footer__col a {
    color: rgba(245, 239, 224, 0.85);
    font-size: 0.92rem;
    transition: color var(--jg-trans-fast);
    text-decoration: none;
}

.jg-footer__col a:hover {
    color: var(--jg-mustard);
}

.jg-footer__bottom {
    border-top: 1px solid rgba(245, 239, 224, 0.12);
    padding-top: var(--jg-space-5);
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    gap: var(--jg-space-3);
    font-family: var(--jg-mono);
    font-size: 0.78rem;
    color: rgba(245, 239, 224, 0.6);
    letter-spacing: 0.04em;
}

.jg-footer__bottom-disclaimer {
    flex: 1;
    min-width: 280px;
    line-height: 1.55;
}

/* ---------- BREADCRUMBS ---------- */
.jg-breadcrumb {
    font-family: var(--jg-mono);
    font-size: 0.75rem;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--jg-text-mute);
    margin-bottom: var(--jg-space-5);
    display: flex;
    gap: var(--jg-space-2);
    flex-wrap: wrap;
    align-items: center;
}

.jg-breadcrumb a {
    color: var(--jg-text-mute);
}

.jg-breadcrumb a:hover {
    color: var(--jg-burgundy);
}

.jg-breadcrumb__sep {
    opacity: 0.4;
}

/* ---------- LISTADO DE CATEGORÍA ---------- */
.jg-category-page__head {
    text-align: center;
    max-width: 720px;
    margin: 0 auto var(--jg-space-8);
}

.jg-posts-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: var(--jg-space-5);
}

.jg-post-card {
    background: var(--jg-paper);
    border: 1px solid var(--jg-line);
    border-radius: var(--jg-radius-lg);
    overflow: hidden;
    text-decoration: none;
    color: var(--jg-ink);
    transition: transform var(--jg-trans), box-shadow var(--jg-trans);
    box-shadow: var(--jg-shadow-sm);
    display: flex;
    flex-direction: column;
}

.jg-post-card:hover {
    transform: translateY(-3px);
    box-shadow: var(--jg-shadow-lg);
}

.jg-post-card__cover {
    height: 180px;
    background: linear-gradient(135deg, var(--jg-burgundy-soft), var(--jg-mustard-soft));
    display: flex;
    align-items: center;
    justify-content: center;
}

.jg-post-card__body {
    padding: var(--jg-space-5);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.jg-post-card__category {
    font-family: var(--jg-mono);
    font-size: 0.7rem;
    color: var(--jg-burgundy);
    letter-spacing: 0.12em;
    text-transform: uppercase;
    font-weight: 600;
    margin-bottom: var(--jg-space-2);
}

.jg-post-card__title {
    font-size: 1.2rem;
    line-height: 1.3;
    margin-bottom: var(--jg-space-3);
}

.jg-post-card__excerpt {
    color: var(--jg-text-soft);
    font-size: 0.92rem;
    line-height: 1.55;
    margin-bottom: var(--jg-space-4);
    flex: 1;
}

.jg-post-card__meta {
    font-family: var(--jg-mono);
    font-size: 0.7rem;
    color: var(--jg-text-mute);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border-top: 1px solid var(--jg-line);
    padding-top: var(--jg-space-3);
}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px) {
    .jg-games-grid,
    .jg-categories {
        grid-template-columns: 1fr;
        gap: var(--jg-space-4);
    }
    .jg-footer__grid {
        grid-template-columns: 1fr 1fr;
        gap: var(--jg-space-6);
    }
    .jg-section { padding: var(--jg-space-7) 0; }
    .jg-hero { padding: var(--jg-space-8) 0 var(--jg-space-7); }
}

@media (max-width: 600px) {
    body { font-size: 16px; }
    .jg-footer__grid { grid-template-columns: 1fr; }
    .jg-hero__ctas { flex-direction: column; align-items: stretch; }
    .jg-btn { justify-content: center; }
    .jg-pullquote { font-size: 1.2rem; padding: var(--jg-space-5); }
    .jg-section-head { margin-bottom: var(--jg-space-6); }
    .jg-article__meta { flex-direction: column; gap: var(--jg-space-2); align-items: center; }
    .jg-article__meta-divider { display: none; }
}
