:root {
    --fr-black: #090909;
    --fr-ink: #151515;
    --fr-charcoal: #505050;
    --fr-cream: #f7f4ef;
    --fr-white: #ffffff;
    --fr-red: #780018;
    --fr-gold: #d4b586;
    --fr-line: #ded8cf;
    --fr-max: 1240px;
    --fr-serif: Didot, "Bodoni 72", "Bodoni MT", "Playfair Display", Georgia, serif;
    --fr-body: "Lora", Georgia, serif;
    --fr-sans: Montserrat, "Helvetica Neue", Arial, sans-serif;
}
* { box-sizing: border-box; }
body { margin: 0; background: var(--fr-cream); color: var(--fr-ink); font-family: var(--fr-body); font-size: 17px; line-height: 1.65; }
a { color: inherit; text-decoration: none; }
a:hover { color: var(--fr-red); }
img { max-width: 100%; height: auto; display: block; }
.fr-container { width: min(var(--fr-max), calc(100% - 40px)); margin-inline: auto; }
.screen-reader-text { position: absolute; left: -9999px; }
.skip-link:focus { left: 20px; top: 20px; background: var(--fr-black); color: white; padding: 10px; z-index: 99; }
.site-header { background: var(--fr-cream); border-bottom: 1px solid var(--fr-line); }
.top-utility { background: var(--fr-black); color: var(--fr-white); font-family: var(--fr-sans); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; }
.utility-inner { display: flex; align-items: center; justify-content: space-between; min-height: 38px; gap: 18px; }
.utility-inner ul { list-style: none; display: flex; gap: 22px; margin: 0; padding: 0; }
.utility-actions { display: flex; gap: 18px; align-items: center; }
.search-toggle, .menu-toggle { background: transparent; border: 0; color: inherit; cursor: pointer; font: inherit; }
.masthead-main { position: relative; text-align: center; padding: 34px 0 24px; }
.menu-toggle { display: none; position: absolute; left: 0; top: 42px; font-size: 28px; color: var(--fr-black); }
.site-title { font-family: var(--fr-serif); text-transform: uppercase; letter-spacing: .045em; font-size: clamp(46px, 8vw, 90px); line-height: .92; }
.site-tagline { margin: 10px 0 0; font-family: var(--fr-sans); font-size: 10px; letter-spacing: .18em; text-transform: uppercase; }
.primary-nav { border-top: 1px solid var(--fr-line); border-bottom: 1px solid var(--fr-line); font-family: var(--fr-sans); font-size: 10px; letter-spacing: .13em; text-transform: uppercase; }
.primary-nav ul { list-style: none; margin: 0; padding: 0; display: flex; justify-content: center; flex-wrap: wrap; gap: 0; }
.primary-nav a { display: block; padding: 14px 15px; }
.fr-search-panel { padding: 18px 0; border-top: 1px solid var(--fr-line); }
.fr-search-panel input[type="search"] { width: min(680px, 100%); padding: 14px; border: 1px solid var(--fr-line); background: white; }
.home-hero { padding: 24px 0 10px; }
.fr-story-feature { display: grid; grid-template-columns: .72fr 1.28fr; min-height: 520px; background: var(--fr-black); color: var(--fr-white); }
.fr-story-feature .card-image { order: 2; min-height: 520px; }
.fr-story-feature .card-image img, .fr-story-feature .fr-placeholder { width: 100%; height: 100%; object-fit: cover; }
.fr-story-feature .card-body { padding: clamp(30px, 5vw, 62px); display: flex; flex-direction: column; justify-content: center; align-items: flex-start; }
.fr-kicker { margin: 0 0 12px; font-family: var(--fr-sans); font-size: 10px; letter-spacing: .17em; text-transform: uppercase; color: var(--fr-red); font-weight: 700; }
.fr-story-feature .fr-kicker, .talks-module .fr-kicker, .newsletter-module .fr-kicker { color: #e1b6bd; }
h1,h2,h3,h4 { font-family: var(--fr-serif); font-weight: 400; line-height: 1.05; margin: 0; }
.fr-story-feature h2 { font-size: clamp(42px, 5.8vw, 76px); }
.card-deck { color: inherit; opacity: .86; max-width: 540px; }
.card-meta, .article-meta { font-family: var(--fr-sans); font-size: 10px; letter-spacing: .12em; text-transform: uppercase; color: var(--fr-charcoal); }
.fr-story-feature .card-meta { color: rgba(255,255,255,.75); }
.fr-button, button, input[type="submit"] { display: inline-flex; align-items: center; justify-content: center; padding: 12px 18px; border: 1px solid var(--fr-black); background: var(--fr-black); color: var(--fr-white); font-family: var(--fr-sans); font-size: 10px; letter-spacing: .14em; text-transform: uppercase; cursor: pointer; }
.fr-button:hover, button:hover, input[type="submit"]:hover { background: var(--fr-red); border-color: var(--fr-red); color: white; }
.fr-button.light { background: transparent; color: var(--fr-white); border-color: rgba(255,255,255,.6); }
.fr-card-grid { display: grid; gap: 22px; margin-top: 26px; }
.four-up { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.three-up { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.fr-story-medium { background: var(--fr-cream); }
.fr-story-medium .card-image { aspect-ratio: 4 / 3; overflow: hidden; background: #ddd; }
.fr-story-medium .card-image img { width: 100%; height: 100%; object-fit: cover; transition: transform .35s ease; }
.fr-story-medium:hover .card-image img { transform: scale(1.035); }
.fr-story-medium .card-body { padding: 14px 0 0; }
.fr-story-medium h3 { font-size: clamp(21px, 2vw, 28px); }
.secondary-grid { padding-bottom: 36px; border-bottom: 1px solid var(--fr-line); }
.fr-home-columns { display: grid; grid-template-columns: .72fr 1.28fr; gap: 34px; padding: 34px 0; border-bottom: 1px solid var(--fr-line); }
.section-heading { display: flex; justify-content: space-between; align-items: center; gap: 20px; border-top: 1px solid var(--fr-line); padding-top: 14px; margin-bottom: 18px; font-family: var(--fr-sans); text-transform: uppercase; letter-spacing: .12em; font-size: 10px; }
.section-heading h2 { font-family: var(--fr-sans); font-size: 12px; font-weight: 700; letter-spacing: .14em; }
.latest-list { display: grid; gap: 16px; }
.fr-story-compact { display: grid; grid-template-columns: 76px 1fr; gap: 12px; padding-bottom: 14px; border-bottom: 1px solid var(--fr-line); }
.compact-image { aspect-ratio: 4 / 5; background: #ddd; overflow: hidden; }
.compact-image img { width: 100%; height: 100%; object-fit: cover; }
.fr-story-compact h4 { font-size: 16px; line-height: 1.18; }
.module-category-rail { padding: 34px 0; border-bottom: 1px solid var(--fr-line); }
.talks-module { padding: 44px 0; }
.talks-inner { display: grid; grid-template-columns: .68fr 1.32fr; background: var(--fr-black); color: white; }
.talks-copy { padding: clamp(28px, 4vw, 52px); align-self: center; }
.talks-copy h2 { font-size: clamp(36px, 4.5vw, 58px); }
.talks-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; padding: 28px; align-content: center; }
.fr-story-video .card-image { aspect-ratio: 16 / 9; position: relative; overflow: hidden; background: #222; }
.play-badge { position: absolute; inset: 50% auto auto 50%; transform: translate(-50%, -50%); background: rgba(0,0,0,.7); color: white; width: 44px; height: 44px; border-radius: 50%; display: grid; place-items: center; }
.fr-story-video h3 { font-size: 20px; margin-top: 8px; }
.newsletter-module { padding: 44px 0 64px; }
.newsletter-inner { background: var(--fr-black); color: white; text-align: center; padding: clamp(34px, 6vw, 70px); }
.newsletter-inner h2 { font-size: clamp(34px, 5vw, 62px); }
.newsletter-form { margin: 24px auto 0; display: flex; justify-content: center; gap: 8px; max-width: 560px; }
.newsletter-form input { flex: 1; padding: 13px; border: 1px solid rgba(255,255,255,.4); background: transparent; color: white; }
.site-footer { background: var(--fr-black); color: white; padding: 46px 0 24px; }
.footer-grid { display: grid; grid-template-columns: 1.3fr 1fr 1fr; gap: 30px; }
.footer-brand { font-size: 34px; text-transform: uppercase; letter-spacing: .04em; }
.footer-nav ul { list-style: none; padding: 0; margin: 0; columns: 2; font-family: var(--fr-sans); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; }
.footer-bottom { border-top: 1px solid rgba(255,255,255,.2); margin-top: 30px; padding-top: 18px; font-family: var(--fr-sans); font-size: 11px; text-transform: uppercase; letter-spacing: .08em; color: rgba(255,255,255,.72); }
.archive-header, .article-header { padding: 48px 0 24px; max-width: 900px; }
.archive-header.centered, .article-header.centered { text-align: center; margin-inline: auto; }
.archive-header h1, .article-header h1 { font-size: clamp(46px, 6vw, 88px); }
.article-deck { font-size: 22px; line-height: 1.45; color: var(--fr-charcoal); max-width: 760px; }
.article-meta { display: flex; flex-wrap: wrap; gap: 10px 18px; margin-top: 18px; }
.fr-article-layout { display: grid; grid-template-columns: minmax(0, 1fr) 300px; gap: 46px; }
.article-featured-image { margin: 0 0 28px; }
.article-featured-image img { width: 100%; }
figcaption { font-family: var(--fr-sans); font-size: 11px; color: var(--fr-charcoal); margin-top: 8px; text-transform: uppercase; letter-spacing: .07em; }
.article-content { max-width: 760px; font-size: 19px; }
.article-content.narrow { margin-inline: auto; }
.article-content p { margin-bottom: 1.45em; }
.article-content a { color: var(--fr-red); text-decoration: underline; text-underline-offset: 3px; }
.fr-pullquote { margin: 42px 0; padding: 0 0 0 24px; border-left: 3px solid var(--fr-red); font-family: var(--fr-serif); font-size: clamp(30px, 4vw, 48px); line-height: 1.12; }
.fr-share { display: flex; gap: 14px; align-items: center; margin: 20px 0 30px; font-family: var(--fr-sans); font-size: 10px; text-transform: uppercase; letter-spacing: .14em; }
.article-sidebar { position: sticky; top: 24px; align-self: start; border-left: 1px solid var(--fr-line); padding-left: 24px; }
.article-sidebar h2 { font-family: var(--fr-sans); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; margin-bottom: 20px; }
.related-stories { margin-top: 54px; }
.model-layout { display: grid; grid-template-columns: .9fr 1.1fr; gap: 38px; align-items: start; }
.model-details { display: grid; grid-template-columns: 120px 1fr; gap: 6px 14px; font-family: var(--fr-sans); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; margin: 0 0 28px; }
.model-details dt { color: var(--fr-red); }
.fr-video-embed { max-width: 980px; margin: 0 auto 34px; aspect-ratio: 16 / 9; }
.fr-video-embed iframe { width: 100%; height: 100%; }
.fr-placeholder { display: grid; place-items: center; background: #dfd8ce; color: #938b81; min-height: 160px; font-family: var(--fr-sans); text-transform: uppercase; letter-spacing: .16em; font-size: 10px; }
.fr-pagination { padding: 30px 0 50px; }
@media (max-width: 960px) {
    .fr-story-feature, .fr-home-columns, .talks-inner, .model-layout, .fr-article-layout { grid-template-columns: 1fr; }
    .fr-story-feature .card-image { order: 0; min-height: 360px; }
    .talks-grid, .four-up, .three-up { grid-template-columns: repeat(2, 1fr); }
    .article-sidebar { position: static; border-left: 0; padding-left: 0; }
}
@media (max-width: 720px) {
    .fr-container { width: min(100% - 28px, var(--fr-max)); }
    .utility-inner nav { display: none; }
    .menu-toggle { display: block; }
    .site-title { font-size: clamp(34px, 11vw, 56px); }
    .site-tagline { font-size: 8px; line-height: 1.5; }
    .primary-nav ul { display: none; flex-direction: column; align-items: stretch; border-top: 1px solid var(--fr-line); }
    .primary-nav.is-open ul { display: flex; }
    .primary-nav a { padding: 14px 0; border-bottom: 1px solid var(--fr-line); }
    .fr-story-feature { min-height: auto; }
    .fr-story-feature .card-body { padding: 28px; }
    .fr-story-feature h2 { font-size: 40px; }
    .four-up, .three-up, .talks-grid { grid-template-columns: 1fr; }
    .newsletter-form { flex-direction: column; }
    .footer-grid { grid-template-columns: 1fr; }
    .article-content { font-size: 18px; }
}

/* Phase 1.1 stabilization refinements */
.site-branding { max-width: 100%; }
.site-title { display: inline-block; color: var(--fr-black); max-width: 100%; overflow-wrap: normal; word-break: keep-all; }
.search-toggle { display: inline-flex; align-items: center; gap: 6px; }
.fr-search-form { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 10px; align-items: center; max-width: 820px; margin: 0 auto; }
.fr-search-form input[type="search"] { width: 100%; padding: 14px 16px; border: 1px solid var(--fr-line); background: var(--fr-white); color: var(--fr-ink); font-family: var(--fr-sans); font-size: 13px; letter-spacing: .02em; }
.fr-search-form button { min-height: 48px; }
.editorial-intro { max-width: 700px; margin: 18px auto 0; color: var(--fr-charcoal); font-size: 19px; line-height: 1.55; }
.category-feature { margin-bottom: 34px; }
.archive-grid { padding-bottom: 48px; }
.site-footer h3 { margin: 0 0 12px; font-family: var(--fr-sans); font-size: 11px; letter-spacing: .14em; text-transform: uppercase; color: rgba(255,255,255,.72); }
.footer-grid { grid-template-columns: 1.35fr 1.15fr .85fr .85fr; align-items: start; }
.footer-about p { max-width: 360px; color: rgba(255,255,255,.72); }
.footer-nav ul, .footer-social ul { list-style: none; padding: 0; margin: 0; font-family: var(--fr-sans); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; }
.footer-nav ul { columns: 1; display: grid; gap: 7px; }
.footer-contact p, .footer-social li { margin: 0 0 7px; font-family: var(--fr-sans); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; }
.footer-muted { color: rgba(255,255,255,.5); text-transform: none; letter-spacing: 0; line-height: 1.45; }
@media (max-width: 960px) {
    .footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
    .fr-search-form { grid-template-columns: 1fr; }
    .site-title { font-size: clamp(34px, 13vw, 58px); letter-spacing: .035em; }
    .footer-grid { grid-template-columns: 1fr; }
}


/* Phase 1.2 front-page spacing, subscribe/sign-in, and social icon refinements */
.utility-actions { flex-wrap: wrap; justify-content: flex-end; row-gap: 8px; }
.utility-link { white-space: nowrap; }
.utility-subscribe { display: inline-flex; align-items: center; justify-content: center; min-height: 26px; padding: 0 11px; border: 1px solid rgba(255,255,255,.6); border-radius: 999px; background: rgba(255,255,255,.08); color: var(--fr-white); white-space: nowrap; }
.utility-subscribe:hover { background: var(--fr-white); color: var(--fr-black); }
.fr-social-icons { display: inline-flex; align-items: center; gap: 7px; }
.fr-social-icons a { width: 26px; height: 26px; border: 1px solid currentColor; border-radius: 999px; display: inline-grid; place-items: center; font-family: var(--fr-sans); font-size: 9px; line-height: 1; letter-spacing: .04em; text-transform: uppercase; color: inherit; opacity: .88; }
.fr-social-icons a:hover { background: var(--fr-red); border-color: var(--fr-red); color: var(--fr-white); opacity: 1; }
.utility-social-icons { margin-right: 4px; }
.reader-access-module { clear: both; padding: 28px 0 34px; }
.reader-access-inner { display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 28px; align-items: center; border-top: 1px solid var(--fr-line); border-bottom: 1px solid var(--fr-line); padding: 24px 0; }
.reader-access-copy h2 { font-size: clamp(28px, 3.2vw, 44px); max-width: 760px; }
.reader-access-copy p:not(.fr-kicker) { max-width: 700px; margin: 10px 0 0; color: var(--fr-charcoal); }
.reader-access-actions { display: flex; flex-wrap: wrap; align-items: center; justify-content: flex-end; gap: 10px; min-width: 310px; }
.fr-button.outline { background: transparent; color: var(--fr-black); }
.fr-button.outline:hover { background: var(--fr-red); border-color: var(--fr-red); color: var(--fr-white); }
.reader-social-icons { margin-left: 4px; }
.module-category-rail { clear: both; position: relative; z-index: 1; overflow: visible; margin-bottom: 22px; }
.module-category-rail .fr-card-grid { align-items: start; }
.talks-module { clear: both; position: relative; z-index: 2; margin-top: clamp(24px, 4vw, 52px); padding-top: 0; }
.home .module-category-rail + .talks-module, body.home .module-category-rail + .talks-module { margin-top: clamp(34px, 5vw, 64px); }
.talks-inner { overflow: hidden; }
.footer-social-icons { margin-top: 8px; }
.footer-social-icons a { color: var(--fr-white); border-color: rgba(255,255,255,.65); }
@media (max-width: 960px) {
    .reader-access-inner { grid-template-columns: 1fr; }
    .reader-access-actions { justify-content: flex-start; min-width: 0; }
}
@media (max-width: 720px) {
    .top-utility { font-size: 9px; }
    .utility-actions { gap: 10px; }
    .utility-social-icons { display: none; }
    .utility-signin { display: inline-flex; }
    .reader-access-module { padding: 22px 0 28px; }
    .reader-access-inner { gap: 18px; padding: 20px 0; }
    .reader-access-actions { flex-direction: column; align-items: stretch; }
    .reader-access-actions .fr-button { width: 100%; }
    .reader-social-icons { justify-content: center; margin: 4px 0 0; }
    .module-category-rail { margin-bottom: 28px; }
    .talks-module { margin-top: 36px; }
}


/* Phase 1.3 homepage layout stabilization */
.site-main { overflow-x: clip; }
.utility-inner nav:empty { display: none; }
.utility-inner { justify-content: flex-end; }
.utility-actions { width: 100%; justify-content: flex-end; }
.fr-social-icons a,
.fr-social-icons .fr-social-placeholder { width: 26px; height: 26px; border: 1px solid currentColor; border-radius: 999px; display: inline-grid; place-items: center; font-family: var(--fr-sans); font-size: 9px; line-height: 1; letter-spacing: .04em; text-transform: uppercase; color: inherit; opacity: .88; }
.fr-social-icons .fr-social-placeholder { opacity: .42; cursor: default; }
.fr-social-icons a:hover { background: var(--fr-red); border-color: var(--fr-red); color: var(--fr-white); opacity: 1; }
.fr-latest-block { clear: both; padding: clamp(34px, 5vw, 58px) 0; border-bottom: 1px solid var(--fr-line); }
.fr-latest-block .module-latest { max-width: 980px; margin: 0 auto; }
.fr-home-columns { display: block; padding: 0; border-bottom: 0; }
body.home .module-category-rail.fr-container { width: min(var(--fr-max), calc(100% - 40px)); margin: 0 auto; padding: clamp(38px, 5.5vw, 68px) 0; border-bottom: 1px solid var(--fr-line); clear: both; }
body.home .module-category-rail .fr-card-grid { margin-top: 22px; gap: clamp(20px, 2.3vw, 30px); align-items: start; }
body.home .module-category-rail .fr-story-card { min-width: 0; }
body.home .module-category-rail .card-body { min-height: auto; }
.talks-module.fr-container { clear: both; width: min(var(--fr-max), calc(100% - 40px)); margin: clamp(44px, 6vw, 76px) auto; padding: 0; }
.talks-inner { min-height: auto; align-items: stretch; }
.talks-grid { min-width: 0; }
.talks-grid .fr-story-video { min-width: 0; }
.newsletter-module.fr-container { clear: both; margin-top: clamp(28px, 4vw, 52px); }
@media (max-width: 1180px) {
    .four-up { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .talks-inner { grid-template-columns: 1fr; }
    .talks-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
    .utility-inner { justify-content: center; }
    .utility-actions { justify-content: center; }
    .fr-latest-block .module-latest { max-width: none; }
    .talks-grid { grid-template-columns: 1fr; }
}
@media (max-width: 720px) {
    body.home .module-category-rail.fr-container,
    .talks-module.fr-container { width: min(100% - 28px, var(--fr-max)); }
    .four-up { grid-template-columns: 1fr; }
    .utility-actions { gap: 8px 10px; }
    .utility-link.utility-signin, .utility-link, .utility-subscribe, .search-toggle { font-size: 9px; }
    .fr-social-icons a,
    .fr-social-icons .fr-social-placeholder { width: 24px; height: 24px; font-size: 8px; }
    .talks-module.fr-container { margin-top: 44px; margin-bottom: 44px; }
}


/* Phase 1.4 latest module horizontal editorial rail */
.fr-latest-block { width: min(var(--fr-max), calc(100% - 40px)); margin-inline: auto; }
.fr-latest-block .module-latest { max-width: none; width: 100%; }
.fr-latest-block .section-heading { margin-bottom: 22px; }
.fr-latest-block .latest-list {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: clamp(18px, 2.1vw, 30px);
    align-items: start;
}
.fr-latest-block .fr-story-compact {
    display: block;
    min-width: 0;
    padding-bottom: 0;
    border-bottom: 0;
}
.fr-latest-block .compact-image {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    margin: 0 0 12px;
    background: #ddd;
}
.fr-latest-block .fr-story-compact h4 {
    font-family: var(--fr-serif);
    font-size: clamp(18px, 1.6vw, 24px);
    font-weight: 400;
    line-height: 1.06;
    margin: 0;
}
.fr-latest-block .fr-story-compact .card-meta { margin-top: 8px; }
@media (max-width: 1180px) {
    .fr-latest-block .latest-list { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 720px) {
    .fr-latest-block { width: min(100% - 28px, var(--fr-max)); }
    .fr-latest-block .latest-list {
        display: flex;
        overflow-x: auto;
        gap: 16px;
        padding: 0 2px 14px;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }
    .fr-latest-block .fr-story-compact {
        flex: 0 0 76%;
        scroll-snap-align: start;
    }
}


/* Phase 1.5: homepage access strip removal + hard latest rail reset */
body.home .reader-access-module { display: none !important; }
body.home .fr-latest-block {
    width: min(var(--fr-max), calc(100% - 40px));
    margin: 0 auto;
    padding: clamp(34px, 5vw, 58px) 0;
    border-bottom: 1px solid var(--fr-line);
    clear: both;
}
body.home .fr-latest-block .module-latest,
body.home .fr-latest-block .module-latest-rail {
    width: 100%;
    max-width: none;
    margin: 0;
}
body.home .fr-latest-block .latest-list,
body.home .fr-latest-block .latest-rail {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: clamp(18px, 2.1vw, 30px) !important;
    align-items: start;
}
body.home .fr-latest-block .latest-rail-item {
    min-width: 0;
}
body.home .fr-latest-block .fr-story-compact {
    display: block !important;
    grid-template-columns: none !important;
    gap: 0 !important;
    padding: 0 !important;
    border-bottom: 0 !important;
}
body.home .fr-latest-block .compact-image {
    display: block;
    width: 100%;
    aspect-ratio: 4 / 5;
    margin: 0 0 12px;
}
body.home .fr-latest-block .fr-story-compact h4 {
    font-family: var(--fr-serif);
    font-size: clamp(18px, 1.6vw, 24px);
    line-height: 1.06;
}
body.home .fr-latest-block .fr-story-compact .card-meta { margin-top: 8px; }
@media (max-width: 1180px) {
    body.home .fr-latest-block .latest-list,
    body.home .fr-latest-block .latest-rail { grid-template-columns: repeat(3, minmax(0, 1fr)) !important; }
}
@media (max-width: 720px) {
    body.home .fr-latest-block { width: min(100% - 28px, var(--fr-max)); }
    body.home .fr-latest-block .latest-list,
    body.home .fr-latest-block .latest-rail {
        display: flex !important;
        overflow-x: auto;
        gap: 16px !important;
        padding: 0 2px 14px;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
    }
    body.home .fr-latest-block .latest-rail-item {
        flex: 0 0 76%;
        scroll-snap-align: start;
    }
}


/* Phase 1.6: lower The Latest rail and restore editorial breathing room */
body.home .secondary-grid + .fr-latest-block {
    margin-top: clamp(28px, 4.5vw, 64px) !important;
}
body.home .fr-latest-block {
    padding-top: clamp(42px, 5.5vw, 72px) !important;
    padding-bottom: clamp(44px, 5.5vw, 72px) !important;
}
body.home .fr-latest-block .section-heading {
    margin-bottom: clamp(24px, 2.8vw, 34px) !important;
}
body.home .fr-latest-block + .module-category-rail {
    margin-top: clamp(18px, 3vw, 34px) !important;
}
@media (max-width: 720px) {
    body.home .secondary-grid + .fr-latest-block {
        margin-top: 34px !important;
    }
    body.home .fr-latest-block {
        padding-top: 40px !important;
        padding-bottom: 46px !important;
    }
}


/* Phase 1.7: brand cleanup, search polish, stronger Latest placement */
body.home .secondary-grid {
    margin-bottom: clamp(48px, 6.5vw, 92px) !important;
}
body.home .secondary-grid + .fr-latest-block {
    margin-top: 0 !important;
}
body.home .fr-latest-block {
    position: relative;
    padding-top: clamp(56px, 6.5vw, 92px) !important;
    padding-bottom: clamp(52px, 6vw, 86px) !important;
    margin-bottom: clamp(20px, 3vw, 46px) !important;
}
body.home .fr-latest-block::before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 1px;
    background: var(--fr-line);
}
body.home .fr-latest-block .section-heading {
    border-top: 0;
    padding-top: 0;
}
.fr-search-form {
    display: flex;
    gap: 8px;
    align-items: stretch;
    width: 100%;
}
.fr-search-form input[type="search"],
.fr-search-form .search-field {
    flex: 1;
    width: 100%;
    min-height: 46px;
    padding: 13px 14px;
    border: 1px solid var(--fr-line);
    background: var(--fr-white);
    color: var(--fr-ink);
    font-family: var(--fr-sans);
    font-size: 12px;
    letter-spacing: .04em;
}
.fr-search-form button,
.fr-search-form .search-submit {
    min-height: 46px;
    white-space: nowrap;
}
.article-author-name { color: var(--fr-ink); }
.archive-description.editorial-intro {
    max-width: 760px;
    margin: 18px auto 0;
    font-size: clamp(18px, 2vw, 22px);
    line-height: 1.45;
    color: var(--fr-charcoal);
}
@media (max-width: 720px) {
    body.home .secondary-grid { margin-bottom: 44px !important; }
    body.home .fr-latest-block {
        padding-top: 44px !important;
        padding-bottom: 52px !important;
    }
    .fr-search-form { flex-direction: column; }
    .fr-search-form button,
    .fr-search-form .search-submit { width: 100%; }
}


/* Phase 1.8: homepage editorial polish without carousel */
body.home .site-main {
    padding-bottom: 0;
}

body.home .home-hero {
    padding-top: clamp(28px, 4vw, 46px);
    padding-bottom: clamp(18px, 2.5vw, 30px);
}

body.home .secondary-grid {
    padding-top: clamp(10px, 1.5vw, 18px);
    padding-bottom: clamp(48px, 6vw, 82px) !important;
}

body.home .secondary-grid .fr-story-medium h3 {
    font-size: clamp(20px, 1.75vw, 25px);
}

body.home .fr-latest-block {
    margin-top: clamp(18px, 2.8vw, 42px) !important;
    margin-bottom: clamp(34px, 4.5vw, 64px) !important;
    padding-top: clamp(46px, 5.5vw, 78px) !important;
    padding-bottom: clamp(48px, 5.5vw, 78px) !important;
    background: linear-gradient(180deg, rgba(255,255,255,0.32), rgba(255,255,255,0));
}

body.home .fr-latest-block::before {
    background: linear-gradient(90deg, transparent, var(--fr-line), transparent);
}

body.home .fr-latest-block .section-heading {
    align-items: end;
}

body.home .fr-latest-block .section-heading h2::after,
body.home .module-category-rail .section-heading h2::after {
    content: "";
    display: block;
    width: 38px;
    height: 2px;
    margin-top: 9px;
    background: var(--fr-red);
}

body.home .fr-latest-block .fr-story-compact {
    background: rgba(255,255,255,0.28);
    padding-bottom: 14px !important;
}

body.home .fr-latest-block .compact-image {
    aspect-ratio: 3 / 4;
    margin-bottom: 14px !important;
}

body.home .fr-latest-block .fr-story-compact h4 {
    font-size: clamp(19px, 1.45vw, 23px) !important;
    line-height: 1.08 !important;
}

body.home .fr-latest-block .fr-story-compact .fr-kicker,
body.home .fr-latest-block .fr-story-compact h4,
body.home .fr-latest-block .fr-story-compact .card-meta {
    padding-left: 2px;
    padding-right: 2px;
}

.section-heading-copy {
    display: grid;
    gap: 8px;
}

.section-deck {
    max-width: 680px;
    margin: 0;
    font-family: var(--fr-body);
    font-size: clamp(15px, 1.35vw, 18px);
    line-height: 1.45;
    letter-spacing: 0;
    text-transform: none;
    color: var(--fr-charcoal);
}

body.home .module-category-rail .section-heading {
    align-items: end;
    padding-top: clamp(20px, 2.5vw, 28px);
    margin-bottom: clamp(24px, 3vw, 36px);
}

body.home .module-category-rail .section-heading h2 {
    font-size: clamp(12px, 1.1vw, 14px);
}

body.home .module-category-rail .fr-card-grid {
    gap: clamp(24px, 2.6vw, 34px);
}

body.home .module-front_row_runway .fr-card-grid {
    grid-template-columns: 1.15fr repeat(3, minmax(0, .95fr));
    align-items: stretch;
}

body.home .module-front_row_runway .fr-story-medium:first-child {
    background: var(--fr-black);
    color: var(--fr-white);
    display: flex;
    flex-direction: column;
    min-height: 100%;
}

body.home .module-front_row_runway .fr-story-medium:first-child .card-image {
    aspect-ratio: 4 / 5;
}

body.home .module-front_row_runway .fr-story-medium:first-child .card-body {
    padding: clamp(20px, 2.5vw, 30px);
}

body.home .module-front_row_runway .fr-story-medium:first-child .fr-kicker {
    color: #e1b6bd;
}

body.home .module-front_row_runway .fr-story-medium:first-child h3 {
    font-size: clamp(30px, 3vw, 44px);
}

body.home .module-front_row_runway .fr-story-medium:first-child .card-deck {
    margin: 14px 0 0;
    opacity: .82;
    color: rgba(255,255,255,.86);
    font-size: 16px;
    line-height: 1.45;
}

body.home .module-front_row_runway .fr-story-medium:first-child .card-meta {
    margin-top: 16px;
    color: rgba(255,255,255,.68);
}

body.home .module-category-rail:not(.module-front_row_runway) .fr-story-medium {
    border-top: 1px solid transparent;
}

body.home .module-category-rail:not(.module-front_row_runway) .fr-story-medium:hover {
    border-top-color: var(--fr-red);
}

body.home .module-style_beauty {
    background: rgba(255,255,255,0.18);
}

body.home .module-style_beauty .fr-story-medium .card-image {
    aspect-ratio: 4 / 5;
}

body.home .talks-module.fr-container {
    margin-top: clamp(58px, 7vw, 96px);
    margin-bottom: clamp(58px, 7vw, 96px);
}

body.home .talks-inner {
    box-shadow: 0 18px 50px rgba(0,0,0,.08);
}

body.home .talks-copy p:not(.fr-kicker) {
    color: rgba(255,255,255,.78);
}

body.home .talks-grid {
    gap: clamp(18px, 2vw, 26px);
}

body.home .module-interviews_features {
    padding-top: clamp(46px, 6vw, 82px) !important;
}

body.home .newsletter-module.fr-container {
    margin-top: clamp(26px, 4vw, 58px);
}

body.home .newsletter-inner {
    border: 1px solid rgba(255,255,255,.06);
}

@media (max-width: 1180px) {
    body.home .module-front_row_runway .fr-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    body.home .module-front_row_runway .fr-story-medium:first-child {
        grid-column: span 2;
        display: grid;
        grid-template-columns: 1fr 1fr;
    }
    body.home .module-front_row_runway .fr-story-medium:first-child .card-image {
        aspect-ratio: auto;
        min-height: 360px;
    }
}

@media (max-width: 860px) {
    body.home .fr-latest-block .section-heading,
    body.home .module-category-rail .section-heading {
        align-items: start;
        flex-direction: column;
    }
    body.home .module-front_row_runway .fr-story-medium:first-child {
        grid-template-columns: 1fr;
    }
    body.home .module-front_row_runway .fr-story-medium:first-child .card-image {
        min-height: 0;
        aspect-ratio: 4 / 3;
    }
}

@media (max-width: 720px) {
    body.home .home-hero {
        padding-top: 20px;
    }
    body.home .secondary-grid {
        padding-bottom: 44px !important;
    }
    body.home .fr-latest-block {
        margin-top: 16px !important;
        padding-top: 42px !important;
        padding-bottom: 50px !important;
    }
    body.home .fr-latest-block .latest-rail-item {
        flex: 0 0 72%;
    }
    body.home .fr-latest-block .compact-image {
        aspect-ratio: 4 / 5;
    }
    body.home .module-category-rail .section-heading {
        padding-top: 18px;
        margin-bottom: 22px;
    }
    body.home .module-front_row_runway .fr-story-medium:first-child {
        grid-column: auto;
    }
    body.home .module-front_row_runway .fr-story-medium:first-child h3 {
        font-size: clamp(30px, 10vw, 42px);
    }
    body.home .module-style_beauty .fr-story-medium .card-image {
        aspect-ratio: 4 / 3;
    }
    body.home .talks-module.fr-container {
        margin-top: 48px;
        margin-bottom: 48px;
    }
}

/* Phase 1.9: logo integration + front-page formatting cleanup */
.site-header {
    background: #faf6ef;
}
.masthead-main {
    padding: clamp(22px, 3.4vw, 42px) 0 clamp(16px, 2.4vw, 28px);
}
.site-branding {
    display: grid;
    justify-items: center;
    gap: 8px;
}
.site-logo-default,
.custom-logo-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    max-width: min(760px, 88vw);
}
.site-logo-default img,
.custom-logo-link img,
.custom-logo {
    width: min(760px, 88vw);
    max-height: 122px;
    object-fit: contain;
}
.site-tagline {
    margin-top: 4px;
    color: rgba(21, 21, 21, .66);
}
.top-utility {
    min-height: 36px;
}
.utility-inner {
    min-height: 36px;
    justify-content: flex-end;
}
.utility-inner > nav:empty {
    display: none;
}
.utility-actions {
    width: auto;
    margin-left: auto;
    gap: 14px;
    justify-content: flex-end;
}
.utility-social-icons:empty,
.footer-social-icons:empty {
    display: none;
}
.fr-social-placeholder {
    display: none !important;
}
.utility-link,
.utility-subscribe,
.search-toggle {
    line-height: 1;
}
.utility-subscribe {
    min-height: 24px;
    padding-inline: 12px;
}
body.home .secondary-grid {
    margin-bottom: clamp(54px, 7vw, 104px) !important;
}
body.home .fr-latest-block {
    display: block;
    background: rgba(255,255,255,.22);
    border-top: 1px solid var(--fr-line);
    border-bottom: 1px solid var(--fr-line);
    margin-top: 0 !important;
    margin-bottom: clamp(44px, 5vw, 76px) !important;
    padding-top: clamp(54px, 6vw, 86px) !important;
    padding-bottom: clamp(54px, 6vw, 86px) !important;
}
body.home .fr-latest-block::before {
    content: none !important;
}
body.home .fr-latest-block .section-heading {
    border-top: 0;
    padding-top: 0;
    margin-bottom: clamp(24px, 3vw, 38px) !important;
}
body.home .fr-latest-block .latest-list,
body.home .fr-latest-block .latest-rail {
    align-items: stretch;
    gap: clamp(18px, 2.1vw, 28px) !important;
}
body.home .fr-latest-block .latest-rail-item,
body.home .fr-latest-block .fr-story-compact {
    min-width: 0;
    height: 100%;
}
body.home .fr-latest-block .fr-story-compact {
    background: #faf6ef;
    border: 1px solid rgba(9,9,9,.08) !important;
    padding: 0 0 16px !important;
}
body.home .fr-latest-block .fr-story-compact .fr-kicker,
body.home .fr-latest-block .fr-story-compact h4,
body.home .fr-latest-block .fr-story-compact .card-meta {
    padding-left: 14px;
    padding-right: 14px;
}
body.home .module-category-rail.fr-container {
    padding-top: clamp(54px, 6vw, 88px) !important;
    padding-bottom: clamp(56px, 6vw, 90px) !important;
}
body.home .module-category-rail + .module-category-rail {
    margin-top: clamp(8px, 1.5vw, 18px);
}
body.home .module-style_beauty {
    position: relative;
    margin-bottom: clamp(50px, 6vw, 88px) !important;
}
body.home .module-style_beauty::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: calc(-1 * clamp(24px, 3vw, 44px));
    height: 1px;
    background: linear-gradient(90deg, transparent, var(--fr-line), transparent);
}
body.home .talks-module.fr-container {
    width: 100% !important;
    max-width: none !important;
    margin: clamp(56px, 7vw, 104px) 0 !important;
    padding: clamp(58px, 7vw, 98px) 0 !important;
    background: var(--fr-black);
    color: var(--fr-white);
}
body.home .talks-module.fr-container .talks-inner {
    width: min(var(--fr-max), calc(100% - 40px));
    margin-inline: auto;
    background: transparent;
    color: var(--fr-white);
    box-shadow: none;
}
body.home .talks-module.fr-container .talks-copy {
    padding-left: 0;
}
body.home .talks-module.fr-container .talks-grid {
    padding-right: 0;
}
body.home .talks-module.fr-container .fr-story-video {
    background: rgba(255,255,255,.045);
    padding-bottom: 16px;
}
body.home .talks-module.fr-container .fr-story-video .card-body {
    padding: 0 14px;
}
body.home .talks-module.fr-container .fr-story-video h3,
body.home .talks-module.fr-container .fr-story-video a {
    color: var(--fr-white);
}
body.home .talks-module.fr-container + .module-category-rail {
    padding-top: clamp(52px, 6vw, 84px) !important;
}
body.home .newsletter-module.fr-container {
    padding-top: clamp(28px, 4vw, 58px);
}
@media (max-width: 980px) {
    .utility-actions {
        gap: 10px;
    }
    body.home .talks-module.fr-container .talks-inner {
        grid-template-columns: 1fr;
    }
    body.home .talks-module.fr-container .talks-copy,
    body.home .talks-module.fr-container .talks-grid {
        padding-left: 0;
        padding-right: 0;
    }
    body.home .talks-module.fr-container .talks-grid {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }
}
@media (max-width: 720px) {
    .top-utility {
        font-size: 9px;
    }
    .utility-actions {
        width: 100%;
        justify-content: center;
        flex-wrap: wrap;
        gap: 8px 10px;
    }
    .masthead-main {
        padding-top: 20px;
        padding-bottom: 18px;
    }
    .site-logo-default img,
    .custom-logo-link img,
    .custom-logo {
        width: min(92vw, 540px);
        max-height: 86px;
    }
    .site-tagline {
        font-size: 8px;
        letter-spacing: .13em;
        max-width: 86vw;
    }
    body.home .secondary-grid {
        margin-bottom: 46px !important;
    }
    body.home .fr-latest-block {
        padding-top: 42px !important;
        padding-bottom: 46px !important;
        margin-bottom: 38px !important;
    }
    body.home .fr-latest-block .fr-story-compact {
        min-height: 100%;
    }
    body.home .module-category-rail.fr-container {
        padding-top: 42px !important;
        padding-bottom: 48px !important;
    }
    body.home .talks-module.fr-container {
        margin: 46px 0 !important;
        padding: 46px 0 !important;
    }
    body.home .talks-module.fr-container .talks-inner {
        width: min(100% - 28px, var(--fr-max));
    }
    body.home .talks-module.fr-container .talks-grid {
        grid-template-columns: 1fr;
    }
}

/* Phase 1.9 footer grid correction */
.site-footer .footer-grid {
    grid-template-columns: minmax(0, 1.4fr) minmax(0, 1fr) minmax(0, .9fr) minmax(0, .8fr);
}
.footer-social:empty {
    display: none;
}
@media (max-width: 980px) {
    .site-footer .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 640px) {
    .site-footer .footer-grid {
        grid-template-columns: 1fr;
    }
}

/* Phase 2.0: front-page layout reset
   This section intentionally overrides earlier prototype spacing rules.
   Goal: stable magazine rhythm, clean cards, no overlapping/awkward section jumps. */
body.home .site-main {
    overflow: hidden;
}
body.home .home-hero,
body.home .secondary-grid,
body.home .fr-latest-block,
body.home .module-category-rail.fr-container,
body.home .newsletter-module.fr-container {
    width: min(var(--fr-max), calc(100% - 40px)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
body.home .home-hero {
    padding-top: clamp(28px, 3.5vw, 46px) !important;
    padding-bottom: clamp(20px, 2.5vw, 32px) !important;
}
body.home .fr-story-feature {
    grid-template-columns: minmax(360px, .72fr) minmax(0, 1.28fr) !important;
    min-height: clamp(480px, 48vw, 620px) !important;
}
body.home .fr-story-feature .card-image {
    min-height: clamp(480px, 48vw, 620px) !important;
}
body.home .fr-story-feature .card-body {
    padding: clamp(34px, 4.6vw, 64px) !important;
}
body.home .secondary-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: clamp(20px, 2.2vw, 30px) !important;
    padding-top: 0 !important;
    padding-bottom: clamp(54px, 5.8vw, 84px) !important;
    margin-bottom: 0 !important;
    border-bottom: 1px solid var(--fr-line) !important;
}
body.home .secondary-grid .fr-story-medium .card-image,
body.home .module-category-rail .fr-story-medium .card-image {
    aspect-ratio: 4 / 3 !important;
}
body.home .secondary-grid .fr-story-medium h3 {
    font-size: clamp(20px, 1.75vw, 25px) !important;
    line-height: 1.08 !important;
}

/* Latest rail: make it an actual horizontal magazine rail, not compact list columns. */
body.home .fr-latest-block {
    clear: both !important;
    display: block !important;
    position: relative !important;
    background: #f2ece4 !important;
    border-top: 1px solid var(--fr-line) !important;
    border-bottom: 1px solid var(--fr-line) !important;
    margin-top: clamp(34px, 4vw, 58px) !important;
    margin-bottom: clamp(52px, 5.5vw, 82px) !important;
    padding: clamp(48px, 5.2vw, 76px) clamp(22px, 2.8vw, 36px) !important;
}
body.home .fr-latest-block .module-latest,
body.home .fr-latest-block .module-latest-rail {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
body.home .fr-latest-block .section-heading {
    display: flex !important;
    align-items: flex-end !important;
    justify-content: space-between !important;
    gap: 24px !important;
    border-top: 0 !important;
    padding-top: 0 !important;
    margin: 0 0 clamp(26px, 3vw, 38px) !important;
}
body.home .fr-latest-block .latest-list,
body.home .fr-latest-block .latest-rail {
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    gap: clamp(18px, 2vw, 28px) !important;
    align-items: stretch !important;
    overflow: visible !important;
}
body.home .fr-latest-block .latest-rail-item {
    min-width: 0 !important;
    height: 100% !important;
}
body.home .fr-latest-block .fr-story-compact {
    display: flex !important;
    flex-direction: column !important;
    grid-template-columns: none !important;
    gap: 0 !important;
    min-height: 100% !important;
    height: 100% !important;
    padding: 0 0 16px !important;
    border: 1px solid rgba(9, 9, 9, .09) !important;
    border-bottom: 1px solid rgba(9, 9, 9, .09) !important;
    background: #faf6ef !important;
}
body.home .fr-latest-block .compact-image {
    display: block !important;
    width: 100% !important;
    aspect-ratio: 4 / 5 !important;
    margin: 0 0 14px !important;
    background: #ded8cf !important;
    overflow: hidden !important;
}
body.home .fr-latest-block .compact-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}
body.home .fr-latest-block .fr-story-compact > div {
    display: flex !important;
    flex-direction: column !important;
    flex: 1 1 auto !important;
    padding: 0 14px !important;
}
body.home .fr-latest-block .fr-story-compact .fr-kicker,
body.home .fr-latest-block .fr-story-compact h4,
body.home .fr-latest-block .fr-story-compact .card-meta {
    padding-left: 0 !important;
    padding-right: 0 !important;
}
body.home .fr-latest-block .fr-story-compact h4 {
    font-size: clamp(18px, 1.35vw, 22px) !important;
    line-height: 1.08 !important;
    margin-bottom: 14px !important;
}
body.home .fr-latest-block .fr-story-compact .card-meta {
    margin-top: auto !important;
}

/* Category rails: normalize the grid. The earlier oversized first-card treatment was causing an uneven front page. */
body.home .module-category-rail.fr-container {
    clear: both !important;
    display: block !important;
    position: relative !important;
    padding-top: clamp(46px, 5.5vw, 78px) !important;
    padding-bottom: clamp(52px, 6vw, 86px) !important;
    margin-top: 0 !important;
    margin-bottom: 0 !important;
    border-bottom: 1px solid var(--fr-line) !important;
    background: transparent !important;
}
body.home .module-category-rail + .module-category-rail {
    margin-top: 0 !important;
}
body.home .module-category-rail .section-heading {
    display: flex !important;
    justify-content: space-between !important;
    align-items: flex-end !important;
    gap: 28px !important;
    border-top: 0 !important;
    padding-top: 0 !important;
    margin-bottom: clamp(26px, 3vw, 38px) !important;
}
body.home .module-category-rail .section-heading h2 {
    font-family: var(--fr-serif) !important;
    font-size: clamp(34px, 4vw, 54px) !important;
    font-weight: 400 !important;
    line-height: .98 !important;
    letter-spacing: .02em !important;
    text-transform: none !important;
}
body.home .module-category-rail .section-heading > a,
body.home .fr-latest-block .section-heading > a {
    white-space: nowrap !important;
    font-family: var(--fr-sans) !important;
    font-size: 10px !important;
    letter-spacing: .14em !important;
    text-transform: uppercase !important;
}
body.home .module-category-rail .section-deck {
    max-width: 690px !important;
    margin-top: 8px !important;
    color: var(--fr-charcoal) !important;
}
body.home .module-category-rail .fr-card-grid,
body.home .module-front_row_runway .fr-card-grid {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: clamp(20px, 2.2vw, 30px) !important;
    align-items: start !important;
}
body.home .module-front_row_runway .fr-story-medium:first-child,
body.home .module-front_row_runway .fr-story-medium:first-child .card-body,
body.home .module-front_row_runway .fr-story-medium:first-child .card-image {
    display: block !important;
    grid-column: auto !important;
    grid-template-columns: none !important;
    min-height: 0 !important;
    background: transparent !important;
    color: var(--fr-ink) !important;
    padding: 0 !important;
}
body.home .module-front_row_runway .fr-story-medium:first-child .card-image {
    aspect-ratio: 4 / 3 !important;
}
body.home .module-front_row_runway .fr-story-medium:first-child h3 {
    font-size: clamp(21px, 2vw, 28px) !important;
}
body.home .module-front_row_runway .fr-story-medium:first-child .fr-kicker {
    color: var(--fr-red) !important;
}
body.home .module-front_row_runway .fr-story-medium:first-child .card-deck {
    display: none !important;
}
body.home .fr-story-medium .card-body {
    padding-top: 15px !important;
}
body.home .fr-story-medium .card-meta {
    margin-top: 10px !important;
}

/* Talks: keep the full-width contrast band, but contain the content and prevent crowding. */
body.home .talks-module.fr-container {
    clear: both !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: clamp(58px, 7vw, 96px) 0 !important;
    background: var(--fr-black) !important;
    color: var(--fr-white) !important;
    border: 0 !important;
}
body.home .talks-module.fr-container .talks-inner {
    width: min(var(--fr-max), calc(100% - 40px)) !important;
    margin: 0 auto !important;
    display: grid !important;
    grid-template-columns: minmax(280px, .72fr) minmax(0, 1.28fr) !important;
    gap: clamp(28px, 4vw, 56px) !important;
    align-items: center !important;
    background: transparent !important;
    color: var(--fr-white) !important;
    box-shadow: none !important;
}
body.home .talks-module.fr-container .talks-copy,
body.home .talks-module.fr-container .talks-grid {
    padding: 0 !important;
}
body.home .talks-module.fr-container .talks-grid {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: clamp(18px, 2vw, 26px) !important;
}
body.home .talks-module.fr-container .fr-story-video {
    background: rgba(255,255,255,.055) !important;
    padding-bottom: 16px !important;
    min-width: 0 !important;
}
body.home .talks-module.fr-container .fr-story-video .card-body {
    padding: 0 14px !important;
}
body.home .talks-module.fr-container .fr-story-video h3 {
    font-size: clamp(18px, 1.45vw, 22px) !important;
}
body.home .talks-module.fr-container + .module-category-rail {
    padding-top: clamp(52px, 6vw, 84px) !important;
}

/* Footer: avoid empty fourth-column spacing when no social column is rendered. */
.site-footer .footer-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1.45fr) minmax(0, 1.1fr) minmax(0, .9fr) !important;
    gap: clamp(26px, 4vw, 50px) !important;
}
.site-footer .footer-social:empty,
.site-footer .footer-social:not(:has(*)) {
    display: none !important;
}

@media (max-width: 1180px) {
    body.home .fr-latest-block .latest-list,
    body.home .fr-latest-block .latest-rail {
        grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    }
    body.home .secondary-grid,
    body.home .module-category-rail .fr-card-grid,
    body.home .module-front_row_runway .fr-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}
@media (max-width: 980px) {
    body.home .fr-story-feature,
    body.home .talks-module.fr-container .talks-inner {
        grid-template-columns: 1fr !important;
    }
    body.home .fr-story-feature .card-image {
        order: 0 !important;
        min-height: 380px !important;
    }
    body.home .fr-story-feature .card-body {
        order: 1 !important;
    }
    body.home .talks-module.fr-container .talks-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
    .site-footer .footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}
@media (max-width: 720px) {
    body.home .home-hero,
    body.home .secondary-grid,
    body.home .fr-latest-block,
    body.home .module-category-rail.fr-container,
    body.home .newsletter-module.fr-container {
        width: min(100% - 28px, var(--fr-max)) !important;
    }
    body.home .fr-story-feature .card-image {
        min-height: 300px !important;
    }
    body.home .secondary-grid,
    body.home .module-category-rail .fr-card-grid,
    body.home .module-front_row_runway .fr-card-grid,
    body.home .talks-module.fr-container .talks-grid {
        grid-template-columns: 1fr !important;
    }
    body.home .fr-latest-block {
        width: 100% !important;
        padding-left: 14px !important;
        padding-right: 14px !important;
    }
    body.home .fr-latest-block .latest-list,
    body.home .fr-latest-block .latest-rail {
        display: flex !important;
        overflow-x: auto !important;
        overscroll-behavior-inline: contain !important;
        scroll-snap-type: x proximity !important;
        padding-bottom: 10px !important;
    }
    body.home .fr-latest-block .latest-rail-item {
        flex: 0 0 76% !important;
        scroll-snap-align: start !important;
    }
    body.home .module-category-rail .section-heading,
    body.home .fr-latest-block .section-heading {
        align-items: flex-start !important;
        flex-direction: column !important;
        gap: 12px !important;
    }
    body.home .module-category-rail .section-heading h2 {
        font-size: clamp(32px, 10vw, 44px) !important;
    }
    .site-footer .footer-grid {
        grid-template-columns: 1fr !important;
    }
}


/* Phase 2.1: secondary-grid bleed fix
   The secondary story row must fully reserve room for titles/meta before The Latest begins. */
body.home .secondary-grid {
    position: relative !important;
    z-index: 1 !important;
    overflow: visible !important;
    align-items: start !important;
    margin-bottom: clamp(72px, 8vw, 126px) !important;
    padding-bottom: clamp(76px, 8vw, 128px) !important;
    border-bottom: 0 !important;
}
body.home .secondary-grid::after {
    content: "" !important;
    display: block !important;
    position: absolute !important;
    left: 0 !important;
    right: 0 !important;
    bottom: 0 !important;
    height: 1px !important;
    background: var(--fr-line) !important;
}
body.home .secondary-grid .fr-story-card,
body.home .secondary-grid .fr-story-medium {
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: visible !important;
    position: relative !important;
    z-index: 2 !important;
}
body.home .secondary-grid .fr-story-medium .card-image {
    display: block !important;
    width: 100% !important;
    aspect-ratio: 4 / 3 !important;
    height: auto !important;
    min-height: 0 !important;
    overflow: hidden !important;
    flex: 0 0 auto !important;
}
body.home .secondary-grid .fr-story-medium .card-image img {
    display: block !important;
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}
body.home .secondary-grid .fr-story-medium .card-body {
    display: block !important;
    flex: 0 0 auto !important;
    min-height: clamp(132px, 11vw, 172px) !important;
    padding-top: 16px !important;
    padding-bottom: 18px !important;
    background: var(--fr-cream) !important;
    position: relative !important;
    z-index: 3 !important;
}
body.home .secondary-grid .fr-story-medium h3 {
    display: block !important;
    margin: 0 !important;
    overflow-wrap: normal !important;
}
body.home .secondary-grid .fr-story-medium .card-meta {
    margin-top: 12px !important;
}
body.home .secondary-grid + .fr-latest-block,
body.home .fr-latest-block {
    clear: both !important;
    position: relative !important;
    z-index: 0 !important;
    margin-top: 0 !important;
}
@media (max-width: 1180px) {
    body.home .secondary-grid {
        margin-bottom: clamp(58px, 7vw, 96px) !important;
        padding-bottom: clamp(64px, 7vw, 104px) !important;
    }
    body.home .secondary-grid .fr-story-medium .card-body {
        min-height: 122px !important;
    }
}
@media (max-width: 720px) {
    body.home .secondary-grid {
        margin-bottom: 44px !important;
        padding-bottom: 54px !important;
    }
    body.home .secondary-grid .fr-story-medium .card-body {
        min-height: 0 !important;
        padding-bottom: 22px !important;
    }
}

/* Phase 2.3: controlled Advanced Ads / sponsor placement zones */
.fr-ad-zone {
    clear: both;
    position: relative;
    box-sizing: border-box;
    margin-top: clamp(26px, 3.8vw, 52px);
    margin-bottom: clamp(26px, 3.8vw, 52px);
    text-align: center;
}
.fr-ad-zone.fr-container,
.fr-ad-zone-home-top.fr-container,
.fr-ad-zone-home-after-latest.fr-container,
.fr-ad-zone-home-between.fr-container,
.fr-ad-zone-category-sponsor.fr-container {
    width: min(var(--fr-max), calc(100% - 40px));
    margin-left: auto;
    margin-right: auto;
}
.fr-ad-label,
.fr-ad-widget-title {
    margin: 0 0 10px;
    font-family: var(--fr-sans);
    font-size: 9px;
    line-height: 1;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(35,31,32,.48);
}
.fr-ad-content {
    display: grid;
    place-items: center;
    min-height: 0;
    padding: clamp(14px, 2vw, 22px);
    border: 1px solid var(--fr-line);
    background: rgba(255,255,255,.58);
}
.fr-ad-content:empty {
    display: none;
}
.fr-ad-content img,
.fr-ad-image {
    display: block;
    max-width: 100%;
    height: auto;
}
.fr-ad-content iframe,
.fr-ad-content ins,
.fr-ad-content div {
    max-width: 100%;
}
.fr-ad-image-link {
    display: inline-block;
    line-height: 0;
}
.fr-ad-zone-home-top {
    margin-top: clamp(18px, 2vw, 28px);
    margin-bottom: clamp(32px, 4.5vw, 62px);
}
.fr-ad-zone-home-after-latest {
    margin-top: clamp(16px, 2.5vw, 34px);
    margin-bottom: clamp(42px, 5.5vw, 74px);
}
.fr-ad-zone-home-between {
    padding-top: clamp(12px, 2vw, 22px);
    padding-bottom: clamp(12px, 2vw, 22px);
    border-top: 1px solid var(--fr-line);
    border-bottom: 1px solid var(--fr-line);
}
.fr-ad-zone-category-sponsor {
    margin-top: 0;
    margin-bottom: clamp(36px, 4vw, 58px);
}
.article-sidebar .fr-ad-zone-article-sidebar {
    margin: 0 0 28px;
    text-align: left;
}
.article-sidebar .fr-ad-zone-article-sidebar .fr-ad-content {
    padding: 12px;
    background: var(--fr-white);
}
.fr-ad-zone-below-article,
.fr-ad-zone--mid-article {
    margin: clamp(36px, 5vw, 58px) 0;
}
.fr-ad-zone--mid-article .fr-ad-content,
.fr-ad-zone-below-article .fr-ad-content {
    background: rgba(248,245,239,.75);
}
.fr-ad-zone-talks-sponsor {
    margin: 24px 0 0;
    text-align: left;
}
.fr-ad-zone-talks-sponsor .fr-ad-label {
    color: rgba(255,255,255,.5);
}
.fr-ad-zone-talks-sponsor .fr-ad-content {
    place-items: start;
    border-color: rgba(255,255,255,.18);
    background: rgba(255,255,255,.07);
    color: var(--fr-white);
}
.fr-ad-zone-newsletter-sponsor {
    margin: 18px auto 24px;
    max-width: 760px;
}
.fr-ad-zone-newsletter-sponsor .fr-ad-content {
    background: rgba(255,255,255,.64);
}
.fr-ad-widget {
    width: 100%;
}
@media (max-width: 720px) {
    .fr-ad-zone.fr-container,
    .fr-ad-zone-home-top.fr-container,
    .fr-ad-zone-home-after-latest.fr-container,
    .fr-ad-zone-home-between.fr-container,
    .fr-ad-zone-category-sponsor.fr-container {
        width: min(100% - 28px, var(--fr-max));
    }
    .fr-ad-content {
        padding: 12px;
    }
    .article-sidebar .fr-ad-zone-article-sidebar {
        text-align: center;
    }
}


/* Phase 2.5: homepage spacing rebalance after ad-zone architecture
   The ad hooks are invisible when empty, so do not reserve oversized blank space
   between the secondary story row, The Latest, and Front Row / Runway. */
body.home .secondary-grid {
    margin-bottom: clamp(18px, 2.5vw, 34px) !important;
    padding-bottom: clamp(28px, 3.5vw, 48px) !important;
    border-bottom: 1px solid var(--fr-line) !important;
}
body.home .secondary-grid::after {
    display: none !important;
}
body.home .secondary-grid .fr-story-medium .card-body {
    min-height: clamp(96px, 8vw, 132px) !important;
    padding-top: 14px !important;
    padding-bottom: 10px !important;
}
body.home .secondary-grid .fr-story-medium h3 {
    font-size: clamp(22px, 2vw, 28px) !important;
    line-height: 1.08 !important;
}
body.home .secondary-grid .fr-story-medium .card-meta {
    margin-top: 10px !important;
}
body.home .secondary-grid + .fr-latest-block,
body.home .fr-latest-block {
    margin-top: 0 !important;
    padding-top: clamp(38px, 4.8vw, 64px) !important;
    padding-bottom: clamp(38px, 4.8vw, 64px) !important;
}
body.home .fr-latest-block + .fr-ad-zone-home-after-latest {
    margin-top: clamp(18px, 2vw, 28px) !important;
    margin-bottom: clamp(24px, 3vw, 42px) !important;
}
body.home .fr-latest-block + .module-category-rail,
body.home .fr-ad-zone-home-after-latest + .module-category-rail,
body.home .module-front_row_runway {
    margin-top: clamp(44px, 5vw, 72px) !important;
}
body.home .module-front_row_runway {
    padding-top: clamp(42px, 5vw, 68px) !important;
}
/* Keep actual ads neat, but only when they render. */
body.home .fr-ad-zone {
    margin-top: clamp(18px, 2.5vw, 34px);
    margin-bottom: clamp(18px, 2.5vw, 34px);
}
body.home .fr-ad-zone-home-after-latest,
body.home .fr-ad-zone-home-between {
    margin-top: clamp(18px, 2.5vw, 34px) !important;
    margin-bottom: clamp(28px, 3.5vw, 52px) !important;
}
@media (max-width: 1180px) {
    body.home .secondary-grid {
        margin-bottom: 24px !important;
        padding-bottom: 34px !important;
    }
    body.home .secondary-grid .fr-story-medium .card-body {
        min-height: 104px !important;
    }
}
@media (max-width: 720px) {
    body.home .secondary-grid {
        margin-bottom: 18px !important;
        padding-bottom: 28px !important;
    }
    body.home .secondary-grid .fr-story-medium .card-body {
        min-height: 0 !important;
        padding-bottom: 18px !important;
    }
    body.home .secondary-grid + .fr-latest-block,
    body.home .fr-latest-block {
        padding-top: 32px !important;
        padding-bottom: 34px !important;
    }
    body.home .module-front_row_runway {
        margin-top: 34px !important;
        padding-top: 36px !important;
    }
}


/* Phase 2.6: single-post related stories / newsletter separation
   Prevent related story cards from flowing under the newsletter module on article pages. */
.single .fr-article {
    padding-bottom: clamp(56px, 7vw, 100px) !important;
}
.single .fr-article-layout {
    align-items: start !important;
    overflow: visible !important;
}
.single .fr-article-main {
    min-width: 0 !important;
    overflow: visible !important;
}
.single .related-stories {
    clear: both !important;
    display: block !important;
    position: relative !important;
    z-index: 1 !important;
    margin-top: clamp(56px, 6vw, 84px) !important;
    margin-bottom: clamp(72px, 8vw, 120px) !important;
    padding-bottom: clamp(42px, 5vw, 76px) !important;
    border-bottom: 1px solid var(--fr-line) !important;
    overflow: visible !important;
}
.single .related-stories .section-heading {
    margin-bottom: clamp(24px, 3vw, 38px) !important;
}
.single .related-stories .fr-card-grid,
.single .related-stories .fr-card-grid.three-up {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: clamp(24px, 3vw, 38px) !important;
    align-items: start !important;
    overflow: visible !important;
}
.single .related-stories .fr-story-card,
.single .related-stories .fr-story-medium {
    display: flex !important;
    flex-direction: column !important;
    min-width: 0 !important;
    min-height: 0 !important;
    height: auto !important;
    overflow: visible !important;
    background: transparent !important;
}
.single .related-stories .fr-story-medium .card-image {
    width: 100% !important;
    aspect-ratio: 4 / 5 !important;
    overflow: hidden !important;
    flex: 0 0 auto !important;
}
.single .related-stories .fr-story-medium .card-image img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
}
.single .related-stories .fr-story-medium .card-body {
    display: block !important;
    position: static !important;
    height: auto !important;
    min-height: clamp(150px, 13vw, 220px) !important;
    padding: 18px 0 24px !important;
    overflow: visible !important;
}
.single .related-stories .fr-story-medium h3 {
    font-size: clamp(24px, 2.4vw, 34px) !important;
    line-height: 1.08 !important;
    margin-bottom: 12px !important;
    overflow-wrap: break-word !important;
}
.single .related-stories .fr-story-medium .card-meta {
    display: block !important;
    margin-top: 10px !important;
}
.single .fr-article + .newsletter-module.fr-container,
.single .newsletter-module.fr-container {
    clear: both !important;
    display: block !important;
    position: relative !important;
    z-index: 0 !important;
    margin-top: clamp(34px, 4.5vw, 72px) !important;
    padding-top: 0 !important;
}

@media (max-width: 980px) {
    .single .fr-article-layout {
        grid-template-columns: 1fr !important;
    }
    .single .article-sidebar {
        position: static !important;
        border-left: 0 !important;
        padding-left: 0 !important;
        margin-top: 44px !important;
    }
    .single .related-stories .fr-card-grid,
    .single .related-stories .fr-card-grid.three-up {
        grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    }
}

@media (max-width: 720px) {
    .single .related-stories {
        margin-bottom: 54px !important;
        padding-bottom: 44px !important;
    }
    .single .related-stories .fr-card-grid,
    .single .related-stories .fr-card-grid.three-up {
        grid-template-columns: 1fr !important;
    }
    .single .related-stories .fr-story-medium .card-body {
        min-height: 0 !important;
        padding-bottom: 22px !important;
    }
    .single .fr-article + .newsletter-module.fr-container,
    .single .newsletter-module.fr-container {
        width: min(100% - 28px, var(--fr-max)) !important;
        margin-top: 32px !important;
    }
}

/* Phase 2.7 Front Row homepage carousel */
.fr-front-row-carousel {
    clear: both;
    margin-top: clamp(34px, 5vw, 64px);
    margin-bottom: clamp(42px, 6vw, 78px);
    padding: 0 0 clamp(22px, 3vw, 36px);
    border-bottom: 1px solid var(--fr-line);
}
.fr-front-row-carousel .fr-carousel-heading {
    align-items: flex-end;
    margin-bottom: 24px;
}
.fr-carousel-shell {
    position: relative;
    background: var(--fr-black);
    overflow: hidden;
    min-height: clamp(460px, 56vw, 650px);
    border: 1px solid rgba(0,0,0,.08);
}
.fr-carousel-track {
    position: relative;
    min-height: inherit;
}
.fr-carousel-slide {
    position: absolute;
    inset: 0;
    opacity: 0;
    visibility: hidden;
    transform: translateX(18px);
    transition: opacity .55s ease, transform .55s ease, visibility .55s ease;
    background: var(--fr-black);
}
.fr-carousel-slide.is-active {
    opacity: 1;
    visibility: visible;
    transform: translateX(0);
    z-index: 2;
}
.fr-carousel-image {
    position: absolute;
    inset: 0;
    display: block;
    background: #111;
}
.fr-carousel-image::after {
    content: "";
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg, rgba(0,0,0,.48) 0%, rgba(0,0,0,.22) 38%, rgba(0,0,0,.08) 78%);
    pointer-events: none;
}
.fr-carousel-image img,
.fr-carousel-image .fr-placeholder {
    width: 100%;
    height: 100%;
    object-fit: cover;
}
.fr-carousel-panel {
    position: absolute;
    left: clamp(24px, 5vw, 68px);
    bottom: clamp(24px, 5vw, 68px);
    width: min(520px, calc(100% - 48px));
    padding: clamp(24px, 4vw, 44px);
    color: var(--fr-white);
    background: rgba(10, 10, 10, .68);
    border: 1px solid rgba(255,255,255,.16);
    backdrop-filter: blur(8px);
    -webkit-backdrop-filter: blur(8px);
    box-shadow: 0 24px 80px rgba(0,0,0,.28);
}
.fr-carousel-panel .fr-kicker { color: #e1b6bd; }
.fr-carousel-panel h3 {
    font-size: clamp(34px, 4.8vw, 64px);
    max-width: 10.5em;
}
.fr-carousel-panel .card-deck {
    margin: 14px 0 0;
    font-size: clamp(15px, 1.25vw, 18px);
    line-height: 1.55;
    color: rgba(255,255,255,.88);
}
.fr-carousel-panel .card-meta {
    margin: 18px 0 20px;
    color: rgba(255,255,255,.72);
}
.fr-carousel-controls {
    position: absolute;
    left: clamp(24px, 5vw, 68px);
    right: clamp(24px, 5vw, 68px);
    bottom: 18px;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 12px;
    pointer-events: none;
}
.fr-carousel-prev,
.fr-carousel-next,
.fr-carousel-dot {
    pointer-events: auto;
}
.fr-carousel-prev,
.fr-carousel-next {
    width: 42px;
    height: 42px;
    padding: 0;
    border-color: rgba(255,255,255,.55);
    background: rgba(0,0,0,.35);
    color: var(--fr-white);
    font-size: 18px;
    letter-spacing: 0;
}
.fr-carousel-prev:hover,
.fr-carousel-next:hover,
.fr-carousel-prev:focus,
.fr-carousel-next:focus {
    background: var(--fr-red);
    border-color: var(--fr-red);
}
.fr-carousel-dots {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 0 8px;
}
.fr-carousel-dot {
    width: 8px;
    height: 8px;
    padding: 0;
    border: 1px solid rgba(255,255,255,.78);
    border-radius: 999px;
    background: transparent;
    min-height: 0;
}
.fr-carousel-dot.is-active,
.fr-carousel-dot:hover,
.fr-carousel-dot:focus {
    background: var(--fr-white);
    border-color: var(--fr-white);
}
@media (prefers-reduced-motion: reduce) {
    .fr-carousel-slide { transition: none; }
}
@media (max-width: 900px) {
    .fr-carousel-shell { min-height: auto; background: var(--fr-black); }
    .fr-carousel-track { min-height: 0; }
    .fr-carousel-slide { position: relative; display: none; min-height: 0; transform: none; }
    .fr-carousel-slide.is-active { display: block; }
    .fr-carousel-image { position: relative; inset: auto; aspect-ratio: 16 / 10; }
    .fr-carousel-panel {
        position: relative;
        left: auto;
        bottom: auto;
        width: 100%;
        padding: 26px;
        background: var(--fr-black);
        border: 0;
        box-shadow: none;
        backdrop-filter: none;
        -webkit-backdrop-filter: none;
    }
    .fr-carousel-panel h3 { font-size: clamp(32px, 9vw, 46px); }
    .fr-carousel-controls {
        position: relative;
        left: auto;
        right: auto;
        bottom: auto;
        justify-content: center;
        padding: 0 0 22px;
    }
}
@media (max-width: 600px) {
    .fr-front-row-carousel { margin-top: 36px; margin-bottom: 46px; }
    .fr-front-row-carousel .fr-carousel-heading { align-items: flex-start; }
    .fr-carousel-image { aspect-ratio: 4 / 5; }
    .fr-carousel-panel { padding: 24px 22px; }
    .fr-carousel-controls { gap: 8px; }
}

/* Phase 2.8: homepage carousel header replacement */
body.home .fr-home-carousel-header {
    width: 100%;
    max-width: none;
    margin: 0 0 clamp(44px, 5vw, 72px) !important;
    padding: 0 !important;
    border-bottom: 0 !important;
    clear: both;
}
body.home .fr-ad-zone-home-top:not(:empty) + .fr-home-carousel-header {
    margin-top: clamp(18px, 2vw, 28px) !important;
}
body.home .fr-home-carousel-header .fr-carousel-shell {
    min-height: clamp(560px, 62vw, 760px);
    border: 0;
    border-radius: 0;
    box-shadow: none;
}
body.home .fr-home-carousel-header .fr-carousel-image::after {
    background: linear-gradient(90deg, rgba(0,0,0,.58) 0%, rgba(0,0,0,.30) 42%, rgba(0,0,0,.06) 78%);
}
body.home .fr-home-carousel-header .fr-carousel-panel {
    left: max(28px, calc((100vw - var(--fr-max)) / 2 + 28px));
    bottom: clamp(38px, 6vw, 86px);
    width: min(560px, calc(100% - 56px));
    padding: clamp(28px, 4.5vw, 52px);
}
body.home .fr-home-carousel-header .fr-carousel-panel h3 {
    font-size: clamp(44px, 6.3vw, 84px);
    max-width: 9.5em;
}
body.home .fr-home-carousel-header .fr-carousel-panel .card-deck {
    max-width: 490px;
}
body.home .fr-home-carousel-header .fr-carousel-controls {
    left: max(28px, calc((100vw - var(--fr-max)) / 2 + 28px));
    right: max(28px, calc((100vw - var(--fr-max)) / 2 + 28px));
    bottom: 24px;
}
body.home .fr-home-carousel-header + .secondary-grid,
body.home .fr-home-carousel-header + .fr-container.secondary-grid {
    margin-top: 0;
    padding-top: clamp(26px, 3.5vw, 46px) !important;
}
body.home .fr-home-carousel-header + .secondary-grid .fr-story-medium .card-image {
    aspect-ratio: 4 / 3;
}
@media (max-width: 900px) {
    body.home .fr-home-carousel-header {
        margin-bottom: 38px !important;
    }
    body.home .fr-home-carousel-header .fr-carousel-shell {
        min-height: auto;
    }
    body.home .fr-home-carousel-header .fr-carousel-panel {
        left: auto;
        bottom: auto;
        width: 100%;
        padding: 28px 24px 30px;
    }
    body.home .fr-home-carousel-header .fr-carousel-panel h3 {
        font-size: clamp(34px, 9vw, 52px);
    }
    body.home .fr-home-carousel-header .fr-carousel-controls {
        left: auto;
        right: auto;
        bottom: auto;
    }
}
@media (max-width: 600px) {
    body.home .fr-home-carousel-header .fr-carousel-image {
        aspect-ratio: 4 / 5;
    }
    body.home .fr-home-carousel-header + .secondary-grid,
    body.home .fr-home-carousel-header + .fr-container.secondary-grid {
        padding-top: 24px !important;
    }
}


/* Phase 2.9: narrower logo / masthead bar */
.masthead-main {
    padding-top: clamp(12px, 1.6vw, 22px) !important;
    padding-bottom: clamp(8px, 1.2vw, 16px) !important;
}
.site-branding {
    gap: 3px !important;
}
.site-logo-default,
.custom-logo-link {
    max-width: min(620px, 82vw) !important;
}
.site-logo-default img,
.custom-logo-link img,
.custom-logo {
    width: min(620px, 82vw) !important;
    max-height: 96px !important;
    object-fit: contain;
}
.site-tagline {
    margin-top: 1px !important;
    font-size: 9px !important;
    line-height: 1.25 !important;
    letter-spacing: .16em !important;
}
.menu-toggle {
    top: 24px !important;
}
.primary-nav a {
    padding-top: 12px;
    padding-bottom: 12px;
}
@media (max-width: 720px) {
    .masthead-main {
        padding-top: 12px !important;
        padding-bottom: 10px !important;
    }
    .site-logo-default,
    .custom-logo-link {
        max-width: min(82vw, 430px) !important;
    }
    .site-logo-default img,
    .custom-logo-link img,
    .custom-logo {
        width: min(82vw, 430px) !important;
        max-height: 68px !important;
    }
    .site-tagline {
        font-size: 7.5px !important;
        line-height: 1.25 !important;
        letter-spacing: .11em !important;
        max-width: 82vw !important;
    }
    .menu-toggle {
        top: 18px !important;
        font-size: 24px !important;
    }
}

/* Phase 3.0: Fashion Reverie branded login experience */
.fr-sign-in-template {
    width: 100%;
}
.fr-sign-in-template .fr-login-page {
    margin-top: 0;
}
.fr-login-page {
    width: min(var(--fr-max), calc(100% - 40px));
    margin: clamp(30px, 5vw, 76px) auto clamp(60px, 7vw, 104px);
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(360px, .7fr);
    min-height: 640px;
    border: 1px solid rgba(17,17,17,.10);
    background: var(--fr-white);
    box-shadow: 0 34px 110px rgba(17,17,17,.10);
    overflow: hidden;
}
.fr-login-visual {
    position: relative;
    min-height: 560px;
    background:
        linear-gradient(120deg, rgba(0,0,0,.78), rgba(0,0,0,.24)),
        radial-gradient(circle at 20% 30%, rgba(124,28,44,.55), transparent 28%),
        linear-gradient(135deg, #111 0%, #2a2021 46%, #7c1c2c 100%);
    color: var(--fr-white);
    display: flex;
    align-items: flex-end;
    padding: clamp(36px, 5vw, 72px);
}
.fr-login-visual::after {
    content: "";
    position: absolute;
    inset: 0;
    background-image: linear-gradient(rgba(255,255,255,.06) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
    background-size: 42px 42px;
    opacity: .38;
}
.fr-login-visual-inner {
    position: relative;
    z-index: 1;
    max-width: 620px;
}
.fr-login-visual h1 {
    color: var(--fr-white);
    font-size: clamp(46px, 6.2vw, 82px);
    line-height: .93;
    max-width: 9em;
}
.fr-login-visual p:not(.fr-kicker) {
    max-width: 480px;
    color: rgba(255,255,255,.78);
    font-size: 18px;
    line-height: 1.55;
}
.fr-login-panel {
    display: flex;
    align-items: center;
    justify-content: center;
    padding: clamp(28px, 4vw, 56px);
    background: #fbf7f1;
}
.fr-login-card {
    width: 100%;
    max-width: 460px;
}
.fr-login-brand {
    margin-bottom: 28px;
    padding-bottom: 22px;
    border-bottom: 1px solid rgba(17,17,17,.10);
}
.fr-login-title {
    display: block;
    font-family: Georgia, 'Times New Roman', serif;
    font-size: clamp(32px, 3.2vw, 48px);
    line-height: 1;
    color: var(--fr-black);
}
.fr-login-brand p {
    margin: 8px 0 0;
    color: var(--fr-muted);
    font-size: 12px;
    letter-spacing: .08em;
    text-transform: uppercase;
    line-height: 1.5;
}
.fr-login-form label {
    display: block;
    margin: 18px 0 7px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--fr-black);
}
.fr-login-form input[type="text"],
.fr-login-form input[type="password"] {
    width: 100%;
    min-height: 50px;
    border: 1px solid rgba(17,17,17,.18);
    background: var(--fr-white);
    color: var(--fr-black);
    padding: 0 14px;
    font-size: 16px;
    border-radius: 0;
}
.fr-login-form input[type="text"]:focus,
.fr-login-form input[type="password"]:focus {
    outline: 2px solid rgba(124,28,44,.28);
    border-color: var(--fr-red);
}
.fr-login-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    margin: 16px 0 22px;
    font-size: 13px;
}
.fr-login-row label,
.fr-login-row a {
    margin: 0;
    font-size: 13px;
    letter-spacing: 0;
    text-transform: none;
    font-weight: 600;
}
.fr-remember {
    display: inline-flex !important;
    align-items: center;
    gap: 7px;
    color: var(--fr-muted) !important;
}
.fr-login-submit {
    width: 100%;
    min-height: 52px;
    border: 1px solid var(--fr-black);
    background: var(--fr-black);
    color: var(--fr-white);
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 900;
    cursor: pointer;
}
.fr-login-submit:hover,
.fr-login-submit:focus {
    background: var(--fr-red);
    border-color: var(--fr-red);
}
.fr-login-message {
    margin: 0 0 18px;
    padding: 13px 15px;
    border-left: 4px solid var(--fr-red);
    background: rgba(124,28,44,.08);
    font-size: 14px;
    line-height: 1.5;
}
.fr-login-message.success {
    border-left-color: #1d6f42;
    background: rgba(29,111,66,.08);
}
.fr-login-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.fr-login-secondary-links {
    margin-top: 24px;
    display: flex;
    flex-wrap: wrap;
    gap: 10px 18px;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .09em;
    font-weight: 800;
}
.fr-login-secondary-links a {
    color: var(--fr-muted);
}
.fr-login-secondary-links a:hover,
.fr-login-secondary-links a:focus {
    color: var(--fr-red);
}
@media (max-width: 900px) {
    .fr-login-page {
        grid-template-columns: 1fr;
        min-height: 0;
    }
    .fr-login-visual {
        min-height: 310px;
        padding: 34px 28px;
        align-items: flex-end;
    }
    .fr-login-visual h1 {
        font-size: clamp(38px, 10vw, 60px);
    }
    .fr-login-panel {
        padding: 34px 24px 42px;
    }
}
@media (max-width: 600px) {
    .fr-login-page {
        width: calc(100% - 24px);
        margin-top: 24px;
    }
    .fr-login-visual {
        min-height: 260px;
    }
    .fr-login-row {
        align-items: flex-start;
        flex-direction: column;
    }
    .fr-login-secondary-links {
        flex-direction: column;
    }
}


/* Phase 3.3 HTML Sitemap */
.fr-sitemap {
    width: min(var(--fr-max), calc(100% - 40px));
    margin: 0 auto;
    padding: clamp(38px, 6vw, 78px) 0 clamp(56px, 8vw, 94px);
}
.fr-sitemap-header {
    max-width: 900px;
    margin: 0 auto 34px;
    text-align: center;
}
.fr-sitemap-header h1 {
    font-size: clamp(46px, 8vw, 88px);
    text-transform: uppercase;
    letter-spacing: .035em;
}
.fr-sitemap-header p:not(.fr-kicker) {
    max-width: 680px;
    margin: 18px auto 0;
    color: var(--fr-charcoal);
    font-size: 19px;
    line-height: 1.5;
}
.fr-sitemap-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
}
.fr-sitemap-section {
    padding: 24px;
    background: rgba(255,255,255,.62);
    border: 1px solid var(--fr-line);
}
.fr-sitemap-section h2 {
    margin-bottom: 16px;
    font-family: var(--fr-sans);
    font-size: 12px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.fr-sitemap-section ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.fr-sitemap-section li {
    margin: 0;
    padding: 10px 0;
    border-top: 1px solid rgba(0,0,0,.08);
    line-height: 1.35;
}
.fr-sitemap-section li:first-child {
    border-top: 0;
    padding-top: 0;
}
.fr-sitemap-section a {
    color: var(--fr-ink);
}
.fr-sitemap-section a:hover,
.fr-sitemap-section a:focus {
    color: var(--fr-red);
}
@media (max-width: 960px) {
    .fr-sitemap-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
    .fr-sitemap-grid { grid-template-columns: 1fr; }
    .fr-sitemap-section { padding: 20px; }
}


/* Phase 3.4 Media Kit */
.fr-page-media-kit .article-content { margin: 0; }
.fr-page-media-kit { margin: 0; }
.fr-media-kit { overflow: hidden; }
.fr-media-hero {
    margin: 0 0 clamp(48px, 7vw, 82px);
    padding: clamp(68px, 9vw, 120px) 0;
    color: #fff8ef;
    background:
        linear-gradient(115deg, rgba(20,14,15,.95), rgba(64,13,18,.88)),
        radial-gradient(circle at 78% 20%, rgba(179,137,77,.28), transparent 34%),
        #171313;
}
.fr-media-hero-inner { max-width: 1100px; }
.fr-media-hero h1 {
    margin: 0;
    max-width: 930px;
    font-size: clamp(52px, 8vw, 112px);
    line-height: .88;
    letter-spacing: -.055em;
    text-transform: uppercase;
}
.fr-media-hero p:not(.fr-kicker) {
    max-width: 760px;
    margin: 22px 0 0;
    color: rgba(255,248,239,.82);
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1.45;
}
.fr-media-hero .fr-kicker { color: #f0d4aa; }
.fr-media-hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 32px; }
.fr-media-hero .fr-button.outline { color: #fff8ef; border-color: rgba(255,255,255,.55); background: transparent; }
.fr-media-hero .fr-button.light { color: var(--fr-ink); background: #fff8ef; }
.fr-media-section { margin-bottom: clamp(52px, 7vw, 88px); }
.fr-media-section-heading { max-width: 900px; margin-bottom: 28px; }
.fr-media-section-heading h2 {
    margin: 0;
    font-size: clamp(34px, 5vw, 66px);
    line-height: .95;
    letter-spacing: -.035em;
    text-transform: uppercase;
}
.fr-media-section-heading p:not(.fr-kicker) { max-width: 760px; margin-top: 14px; color: var(--fr-charcoal); font-size: 18px; line-height: 1.55; }
.fr-media-benefits,
.fr-media-spec-grid,
.fr-media-download-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 16px;
}
.fr-media-benefit,
.fr-media-spec-grid div,
.fr-media-download-card,
.fr-media-payment-note,
.fr-media-request-form {
    background: rgba(255,255,255,.72);
    border: 1px solid var(--fr-line);
    box-shadow: 0 16px 35px rgba(20,14,15,.05);
}
.fr-media-benefit { padding: 20px; font-weight: 900; text-transform: uppercase; letter-spacing: .08em; font-size: 12px; }
.fr-rate-table-wrap { overflow-x: auto; border: 1px solid var(--fr-line); background: #fff; }
.fr-rate-table { width: 100%; border-collapse: collapse; min-width: 860px; }
.fr-rate-table th,
.fr-rate-table td { padding: 18px; text-align: left; border-bottom: 1px solid var(--fr-line); vertical-align: top; }
.fr-rate-table th { font-family: var(--fr-sans); font-size: 11px; text-transform: uppercase; letter-spacing: .12em; color: var(--fr-muted); background: #f8f3ee; }
.fr-rate-table td strong { display: block; }
.fr-rate-table td span,
.fr-rate-table td em { display: block; margin-top: 5px; color: var(--fr-muted); font-size: 12px; font-style: normal; }
.fr-media-spec-grid div { padding: 22px; }
.fr-media-spec-grid strong { display: block; font-family: var(--fr-serif); font-size: 26px; }
.fr-media-spec-grid span { display: block; margin-top: 8px; color: var(--fr-charcoal); line-height: 1.45; }
.fr-media-download-card { padding: 24px; display: flex; flex-direction: column; align-items: flex-start; }
.fr-media-download-card h3 { margin: 0; font-size: 24px; line-height: 1.1; }
.fr-media-download-card p { color: var(--fr-charcoal); line-height: 1.5; }
.fr-media-download-card .fr-button { margin-top: auto; }
.fr-media-request-section { padding: clamp(34px, 6vw, 68px); background: #171313; color: #fff8ef; width: min(var(--fr-max), calc(100% - 40px)); }
.fr-media-request-section .fr-kicker { color: #f0d4aa; }
.fr-media-request-section h2 { color: #fff8ef; }
.fr-media-request-section p { color: rgba(255,248,239,.78); }
.fr-media-request-grid { display: grid; grid-template-columns: minmax(0, .85fr) minmax(420px, 1fr); gap: clamp(24px, 5vw, 62px); align-items: start; }
.fr-media-payment-note { padding: 22px; margin-top: 24px; background: rgba(255,255,255,.06); border-color: rgba(255,255,255,.16); }
.fr-media-payment-note h3 { margin-top: 0; color: #fff8ef; }
.fr-media-contact-note a { color: #fff; }
.fr-media-request-form { padding: 24px; background: #fff8ef; color: var(--fr-ink); }
.fr-media-request-form p { margin: 0 0 16px; color: var(--fr-ink); }
.fr-media-request-form label { display: block; color: var(--fr-ink); font-weight: 800; font-size: 12px; text-transform: uppercase; letter-spacing: .08em; }
.fr-media-request-form input,
.fr-media-request-form select,
.fr-media-request-form textarea {
    width: 100%;
    margin-top: 7px;
    padding: 12px 13px;
    border: 1px solid #d8cbc0;
    background: #fff;
    color: var(--fr-ink);
    font: inherit;
    text-transform: none;
    letter-spacing: 0;
    font-weight: 400;
}
.fr-form-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.fr-file-field span { display: block; margin-top: 6px; color: var(--fr-muted); font-weight: 400; text-transform: none; letter-spacing: 0; }
.fr-form-consent label { display: flex; gap: 10px; align-items: flex-start; text-transform: none; letter-spacing: 0; font-weight: 600; line-height: 1.4; }
.fr-form-consent input { width: auto; margin-top: 2px; }
.fr-media-form-notice { margin-bottom: 18px; padding: 14px 16px; border: 1px solid transparent; }
.fr-media-form-notice.success { background: #effaf0; color: #103d18; border-color: #b8e2be; }
.fr-media-form-notice.error { background: #fff0f0; color: #651016; border-color: #e7b9bd; }
@media (max-width: 1100px) {
    .fr-media-benefits,
    .fr-media-spec-grid,
    .fr-media-download-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
    .fr-media-request-grid { grid-template-columns: 1fr; }
}
@media (max-width: 640px) {
    .fr-media-benefits,
    .fr-media-spec-grid,
    .fr-media-download-grid,
    .fr-form-grid { grid-template-columns: 1fr; }
    .fr-media-request-section { width: calc(100% - 24px); padding: 28px 18px; }
    .fr-media-request-form { padding: 18px; }
    .fr-media-hero-actions .fr-button { width: 100%; justify-content: center; }
}

/* Phase 3.5 Media Kit layout cleanup */
.fr-page-media-kit {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}
.fr-page-media-kit .article-content {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}
.fr-page-media-kit .article-content > * {
    max-width: none;
}
.fr-media-kit-clean,
.fr-media-kit {
    width: 100%;
    clear: both;
}
.fr-media-kit-clean .fr-container {
    width: min(var(--fr-max), calc(100% - 48px));
    margin-left: auto;
    margin-right: auto;
}
.fr-media-hero {
    width: 100vw;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    margin-top: 0;
    padding: clamp(76px, 9vw, 128px) 0;
    overflow: hidden;
}
.fr-media-hero-inner {
    width: min(var(--fr-max), calc(100% - 48px));
    margin-left: auto;
    margin-right: auto;
}
.fr-media-hero h1 {
    max-width: 980px;
    font-size: clamp(44px, 7.2vw, 104px);
    overflow-wrap: normal;
    word-break: normal;
}
.fr-media-lede,
.fr-media-copy {
    color: var(--fr-charcoal);
    font-size: 18px;
    line-height: 1.55;
}
.fr-media-hero .fr-media-lede {
    max-width: 760px;
    margin-top: 22px;
    color: rgba(255,248,239,.82);
    font-size: clamp(18px, 2vw, 24px);
    line-height: 1.45;
}
.fr-media-section {
    clear: both;
    position: relative;
}
.fr-media-section-heading {
    max-width: 880px;
}
.fr-media-section-heading .fr-media-copy {
    max-width: 760px;
    margin-top: 14px;
}
.fr-media-why {
    display: grid;
    grid-template-columns: minmax(0, .92fr) minmax(420px, 1fr);
    gap: clamp(28px, 5vw, 72px);
    align-items: start;
}
.fr-media-why .fr-media-section-heading {
    margin-bottom: 0;
}
.fr-media-why .fr-media-benefits {
    margin-top: 8px;
}
.fr-media-benefits,
.fr-media-spec-grid,
.fr-media-download-grid {
    align-items: stretch;
}
.fr-media-benefit,
.fr-media-spec-grid div,
.fr-media-download-card {
    min-height: 92px;
}
.fr-rate-table-wrap,
.fr-media-spec-grid,
.fr-media-download-grid,
.fr-media-request-section {
    clear: both;
}
.fr-page-media-kit .advads-placement,
.fr-page-media-kit .advads-ad-container,
.fr-page-media-kit .advads-edit-bar,
.fr-page-media-kit .kenjo-entity-placement,
.fr-page-media-kit [id^="kenjo-"],
.fr-page-media-kit [class*="kenjo-test-placement"],
.fr-page-media-kit [class*="advanced-ads"],
.fr-page-media-kit [class*="advads"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    min-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}
.fr-page-media-kit .fr-media-request-form,
.fr-page-media-kit .fr-media-request-form * {
    visibility: visible !important;
}
@media (max-width: 1100px) {
    .fr-media-why {
        grid-template-columns: 1fr;
    }
}
@media (max-width: 760px) {
    .fr-media-kit-clean .fr-container,
    .fr-media-hero-inner {
        width: calc(100% - 28px);
    }
    .fr-media-hero {
        padding: 54px 0 62px;
    }
    .fr-media-section-heading h2 {
        font-size: clamp(32px, 11vw, 54px);
    }
}

/* Phase 3.6 Media Kit Chrome/table/form hardening */
.fr-page-media-kit,
.fr-page-media-kit .article-content,
.fr-page-media-kit .fr-media-kit,
.fr-page-media-kit .fr-media-kit-clean {
    display: block !important;
    max-width: none !important;
    width: 100% !important;
    overflow-x: clip;
}
.fr-page-media-kit .fr-media-kit-clean .fr-container,
.fr-page-media-kit .fr-media-section,
.fr-page-media-kit .fr-media-hero-inner {
    width: min(var(--fr-max), calc(100vw - 64px)) !important;
    max-width: var(--fr-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
}
.fr-page-media-kit .fr-media-hero {
    width: 100vw !important;
    max-width: none !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
}
.fr-page-media-kit .fr-rate-table-wrap {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
    -webkit-overflow-scrolling: touch;
}
.fr-page-media-kit .fr-rate-table {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    table-layout: fixed !important;
}
.fr-page-media-kit .fr-rate-table th,
.fr-page-media-kit .fr-rate-table td {
    overflow-wrap: anywhere;
    word-break: normal;
}
.fr-page-media-kit .fr-rate-table th:nth-child(1),
.fr-page-media-kit .fr-rate-table td:nth-child(1) { width: 28%; }
.fr-page-media-kit .fr-rate-table th:nth-child(2),
.fr-page-media-kit .fr-rate-table td:nth-child(2) { width: 20%; }
.fr-page-media-kit .fr-rate-table th:nth-child(3),
.fr-page-media-kit .fr-rate-table td:nth-child(3) { width: 34%; }
.fr-page-media-kit .fr-rate-table th:nth-child(4),
.fr-page-media-kit .fr-rate-table td:nth-child(4) { width: 18%; }
.fr-page-media-kit .fr-form-field,
.fr-page-media-kit .fr-media-request-form .fr-form-field {
    margin: 0 0 16px;
}
.fr-page-media-kit .fr-form-grid .fr-form-field {
    margin: 0;
}
.fr-page-media-kit .fr-form-field-full {
    grid-column: 1 / -1;
}
.fr-page-media-kit .fr-media-download-description {
    color: var(--fr-charcoal);
    line-height: 1.5;
    margin: 12px 0 18px;
}
.fr-page-media-kit .fr-media-contact-note {
    margin-top: 18px;
    color: rgba(255,248,239,.78);
    line-height: 1.55;
}
.fr-page-media-kit .fr-media-payment-link {
    margin-top: 12px;
}
.fr-page-media-kit .fr-media-payment-link a {
    color: #fff8ef;
    text-decoration: underline;
    text-underline-offset: 3px;
}
/* Hide Advanced Ads automatic injections on the dedicated Media Kit sales/form page. */
.fr-page-media-kit div[id^="kenjo-"],
.fr-page-media-kit .kenjo-entity-placement,
.fr-page-media-kit .advads-placement,
.fr-page-media-kit .advads-ad-container,
.fr-page-media-kit ins.adsbygoogle,
.fr-page-media-kit [class*="advads"],
.fr-page-media-kit [class*="advanced-ads"] {
    display: none !important;
    visibility: hidden !important;
    width: 0 !important;
    max-width: 0 !important;
    height: 0 !important;
    max-height: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
}
@media (max-width: 900px) {
    .fr-page-media-kit .fr-rate-table,
    .fr-page-media-kit .fr-rate-table thead,
    .fr-page-media-kit .fr-rate-table tbody,
    .fr-page-media-kit .fr-rate-table tr,
    .fr-page-media-kit .fr-rate-table th,
    .fr-page-media-kit .fr-rate-table td {
        display: block;
        width: 100% !important;
    }
    .fr-page-media-kit .fr-rate-table thead {
        position: absolute;
        left: -9999px;
        height: 1px;
        overflow: hidden;
    }
    .fr-page-media-kit .fr-rate-table tr {
        border-bottom: 1px solid var(--fr-line);
        padding: 14px 0;
    }
    .fr-page-media-kit .fr-rate-table td {
        border-bottom: 0;
        padding: 7px 18px;
    }
    .fr-page-media-kit .fr-rate-table td:nth-child(1)::before { content: 'Placement'; }
    .fr-page-media-kit .fr-rate-table td:nth-child(2)::before { content: 'Size'; }
    .fr-page-media-kit .fr-rate-table td:nth-child(3)::before { content: 'Description'; }
    .fr-page-media-kit .fr-rate-table td:nth-child(4)::before { content: 'Starting Price'; }
    .fr-page-media-kit .fr-rate-table td::before {
        display: block;
        margin-bottom: 3px;
        font-family: var(--fr-sans);
        font-size: 10px;
        text-transform: uppercase;
        letter-spacing: .12em;
        color: var(--fr-muted);
        font-weight: 800;
    }
}
@media (max-width: 760px) {
    .fr-page-media-kit .fr-media-kit-clean .fr-container,
    .fr-page-media-kit .fr-media-section,
    .fr-page-media-kit .fr-media-hero-inner {
        width: calc(100vw - 28px) !important;
    }
}

/* Phase 3.7 Media Kit rate-card layout rebalance */
.fr-page-media-kit .fr-media-rate-section {
    display: block !important;
    clear: both !important;
    width: min(var(--fr-max), calc(100vw - 64px)) !important;
    max-width: var(--fr-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-top: clamp(18px, 3vw, 34px);
}
.fr-page-media-kit .fr-media-rate-heading {
    max-width: none !important;
    display: grid;
    grid-template-columns: minmax(0, .72fr) minmax(300px, .48fr);
    gap: clamp(22px, 5vw, 72px);
    align-items: end;
    margin-bottom: clamp(26px, 4vw, 44px);
}
.fr-page-media-kit .fr-media-rate-heading h2 {
    max-width: 780px;
    font-size: clamp(42px, 5.8vw, 82px);
    line-height: .92;
    letter-spacing: -.045em;
}
.fr-page-media-kit .fr-media-rate-heading .fr-media-copy {
    max-width: 460px;
    margin-top: 0;
    font-size: clamp(16px, 1.45vw, 20px);
    line-height: 1.55;
}
.fr-page-media-kit .fr-rate-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 18px;
    width: 100%;
    max-width: 100%;
    clear: both;
}
.fr-page-media-kit .fr-rate-card {
    display: flex;
    flex-direction: column;
    min-width: 0;
    min-height: 290px;
    padding: clamp(22px, 2.4vw, 30px);
    background: rgba(255,255,255,.82);
    border: 1px solid var(--fr-line);
    box-shadow: 0 16px 36px rgba(20,14,15,.045);
}
.fr-page-media-kit .fr-rate-card-topline {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-bottom: 18px;
    color: var(--fr-muted);
    font-family: var(--fr-sans);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.fr-page-media-kit .fr-rate-card-topline code {
    max-width: 58%;
    overflow: hidden;
    color: var(--fr-red);
    background: transparent;
    font-family: var(--fr-sans);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .04em;
    text-overflow: ellipsis;
    text-transform: none;
    white-space: nowrap;
}
.fr-page-media-kit .fr-rate-card h3 {
    margin: 0 0 18px;
    max-width: 96%;
    color: var(--fr-ink);
    font-family: var(--fr-serif);
    font-size: clamp(26px, 2.5vw, 36px);
    line-height: 1.02;
    letter-spacing: -.025em;
}
.fr-page-media-kit .fr-rate-card dl {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin: auto 0 18px;
    padding: 18px 0;
    border-top: 1px solid var(--fr-line);
    border-bottom: 1px solid var(--fr-line);
}
.fr-page-media-kit .fr-rate-card dt {
    margin: 0 0 5px;
    color: var(--fr-muted);
    font-family: var(--fr-sans);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .12em;
    line-height: 1.2;
    text-transform: uppercase;
}
.fr-page-media-kit .fr-rate-card dd {
    margin: 0;
    color: var(--fr-ink);
    font-size: 16px;
    line-height: 1.35;
}
.fr-page-media-kit .fr-rate-card dd strong {
    font-family: var(--fr-serif);
    font-size: 28px;
    font-weight: 700;
    letter-spacing: -.02em;
}
.fr-page-media-kit .fr-rate-card dd span {
    display: block;
    margin-top: 2px;
    color: var(--fr-muted);
    font-family: var(--fr-sans);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
}
.fr-page-media-kit .fr-rate-card p {
    margin: 0;
    color: var(--fr-charcoal);
    font-size: 16px;
    line-height: 1.5;
}
.fr-page-media-kit .fr-rate-table-wrap {
    display: none !important;
}
@media (max-width: 1180px) {
    .fr-page-media-kit .fr-rate-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
    .fr-page-media-kit .fr-media-rate-heading {
        grid-template-columns: 1fr;
        align-items: start;
    }
    .fr-page-media-kit .fr-media-rate-heading .fr-media-copy {
        max-width: 760px;
    }
}
@media (max-width: 720px) {
    .fr-page-media-kit .fr-media-rate-section {
        width: calc(100vw - 28px) !important;
    }
    .fr-page-media-kit .fr-rate-card-grid {
        grid-template-columns: 1fr;
    }
    .fr-page-media-kit .fr-rate-card {
        min-height: 0;
    }
    .fr-page-media-kit .fr-rate-card dl {
        grid-template-columns: 1fr;
    }
}

/* Phase 3.8: Mailchimp newsletter landing page */
.fr-page-newsletter {
    background: var(--fr-cream);
}
.fr-page-newsletter .article-content {
    margin: 0;
}
.fr-newsletter-page-block {
    overflow: hidden;
}
.fr-newsletter-hero {
    background: linear-gradient(135deg, #210708 0%, #3a0d10 58%, #090909 100%);
    color: #fff;
    padding: clamp(56px, 8vw, 110px) 0;
}
.fr-newsletter-hero-grid {
    display: grid;
    grid-template-columns: minmax(0, 1.05fr) minmax(340px, .75fr);
    gap: clamp(36px, 6vw, 84px);
    align-items: center;
}
.fr-newsletter-hero .fr-kicker,
.fr-newsletter-card .fr-kicker {
    color: #e8b4ba;
}
.fr-newsletter-hero h1 {
    font-size: clamp(48px, 8vw, 96px);
    line-height: .92;
    letter-spacing: -.04em;
    max-width: 820px;
    margin: 0 0 22px;
}
.fr-newsletter-intro {
    font-size: clamp(20px, 2.4vw, 30px);
    line-height: 1.25;
    max-width: 780px;
    margin: 0 0 20px;
}
.fr-newsletter-deck {
    color: rgba(255,255,255,.78);
    max-width: 640px;
    font-size: 16px;
    line-height: 1.65;
}
.fr-newsletter-card {
    background: #fffaf3;
    color: var(--fr-black);
    padding: clamp(28px, 4vw, 48px);
    border: 1px solid rgba(255,255,255,.35);
    box-shadow: 0 28px 80px rgba(0,0,0,.24);
}
.fr-newsletter-card h2 {
    font-size: clamp(30px, 3.7vw, 52px);
    line-height: .98;
    margin: 0 0 16px;
}
.fr-newsletter-card p {
    color: var(--fr-charcoal);
}
.fr-mailchimp-form {
    margin-top: 24px;
    display: grid;
    gap: 14px;
}
.fr-mailchimp-form label {
    font-size: 11px;
    letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 700;
    color: var(--fr-red);
}
.fr-mailchimp-form input[type="text"],
.fr-mailchimp-form input[type="email"] {
    width: 100%;
    min-height: 48px;
    padding: 13px 14px;
    border: 1px solid rgba(20,20,20,.22);
    background: #fff;
    color: var(--fr-black);
    font-family: inherit;
    font-size: 16px;
}
.fr-mailchimp-form button,
.newsletter-form button {
    cursor: pointer;
}
.fr-mailchimp-form-full button {
    width: 100%;
    min-height: 48px;
    border: 1px solid var(--fr-black);
    background: var(--fr-black);
    color: #fff;
    text-transform: uppercase;
    letter-spacing: .14em;
    font-weight: 700;
    font-size: 11px;
}
.fr-mailchimp-form-full button:hover,
.fr-mailchimp-form-full button:focus {
    background: var(--fr-red);
    border-color: var(--fr-red);
}
.fr-mailchimp-hidden-field {
    position: absolute;
    left: -5000px;
}
.fr-form-warning {
    padding: 10px 12px;
    background: #fff2d7;
    border-left: 3px solid var(--fr-red);
    font-size: 13px;
}
.fr-newsletter-privacy {
    margin-top: 14px;
    font-size: 12px;
    line-height: 1.55;
    color: rgba(20,20,20,.62) !important;
}
.fr-newsletter-topics {
    padding: clamp(56px, 7vw, 92px) 0;
}
.fr-newsletter-section-heading {
    max-width: 760px;
    margin-bottom: 28px;
}
.fr-newsletter-section-heading h2 {
    font-size: clamp(34px, 5vw, 64px);
    line-height: 1;
    margin: 0;
}
.fr-newsletter-topic-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 14px;
}
.fr-newsletter-topic-card {
    min-height: 112px;
    background: #fffaf4;
    border: 1px solid var(--fr-line);
    padding: 22px;
    display: flex;
    align-items: flex-end;
    font-weight: 800;
    letter-spacing: .08em;
    text-transform: uppercase;
    font-size: 13px;
    box-shadow: 0 18px 42px rgba(0,0,0,.04);
}
.newsletter-inner .fr-mailchimp-form-compact,
.newsletter-form {
    margin: 24px auto 0;
    display: flex;
    justify-content: center;
    gap: 8px;
    max-width: 560px;
}
.newsletter-inner .fr-mailchimp-form-compact input[type="email"] {
    flex: 1;
    min-height: 48px;
    padding: 13px;
    border: 1px solid rgba(255,255,255,.4);
    background: transparent;
    color: white;
}
.newsletter-inner .fr-mailchimp-form-compact input[type="email"]::placeholder {
    color: rgba(255,255,255,.72);
}
.newsletter-inner .fr-mailchimp-form-compact button {
    min-height: 48px;
    border: 1px solid #fff;
    background: #fff;
    color: var(--fr-black);
    padding: 0 20px;
    text-transform: uppercase;
    letter-spacing: .12em;
    font-weight: 800;
    font-size: 11px;
}
.newsletter-inner .fr-mailchimp-form-compact .fr-form-warning {
    grid-column: 1 / -1;
    flex-basis: 100%;
    color: var(--fr-black);
}
.newsletter-page-link {
    margin-top: 18px;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: .12em;
}
.newsletter-page-link a {
    color: rgba(255,255,255,.74);
}
.newsletter-page-link a:hover,
.newsletter-page-link a:focus {
    color: #fff;
}
@media (max-width: 900px) {
    .fr-newsletter-hero-grid {
        grid-template-columns: 1fr;
    }
    .fr-newsletter-topic-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 640px) {
    .fr-newsletter-hero {
        padding: 46px 0;
    }
    .fr-newsletter-topic-grid {
        grid-template-columns: 1fr;
    }
    .newsletter-inner .fr-mailchimp-form-compact,
    .newsletter-form {
        flex-direction: column;
    }
    .newsletter-inner .fr-mailchimp-form-compact button {
        width: 100%;
    }
}


/* Phase 3.9: Newsletter page full-width layout + Advanced Ads injection guard
   The newsletter landing page is a designed sales/subscribe page, not a narrow article body. */
.fr-page-newsletter,
body:has(.fr-page-newsletter) .site-main {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.fr-page-newsletter .article-content {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    font-size: inherit;
}
.fr-page-newsletter .article-content > * {
    max-width: none !important;
}
.fr-newsletter-page-block {
    width: 100% !important;
    max-width: none !important;
    overflow: clip;
    clear: both;
}
.fr-newsletter-page-block .fr-container,
.fr-newsletter-hero .fr-container,
.fr-newsletter-topics.fr-container {
    width: min(var(--fr-max), calc(100% - 48px));
    max-width: var(--fr-max);
    margin-left: auto;
    margin-right: auto;
}
.fr-newsletter-hero {
    width: 100%;
    max-width: none;
    margin: 0;
    overflow: hidden;
}
.fr-newsletter-hero-grid {
    width: 100%;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 520px);
    justify-content: space-between;
}
.fr-newsletter-hero-copy {
    min-width: 0;
}
.fr-newsletter-card {
    width: 100%;
    max-width: 520px;
    justify-self: end;
}
.fr-newsletter-topics {
    margin-left: auto !important;
    margin-right: auto !important;
}
/* Hide unintended Advanced Ads automatic insertions inside the newsletter landing page. Intentional newsletter sponsor zones should be inserted outside this page block. */
.fr-page-newsletter [id^="kenjo-"],
.fr-page-newsletter [class*="kenjo-"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    min-height: 0 !important;
    max-height: 0 !important;
    width: 0 !important;
    min-width: 0 !important;
    max-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
    border: 0 !important;
}
.fr-page-newsletter .fr-newsletter-hero-copy > *:last-child,
.fr-page-newsletter .fr-newsletter-card > *:last-child {
    margin-bottom: 0;
}
@media (max-width: 1020px) {
    .fr-newsletter-hero-grid {
        grid-template-columns: 1fr;
    }
    .fr-newsletter-card {
        justify-self: start;
        max-width: 680px;
    }
}
@media (max-width: 640px) {
    .fr-newsletter-page-block .fr-container,
    .fr-newsletter-hero .fr-container,
    .fr-newsletter-topics.fr-container {
        width: calc(100% - 28px);
    }
    .fr-newsletter-hero h1 {
        font-size: clamp(42px, 15vw, 68px);
    }
    .fr-newsletter-card {
        max-width: none;
        padding: 24px;
    }
}
.fr-newsletter-card-copy {
    color: var(--fr-charcoal);
    line-height: 1.55;
    margin: 0 0 18px;
}
.fr-newsletter-card .fr-form-warning {
    margin-top: 10px;
}


/* Phase 4.0: definitive newsletter full-width landing page fix
   The newsletter page must break out of narrow article/page containers and center its designed hero. */
.fr-page-newsletter.fr-fullwidth-page,
.site-main > .fr-page-newsletter {
    display: block !important;
    position: relative !important;
    width: 100vw !important;
    max-width: none !important;
    margin-left: calc(50% - 50vw) !important;
    margin-right: calc(50% - 50vw) !important;
    padding: 0 !important;
    background: var(--fr-cream) !important;
    overflow-x: clip !important;
}
.fr-page-newsletter.fr-fullwidth-page .article-content,
.fr-page-newsletter .article-content {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
}
.fr-page-newsletter .fr-newsletter-page-block {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow-x: clip !important;
}
.fr-page-newsletter .fr-newsletter-hero {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.fr-page-newsletter .fr-newsletter-hero-grid,
.fr-page-newsletter .fr-newsletter-topics.fr-container {
    width: min(var(--fr-max), calc(100vw - 64px)) !important;
    max-width: var(--fr-max) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    box-sizing: border-box !important;
}
.fr-page-newsletter .fr-newsletter-hero-grid {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) minmax(360px, 520px) !important;
    gap: clamp(36px, 6vw, 84px) !important;
    align-items: center !important;
}
.fr-page-newsletter .fr-newsletter-card {
    width: 100% !important;
    max-width: 520px !important;
    justify-self: end !important;
    box-sizing: border-box !important;
}
.fr-page-newsletter .fr-newsletter-hero-copy {
    min-width: 0 !important;
    max-width: 820px !important;
}
/* Hide unintended Advanced Ads automatic insertions inside newsletter content. */
.fr-page-newsletter [id^="kenjo-"],
.fr-page-newsletter [class*="kenjo-entity-placement"],
.fr-page-newsletter [class*="kenjo-test-placement"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    max-height: 0 !important;
    width: 0 !important;
    max-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}
@media (max-width: 1020px) {
    .fr-page-newsletter .fr-newsletter-hero-grid {
        grid-template-columns: 1fr !important;
    }
    .fr-page-newsletter .fr-newsletter-card {
        justify-self: start !important;
        max-width: 680px !important;
    }
}
@media (max-width: 640px) {
    .fr-page-newsletter .fr-newsletter-hero-grid,
    .fr-page-newsletter .fr-newsletter-topics.fr-container {
        width: calc(100vw - 28px) !important;
    }
    .fr-page-newsletter .fr-newsletter-card {
        max-width: none !important;
    }
}

/* Phase 4.1: return to original text masthead while keeping the narrow logo bar */
.site-title-text-logo,
.site-branding .site-title {
    display: inline-block;
    font-family: var(--fr-serif);
    color: var(--fr-black);
    text-transform: uppercase;
    text-decoration: none;
    letter-spacing: .045em;
    font-size: clamp(38px, 6.1vw, 72px);
    line-height: .88;
    max-width: 100%;
    white-space: nowrap;
}
.site-title-text-logo:hover,
.site-branding .site-title:hover {
    color: var(--fr-black);
}
.masthead-main {
    padding-top: clamp(12px, 1.5vw, 20px) !important;
    padding-bottom: clamp(8px, 1vw, 14px) !important;
}
.site-branding {
    gap: 2px !important;
}
@media (max-width: 720px) {
    .site-title-text-logo,
    .site-branding .site-title {
        font-size: clamp(32px, 11vw, 54px);
        letter-spacing: .032em;
        white-space: normal;
    }
}


/* Phase 4.2: Launch cleanup + controlled ad-zone hardening */
.utility-actions-clean {
    gap: 12px;
}
.utility-actions-clean .utility-link,
.utility-actions-clean .utility-subscribe,
.utility-actions-clean .search-toggle {
    white-space: nowrap;
}
.fr-suppress-auto-ads [id^="kenjo-"],
.fr-suppress-auto-ads [class*="kenjo-entity-placement"],
.fr-suppress-auto-ads [class*="kenjo-test-placement"],
.fr-suppress-auto-ads [class*="advanced-ads"],
.fr-suppress-auto-ads [class*="advads"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    max-height: 0 !important;
    min-height: 0 !important;
    width: 0 !important;
    max-width: 0 !important;
    min-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    border: 0 !important;
    overflow: hidden !important;
}
.fr-ad-zone [id^="kenjo-"],
.fr-ad-zone [class*="kenjo-entity-placement"],
.fr-ad-zone [class*="advanced-ads"],
.fr-ad-zone [class*="advads"] {
    display: block !important;
    visibility: visible !important;
    height: auto !important;
    width: auto !important;
    max-width: 100% !important;
    overflow: visible !important;
}
.fr-form-warning {
    border-left: 3px solid #9b0000;
    padding-left: 10px;
}
@media (max-width: 720px) {
    .utility-actions-clean {
        justify-content: flex-end;
        gap: 8px;
    }
}


/* Phase 4.3: About Fashion Reverie page layout guard */
body:has(.fr-page-about) .site-main,
.fr-page-about.fr-fullwidth-page {
    max-width: none !important;
    width: 100% !important;
    margin: 0 !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
}
.fr-page-about [id^="kenjo-"],
.fr-page-about [class*="kenjo-entity-placement"],
.fr-page-about [class*="kenjo-test-placement"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    max-height: 0 !important;
    width: 0 !important;
    max-width: 0 !important;
    margin: 0 !important;
    padding: 0 !important;
    overflow: hidden !important;
}

/* Phase 4.4 Media Kit benefit-card layout fix */
.fr-page-media-kit .fr-media-why {
    grid-template-columns: minmax(0, 0.95fr) minmax(520px, 0.95fr);
    align-items: center;
}
.fr-page-media-kit .fr-media-why .fr-media-benefits {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
    width: 100%;
    min-width: 0;
}
.fr-page-media-kit .fr-media-why .fr-media-benefit {
    display: flex;
    align-items: center;
    min-width: 0;
    min-height: 118px;
    padding: clamp(18px, 2vw, 26px);
    font-size: clamp(11px, 0.86vw, 13px);
    line-height: 1.38;
    letter-spacing: 0.075em;
    overflow-wrap: normal;
    word-break: normal;
    hyphens: none;
}
.fr-page-media-kit .fr-media-why .fr-media-section-heading h2 {
    max-width: 640px;
    overflow-wrap: normal;
    word-break: normal;
}
.fr-page-media-kit .fr-media-why .fr-media-copy {
    max-width: 620px;
}
@media (max-width: 1180px) {
    .fr-page-media-kit .fr-media-why {
        grid-template-columns: 1fr;
        align-items: start;
    }
    .fr-page-media-kit .fr-media-why .fr-media-benefits {
        grid-template-columns: repeat(4, minmax(0, 1fr));
    }
    .fr-page-media-kit .fr-media-why .fr-media-benefit {
        min-height: 110px;
        font-size: 11px;
    }
}
@media (max-width: 900px) {
    .fr-page-media-kit .fr-media-why .fr-media-benefits {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}
@media (max-width: 540px) {
    .fr-page-media-kit .fr-media-why .fr-media-benefits {
        grid-template-columns: 1fr;
    }
    .fr-page-media-kit .fr-media-why .fr-media-benefit {
        min-height: 0;
        padding: 18px;
    }
}



/* Phase 4.5 Media Kit contrast/readability cleanup */
.fr-page-media-kit .fr-media-hero-actions a.fr-button,
.fr-page-media-kit .fr-media-hero-actions a.fr-button:visited {
    color: #fff8ef !important;
    text-decoration: none !important;
    text-underline-offset: 0 !important;
}
.fr-page-media-kit .fr-media-hero-actions a.fr-button:not(.outline) {
    background: #050505 !important;
    border-color: #050505 !important;
    color: #fff8ef !important;
}
.fr-page-media-kit .fr-media-hero-actions a.fr-button:not(.outline):hover,
.fr-page-media-kit .fr-media-hero-actions a.fr-button:not(.outline):focus {
    background: #fff8ef !important;
    border-color: #fff8ef !important;
    color: #170606 !important;
}
.fr-page-media-kit .fr-media-hero-actions a.fr-button.outline {
    background: transparent !important;
    border-color: rgba(255,248,239,.78) !important;
    color: #fff8ef !important;
}
.fr-page-media-kit .fr-media-hero-actions a.fr-button.outline:hover,
.fr-page-media-kit .fr-media-hero-actions a.fr-button.outline:focus {
    background: #fff8ef !important;
    border-color: #fff8ef !important;
    color: #170606 !important;
}
.fr-page-media-kit .fr-media-request-section {
    background: #130b0b !important;
    color: #fff8ef !important;
}
.fr-page-media-kit .fr-media-request-section .fr-kicker {
    color: #f2c9a0 !important;
}
.fr-page-media-kit .fr-media-request-section h2,
.fr-page-media-kit .fr-media-request-section h3 {
    color: #fff8ef !important;
}
.fr-page-media-kit .fr-media-request-section .fr-media-copy,
.fr-page-media-kit .fr-media-request-section p,
.fr-page-media-kit .fr-media-request-section .fr-media-contact-note {
    color: rgba(255,248,239,.88) !important;
}
.fr-page-media-kit .fr-media-request-section .fr-media-copy {
    font-size: 19px;
    line-height: 1.62;
}
.fr-page-media-kit .fr-media-payment-note {
    background: rgba(255,248,239,.10) !important;
    border: 1px solid rgba(255,248,239,.32) !important;
    box-shadow: none !important;
}
.fr-page-media-kit .fr-media-payment-note .fr-media-copy,
.fr-page-media-kit .fr-media-payment-note p {
    color: rgba(255,248,239,.84) !important;
}
.fr-page-media-kit .fr-media-contact-note a,
.fr-page-media-kit .fr-media-contact-note a:visited {
    color: #fff8ef !important;
    text-decoration-color: rgba(255,248,239,.72) !important;
    text-underline-offset: 4px;
}
.fr-page-media-kit .fr-media-contact-note a:hover,
.fr-page-media-kit .fr-media-contact-note a:focus {
    color: #f2c9a0 !important;
}
.fr-page-media-kit .fr-media-request-section .fr-media-request-form,
.fr-page-media-kit .fr-media-request-section .fr-media-request-form *:not(button):not(.fr-button) {
    color: var(--fr-ink) !important;
}
.fr-page-media-kit .fr-media-request-section .fr-media-request-form a {
    color: var(--fr-red) !important;
}
@media (max-width: 760px) {
    .fr-page-media-kit .fr-media-hero-actions {
        gap: 10px;
    }
    .fr-page-media-kit .fr-media-request-section .fr-media-copy {
        font-size: 17px;
    }
}

/* Phase 4.6 Reader Comments + Social Article Tools */
.fr-share-polished {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 10px;
    padding: 18px 0;
    border-top: 1px solid rgba(0,0,0,.12);
    border-bottom: 1px solid rgba(0,0,0,.12);
    margin: 30px 0;
}
.fr-share-polished .fr-share-label {
    font-family: var(--fr-sans, Arial, Helvetica, sans-serif);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: var(--fr-red, #9b0000);
    margin-right: 6px;
}
.fr-share-polished a,
.fr-share-polished button {
    appearance: none;
    border: 1px solid rgba(0,0,0,.20);
    background: #fffaf4;
    color: var(--fr-ink, #111);
    cursor: pointer;
    display: inline-flex;
    align-items: center;
    min-height: 34px;
    padding: 8px 11px;
    font-family: var(--fr-sans, Arial, Helvetica, sans-serif);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .13em;
    text-transform: uppercase;
    text-decoration: none;
    line-height: 1;
}
.fr-share-polished a:hover,
.fr-share-polished a:focus,
.fr-share-polished button:hover,
.fr-share-polished button:focus,
.fr-share-polished .fr-comment-jump {
    background: #050505;
    color: #fff8ef;
    border-color: #050505;
}
.fr-reader-discussion {
    margin-top: 60px;
    padding-top: 32px;
    border-top: 1px solid rgba(0,0,0,.16);
    clear: both;
}
.fr-container-narrow {
    max-width: 920px;
}
.fr-reader-discussion-gate {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 24px;
    align-items: center;
    margin-bottom: 28px;
}
.fr-reader-discussion-gate h2 {
    font-size: clamp(34px, 4vw, 58px);
    line-height: 1;
    letter-spacing: -.04em;
    font-weight: 400;
    margin: 0;
}
.fr-comments-panel {
    background: #fffaf4;
    border: 1px solid rgba(0,0,0,.14);
    padding: clamp(24px, 4vw, 44px);
}
.fr-comments-panel-header {
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 24px;
    align-items: start;
    padding-bottom: 24px;
    border-bottom: 1px solid rgba(0,0,0,.12);
}
.fr-comments-panel-header h2 {
    font-size: clamp(28px, 3.4vw, 48px);
    line-height: 1;
    letter-spacing: -.035em;
    font-weight: 400;
    margin: 0 0 10px;
}
.fr-comments-panel-header p {
    max-width: 620px;
    margin: 0;
    font-size: 17px;
    line-height: 1.55;
}
.fr-comments-guidelines-link {
    color: #fff8ef;
    background: #050505;
    border: 1px solid #050505;
    padding: 12px 16px;
    font-family: var(--fr-sans, Arial, Helvetica, sans-serif);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    text-decoration: none;
}
.fr-comments-guidelines {
    background: #f7f2ec;
    border-left: 3px solid var(--fr-red, #9b0000);
    margin: 26px 0 30px;
    padding: 20px 22px;
}
.fr-comments-guidelines h3 {
    margin: 0 0 8px;
    font-family: var(--fr-sans, Arial, Helvetica, sans-serif);
    font-size: 12px;
    letter-spacing: .16em;
    text-transform: uppercase;
}
.fr-comments-guidelines p,
.fr-comments-empty p,
.fr-comments-closed {
    margin: 0;
    font-size: 16px;
    line-height: 1.6;
}
.fr-comment-list {
    list-style: none;
    margin: 0;
    padding: 0;
    display: grid;
    gap: 18px;
}
.fr-comment-list .children {
    list-style: none;
    margin: 18px 0 0 34px;
    padding: 0;
    display: grid;
    gap: 18px;
}
.fr-comment-card {
    margin: 0;
}
.fr-comment-body {
    background: #fff;
    border: 1px solid rgba(0,0,0,.12);
    padding: 22px;
}
.fr-comment-header {
    display: flex;
    justify-content: space-between;
    gap: 18px;
    align-items: flex-start;
    margin-bottom: 14px;
}
.fr-comment-author {
    display: block;
    font-size: 18px;
    line-height: 1.2;
}
.fr-comment-header time,
.fr-comment-footer a {
    font-family: var(--fr-sans, Arial, Helvetica, sans-serif);
    font-size: 10px;
    font-weight: 800;
    letter-spacing: .13em;
    text-transform: uppercase;
    color: rgba(0,0,0,.56);
    text-decoration: none;
}
.fr-comment-badges {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: flex-end;
}
.fr-comment-badges span {
    background: #130000;
    color: #fff8ef;
    padding: 6px 8px;
    font-family: var(--fr-sans, Arial, Helvetica, sans-serif);
    font-size: 9px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
}
.fr-comment-staff-reply > .fr-comment-body,
.fr-comment-editors-pick > .fr-comment-body {
    border-color: rgba(155,0,0,.45);
    box-shadow: 0 18px 36px rgba(0,0,0,.06);
}
.fr-comment-text {
    font-size: 17px;
    line-height: 1.62;
}
.fr-comment-text p:last-child {
    margin-bottom: 0;
}
.fr-comment-awaiting {
    color: #9b0000;
    font-family: var(--fr-sans, Arial, Helvetica, sans-serif);
    font-size: 12px;
    font-weight: 700;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.fr-comment-footer {
    display: flex;
    gap: 14px;
    margin-top: 16px;
}
.fr-comment-form-wrap {
    margin-top: 34px;
    padding-top: 26px;
    border-top: 1px solid rgba(0,0,0,.14);
}
.fr-comment-form-wrap .comment-reply-title {
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1;
    letter-spacing: -.035em;
    font-weight: 400;
    margin: 0 0 10px;
}
.fr-comment-form-wrap label {
    display: block;
    font-family: var(--fr-sans, Arial, Helvetica, sans-serif);
    font-size: 11px;
    font-weight: 800;
    letter-spacing: .14em;
    text-transform: uppercase;
    margin: 0 0 8px;
}
.fr-comment-form-wrap input[type="text"],
.fr-comment-form-wrap input[type="email"],
.fr-comment-form-wrap input[type="url"],
.fr-comment-form-wrap textarea {
    width: 100%;
    border: 1px solid rgba(0,0,0,.20);
    background: #fff;
    color: #111;
    padding: 13px 14px;
    font: inherit;
    box-sizing: border-box;
}
.fr-comment-form-wrap .comment-form-author,
.fr-comment-form-wrap .comment-form-email,
.fr-comment-form-wrap .comment-form-url {
    display: grid;
    grid-template-columns: 1fr;
}
.fr-comment-form-wrap .form-submit {
    margin-bottom: 0;
}
.fr-comment-form-wrap .logged-in-as,
.fr-comment-form-wrap .comment-notes {
    font-size: 14px;
    line-height: 1.5;
    color: rgba(0,0,0,.68);
}
.comment-navigation {
    margin: 24px 0;
}
@media (max-width: 760px) {
    .fr-reader-discussion-gate,
    .fr-comments-panel-header {
        grid-template-columns: 1fr;
    }
    .fr-comments-guidelines-link,
    .fr-reader-discussion-gate .fr-button {
        width: fit-content;
    }
    .fr-comment-list .children {
        margin-left: 16px;
    }
    .fr-comment-header {
        display: grid;
    }
    .fr-comment-badges {
        justify-content: flex-start;
    }
}


/* Phase 4.7 Social logo icons in top utility and footer */
.fr-social-icons {
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.fr-social-icons a,
.fr-social-icons .fr-social-placeholder {
    width: 28px;
    height: 28px;
    border: 1px solid currentColor;
    border-radius: 999px;
    display: inline-grid;
    place-items: center;
    color: inherit;
    opacity: .9;
    transition: background .18s ease, border-color .18s ease, color .18s ease, opacity .18s ease, transform .18s ease;
}
.fr-social-icons a:hover,
.fr-social-icons a:focus {
    background: var(--fr-red);
    border-color: var(--fr-red);
    color: var(--fr-white);
    opacity: 1;
    transform: translateY(-1px);
}
.fr-social-icons .fr-social-placeholder {
    opacity: .35;
    cursor: default;
}
.fr-social-mark {
    width: 15px;
    height: 15px;
    display: inline-grid;
    place-items: center;
    line-height: 0;
}
.fr-social-mark svg {
    width: 15px;
    height: 15px;
    display: block;
}
.fr-social-mark svg :is(path, rect, circle) {
    fill: currentColor;
    stroke: none;
}
.fr-social-mark svg .fr-social-cutout {
    fill: var(--fr-black);
}
.fr-social-icons a:hover .fr-social-cutout,
.fr-social-icons a:focus .fr-social-cutout {
    fill: var(--fr-red);
}
.utility-actions-clean .utility-social-icons {
    margin-right: 8px;
    padding-right: 10px;
    border-right: 1px solid rgba(255,255,255,.24);
}
.top-social-icons a,
.top-social-icons .fr-social-placeholder {
    width: 24px;
    height: 24px;
    border-color: rgba(255,255,255,.52);
    color: #fff8ef;
}
.top-social-icons .fr-social-mark,
.top-social-icons .fr-social-mark svg {
    width: 13px;
    height: 13px;
}
.footer-social-icons {
    gap: 9px;
}
.footer-social-icons a {
    width: 30px;
    height: 30px;
}
@media (max-width: 720px) {
    .utility-actions-clean .utility-social-icons {
        display: inline-flex;
        order: -1;
        flex-basis: 100%;
        justify-content: center;
        margin: 2px 0 0;
        padding-right: 0;
        border-right: 0;
    }
    .utility-actions-clean {
        justify-content: center;
        padding: 8px 0;
    }
    .top-social-icons a,
    .top-social-icons .fr-social-placeholder {
        width: 25px;
        height: 25px;
    }
}

/* Phase 4.8 launch cleanup: consistent utility bar, legal/sitemap readability, and comments visibility. */
.utility-actions-clean .utility-social-icons,
.top-social-icons {
    display: none !important;
}
.utility-actions-clean {
    gap: 14px;
}
.fr-page-privacy.fr-legal-page {
    padding-top: clamp(46px, 6vw, 76px);
    padding-bottom: clamp(56px, 7vw, 90px);
}
.fr-legal-content {
    width: min(860px, 100%);
    margin: 0 auto;
    font-size: 18px;
    line-height: 1.72;
}
.fr-legal-content > h1:first-child,
.fr-legal-content > .wp-block-heading:first-child:is(h1) {
    display: none;
}
.fr-legal-content h2 {
    margin-top: 42px;
    font-size: clamp(28px, 3vw, 42px);
    line-height: 1.08;
    letter-spacing: -.035em;
}
.fr-legal-content h3 {
    margin-top: 28px;
    font-size: 20px;
}
.fr-legal-content ul {
    padding-left: 1.2em;
}
.fr-page-sitemap.fr-fullwidth-page {
    width: 100%;
    max-width: none;
    padding: 0;
}
.fr-sitemap {
    width: min(1180px, calc(100% - 40px));
    margin: 0 auto;
    padding: clamp(50px, 7vw, 86px) 0;
}
.fr-sitemap-header {
    margin: 0 0 36px;
    padding-bottom: 30px;
    border-bottom: 1px solid rgba(0,0,0,.14);
}
.fr-sitemap-header h1 {
    margin: 0 0 14px;
    font-size: clamp(46px, 7vw, 92px);
    line-height: .95;
    letter-spacing: -.05em;
    font-weight: 400;
}
.fr-sitemap-header p:last-child {
    max-width: 760px;
    font-size: 18px;
    line-height: 1.55;
}
.fr-sitemap-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 28px;
}
.fr-sitemap-section {
    background: #fffaf4;
    border: 1px solid rgba(0,0,0,.12);
    padding: 28px;
}
.fr-sitemap-section h2 {
    margin: 0 0 18px;
    font-size: 24px;
    line-height: 1.1;
}
.fr-sitemap-section ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.fr-sitemap-section li + li {
    margin-top: 10px;
}
.fr-sitemap-section a {
    color: inherit;
    text-decoration: none;
    border-bottom: 1px solid rgba(155,0,0,.28);
}
.fr-reader-discussion {
    display: block;
    clear: both;
    margin-top: clamp(44px, 6vw, 74px);
}
@media (max-width: 760px) {
    .fr-sitemap-grid {
        grid-template-columns: 1fr;
    }
    .fr-sitemap {
        width: min(100% - 28px, 680px);
    }
}
