/* ═══════════════════════════════════════════════════════════════════════
   /blog/ catalog hub bespoke styles
   ═══════════════════════════════════════════════════════════════════════ */
.page--blog-list .main { padding-top: 0; }
.page--blog-list main > .hero-blog:first-child,
.page--blog-list main > section:first-child { margin-top: 0; }


.page--blog-list main > .hero-blog:first-child { margin-top: 0; }

.hero-blog {
    position: relative;
    overflow: hidden;
    padding: clamp(32px, 5vw, 64px) 0 clamp(28px, 4vw, 48px);
    background:
        radial-gradient(70% 80% at 50% 0%, rgba(79, 70, 229, 0.10), transparent 70%),
        radial-gradient(50% 60% at 85% 100%, rgba(249, 115, 22, 0.06), transparent 70%),
        var(--bg);
    border-bottom: 1px solid var(--border);
}
.hero-blog__topic-ribbon {
    position: absolute; inset: 0;
    display: flex; align-items: center;
    gap: clamp(28px, 4vw, 60px);
    padding: 0 var(--sp-4);
    pointer-events: none; user-select: none;
    font-family: 'Geist Mono', ui-monospace, monospace;
    font-size: clamp(2.25rem, 5.5vw, 4.75rem);
    font-weight: 800;
    color: rgba(79, 70, 229, 0.06);
    letter-spacing: -0.02em;
    overflow: hidden; white-space: nowrap; z-index: 0;
}
.hero-blog__topic-ribbon span { flex-shrink: 0; transform: rotate(-6deg); }
.hero-blog__topic-ribbon-accent { color: rgba(249, 115, 22, 0.06); }

.hero-blog__inner {
    position: relative; z-index: 1; text-align: center;
    display: flex; flex-direction: column; align-items: center; gap: var(--sp-4);
}
.hero-blog__eyebrow {
    display: inline-block; padding: 6px 14px;
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--primary);
    background: var(--bg-alt); border: 1px solid var(--border); border-radius: var(--r-full);
    margin-bottom: var(--sp-2);
}
.hero-blog__title {
    margin: 0;
    font-size: clamp(1.875rem, 4.5vw + 0.5rem, 3.5rem);
    font-weight: var(--fw-black); line-height: 1.05;
    letter-spacing: -0.025em; color: var(--text); max-width: 920px;
}
.hero-blog__lead {
    margin: 0; max-width: 720px;
    font-size: var(--fs-md); color: var(--text-muted); line-height: var(--lh-relaxed);
}
.hero-blog__topline {
    display: flex; align-items: center; flex-wrap: wrap; justify-content: center;
    gap: clamp(16px, 3vw, 32px);
    padding: var(--sp-4) clamp(16px, 3vw, 32px);
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-xl); box-shadow: var(--shadow-sm);
    margin-top: var(--sp-2);
}
.hero-blog__topline-stat {
    display: flex; flex-direction: column; align-items: center; gap: 2px; min-width: 72px;
}
.hero-blog__topline-value {
    font-family: var(--font-mono);
    font-size: clamp(1.5rem, 3vw, 2.25rem);
    font-weight: var(--fw-black); line-height: 1;
    color: var(--primary); letter-spacing: -0.02em;
}
.hero-blog__topline-label {
    font-size: var(--fs-xs); text-transform: uppercase; letter-spacing: 0.05em;
    color: var(--text-muted); font-weight: var(--fw-medium);
}
.hero-blog__topline-sep { width: 1px; height: 32px; background: var(--border); }
@media (max-width: 540px) {
    .hero-blog__topline-sep { display: none; }
    .hero-blog__topline { gap: var(--sp-3); }
    .hero-blog__topline-stat { flex-direction: row; align-items: baseline; gap: 6px; }
    .hero-blog__topline-value { font-size: 1.5rem; }
    .hero-blog__topic-ribbon { font-size: 2rem; }
}
.hero-blog__filters { display: flex; flex-direction: column; align-items: center; gap: var(--sp-2); width: 100%; }
.hero-blog__filters-label {
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-muted);
}
.filter-chips { display: flex; flex-wrap: wrap; justify-content: center; gap: var(--sp-2); max-width: 720px; }
.filter-chip {
    display: inline-flex; align-items: center; gap: var(--sp-2);
    padding: 8px 14px; background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-full); color: var(--text);
    font-size: var(--fs-sm); font-weight: var(--fw-medium); text-decoration: none;
    transition: border-color var(--t-fast), background var(--t-fast), transform var(--t-fast);
}
.filter-chip:hover {
    border-color: var(--primary); background: var(--primary-50); color: var(--primary-dark); transform: translateY(-1px);
}
.filter-chip__label { white-space: nowrap; }
.filter-chip__count {
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    color: var(--text-muted); background: var(--bg-alt);
    padding: 2px 7px; border-radius: var(--r-sm); line-height: 1.4;
}
.hero-blog__meta {
    display: inline-flex; align-items: center; flex-wrap: wrap; justify-content: center;
    gap: var(--sp-2); padding: 6px 14px;
    font-size: var(--fs-xs); color: var(--text-muted);
    background: var(--bg-alt); border: 1px solid var(--border); border-radius: var(--r-full);
    margin-top: var(--sp-2);
}
.hero-blog__meta-sep { opacity: 0.5; }

/* COMMON */
.block-eyebrow {
    display: inline-block; font-family: var(--font-mono);
    font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    letter-spacing: 0.08em; text-transform: uppercase;
    color: var(--primary); background: var(--primary-50);
    border: 1px solid color-mix(in srgb, var(--primary) 18%, transparent);
    padding: 4px 10px; border-radius: var(--r-full); margin-bottom: var(--sp-3);
}
.block-eyebrow--accent {
    color: var(--accent-dark); background: var(--accent-50);
    border-color: color-mix(in srgb, var(--accent) 22%, transparent);
}
.section-head--centered { text-align: center; margin-bottom: var(--section-head-mb); }
.section-head--centered .section-head__title { margin: 0 0 var(--sp-2); font-size: clamp(1.25rem, 2vw + 0.5rem, 1.875rem); }
.section-head--centered .section-head__subtitle {
    margin: 0 auto; font-size: var(--fs-sm); color: var(--text-muted);
    line-height: var(--lh-relaxed); max-width: 720px;
}

/* 3. CLUSTER MAP */
.cluster-map-section { background: var(--bg); }
.cluster-map {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-4);
}
@media (min-width: 768px) {
    .cluster-map { grid-template-columns: repeat(2, 1fr); gap: var(--sp-5); }
}
@media (min-width: 1100px) {
    .cluster-map { grid-template-columns: repeat(3, 1fr); }
}
.cluster-card {
    position: relative;
    display: flex; flex-direction: column; gap: var(--sp-3);
    padding: var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--shadow-xs);
    transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
    overflow: hidden;
}
.cluster-card::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
    background: var(--grad-primary); opacity: 0.6; transition: opacity var(--t-fast);
}
.cluster-card--success::before { background: linear-gradient(135deg, var(--success), #06B6D4); }
.cluster-card--accent::before  { background: linear-gradient(135deg, var(--accent-dark), var(--accent)); }
.cluster-card--alert::before   { background: var(--grad-crash); }
.cluster-card--neutral::before { background: linear-gradient(135deg, var(--text-dim), var(--border-strong)); }
.cluster-card:hover { border-color: var(--primary); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.cluster-card:hover::before { opacity: 1; }

.cluster-card__head { display: flex; gap: var(--sp-3); align-items: flex-start; }
.cluster-card__icon {
    flex-shrink: 0; width: 44px; height: 44px;
    border-radius: var(--r-md); background: var(--primary-50); color: var(--primary);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.4rem; line-height: 1;
}
.cluster-card--success .cluster-card__icon { background: var(--success-50); color: var(--success); }
.cluster-card--accent  .cluster-card__icon { background: var(--accent-50);  color: var(--accent-dark); }
.cluster-card--alert   .cluster-card__icon { background: var(--alert-50);   color: var(--alert); }
.cluster-card--neutral .cluster-card__icon { background: var(--bg-alt);     color: var(--text-muted); }
.cluster-card__title-wrap { flex: 1; min-width: 0; }
.cluster-card__name {
    margin: 0 0 4px; font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--text);
    line-height: var(--lh-snug);
}
.cluster-card__count {
    font-family: var(--font-mono); font-size: var(--fs-sm);
    font-weight: var(--fw-medium); color: var(--text-muted);
}
.cluster-card__lead {
    margin: 0; font-size: var(--fs-sm);
    color: var(--text-muted); line-height: var(--lh-relaxed);
}

.cluster-card__pillar {
    position: relative;
    display: flex; flex-direction: column; gap: 4px;
    padding: var(--sp-3) 32px var(--sp-3) var(--sp-3);
    background: var(--bg-alt);
    border-radius: var(--r-md);
    text-decoration: none;
    transition: background var(--t-fast);
}
.cluster-card__pillar:hover { background: var(--primary-50); }
.cluster-card__pillar-label {
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-bold);
    text-transform: uppercase; letter-spacing: 0.06em; color: var(--primary);
}
.cluster-card__pillar-title {
    font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--text); line-height: var(--lh-snug);
}
.cluster-card__pillar-arrow {
    position: absolute; right: var(--sp-3); top: 50%; transform: translateY(-50%);
    color: var(--primary); font-family: var(--font-mono); font-size: var(--fs-md);
    transition: transform var(--t-fast);
}
.cluster-card__pillar:hover .cluster-card__pillar-arrow { transform: translateY(-50%) translateX(2px); }

.cluster-card__supporting {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 6px;
}
.cluster-card__supporting li {
    position: relative;
    padding-left: 16px;
    font-size: var(--fs-sm);
    line-height: var(--lh-snug);
}
.cluster-card__supporting li::before {
    content: '→';
    position: absolute; left: 0; top: 0;
    color: var(--text-dim);
    font-family: var(--font-mono);
    font-size: var(--fs-sm);
}
.cluster-card__supporting a {
    color: var(--text);
    text-decoration: none;
    border-bottom: 1px solid transparent;
    transition: color var(--t-fast), border-color var(--t-fast);
}
.cluster-card__supporting a:hover {
    color: var(--primary);
    border-bottom-color: var(--primary);
}
/* Pillar item - highlighted first row, with PILLAR badge inline */
.cluster-card__supporting-item--pillar {
    margin-bottom: 4px;
    padding-bottom: 6px;
    border-bottom: 1px dashed var(--border-subtle);
}
.cluster-card__supporting-item--pillar a {
    font-weight: var(--fw-bold);
    color: var(--text);
    display: inline-flex;
    align-items: center;
    flex-wrap: wrap;
    gap: 8px;
}
.cluster-card__pillar-tag {
    display: inline-flex;
    align-items: center;
    padding: 2px 8px;
    border-radius: var(--r-sm);
    background: var(--primary-50);
    color: var(--primary);
    font-size: 0.65rem;
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: 0.06em;
    line-height: 1.2;
}

/* 4. TIMELINE */
.timeline-section { background: var(--bg-alt); }
.timeline-list {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: var(--sp-3);
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-xl); padding: clamp(16px, 2.5vw, 28px);
    box-shadow: var(--shadow-sm);
}
.timeline-entry {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: var(--sp-4);
    padding: var(--sp-3) 0;
    border-bottom: 1px dashed var(--border);
    align-items: start;
}
@media (max-width: 540px) {
    .timeline-entry { grid-template-columns: 1fr; gap: var(--sp-2); }
}
.timeline-entry:last-child { border-bottom: 0; padding-bottom: 0; }
.timeline-entry:first-child { padding-top: 0; }
.timeline-entry__date {
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-bold);
    text-transform: uppercase; letter-spacing: 0.05em;
    color: var(--accent-dark); background: var(--accent-50);
    padding: 4px 10px; border-radius: var(--r-sm);
    align-self: start; justify-self: start;
}
.timeline-entry--alert   .timeline-entry__date { color: var(--alert); background: var(--alert-50); }
.timeline-entry--success .timeline-entry__date { color: var(--success); background: var(--success-50); }
.timeline-entry--primary .timeline-entry__date { color: var(--primary); background: var(--primary-50); }
.timeline-entry--neutral .timeline-entry__date { color: var(--text-muted); background: var(--bg-alt); }

.timeline-entry__cluster {
    display: inline-block;
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-bold);
    text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--text-muted);
    margin-bottom: 4px;
}
.timeline-entry__title { margin: 0 0 4px; font-size: var(--fs-md); font-weight: var(--fw-bold); }
.timeline-entry__title a { color: var(--text); }
.timeline-entry__title a:hover { color: var(--primary); }
.timeline-entry__lead {
    margin: 0; font-size: var(--fs-sm); color: var(--text-muted); line-height: var(--lh-relaxed);
}

/* 5. READING SEQUENCES */
.reading-sequences-section { background: var(--bg); }
.reading-sequences {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-4);
}
@media (min-width: 768px) {
    .reading-sequences { grid-template-columns: repeat(2, 1fr); gap: var(--sp-5); }
}
.reading-sequence {
    display: flex; flex-direction: column; gap: var(--sp-3);
    padding: var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    box-shadow: var(--shadow-xs);
    transition: border-color var(--t-fast), transform var(--t-fast);
}
.reading-sequence:hover { border-color: var(--primary); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.reading-sequence--success { border-top: 4px solid var(--success); }
.reading-sequence--accent  { border-top: 4px solid var(--accent-dark); }
.reading-sequence--alert   { border-top: 4px solid var(--alert); }
.reading-sequence--primary { border-top: 4px solid var(--primary); }

.reading-sequence__head {
    display: flex; align-items: center; gap: var(--sp-3);
    padding-bottom: var(--sp-3);
    border-bottom: 1px dashed var(--border);
}
.reading-sequence__icon {
    flex-shrink: 0; width: 44px; height: 44px;
    border-radius: var(--r-md);
    background: var(--primary-50);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
}
.reading-sequence--success .reading-sequence__icon { background: var(--success-50); }
.reading-sequence--accent  .reading-sequence__icon { background: var(--accent-50); }
.reading-sequence--alert   .reading-sequence__icon { background: var(--alert-50); }
.reading-sequence__title-wrap { flex: 1; min-width: 0; }
.reading-sequence__name {
    margin: 0 0 2px; font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--text); line-height: var(--lh-snug);
}
.reading-sequence__duration {
    font-family: var(--font-mono); font-size: var(--fs-xs);
    color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em;
}
.reading-sequence__lead {
    margin: 0; font-size: var(--fs-sm); color: var(--text-muted); line-height: var(--lh-relaxed);
}
.reading-sequence__steps {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: var(--sp-2);
}
.reading-sequence__step {
    display: grid;
    grid-template-columns: 28px 1fr;
    gap: var(--sp-2);
    align-items: center;
    padding: var(--sp-2) var(--sp-3);
    background: var(--bg);
    border: 1px solid var(--border-subtle);
    border-radius: var(--r-md);
    transition: border-color var(--t-fast), background var(--t-fast);
}
.reading-sequence__step:hover { border-color: var(--primary); background: var(--primary-50); }
.reading-sequence__step-num {
    width: 24px; height: 24px;
    border-radius: var(--r-full);
    background: var(--primary-50);
    color: var(--primary);
    font-family: var(--font-mono);
    font-size: var(--fs-xs);
    font-weight: var(--fw-black);
    display: inline-flex; align-items: center; justify-content: center;
}
.reading-sequence--success .reading-sequence__step-num { background: var(--success-50); color: var(--success); }
.reading-sequence--accent  .reading-sequence__step-num { background: var(--accent-50);  color: var(--accent-dark); }
.reading-sequence--alert   .reading-sequence__step-num { background: var(--alert-50);   color: var(--alert); }
.reading-sequence__step-link {
    color: var(--text);
    text-decoration: none;
    font-size: var(--fs-sm);
    font-weight: var(--fw-medium);
    line-height: var(--lh-snug);
}
.reading-sequence__step:hover .reading-sequence__step-link { color: var(--primary); }

/* 6. FEATURED POSTS */
.featured-posts-section { background: var(--bg-alt); }
.featured-posts-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-4);
}
@media (min-width: 768px) {
    .featured-posts-grid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-5); }
}
.featured-post {
    position: relative;
    display: flex; flex-direction: column; gap: var(--sp-3);
    padding: var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    text-decoration: none;
    box-shadow: var(--shadow-xs);
    transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
    overflow: hidden;
}
.featured-post::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 4px;
    background: var(--grad-primary);
}
.featured-post--accent::before { background: linear-gradient(135deg, var(--accent-dark), var(--accent)); }
.featured-post--alert::before  { background: var(--grad-crash); }
.featured-post:hover { border-color: var(--primary); transform: translateY(-3px); box-shadow: var(--shadow-md); }

.featured-post__badge {
    align-self: flex-start;
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-bold);
    text-transform: uppercase; letter-spacing: 0.06em;
    color: #FFFFFF;
    background: var(--grad-primary);
    padding: 4px 10px; border-radius: var(--r-full);
}
.featured-post--accent .featured-post__badge { background: linear-gradient(135deg, var(--accent-dark), var(--accent)); }
.featured-post--alert  .featured-post__badge { background: var(--grad-crash); }

.featured-post__cluster {
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-bold);
    text-transform: uppercase; letter-spacing: 0.06em;
    color: var(--text-muted);
}
.featured-post__title {
    margin: 0;
    font-size: 1.4rem; font-weight: var(--fw-black);
    color: var(--text);
    line-height: 1.05; letter-spacing: -0.02em;
}
.featured-post__summary {
    margin: 0; font-size: var(--fs-sm);
    color: var(--text); line-height: var(--lh-relaxed);
    flex: 1;
}
.featured-post__cta {
    margin-top: auto;
    font-size: var(--fs-sm); font-weight: var(--fw-semibold);
    color: var(--primary);
    transition: transform var(--t-fast);
}
.featured-post--accent .featured-post__cta { color: var(--accent-dark); }
.featured-post--alert  .featured-post__cta { color: var(--alert); }
.featured-post:hover .featured-post__cta { transform: translateX(4px); }

/* 7. BODY */
.catalog-body-section { background: var(--bg); }
.hub-body h2 {
    margin-top: var(--sp-10); margin-bottom: var(--sp-4);
    padding-top: var(--sp-4); border-top: 1px solid var(--border-subtle);
}
.hub-body h2:first-child { margin-top: 0; padding-top: 0; border-top: 0; }
.hub-body p { margin-bottom: var(--sp-4); line-height: var(--lh-relaxed); }
.hub-body .answer-box {
    background: var(--primary-50);
    border-left: 3px solid var(--primary);
    border-radius: var(--r-md);
    padding: var(--sp-4) var(--sp-5);
    margin: var(--sp-5) 0;
}
.hub-body .answer-box__label {
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-bold);
    text-transform: uppercase; letter-spacing: 0.08em; color: var(--primary);
    margin-bottom: 6px;
}
.hub-body .answer-box__text { margin: 0; font-size: var(--fs-md); line-height: var(--lh-relaxed); }
.hub-body .review-pullquote {
    margin: var(--sp-8) 0; padding: var(--sp-5) var(--sp-6);
    background: var(--surface); border: 1px solid var(--border);
    border-left: 4px solid var(--primary); border-radius: var(--r-lg);
}
.hub-body .review-pullquote blockquote {
    margin: 0 0 var(--sp-3); font-size: var(--fs-lg); font-weight: var(--fw-medium);
    line-height: var(--lh-snug); color: var(--text); font-style: italic;
}
.hub-body .review-pullquote figcaption { font-size: var(--fs-sm); color: var(--text-muted); }
.hub-body .body-aside {
    display: flex; gap: var(--sp-4); align-items: flex-start;
    margin: var(--sp-6) 0;
    padding: var(--sp-4) var(--sp-5);
    background: var(--surface);
    border: 1px solid var(--border);
    border-left: 4px solid var(--primary);
    border-radius: var(--r-md);
    box-shadow: var(--shadow-xs);
}
.hub-body .body-aside--exclude { border-left-color: var(--alert); }
.hub-body .body-aside--stats   { border-left-color: var(--accent); }
.hub-body .body-aside--ethics  { border-left-color: var(--success); }
.hub-body .body-aside__icon {
    flex-shrink: 0; width: 40px; height: 40px;
    border-radius: var(--r-md);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.25rem; line-height: 1;
}
.hub-body .body-aside--exclude .body-aside__icon { background: var(--alert-50);   color: var(--alert); }
.hub-body .body-aside--stats   .body-aside__icon { background: var(--accent-50);  color: var(--accent-dark); }
.hub-body .body-aside--ethics  .body-aside__icon { background: var(--success-50); color: var(--success); }
.hub-body .body-aside__body { flex: 1; min-width: 0; }
.hub-body .body-aside__title { margin: 0 0 var(--sp-2); font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--text); }
.hub-body .body-aside p { margin: 0; font-size: var(--fs-sm); line-height: var(--lh-relaxed); }
@media (max-width: 540px) {
    .hub-body .body-aside { flex-direction: column; gap: var(--sp-3); }
}

/* 8. METHODOLOGY 2x2 */
.methodology-section { background: var(--bg-alt); }
.methodology-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: var(--sp-4);
}
@media (min-width: 640px) {
    .methodology-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-5); }
}
.meth-card {
    padding: var(--sp-5);
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-lg); box-shadow: var(--shadow-xs);
    transition: border-color var(--t-fast), transform var(--t-fast);
    display: flex; flex-direction: column; gap: var(--sp-3);
}
.meth-card:hover { border-color: var(--primary); transform: translateY(-2px); box-shadow: var(--shadow-md); }
.meth-card__icon {
    width: 44px; height: 44px;
    border-radius: var(--r-md);
    background: var(--primary-50); color: var(--primary);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
}
.meth-card:nth-child(2) .meth-card__icon { background: var(--accent-50); color: var(--accent-dark); }
.meth-card:nth-child(3) .meth-card__icon { background: var(--success-50); color: var(--success); }
.meth-card:nth-child(4) .meth-card__icon { background: var(--alert-50); color: var(--alert); }
.meth-card__title { margin: 0; font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--text); line-height: var(--lh-snug); }
.meth-card__body { margin: 0; font-size: var(--fs-sm); color: var(--text-muted); line-height: var(--lh-relaxed); }

/* 9. GLOSSARY */
.glossary-section { background: var(--bg); }
.glossary-grid {
    display: grid; grid-template-columns: 1fr; gap: var(--sp-3);
}
@media (min-width: 640px) {
    .glossary-grid { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
}
@media (min-width: 1024px) {
    .glossary-grid { grid-template-columns: repeat(3, 1fr); }
    .glossary-grid .glossary-tile:nth-child(4) { grid-column: 1 / 3; }
    .glossary-grid .glossary-tile:nth-child(5) { grid-column: 3 / 4; }
}
.glossary-tile {
    display: flex; gap: var(--sp-3);
    padding: var(--sp-4) var(--sp-5);
    background: var(--surface); border: 1px solid var(--border-subtle);
    border-radius: var(--r-md);
    transition: border-color var(--t-fast), background var(--t-fast);
}
.glossary-tile:hover { border-color: var(--primary); background: var(--primary-50); }
.glossary-tile__icon {
    flex-shrink: 0; width: 36px; height: 36px;
    border-radius: var(--r-sm);
    background: var(--primary-50); color: var(--primary);
    display: inline-flex; align-items: center; justify-content: center;
    font-family: var(--font-mono); font-size: var(--fs-md); font-weight: var(--fw-black);
}
.glossary-tile__body { flex: 1; min-width: 0; }
.glossary-tile__term { margin: 0 0 4px; font-size: var(--fs-sm); font-weight: var(--fw-bold); color: var(--text); }
.glossary-tile__def { margin: 0; font-size: var(--fs-xs); color: var(--text-muted); line-height: var(--lh-relaxed); }

/* 11. FAQ */
.blog-faq-section { background: var(--bg-alt); }
.blog-faq-section .faq-head { text-align: center; margin-bottom: var(--sp-6); }
.blog-faq-section .faq-head__eyebrow {
    display: inline-block;
    font-family: var(--font-mono); font-size: var(--fs-xs); font-weight: var(--fw-semibold);
    text-transform: uppercase; letter-spacing: 0.08em; color: var(--primary);
    background: var(--primary-50);
    padding: 4px 10px; border-radius: var(--r-full);
    margin-bottom: var(--sp-2);
}
.blog-faq-section .faq-head__title { margin: 0 0 var(--sp-2); }
.blog-faq-section .faq-head__lead { margin: 0 auto; font-size: var(--fs-sm); color: var(--text-muted); max-width: 640px; }
.blog-faq-section .faq-list--home {
    display: flex; flex-direction: column; gap: var(--sp-2);
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-xl); padding: var(--sp-3);
    box-shadow: var(--shadow-sm);
}
.blog-faq-section .faq-item {
    border-radius: var(--r-md); background: var(--bg);
    border: 1px solid var(--border-subtle);
    transition: border-color var(--t-fast);
}
.blog-faq-section .faq-item[open] { border-color: var(--primary); }
.blog-faq-section .faq-item__q {
    cursor: pointer; list-style: none;
    padding: var(--sp-3) var(--sp-4);
    font-weight: var(--fw-semibold); font-size: var(--fs-md); color: var(--text);
    display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
}
.blog-faq-section .faq-item__q::-webkit-details-marker { display: none; }
.blog-faq-section .faq-item__q::after {
    content: '+';
    font-family: var(--font-mono); font-size: var(--fs-lg); color: var(--primary);
}
.blog-faq-section .faq-item[open] .faq-item__q::after { content: '−'; }
.blog-faq-section .faq-item__a {
    padding: 0 var(--sp-4) var(--sp-4);
    font-size: var(--fs-sm); color: var(--text); line-height: var(--lh-relaxed);
}
.blog-faq-section .faq-item__a p { margin: 0 0 var(--sp-3); }
.blog-faq-section .faq-item__a p:last-child { margin: 0; }

/* 12. CROSS-HUBS */
.cross-hubs-section { background: var(--bg); }
.cross-hubs {
    display: grid; grid-template-columns: 1fr; gap: var(--sp-3);
}
@media (min-width: 640px) {
    .cross-hubs { grid-template-columns: repeat(2, 1fr); gap: var(--sp-4); }
}
@media (min-width: 1024px) {
    .cross-hubs { grid-template-columns: repeat(5, 1fr); }
}
.cross-hub {
    position: relative;
    display: flex; flex-direction: column; gap: var(--sp-3);
    padding: var(--sp-5);
    background: var(--surface); border: 1px solid var(--border);
    border-radius: var(--r-lg);
    text-decoration: none;
    transition: border-color var(--t-fast), transform var(--t-fast), box-shadow var(--t-fast);
    box-shadow: var(--shadow-xs);
    overflow: hidden;
}
.cross-hub::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: var(--grad-primary); opacity: 0.6;
    transition: opacity var(--t-fast), height var(--t-fast);
}
.cross-hub:hover { border-color: var(--primary); transform: translateY(-3px); box-shadow: var(--shadow-md); }
.cross-hub:hover::before { opacity: 1; height: 4px; }
.cross-hub__icon {
    display: inline-flex; align-items: center; justify-content: center;
    width: 56px; height: 56px;
    border-radius: var(--r-lg);
    background: var(--primary-50); color: var(--primary);
    transition: background var(--t-fast), color var(--t-fast), transform var(--t-fast);
}
.cross-hub__icon svg { width: 32px; height: 32px; }
.cross-hub:hover .cross-hub__icon { transform: scale(1.05) rotate(-3deg); }
.cross-hub--home    .cross-hub__icon { background: var(--primary-50); color: var(--primary-dark); }
.cross-hub--home::before              { background: linear-gradient(135deg, var(--primary), var(--primary-light)); }
.cross-hub--games   .cross-hub__icon { background: var(--accent-50);  color: var(--accent-dark); }
.cross-hub--games::before             { background: linear-gradient(135deg, var(--accent-dark), var(--accent)); }
.cross-hub--studios .cross-hub__icon { background: var(--accent-50);  color: var(--accent-dark); }
.cross-hub--studios::before           { background: linear-gradient(135deg, var(--accent-dark), var(--accent)); }
.cross-hub--versus  .cross-hub__icon { background: #FEF3C7;           color: #B45309; }
.cross-hub--versus::before            { background: linear-gradient(135deg, #F59E0B, #FB923C); }
.cross-hub--tools   .cross-hub__icon { background: var(--success-50); color: var(--success); }
.cross-hub--tools::before             { background: linear-gradient(135deg, #10B981, #06B6D4); }
.cross-hub__title { font-size: var(--fs-md); font-weight: var(--fw-bold); color: var(--text); line-height: var(--lh-snug); }
.cross-hub__lead { flex: 1; font-size: var(--fs-sm); color: var(--text-muted); line-height: var(--lh-relaxed); margin: 0; }
.cross-hub__arrow {
    align-self: flex-end;
    font-family: var(--font-mono); font-size: var(--fs-xl); color: var(--primary);
    line-height: 1; transition: transform var(--t-fast);
}
.cross-hub:hover .cross-hub__arrow { transform: translateX(4px); }

/* AUTHOR */
.author-byline {
    display: flex; justify-content: center;
    padding-top: var(--sp-5); border-top: 1px solid var(--border-subtle);
}
.author-byline__inner {
    display: inline-flex; align-items: center; gap: var(--sp-2);
    font-size: var(--fs-sm); color: var(--text-muted);
    flex-wrap: wrap; justify-content: center;
}
.author-byline__label { font-weight: var(--fw-medium); }
.author-byline__name { color: var(--primary); font-weight: var(--fw-semibold); }
.author-byline__sep { opacity: 0.4; }
.author-byline__date { font-family: var(--font-mono); font-size: var(--fs-xs); }
