/* 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 ymf-e86925; tokens via var(--ymf-group-key). */

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

body.ymf-97c1e1 {
    font-family: var(--ymf-type-body);
    color: var(--ymf-color-ink);
    background: var(--ymf-color-paper);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

a { color: inherit; text-decoration: none; }
.ymf-97c1e1 a:hover { color: var(--ymf-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. */
.ymf-d08f92 { border-bottom: 1px solid var(--ymf-color-rule); background: var(--ymf-masthead-bg); color: var(--ymf-masthead-fg); }
.ymf-d08f92 a { color: inherit; }

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

.ymf-078605 { padding: 2.75rem 1.5rem 1.5rem; text-align: center; }
.ymf-0fe909 { max-width: var(--ymf-grid-max); margin: 0 auto; position: relative; }
.ymf-45ed60 { display: inline-block; font-family: var(--ymf-type-heading); font-size: clamp(2.4rem, 5vw, 4.2rem); font-weight: 600; line-height: 1; letter-spacing: -0.025em; color: var(--ymf-color-ink); }
.ymf-9cbd94 { max-height: 64px; width: auto; }
.ymf-23333a { display: inline-block; }
.ymf-307fcb { margin: 0.7rem 0 0; color: var(--ymf-color-muted); font-size: 0.95rem; font-style: italic; letter-spacing: 0; }
.ymf-dc6c0b {
    display: flex; align-items: center; justify-content: center; gap: 14px;
    margin: 1.4rem auto 0; max-width: 280px;
}
.ymf-dc6c0b::before, .ymf-dc6c0b::after {
    content: ""; flex: 1; height: 1px; background: var(--ymf-color-rule);
}
.ymf-76ff85 {
    width: 6px; height: 6px; background: var(--ymf-color-accent);
    border-radius: 50%; flex-shrink: 0;
}

.ymf-0a2470 { border-top: 1px solid var(--ymf-color-rule); border-bottom: 1px solid var(--ymf-color-rule); }
.ymf-74cab3 { max-width: var(--ymf-grid-max); margin: 0 auto; padding: 0 1.5rem; display: flex; align-items: center; }
.ymf-d751ac { display: none; padding: 1rem 0; background: none; border: 0; cursor: pointer; }
.ymf-56d1d6 { list-style: none; margin: 0; padding: 0; display: flex; gap: 2.25rem; flex: 1; justify-content: center; }
.ymf-56d1d6 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(--ymf-color-ink);
    transition: color 0.25s ease;
}
.ymf-56d1d6 li a::after {
    content: ""; position: absolute; left: 0; right: 0; bottom: 0.55rem;
    height: 1px; background: var(--ymf-color-accent);
    transform: scaleX(0); transform-origin: left center;
    transition: transform 0.42s cubic-bezier(.22,1,.36,1);
}
.ymf-56d1d6 li a:hover { color: var(--ymf-color-accent); }
.ymf-56d1d6 li a:hover::after { transform: scaleX(1); }
.ymf-56d1d6 li[aria-current="page"] a::after,
.ymf-56d1d6 li.current-menu-item a::after { transform: scaleX(1); }

@media (max-width: 720px) {
    .ymf-45ed60 { font-size: 2.25rem; }
    .ymf-d751ac { display: inline-block; padding: 0.75rem 0; margin-right: 1rem; }
    .ymf-56d1d6 { display: none; flex-direction: column; gap: 0; width: 100%; justify-content: stretch; }
    .ymf-56d1d6[data-open="true"] { display: flex; }
    .ymf-56d1d6 li a { padding: 0.85rem 0; border-bottom: 1px solid var(--ymf-color-rule); }
    .ymf-5ef004 { display: block; width: 22px; height: 2px; background: var(--ymf-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). */
.ymf-2e1ebf { max-width: var(--ymf-grid-max); margin: 0 auto; padding: 0.95rem 1.5rem; display: flex; align-items: center; justify-content: space-between; gap: 2rem; }
.ymf-d08f92[data-layout="split-band"] .ymf-45ed60 { order: 2; }
.ymf-d08f92[data-layout="horizontal-bar"] .ymf-45ed60,
.ymf-d08f92[data-layout="split-band"] .ymf-45ed60 {
    color: var(--ymf-masthead-wordmark);
    font-size: clamp(1.35rem, 2.6vw, 2.1rem);
    line-height: 1;
    white-space: nowrap;
}
.ymf-d08f92[data-layout="horizontal-bar"] .ymf-9cbd94,
.ymf-d08f92[data-layout="split-band"] .ymf-9cbd94 { max-height: 40px; }
/* nav: inline, no full-width borders, signature-driven case/tracking/weight */
.ymf-d08f92[data-layout="horizontal-bar"] .ymf-0a2470,
.ymf-d08f92[data-layout="split-band"] .ymf-0a2470 { border: 0; flex: 0 1 auto; }
.ymf-d08f92[data-layout="horizontal-bar"] .ymf-56d1d6,
.ymf-d08f92[data-layout="split-band"] .ymf-56d1d6 { flex: initial; justify-content: flex-end; gap: 1.6rem; }
.ymf-d08f92[data-layout="horizontal-bar"] .ymf-56d1d6 li a,
.ymf-d08f92[data-layout="split-band"] .ymf-56d1d6 li a {
    padding: 0.35rem 0;
    font-size: 0.76rem;
    color: inherit;
    text-transform: var(--ymf-masthead-nav_case);
    letter-spacing: var(--ymf-masthead-nav_tracking);
    font-weight: var(--ymf-masthead-nav_weight);
}
.ymf-d08f92[data-layout="horizontal-bar"] .ymf-56d1d6 li a::after,
.ymf-d08f92[data-layout="split-band"] .ymf-56d1d6 li a::after { bottom: 0; }
@media (max-width: 720px) {
    .ymf-2e1ebf { flex-wrap: wrap; gap: 1rem; padding: 0.8rem 1.25rem; }
    .ymf-d08f92[data-layout="horizontal-bar"] .ymf-56d1d6,
    .ymf-d08f92[data-layout="split-band"] .ymf-56d1d6 { justify-content: flex-start; }
}

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

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

/* ─── hero-1: lead + sidebar stack ─────────────────────────── */
.ymf-2c81a3 { display: grid; grid-template-columns: var(--ymf-grid-hero); gap: 3rem; }
@media (max-width: 880px) { .ymf-2c81a3 { grid-template-columns: 1fr; gap: 2rem; } }
.ymf-d5c801 { display: block; }
.ymf-832bcf { aspect-ratio: 3 / 2; overflow: hidden; margin-bottom: 1.5rem; background: var(--ymf-color-wash); }
.ymf-832bcf img,
.ymf-832bcf > div { width: 100%; height: 100%; object-fit: cover; }
.ymf-503325 { display: inline-block; font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ymf-color-accent); margin-bottom: 0.7rem; font-weight: 600; }
.ymf-7f6288 { font-family: var(--ymf-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; }
.ymf-f0474b { color: var(--ymf-color-muted); font-size: 1.1rem; line-height: 1.55; max-width: 56ch; margin: 0; }
.ymf-9ce039 { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: 1.4rem; border-top: 1px solid var(--ymf-color-rule); padding-top: 1rem; }
.ymf-c0623c { padding-bottom: 1.4rem; border-bottom: 1px solid var(--ymf-color-rule); }
.ymf-c0623c:last-child { border-bottom: 0; padding-bottom: 0; }
.ymf-af52e6 { display: grid; grid-template-columns: 88px 1fr; gap: 1rem; align-items: start; }
.ymf-ded1cf { display: block; }
.ymf-ded1cf > div,
.ymf-ded1cf img { width: 88px; height: 88px; object-fit: cover; }
.ymf-fd2140 { display: block; }
.ymf-6d81af { display: block; font-size: 0.66rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ymf-color-accent); margin-bottom: 0.3rem; font-weight: 600; }
.ymf-a3a1be { font-family: var(--ymf-type-heading); font-size: 1.05rem; line-height: 1.25; font-weight: 500; }

/* ─── hero-2: full-bleed billboard ─────────────────────────── */
.ymf-1bd1ce { margin-bottom: 0; }
.ymf-e1a544 { display: block; position: relative; overflow: hidden; }
.ymf-063ec7 { aspect-ratio: 16 / 7; overflow: hidden; background: var(--ymf-color-wash); position: relative; }
.ymf-063ec7 > div, .ymf-063ec7 img { width: 100%; height: 100%; object-fit: cover; }
.ymf-063ec7::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;
}
.ymf-08d076 {
    position: absolute; left: 0; right: 0; bottom: 0;
    padding: clamp(1.25rem, 4vw, 3rem);
    color: #fff;
    z-index: 1;
}
.ymf-425c8e { display: inline-block; font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--ymf-color-accent); margin-bottom: 0.6rem; font-weight: 600; }
.ymf-b77381 { font-family: var(--ymf-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; }
.ymf-586645 { font-size: 1.05rem; line-height: 1.5; max-width: 56ch; margin: 0; color: rgba(255,255,255,0.9); }
@media (max-width: 720px) { .ymf-063ec7 { aspect-ratio: 4 / 5; } }

/* ─── hero-3: split 2-up ───────────────────────────────────── */
.ymf-38b92e { display: grid; grid-template-columns: 1fr 1fr; gap: 3rem; }
@media (max-width: 720px) { .ymf-38b92e { grid-template-columns: 1fr; gap: 2.5rem; } }
.ymf-42214b { display: block; }
.ymf-62c8f5 { aspect-ratio: 16 / 10; overflow: hidden; margin-bottom: 1.25rem; background: var(--ymf-color-wash); }
.ymf-62c8f5 > div, .ymf-62c8f5 img { width: 100%; height: 100%; object-fit: cover; }
.ymf-984530 { display: inline-block; font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ymf-color-accent); font-weight: 600; }
.ymf-d0ae11 { font-family: var(--ymf-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; }
.ymf-1eb8a7 { color: var(--ymf-color-muted); font-size: 1rem; line-height: 1.55; margin: 0; }

/* ─── hero-4: lead + numbered headlines ────────────────────── */
.ymf-604e00 { display: grid; grid-template-columns: 1.6fr 1fr; gap: 3rem; align-items: start; }
@media (max-width: 880px) { .ymf-604e00 { grid-template-columns: 1fr; } }
.ymf-3cb5b3 { display: block; }
.ymf-1f43d0 { aspect-ratio: 3 / 2; overflow: hidden; margin-bottom: 1.4rem; background: var(--ymf-color-wash); }
.ymf-1f43d0 > div, .ymf-1f43d0 img { width: 100%; height: 100%; object-fit: cover; }
.ymf-75674f { display: inline-block; font-size: 0.7rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ymf-color-accent); margin-bottom: 0.7rem; font-weight: 600; }
.ymf-5c956d { font-family: var(--ymf-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; }
.ymf-a8e685 { color: var(--ymf-color-muted); font-size: 1.05rem; line-height: 1.55; max-width: 56ch; margin: 0; }
.ymf-f8407d { list-style: none; margin: 0; padding: 0; counter-reset: hero-num; border-top: 1px solid var(--ymf-color-rule); }
.ymf-3ffa25 { border-bottom: 1px solid var(--ymf-color-rule); }
.ymf-08fd19 { display: grid; grid-template-columns: 48px 1fr; gap: 1rem; align-items: baseline; padding: 1rem 0; }
.ymf-529366 { font-family: var(--ymf-type-heading); font-size: 1.6rem; line-height: 1; color: var(--ymf-color-muted); font-weight: 400; font-variant-numeric: tabular-nums; }
.ymf-27a2d4 { font-family: var(--ymf-type-heading); font-size: 1.15rem; line-height: 1.25; font-weight: 500; }

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

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

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

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

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

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

/* ─── editor-pick ──────────────────────────────────────────── */
.ymf-5083f9 { padding: 3rem 0; border-top: 2px solid var(--ymf-color-ink); border-bottom: 2px solid var(--ymf-color-ink); max-width: 720px; margin-left: auto; margin-right: auto; }
.ymf-5fa46c { font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ymf-color-muted); margin: 0 0 1.25rem; font-weight: 600; }
.ymf-40f6fa { margin: 0; font-family: var(--ymf-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; }
.ymf-3f7afc { color: var(--ymf-color-accent); margin-right: 0.2em; font-weight: 600; }
.ymf-a4f00d { margin: 1.25rem 0 0; font-size: 0.85rem; color: var(--ymf-color-muted); letter-spacing: 0.04em; }

/* ─── single article body ──────────────────────────────────── */
.ymf-2d9379 { max-width: var(--ymf-type-measure); margin: 2.5rem auto; }
.ymf-ccd921 { display: inline-block; font-size: 0.72rem; letter-spacing: 0.16em; text-transform: uppercase; color: var(--ymf-color-accent); margin-bottom: 0.85rem; font-weight: 600; }
.ymf-cbd11c { font-family: var(--ymf-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; }
.ymf-313eb3 { font-size: 1.25rem; line-height: 1.5; color: var(--ymf-color-muted); margin: 0 0 1.25rem; max-width: 60ch; }
.ymf-572011 { font-size: 0.85rem; color: var(--ymf-color-muted); display: flex; gap: 1.25rem; flex-wrap: wrap; padding-bottom: 1rem; border-bottom: 1px solid var(--ymf-color-rule); letter-spacing: 0.02em; }
.ymf-c382bb { margin: 2rem 0; }
.ymf-73bb89 { width: 100%; height: auto; }
.ymf-be4956 { font-size: 0.82rem; color: var(--ymf-color-muted); margin-top: 0.5rem; font-style: italic; }
.ymf-066f1a { font-size: 1.1rem; line-height: 1.78; }
.ymf-066f1a p { margin: 1.4rem 0; }
.ymf-066f1a h2 { font-family: var(--ymf-type-heading); font-size: 1.85rem; margin: 2.4rem 0 0.8rem; line-height: 1.18; font-weight: 600; }
.ymf-066f1a h3 { font-family: var(--ymf-type-heading); font-size: 1.4rem; margin: 1.75rem 0 0.5rem; font-weight: 600; }

/* ─── category archive ─────────────────────────────────────── */
.ymf-b98c7c { padding-top: 1rem; }
.ymf-9a4ae6 { font-size: 0.72rem; letter-spacing: 0.22em; text-transform: uppercase; color: var(--ymf-color-muted); margin: 0; font-weight: 600; }
.ymf-4e49f5 { font-family: var(--ymf-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; }
.ymf-a7199d { display: grid; grid-template-columns: repeat(3, 1fr); gap: 2.25rem; margin: 2rem 0; }
@media (max-width: 880px) { .ymf-a7199d { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 560px) { .ymf-a7199d { grid-template-columns: 1fr; } }
.ymf-eb7a37 { aspect-ratio: 3 / 2; overflow: hidden; margin-bottom: 0.9rem; background: var(--ymf-color-wash); }
.ymf-eb7a37 > div, .ymf-eb7a37 img { width: 100%; height: 100%; object-fit: cover; }
.ymf-9aefbc { font-family: var(--ymf-type-heading); font-size: 1.25rem; line-height: 1.22; margin: 0 0 0.4rem; font-weight: 600; }
.ymf-491d9f { font-size: 0.95rem; color: var(--ymf-color-muted); margin: 0 0 0.4rem; line-height: 1.5; }
.ymf-f8b175 { font-size: 0.75rem; color: var(--ymf-color-muted); letter-spacing: 0.04em; }

/* ─── WP Pages (Privacy/TOS/Contact) ───────────────────────── */
.ymf-fa2b0d { max-width: var(--ymf-type-measure); margin: 2.5rem auto; }
.ymf-75fbc5 { font-family: var(--ymf-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; }
.ymf-ae9fd4 { font-size: 1.05rem; line-height: 1.72; }
.ymf-ae9fd4 h2 { font-family: var(--ymf-type-heading); font-size: 1.6rem; margin: 1.9rem 0 0.6rem; font-weight: 600; }
.ymf-ae9fd4 h3 { font-family: var(--ymf-type-heading); font-size: 1.25rem; margin: 1.4rem 0 0.5rem; font-weight: 600; }

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

/* ─── search ───────────────────────────────────────────────── */
.ymf-43965d { max-width: 720px; margin: 2.5rem auto; padding: 0 1rem; }
.ymf-aec4ff { font-family: var(--ymf-type-heading); font-size: 2.2rem; margin: 0 0 1.5rem; font-weight: 600; }
.ymf-a6c93b { padding: 1.1rem 0; border-bottom: 1px solid var(--ymf-color-rule); }
.ymf-7fc08f { font-family: var(--ymf-type-heading); font-size: 1.3rem; margin: 0 0 0.4rem; font-weight: 500; }
.ymf-f9b666 { color: var(--ymf-color-muted); margin: 0; line-height: 1.55; }

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

/* ─── footer ───────────────────────────────────────────────── */
.ymf-480137 { margin-top: 4rem; padding: 3rem 1.5rem; border-top: 1px solid var(--ymf-color-rule); background: var(--ymf-color-wash); }
.ymf-fa7cb2 { max-width: var(--ymf-grid-max); margin: 0 auto; display: flex; justify-content: space-between; gap: 2rem; flex-wrap: wrap; }
.ymf-0ba639 { font-family: var(--ymf-type-heading); font-size: 1.6rem; font-weight: 600; }
.ymf-21476b { font-size: 0.82rem; color: var(--ymf-color-muted); margin: 0.5rem 0 0; line-height: 1.5; }
.ymf-51f773 { list-style: none; margin: 0; padding: 0; display: flex; gap: 1.75rem; flex-wrap: wrap; font-size: 0.85rem; }
.ymf-51f773 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(--ymf-color-accent); }

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

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

/* ─── ad slots (invisible until populated) ─────────────────── */
.ymf-3b7eca, .ymf-29c1c5, .ymf-f00478, .ymf-2d230c, .ymf-c7d025, .ymf-c1c955 { margin: 1.5rem auto; text-align: center; }
.ymf-29c1c5 { position: sticky; bottom: 0; z-index: 50; background: var(--ymf-color-paper); }
