/* skin.css.tmpl — editorial chassis.
   Resolved by tools/skin/build-skin-css.js (or lib/skins/skin-css-resolver.ts).
   All visible classes are per-site hashes via hji-a9a2f8; tokens via var(--hji-group-key). */

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400..700;1,400&family=Inter:wght@400;500;600&display=swap');

body.hji-5f8420 {
    font-family: var(--hji-type-body);
    color: var(--hji-color-ink);
    background: var(--hji-color-paper);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
.hji-5f8420 a:hover { color: var(--hji-color-accent); }

/* ─── masthead ──────────────────────────────────────────────── */
/* The masthead band picks up signature-derived color roles (default to
   paper/ink, so the centered "stacked" layout looks exactly as before). The
   logo-left "horizontal-bar" and "split-band" variants render different DOM
   from parts/header-*.php and are styled by the [data-layout="…"] blocks below. */
.hji-e469d4 { border-bottom: 1px solid var(--hji-color-rule); background: var(--hji-masthead-bg); color: var(--hji-masthead-fg); }
.hji-e469d4 a { color: inherit; }

.hji-8b642f { border-bottom: 1px solid var(--hji-color-rule); font-size: 0.7rem; color: var(--hji-color-muted); }
.hji-bf90d7 { max-width: var(--hji-grid-max); margin: 0 auto; padding: 0.55rem 1.5rem; display: flex; justify-content: space-between; align-items: center; gap: 1rem; }
.hji-181883 { letter-spacing: 0.18em; text-transform: uppercase; font-weight: 500; }
.hji-0ddc04 { letter-spacing: 0.18em; text-transform: uppercase; font-weight: 500; }

.hji-f4e743 { padding: 2.75rem 1.5rem 1.5rem; text-align: center; }
.hji-c3ddb4 { max-width: var(--hji-grid-max); margin: 0 auto; position: relative; }
.hji-5cf9a6 { display: inline-block; font-family: var(--hji-type-heading); font-size: clamp(2.4rem, 5vw, 4.2rem); font-weight: 600; line-height: 1; letter-spacing: -0.025em; color: var(--hji-color-ink); }
.hji-8f3827 { max-height: 64px; width: auto; }
.hji-6698b7 { display: inline-block; }
.hji-a51b6f { margin: 0.7rem 0 0; color: var(--hji-color-muted); font-size: 0.95rem; font-style: italic; letter-spacing: 0; }
.hji-09a5d6 {
    display: flex; align-items: center; justify-content: center; gap: 14px;
    margin: 1.4rem auto 0; max-width: 280px;
}
.hji-09a5d6::before, .hji-09a5d6::after {
    content: ""; flex: 1; height: 1px; background: var(--hji-color-rule);
}
.hji-ec333a {
    width: 6px; height: 6px; background: var(--hji-color-accent);
    border-radius: 50%; flex-shrink: 0;
}

.hji-c9b846 { border-top: 1px solid var(--hji-color-rule); border-bottom: 1px solid var(--hji-color-rule); }
.hji-849053 { max-width: var(--hji-grid-max); margin: 0 auto; padding: 0 1.5rem; display: flex; align-items: center; }
.hji-bab2cd { display: none; padding: 1rem 0; background: none; border: 0; cursor: pointer; }
.hji-6f5b49 { list-style: none; margin: 0; padding: 0; display: flex; gap: 2.25rem; flex: 1; justify-content: center; }
.hji-6f5b49 li a {
    position: relative; display: block; padding: 1.05rem 0.1rem;
    font-size: 0.74rem; letter-spacing: 0.22em; text-transform: uppercase; font-weight: 600;
    color: var(--hji-color-ink);
    transition: color 0.25s ease;
}
.hji-6f5b49 li a::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: 0.55rem;
    height: 1px; background: var(--hji-color-accent);
    transform: scaleX(0); transform-origin: left center;
    transition: transform 0.42s cubic-bezier(.22,1,.36,1);
}
.hji-6f5b49 li a:hover { color: var(--hji-color-accent); }
.hji-6f5b49 li a:hover::after { transform: scaleX(1); }
.hji-6f5b49 li[aria-current="page"] a::after,
.hji-6f5b49 li.current-menu-item a::after { transform: scaleX(1); }

@media (max-width: 720px) {
    .hji-5cf9a6 { font-size: 2.25rem; }
    .hji-bab2cd { display: inline-block; padding: 0.75rem 0; margin-right: 1rem; }
    .hji-6f5b49 { display: none; flex-direction: column; gap: 0; width: 100%; justify-content: stretch; }
    .hji-6f5b49[data-open="true"] { display: flex; }
    .hji-6f5b49 li a { padding: 0.85rem 0; border-bottom: 1px solid var(--hji-color-rule); }
    .hji-34c12d { display: block; width: 22px; height: 2px; background: var(--hji-color-ink); margin: 4px 0; }
}

/* ─── masthead variants: horizontal-bar + split-band ─────────────
   These two layouts share a single flex row (.masthead-bar) and render the
   wordmark + nav inline instead of the stacked centered bands. They reuse the
   .brand-logo / .nav / .nav-list logical classes so the JS nav toggle and
   mobile rules above keep working; only arrangement + color differ.
   The existing logo (text wordmark or logo_svg_url <img>) is rendered as-is —
   no logo regeneration (Logo ⟂ Theme invariant). */
.hji-d8a24d { max-width: var(--hji-grid-max); margin: 0 auto; padding: 0.95rem 1.5rem; display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.hji-e469d4[data-layout="split-band"] .hji-5cf9a6 { order: 2; }
.hji-e469d4[data-layout="horizontal-bar"] .hji-5cf9a6,
.hji-e469d4[data-layout="split-band"] .hji-5cf9a6 {
    color: var(--hji-masthead-wordmark);
    font-size: clamp(1.35rem, 2.6vw, 2.1rem);
    line-height: 1;
    white-space: nowrap;
}
.hji-e469d4[data-layout="horizontal-bar"] .hji-8f3827,
.hji-e469d4[data-layout="split-band"] .hji-8f3827 { max-height: 40px; }
/* nav: inline, no full-width borders, signature-driven case/tracking/weight */
.hji-e469d4[data-layout="horizontal-bar"] .hji-c9b846,
.hji-e469d4[data-layout="split-band"] .hji-c9b846 { border: 0; flex: 0 1 auto; }
.hji-e469d4[data-layout="horizontal-bar"] .hji-6f5b49,
.hji-e469d4[data-layout="split-band"] .hji-6f5b49 { flex: initial; justify-content: flex-end; gap: 1.6rem; }
.hji-e469d4[data-layout="horizontal-bar"] .hji-6f5b49 li a,
.hji-e469d4[data-layout="split-band"] .hji-6f5b49 li a {
    padding: 0.35rem 0;
    font-size: 0.76rem;
    color: inherit;
    text-transform: var(--hji-masthead-nav_case);
    letter-spacing: var(--hji-masthead-nav_tracking);
    font-weight: var(--hji-masthead-nav_weight);
}
.hji-e469d4[data-layout="horizontal-bar"] .hji-6f5b49 li a::after,
.hji-e469d4[data-layout="split-band"] .hji-6f5b49 li a::after { bottom: 0; }
@media (max-width: 720px) {
    .hji-d8a24d { flex-wrap: wrap; gap: 1rem; padding: 0.8rem 1.25rem; }
    .hji-e469d4[data-layout="horizontal-bar"] .hji-6f5b49,
    .hji-e469d4[data-layout="split-band"] .hji-6f5b49 { justify-content: flex-start; }
}

.hji-f637bb { max-width: var(--hji-grid-max); margin: 0 auto; padding: 2rem 1.5rem 4rem; }
.hji-f637bb > section { margin: var(--hji-space-section) 0; }
.hji-f637bb > section:first-child { margin-top: 1.5rem; }
@media (max-width: 720px) { .hji-f637bb > section { margin: 2.5rem 0; } }

/* ─── shared section header — dot on a line ─────────────────── */
.hji-9e7779 {
    position: relative;
    font-family: var(--hji-type-body);
    font-size: 0.72rem;
    font-weight: 600;
    letter-spacing: 0.22em;
    text-transform: uppercase;
    color: var(--hji-color-muted);
    margin: 0 0 1.75rem;
    padding-bottom: 1rem;
}
.hji-9e7779::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: 0;
    height: 1px; background: var(--hji-color-rule);
}
.hji-9e7779::before {
    content: ""; position: absolute; left: 0; bottom: -3.5px;
    width: 8px; height: 8px;
    background: var(--hji-color-accent); border-radius: 50%;
    z-index: 1;
}

/* ─── hero-1: lead + sidebar stack ─────────────────────────── */
.hji-cd7c80 { display: grid; grid-template-columns: var(--hji-grid-hero); gap: 3rem; }
@media (max-width: 880px) { .hji-cd7c80 { grid-template-columns: 1fr; gap: 2rem; } }
.hji-4b7329 { display: block; }
.hji-9f8164 { aspect-ratio: 3 / 2; overflow: hidden; margin-bottom: 1.5rem; background: var(--hji-color-wash); }
.hji-9f8164 img,
.hji-9f8164 > div { width: 100%; height: 100%; object-fit: cover; }
.hji-a84129 { display: inline-block; font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--hji-color-accent); margin-bottom: 0.7rem; font-weight: 600; }
.hji-71632f { font-family: var(--hji-type-heading); font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.08; letter-spacing: -0.015em; margin: 0 0 0.8rem; font-weight: 600; }
.hji-14fe39 { color: var(--hji-color-muted); font-size: 1.1rem; line-height: 1.55; max-width: 56ch; margin: 0; }
.hji-4f5ff9 { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1.4rem; border-top: 1px solid var(--hji-color-rule); padding-top: 1rem; }
.hji-51f4d8 { padding-bottom: 1.4rem; border-bottom: 1px solid var(--hji-color-rule); }
.hji-51f4d8:last-child { border-bottom: 0; padding-bottom: 0; }
.hji-d5b910 { display: grid; grid-template-columns: 88px 1fr; gap: 1rem; align-items: start; }
.hji-e8b55f { display: block; }
.hji-e8b55f > div,
.hji-e8b55f img { width: 88px; height: 88px; object-fit: cover; }
.hji-2e5066 { display: block; }
.hji-b1ab5f { display: block; font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--hji-color-accent); margin-bottom: 0.3rem; font-weight: 600; }
.hji-330d6d { font-family: var(--hji-type-heading); font-size: 1.05rem; line-height: 1.25; font-weight: 500; }

/* ─── hero-2: full-bleed billboard ─────────────────────────── */
.hji-ff8b9e { margin-bottom: 0; }
.hji-c20f4f { display: block; position: relative; overflow: hidden; }
.hji-6163c3 { aspect-ratio: 16 / 7; overflow: hidden; background: var(--hji-color-wash); position: relative; }
.hji-6163c3 > div, .hji-6163c3 img { width: 100%; height: 100%; object-fit: cover; }
.hji-6163c3::after {
    content: ""; position: absolute; inset: 0;
    background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,0.7) 100%);
    pointer-events: none;
}
.hji-fdec72 {
    position: absolute; left: 0; right: 0; bottom: 0;
    padding: clamp(1.25rem, 4vw, 3rem);
    color: #fff;
    z-index: 1;
}
.hji-8bdf56 { display: inline-block; font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--hji-color-accent); margin-bottom: 0.6rem; font-weight: 600; }
.hji-242082 { font-family: var(--hji-type-heading); font-size: clamp(2rem, 5vw, 4rem); line-height: 1.05; letter-spacing: -0.02em; margin: 0 0 0.6rem; font-weight: 600; max-width: 22ch; color: #fff; }
.hji-12c45e { font-size: 1.05rem; line-height: 1.5; max-width: 56ch; margin: 0; color: rgba(255,255,255,0.9); }
@media (max-width: 720px) { .hji-6163c3 { aspect-ratio: 4 / 5; } }

/* ─── hero-3: split 2-up ───────────────────────────────────── */
.hji-8fe9c3 { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; }
@media (max-width: 720px) { .hji-8fe9c3 { grid-template-columns: 1fr; gap: 2.5rem; } }
.hji-3119dd { display: block; }
.hji-5050f0 { aspect-ratio: 16 / 10; overflow: hidden; margin-bottom: 1.25rem; background: var(--hji-color-wash); }
.hji-5050f0 > div, .hji-5050f0 img { width: 100%; height: 100%; object-fit: cover; }
.hji-bc9c05 { display: inline-block; font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--hji-color-accent); font-weight: 600; }
.hji-b660ba { font-family: var(--hji-type-heading); font-size: clamp(1.5rem, 2.8vw, 2.1rem); line-height: 1.15; letter-spacing: -0.01em; margin: 0.5rem 0 0.6rem; font-weight: 600; }
.hji-69b57f { color: var(--hji-color-muted); font-size: 1rem; line-height: 1.55; margin: 0; }

/* ─── hero-4: lead + numbered headlines ────────────────────── */
.hji-c0388d { display: grid; grid-template-columns: 1.6fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 880px) { .hji-c0388d { grid-template-columns: 1fr; } }
.hji-6229f8 { display: block; }
.hji-55d503 { aspect-ratio: 3 / 2; overflow: hidden; margin-bottom: 1.4rem; background: var(--hji-color-wash); }
.hji-55d503 > div, .hji-55d503 img { width: 100%; height: 100%; object-fit: cover; }
.hji-d28589 { display: inline-block; font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--hji-color-accent); margin-bottom: 0.7rem; font-weight: 600; }
.hji-8f34c0 { font-family: var(--hji-type-heading); font-size: clamp(1.9rem, 4vw, 3rem); line-height: 1.08; letter-spacing: -0.015em; margin: 0 0 0.7rem; font-weight: 600; }
.hji-65be71 { color: var(--hji-color-muted); font-size: 1.05rem; line-height: 1.55; max-width: 56ch; margin: 0; }
.hji-1062c5 { list-style: none; margin: 0; padding: 0; counter-reset: hero-num; border-top: 1px solid var(--hji-color-rule); }
.hji-f5a279 { border-bottom: 1px solid var(--hji-color-rule); }
.hji-74a819 { display: grid; grid-template-columns: 48px 1fr; gap: 1rem; align-items: baseline; padding: 1rem 0; }
.hji-945e7b { font-family: var(--hji-type-heading); font-size: 1.6rem; line-height: 1; color: var(--hji-color-muted); font-weight: 400; font-variant-numeric: tabular-nums; }
.hji-8857a6 { font-family: var(--hji-type-heading); font-size: 1.15rem; line-height: 1.25; font-weight: 500; }

/* ─── card-grid-2 (Latest, large cards) ────────────────────── */
.hji-302bf9 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 2.5rem; }
@media (max-width: 720px) { .hji-302bf9 { grid-template-columns: 1fr; gap: 2rem; } }
.hji-05a2b8 { display: block; }
.hji-490319 { aspect-ratio: 3 / 2; overflow: hidden; margin-bottom: 1rem; background: var(--hji-color-wash); }
.hji-490319 > div, .hji-490319 img { width: 100%; height: 100%; object-fit: cover; }
.hji-93b7f6 { display: inline-block; font-size: 0.68rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--hji-color-accent); margin-bottom: 0.45rem; font-weight: 600; }
.hji-a751e9 { font-family: var(--hji-type-heading); font-size: 1.5rem; line-height: 1.18; letter-spacing: -0.005em; margin: 0 0 0.5rem; font-weight: 600; }
.hji-533636 { color: var(--hji-color-muted); font-size: 0.98rem; line-height: 1.5; margin: 0; }

/* ─── card-grid-3 (Latest, standard) ───────────────────────── */
.hji-2a4879 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.25rem; }
@media (max-width: 880px) { .hji-2a4879 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .hji-2a4879 { grid-template-columns: 1fr; } }
.hji-ed5210 { display: block; }
.hji-894b0d { aspect-ratio: 3 / 2; overflow: hidden; margin-bottom: 0.9rem; background: var(--hji-color-wash); }
.hji-894b0d > div, .hji-894b0d img { width: 100%; height: 100%; object-fit: cover; }
.hji-55038d { display: inline-block; font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--hji-color-accent); margin-bottom: 0.4rem; font-weight: 600; }
.hji-d1801d { font-family: var(--hji-type-heading); font-size: 1.25rem; line-height: 1.22; margin: 0.2rem 0 0.5rem; font-weight: 600; }
.hji-cd1e95 { font-size: 0.75rem; color: var(--hji-color-muted); letter-spacing: 0.04em; }

/* ─── card-grid-4 (dense, image-on-top) ────────────────────── */
.hji-ae7967 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.75rem; }
@media (max-width: 880px) { .hji-ae7967 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { .hji-ae7967 { grid-template-columns: 1fr; } }
.hji-cfa3ca { display: block; }
.hji-daa4b7 { aspect-ratio: 1 / 1; overflow: hidden; margin-bottom: 0.75rem; background: var(--hji-color-wash); }
.hji-daa4b7 > div, .hji-daa4b7 img { width: 100%; height: 100%; object-fit: cover; }
.hji-3a9ad9 { font-family: var(--hji-type-heading); font-size: 1.05rem; line-height: 1.25; margin: 0; font-weight: 500; }

/* ─── feature-strip (In Depth, magazine row) ───────────────── */
.hji-cac2d1 { font-family: var(--hji-type-body); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--hji-color-muted); margin: 0 0 1.75rem; padding-bottom: 0.6rem; border-bottom: 1px solid var(--hji-color-rule); }
.hji-b6be40 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.75rem; }
@media (max-width: 880px) { .hji-b6be40 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .hji-b6be40 { grid-template-columns: 1fr; } }
.hji-82bff0 { display: block; }
.hji-a691ef { aspect-ratio: 4 / 5; overflow: hidden; margin-bottom: 0.85rem; background: var(--hji-color-wash); }
.hji-a691ef > div, .hji-a691ef img { width: 100%; height: 100%; object-fit: cover; }
.hji-3730d8 { display: inline-block; font-size: 0.64rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--hji-color-accent); font-weight: 600; }
.hji-5de6b8 { font-family: var(--hji-type-heading); font-size: 1.1rem; line-height: 1.22; margin: 0.35rem 0 0; font-weight: 500; }

/* ─── list-compact (More Reading, type-only) ───────────────── */
.hji-aa1c00 { font-family: var(--hji-type-body); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--hji-color-muted); margin: 0 0 1.5rem; padding-bottom: 0.6rem; border-bottom: 1px solid var(--hji-color-rule); }
.hji-980dda { margin: 0; }
.hji-980dda dt { font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--hji-color-muted); margin-top: 1.3rem; font-weight: 500; }
.hji-980dda dt time { margin-right: 1rem; }
.hji-1520ce { color: var(--hji-color-accent); }
.hji-980dda dd { margin: 0.35rem 0 1.3rem; padding-bottom: 1.3rem; border-bottom: 1px solid var(--hji-color-rule); }
.hji-980dda dd a { font-family: var(--hji-type-heading); font-size: 1.5rem; line-height: 1.22; font-weight: 500; }

/* ─── archive-strip (From the Archive) ─────────────────────── */
.hji-b6cdef { font-family: var(--hji-type-body); font-size: 0.72rem; font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--hji-color-muted); margin: 0 0 1.5rem; padding-bottom: 0.6rem; border-bottom: 1px solid var(--hji-color-rule); }
.hji-6534dd { list-style: none; margin: 0; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1.5rem; }
@media (max-width: 720px) { .hji-6534dd { grid-template-columns: repeat(2, 1fr); } }
.hji-09e5d0 { display: grid; grid-template-columns: 1fr; gap: 0.6rem; }
.hji-ab3aa8 { display: block; aspect-ratio: 1 / 1; overflow: hidden; background: var(--hji-color-wash); }
.hji-ab3aa8 > div, .hji-ab3aa8 img { width: 100%; height: 100%; object-fit: cover; }
.hji-fad8a1 { font-family: var(--hji-type-heading); font-size: 0.98rem; line-height: 1.25; font-weight: 500; }

/* ─── editor-pick ──────────────────────────────────────────── */
.hji-4a47d9 { padding: 3rem 0; border-top: 2px solid var(--hji-color-ink); border-bottom: 2px solid var(--hji-color-ink); max-width: 720px; margin-left: auto; margin-right: auto; }
.hji-b5baba { font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--hji-color-muted); margin: 0 0 1.25rem; font-weight: 600; }
.hji-3f326a { margin: 0; font-family: var(--hji-type-heading); font-size: clamp(1.6rem, 3.2vw, 2.4rem); line-height: 1.18; letter-spacing: -0.01em; max-width: 26ch; font-weight: 500; }
.hji-fc63ad { color: var(--hji-color-accent); margin-right: 0.2em; font-weight: 600; }
.hji-f80fca { margin: 1.25rem 0 0; font-size: 0.85rem; color: var(--hji-color-muted); letter-spacing: 0.04em; }

/* ─── single article body ──────────────────────────────────── */
.hji-d410d3 { max-width: var(--hji-type-measure); margin: 2.5rem auto; }
.hji-f2900e { display: inline-block; font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--hji-color-accent); margin-bottom: 0.85rem; font-weight: 600; }
.hji-2c7789 { font-family: var(--hji-type-heading); font-size: clamp(2rem, 4.5vw, 3.5rem); line-height: 1.05; letter-spacing: -0.02em; margin: 0 0 0.8rem; font-weight: 600; }
.hji-7b83ff { font-size: 1.25rem; line-height: 1.5; color: var(--hji-color-muted); margin: 0 0 1.25rem; max-width: 60ch; }
.hji-476f5e { font-size: 0.85rem; color: var(--hji-color-muted); display: flex; gap: 1.25rem; flex-wrap: wrap; padding-bottom: 1rem; border-bottom: 1px solid var(--hji-color-rule); letter-spacing: 0.02em; }
.hji-ba85c9 { margin: 2rem 0; }
.hji-64bfbd { width: 100%; height: auto; }
.hji-a11ff9 { font-size: 0.82rem; color: var(--hji-color-muted); margin-top: 0.5rem; font-style: italic; }
.hji-c2a95a { font-size: 1.1rem; line-height: 1.78; }
.hji-c2a95a p { margin: 1.4rem 0; }
.hji-c2a95a h2 { font-family: var(--hji-type-heading); font-size: 1.85rem; margin: 2.4rem 0 0.8rem; line-height: 1.18; font-weight: 600; }
.hji-c2a95a h3 { font-family: var(--hji-type-heading); font-size: 1.4rem; margin: 1.75rem 0 0.5rem; font-weight: 600; }

/* ─── category archive ─────────────────────────────────────── */
.hji-11d0db { padding-top: 1rem; }
.hji-766dff { font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--hji-color-muted); margin: 0; font-weight: 600; }
.hji-6cf56b { font-family: var(--hji-type-heading); font-size: clamp(2.2rem, 4.5vw, 3.5rem); line-height: 1.08; letter-spacing: -0.02em; margin: 0.4rem 0 1.2rem; font-weight: 600; }
.hji-d5bf7c { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.25rem; margin: 2rem 0; }
@media (max-width: 880px) { .hji-d5bf7c { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .hji-d5bf7c { grid-template-columns: 1fr; } }
.hji-a8abb9 { aspect-ratio: 3 / 2; overflow: hidden; margin-bottom: 0.9rem; background: var(--hji-color-wash); }
.hji-a8abb9 > div, .hji-a8abb9 img { width: 100%; height: 100%; object-fit: cover; }
.hji-dc6466 { font-family: var(--hji-type-heading); font-size: 1.25rem; line-height: 1.22; margin: 0 0 0.4rem; font-weight: 600; }
.hji-8f375c { font-size: 0.95rem; color: var(--hji-color-muted); margin: 0 0 0.4rem; line-height: 1.5; }
.hji-5c2fc5 { font-size: 0.75rem; color: var(--hji-color-muted); letter-spacing: 0.04em; }

/* ─── WP Pages (Privacy/TOS/Contact) ───────────────────────── */
.hji-879bf9 { max-width: var(--hji-type-measure); margin: 2.5rem auto; }
.hji-95ba46 { font-family: var(--hji-type-heading); font-size: clamp(2.2rem, 4.5vw, 3.2rem); line-height: 1.08; letter-spacing: -0.02em; margin: 0 0 1.5rem; font-weight: 600; }
.hji-8c714e { font-size: 1.05rem; line-height: 1.72; }
.hji-8c714e h2 { font-family: var(--hji-type-heading); font-size: 1.6rem; margin: 1.9rem 0 0.6rem; font-weight: 600; }
.hji-8c714e h3 { font-family: var(--hji-type-heading); font-size: 1.25rem; margin: 1.4rem 0 0.5rem; font-weight: 600; }

/* ─── 404 ──────────────────────────────────────────────────── */
.hji-f74273 { max-width: 50ch; margin: 6rem auto; text-align: center; padding: 0 1rem; }
.hji-4c911a { font-family: var(--hji-type-heading); font-size: clamp(2.5rem, 5vw, 4rem); margin: 0 0 1rem; font-weight: 600; }
.hji-f7305e { color: var(--hji-color-muted); font-size: 1.1rem; margin: 0 0 1.5rem; }
.hji-bb1787 { display: inline-block; border: 1px solid var(--hji-color-ink); padding: 0.85rem 1.4rem; font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 600; }
.hji-bb1787:hover { background: var(--hji-color-ink); color: var(--hji-color-paper); }

/* ─── search ───────────────────────────────────────────────── */
.hji-0c2041 { max-width: 720px; margin: 2.5rem auto; padding: 0 1rem; }
.hji-d944df { font-family: var(--hji-type-heading); font-size: 2.2rem; margin: 0 0 1.5rem; font-weight: 600; }
.hji-33cf14 { padding: 1.1rem 0; border-bottom: 1px solid var(--hji-color-rule); }
.hji-2a1ab4 { font-family: var(--hji-type-heading); font-size: 1.3rem; margin: 0 0 0.4rem; font-weight: 500; }
.hji-61faae { color: var(--hji-color-muted); margin: 0; line-height: 1.55; }

/* ─── share bar ────────────────────────────────────────────── */
.hji-3d3899 { display: flex; align-items: center; gap: 1rem; margin: 2.5rem 0; padding: 1rem 0; border-top: 1px solid var(--hji-color-rule); border-bottom: 1px solid var(--hji-color-rule); }
.hji-b0c8d6 { font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--hji-color-muted); font-weight: 600; }
.hji-5060f6 { list-style: none; margin: 0; padding: 0; display: flex; gap: 0.6rem; }
.hji-fe15ae { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border: 1px solid var(--hji-color-rule); color: var(--hji-color-ink); border-radius: var(--hji-radius-button); transition: all 0.18s ease; background: none; cursor: pointer; }
.hji-fe15ae:hover { background: var(--hji-color-ink); color: var(--hji-color-paper); border-color: var(--hji-color-ink); }

/* ─── footer ───────────────────────────────────────────────── */
.hji-25b2bc { margin-top: 4rem; padding: 3rem 1.5rem; border-top: 1px solid var(--hji-color-rule); background: var(--hji-color-wash); }
.hji-34186d { max-width: var(--hji-grid-max); margin: 0 auto; display: flex; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.hji-fbe12b { font-family: var(--hji-type-heading); font-size: 1.6rem; font-weight: 600; }
.hji-cf6756 { font-size: 0.82rem; color: var(--hji-color-muted); margin: 0.5rem 0 0; line-height: 1.5; }
.hji-d8f5e6 { list-style: none; margin: 0; padding: 0; display: flex; gap: 1.75rem; flex-wrap: wrap; font-size: 0.85rem; }
.hji-d8f5e6 li a { letter-spacing: 0.02em; }

/* ─── universal card hover (data-zoom attribute) ───────────── */
[data-zoom] { overflow: hidden; }
[data-zoom] > * { transition: transform 0.7s cubic-bezier(.22,1,.36,1); will-change: transform; }
a:hover [data-zoom] > *,
button:hover [data-zoom] > * { transform: scale(1.05); }

a:has([data-zoom]) h2,
a:has([data-zoom]) h3 { transition: color 0.25s ease; }
a:has([data-zoom]):hover h2,
a:has([data-zoom]):hover h3 { color: var(--hji-color-accent); }

/* ─── article body drop-cap on first paragraph ─────────────── */
.hji-c2a95a > p:first-of-type::first-letter {
    font-family: var(--hji-type-heading);
    float: left;
    font-size: 4.6rem;
    line-height: 0.88;
    margin: 0.45rem 0.55rem 0 0;
    font-weight: 600;
    color: var(--hji-color-accent);
}

/* ─── footer meta strip ─────────────────────────────────────── */
.hji-acdd26 {
    max-width: var(--hji-grid-max); margin: 2.25rem auto 0;
    padding-top: 1.6rem;
    border-top: 1px solid var(--hji-color-rule);
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
    font-size: 0.74rem; color: var(--hji-color-muted); letter-spacing: 0.06em;
}
.hji-05495a { letter-spacing: 0.18em; text-transform: uppercase; font-weight: 600; }
.hji-05495a span { color: var(--hji-color-accent); margin: 0 0.4em; }

/* ─── ad slots (invisible until populated) ─────────────────── */
.hji-7b7bea, .hji-203261, .hji-deb7d9, .hji-6dc340, .hji-10f45f, .hji-7e2edc { margin: 1.5rem auto; text-align: center; }
.hji-203261 { position: sticky; bottom: 0; z-index: 50; background: var(--hji-color-paper); }
