/* Newsletter archive — self-hosted fonts (paths relative to includes/assets/) */
@font-face {
    font-family: 'Cinzel';
    src: url('fonts/Cinzel/Cinzel-VariableFont_wght.ttf') format('truetype');
    font-weight: 400 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('fonts/Inter/Inter-VariableFont_opsz,wght.ttf') format('truetype');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Inter';
    src: url('fonts/Inter/Inter-Italic-VariableFont_opsz,wght.ttf') format('truetype');
    font-weight: 100 900;
    font-style: italic;
    font-display: swap;
}

@font-face {
    font-family: 'DM Sans';
    src: url('fonts/DM_Sans/DMSans-VariableFont_opsz,wght.ttf') format('truetype');
    font-weight: 100 900;
    font-style: normal;
    font-display: swap;
}

@font-face {
    font-family: 'DM Sans';
    src: url('fonts/DM_Sans/DMSans-Italic-VariableFont_opsz,wght.ttf') format('truetype');
    font-weight: 100 900;
    font-style: italic;
    font-display: swap;
}

/* Cormorant Garamond — roman + italic (variable files, self-hosted) */
@font-face {
    font-family: 'Cormorant Garamond';
    src: url('fonts/Cormorant_Garamond/CormorantGaramond-VariableFont_wght.ttf') format('truetype');
    font-weight: 300 700;
    font-style: normal;
    font-display: swap;
}

/* Tagline: Insights on Products & … (italic) */
@font-face {
    font-family: 'Cormorant Garamond';
    src: url('fonts/Cormorant_Garamond/CormorantGaramond-Italic-VariableFont_wght.ttf') format('truetype');
    font-weight: 300 700;
    font-style: italic;
    font-display: swap;
}

body.newsletter-archive-page {
    margin: 0;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: 1rem;
    background: #F1F1F1;
    color: #2b2b2b;
    overflow-x: hidden;
    /* Rem-based type scale (no vw) — override in media queries only */
    --archive-fs-insights-date: 1.35rem;
    --archive-fs-insights-gtt: 2.55rem;
    --archive-fs-insights-sights: 2.55rem;
    --archive-fs-banner-h1: 2.375rem;
    --archive-fs-card-grid-kicker: 1.0625rem;
    --archive-fs-card-title: 1.25rem;
    --archive-fs-year-kickerline: 1.55rem;
    --archive-fs-detail-kicker: 1.25rem;
    /* Title steps above body so 18px body does not match the headline weight. */
    --archive-fs-detail-title: 1.1rem;
    --archive-fs-content-heading: 1.35rem;
    /* Main site (Elementor) body copy ≈ 18px / line-height ≈ 24px */
    --archive-fs-body: 1rem;
    --archive-fs-body-line: 1.334;
    --archive-fs-body-sm: 0.875rem;
    --archive-fs-body-xs: 0.8125rem;
    --archive-fs-caption: 0.75rem;
    /* Menu bar height. Cover strip = bar + one extra full bar (2×) — more image below the dimmed row. */
    /* Logo asset (GTT_Logo_59.png) is designed at 59px height — keep that; do not scale down in CSS. */
    --archive-header-logo-h: 59px;
    --archive-header-bar-h: 69px;
    --archive-header-hero-total: calc(var(--archive-header-bar-h) * 2);
    /* Match archive shell horizontal padding and max width. */
    --archive-header-pad-x: 28px;
    /* Main column + header (aligns with BS4 .container lg+ at 1140px). Nav `right:` must use this same token. */
    --archive-layout-max: 1140px;
}

body.newsletter-archive-page .newsletter-archive-main,
body.newsletter-archive-page .newsletter-archive-footer {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
}

/* Toolbar + GTT INSIGHTS card stick together as one unit. */
.newsletter-archive-insights-sticky {
    position: sticky;
    top: 0;
    z-index: 50;
    width: 100%;
    box-sizing: border-box;
    background: #f1f1f1;
}

.newsletter-archive-sticky-toolbar {
    width: 100%;
    margin: 0 0 14px;
    padding: 10px 0 12px;
    box-sizing: border-box;
    background: transparent;
}

.newsletter-archive-sticky-toolbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px 20px;
    flex-wrap: wrap;
    width: 100%;
    box-sizing: border-box;
}

.newsletter-archive-toolbar-left {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px 10px;
    min-width: 0;
    flex: 1 1 auto;
    text-decoration: none;
}

.newsletter-archive-toolbar-sep {
    color: rgba(55, 45, 35, 0.35);
    font-weight: 700;
    user-select: none;
    padding: 0 2px;
}

a.newsletter-archive-toolbar-link {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 1.25;
    letter-spacing: 0.03em;
    color: #972626;
    text-decoration: none;
    /* border-bottom: 1px solid rgba(151, 38, 38, 0.35); */
    padding-bottom: 1px;
    transition: color 0.15s ease, border-color 0.15s ease;
}

a.newsletter-archive-toolbar-link:hover {
    color: #5c1414;
    text-decoration: none;
    border-bottom-color: rgba(92, 20, 20, 0.55);
}

a.newsletter-archive-toolbar-link--gtt {
    display: inline-flex;
    align-items: center;
    gap: 0.35em;
}

.newsletter-archive-toolbar-link-icon {
    font-size: 0.72em;
    opacity: 0.9;
}

.newsletter-archive-toolbar-right {
    flex: 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: flex-end;
    margin-left: auto;
}

.newsletter-archive-edition-wrap {
    position: relative;
    outline: none;
}

.newsletter-archive-edition-trigger {
    display: inline-flex;
    align-items: center;
    gap: 0.35em 0.5em;
    margin: 0;
    padding: 6px 4px 6px 8px;
    border: 0;
    background: transparent;
    cursor: pointer;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.04em;
    color: #972626;
    text-align: right;
    transition: color 0.15s ease, opacity 0.15s ease;
    box-sizing: border-box;
}

.newsletter-archive-edition-trigger:hover,
.newsletter-archive-edition-wrap:hover .newsletter-archive-edition-trigger {
    color: #5c1414;
}

.newsletter-archive-edition-trigger-prefix {
    font-weight: 700;
}

.newsletter-archive-edition-trigger-year {
    font-weight: 800;
}

.newsletter-archive-edition-trigger-chevron {
    font-size: 0.65em;
    opacity: 0.75;
    margin-left: 2px;
    transition: transform 0.2s ease;
}

.newsletter-archive-edition-wrap.is-open .newsletter-archive-edition-trigger-chevron {
    transform: rotate(180deg);
}

/* Edition dropdown panel (anchored under trigger). */
.newsletter-archive-nav {
    position: absolute;
    top: 100%;
    right: 0;
    left: auto;
    z-index: 60;
    display: none;
    width: min(150px, calc(100vw - 2 * var(--archive-header-pad-x, 28px)));
    max-width: min(150px, calc(100vw - 2 * var(--archive-header-pad-x, 28px)));
    box-sizing: border-box;
    max-height: min(72vh, 520px);
    overflow-y: auto;
    overflow-x: hidden;
    -webkit-overflow-scrolling: touch;
    background: #ffffff;
    border: 1px solid #c2bcb4;
    border-top: 4px solid #d77a28;
    border-radius: 0;
    box-shadow: none;
}

.newsletter-archive-edition-wrap:focus-within .newsletter-archive-nav,
.newsletter-archive-edition-wrap.is-open .newsletter-archive-nav {
    display: block;
}

@media (hover: hover) and (pointer: fine) {
    .newsletter-archive-edition-wrap:hover .newsletter-archive-nav {
        display: block;
    }
}

.newsletter-archive-nav-list {
    display: block;
    padding: 10px 0 16px;
}

.newsletter-archive-nav-list > .newsletter-archive-nav-item + .newsletter-archive-nav-item {
    border-top: 1px solid #ece8e2;
}

.newsletter-archive-nav-item {
    position: relative;
}

.newsletter-archive-nav-static-title {
    display: flex;
    align-items: center;
    box-sizing: border-box;
    width: 100%;
    margin: 0;
    padding: 16px;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 1.25;
    color: #4a4a4a;
    cursor: default;
    user-select: none;
}

.newsletter-archive-nav-link--back-archive {
    font-weight: 700;
}

.newsletter-archive-nav-link {
    display: flex;
    align-items: center;
    min-height: 0;
    width: 100%;
    box-sizing: border-box;
    justify-content: space-between;
    padding: 16px;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: 0.9375rem;
    font-weight: 600;
    line-height: 1.25;
    color: #4a4a4a;
    text-decoration: none;
    transition: color 0.2s ease, background 0.15s ease;
}

.newsletter-archive-nav-item.is-active > .newsletter-archive-nav-link,
.newsletter-archive-nav-link:hover {
    color: #232323;
    text-decoration: none;
    background: #faf8f4;
}

.newsletter-archive-nav-item-dropdown > .newsletter-archive-nav-link::after {
    content: '';
    display: inline-block;
    width: 8px;
    height: 8px;
    margin-left: 10px;
    border-right: 2px solid currentColor;
    border-bottom: 2px solid currentColor;
    flex-shrink: 0;
    transform: rotate(45deg) translateY(-2px);
}

.newsletter-archive-dropdown {
    position: static;
    min-width: 0;
    max-width: none;
    max-height: none;
    opacity: 1;
    visibility: visible;
    transform: none;
    box-shadow: none;
    border: 0;
    border-top: 1px solid #ece8e2;
    background: #fbf9f6;
    display: none;
}

.newsletter-archive-nav-item-dropdown:hover .newsletter-archive-dropdown,
.newsletter-archive-nav-item-dropdown:focus-within .newsletter-archive-dropdown,
.newsletter-archive-nav-item-dropdown.is-active .newsletter-archive-dropdown,
.newsletter-archive-edition-wrap.is-open .newsletter-archive-dropdown {
    display: block;
}

.newsletter-archive-dropdown-link {
    display: block;
    padding: 12px 14px;
    border-bottom: 1px solid #efefef;
    color: #555555;
    text-decoration: none;
}

.newsletter-archive-dropdown-link:hover,
.newsletter-archive-dropdown-link.is-active {
    background: #faf6f1;
    color: #222222;
    text-decoration: none;
}

.newsletter-archive-dropdown-label {
    display: block;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body-sm);
    font-weight: 600;
    line-height: 1.35;
    color: #555555;
    margin-bottom: 0;
}

.newsletter-archive-main {
    min-height: 100vh;
    /* Default reading weight (main site GT Light ~200); headings/links keep explicit weights */
    font-weight: 300;
}

.newsletter-archive-shell {
    width: 100%;
    max-width: var(--archive-layout-max);
    margin: 0 auto;
    padding: 42px var(--archive-header-pad-x) 56px;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
}

/* GTT INSIGHTS block (aligned with newsletter email template). */
.newsletter-archive-insights-combo {
    width: 100%;
    margin: 0 0 28px;
    box-sizing: border-box;
}

/* index.php: tall parent so sticky toolbar + card stay pinned while year grids scroll. */
.newsletter-archive-insights-combo--index {
    margin: 0 0 28px;
}

.newsletter-archive-insights-combo--index .newsletter-archive-insights-sticky {
    margin-bottom: 22px;
}

/* Scroll: bottom-weighted shadow on the white card (index reference look). */
.newsletter-archive-insights-sticky.is-scrolled .newsletter-archive-insights-card {
    box-shadow: 0 14px 22px -12px rgba(53, 45, 34, 0.17);
}

/* detail: stronger lift so shadow reads like index (hero below absorbs light shadow). */
.newsletter-archive-insights-combo--detail .newsletter-archive-insights-sticky.is-scrolled .newsletter-archive-insights-card {
    box-shadow:
        0 16px 28px -12px rgba(53, 45, 34, 0.22),
        0 8px 14px -10px rgba(53, 45, 34, 0.1);
}

/* First / hero image — below GTT INSIGHTS card, before article (Product Update). */
.newsletter-archive-detail-hero {
    position: relative;
    width: 100%;
    margin: 16px 0 20px;
    border-radius: 20px;
    overflow: hidden;
    background: #1f0f0d;
    /* Fixed visual height band (tune here); image fills with object-fit: cover. */
    aspect-ratio: 16 / 9;
    min-height: 160px;
    max-height: 320px;
    box-shadow: 0 10px 22px rgba(30, 18, 10, 0.12);
}

.newsletter-archive-detail-hero img.newsletter-archive-detail-hero-img {
    position: absolute;
    top: 0;
    left: 0;
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center;
}

.newsletter-archive-detail-hero--empty {
    min-height: 220px;
    max-height: 420px;
    aspect-ratio: 16 / 9;
}

.newsletter-archive-detail-hero-placeholder {
    position: absolute;
    inset: 0;
    background: linear-gradient(150deg, #2d1a1a 0%, #120808 100%);
}

.newsletter-archive-insights-edition {
    font-family: 'Inter', system-ui, sans-serif;
    font-size: 0.9375rem;
    font-weight: 700;
    line-height: 1.2;
    letter-spacing: 0.04em;
    color: #972626;
}

.newsletter-archive-insights-card {
    position: relative;
    width: 100%;
    background: #ffffff;
    border-radius: 20px;
    padding: 28px 32px 30px;
    box-sizing: border-box;
    border: 1px solid rgba(55, 45, 35, 0.08);
    box-shadow: none;
    transition: box-shadow 0.22s ease;
}

/* detail.php: white GTT card — text left, nl_date_text (e.g. “JULY 2026”) on the right, stacked. */
.newsletter-archive-insights-combo--detail .newsletter-archive-insights-card {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px 28px;
    flex-wrap: wrap;
}

.newsletter-archive-insights-combo--detail .newsletter-archive-insights-card-body {
    flex: 1 1 220px;
    min-width: 0;
}

.newsletter-archive-insights-date-rail {
    flex: 0 0 auto;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    justify-content: flex-start;
    text-align: right;
    max-width: 8.5rem;
    padding: 0 0 0 8px;
    box-sizing: border-box;
}

.newsletter-archive-insights-date-line {
    display: block;
    font-family: 'Cinzel', 'Times New Roman', Times, serif;
    font-size: var(--archive-fs-insights-date);
    font-weight: 500;
    line-height: 1.12;
    color: #d46018;
    letter-spacing: 0.04em;
}

@media (max-width: 575px) {
    .newsletter-archive-insights-combo--detail .newsletter-archive-insights-date-rail {
        width: 100%;
        max-width: none;
        flex-direction: row;
        flex-wrap: wrap;
        align-items: baseline;
        justify-content: flex-end;
        gap: 0.35em 0.5em;
        padding: 10px 0 0;
    }

    .newsletter-archive-insights-combo--detail .newsletter-archive-insights-date-line {
        display: inline;
    }
}

.newsletter-archive-insights-heading {
    margin: 0;
    padding: 0;
    font-size: inherit;
    font-weight: inherit;
    line-height: normal;
    border: 0;
}

.newsletter-archive-insights-gtt {
    font-family: 'Cinzel', 'Times New Roman', Times, serif;
    font-size: var(--archive-fs-insights-gtt);
    font-weight: 500;
    line-height: 0.9;
    color: #972626;
    margin: 0;
    padding: 0;
}

.newsletter-archive-insights-sightsline {
    margin: 4px 0 0;
    font-family: 'Cinzel', 'Times New Roman', Times, serif;
    font-size: var(--archive-fs-insights-sights);
    font-weight: 500;
    line-height: 0.95;
}

.newsletter-archive-insights-in {
    font-style: italic;
    font-weight: 500;
    color: #d46018;
}

.newsletter-archive-insights-sightstext {
    font-style: normal;
    font-weight: 500;
    color: #972626;
    /* Slight gap after “IN” so N and S in INSIGHTS don’t meet (see kerning for IN|SIGHTS). */
    margin-left: 0.07em;
}

.newsletter-archive-insights-tagline {
    margin: 10px 0 0;
    /* max-width: 28em; */
    font-family: 'Cormorant Garamond', Georgia, 'Times New Roman', Times, serif;
    font-size: 1.585rem;
    font-weight: 500;
    line-height: 1.35;
    font-style: italic;
    color: #3e3523;
}

.newsletter-archive-hero,
.newsletter-archive-latest,
.newsletter-archive-year-section,
.newsletter-archive-article,
.newsletter-archive-state {
    background: #ffffff;
    border-radius: 18px;
    box-shadow: 0 16px 32px rgba(53, 45, 34, 0.08);
}

.newsletter-archive-hero {
    padding: 34px;
    margin-bottom: 28px;
}

.newsletter-archive-banner {
    position: relative;
    isolation: isolate;
    width: 100%;
    min-height: 180px;
    margin-bottom: 28px;
    border-radius: 18px;
    overflow: hidden;
    display: flex;
    align-items: center;
    justify-content: center;
    background:
        linear-gradient(rgba(90, 90, 90, 0.32), rgba(90, 90, 90, 0.32)),
        linear-gradient(135deg, #d4d4d4 0%, #bcbcbc 45%, #a3a3a3 100%);
    box-shadow: 0 16px 32px rgba(53, 45, 34, 0.08);
}

.newsletter-archive-banner::before,
.newsletter-archive-banner::after {
    content: '';
    position: absolute;
    z-index: 0;
    width: clamp(50px, 10vw, 100px);
    height: clamp(50px, 10vw, 100px);
    pointer-events: none;
    background-image: url('images/Table%20Sign%20Stand.png');
    background-repeat: no-repeat;
    background-position: center;
    background-size: contain;
    opacity: 0.68;
    filter: brightness(1.85) contrast(1.12) drop-shadow(0 0 9px rgba(255, 255, 255, 0.45));
}

.newsletter-archive-banner::before {
    top: 10px;
    right: 12px;
}

.newsletter-archive-banner::after {
    bottom: 8px;
    left: 10px;
}

.newsletter-archive-banner-content {
    position: relative;
    z-index: 1;
    text-align: center;
    color: #ffffff;
    padding: 28px 24px;
}

.newsletter-archive-banner-content h1 {
    margin: 0;
    font-family: 'Cinzel', 'Times New Roman', serif;
    font-size: var(--archive-fs-banner-h1);
    font-weight: 400;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    line-height: 1.08;
    color: #ffffff;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.35);
}

.newsletter-archive-banner-content p {
    margin: 14px 0 0;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body-xs);
    font-weight: 500;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    line-height: 1.45;
    text-shadow: 0 1px 4px rgba(0, 0, 0, 0.28);
}

.newsletter-archive-eyebrow {
    margin-bottom: 12px;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-caption);
    font-weight: 600;
    letter-spacing: 1.2px;
    text-transform: uppercase;
    color: #9d5926;
}

.newsletter-archive-page-title {
    margin: 0 0 14px;
    font-family: 'Cinzel', 'Times New Roman', serif;
    font-size: 2.125rem;
    font-weight: 400;
    line-height: 1.2;
    color: #d46018;
}

.newsletter-archive-page-copy {
    max-width: 780px;
    margin: 0;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body);
    line-height: var(--archive-fs-body-line);
    color: #656565;
}

.newsletter-archive-latest {
    padding: 28px;
    margin-bottom: 28px;
}

.newsletter-archive-section-head,
.newsletter-archive-year-head,
.newsletter-archive-article-head {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    gap: 18px;
    margin-bottom: 20px;
}

.newsletter-archive-section-head h2,
.newsletter-archive-year-head h2,
.newsletter-archive-article-head h1 {
    margin: 0;
    font-family: 'Cinzel', 'Times New Roman', serif;
    font-size: 1.75rem;
    font-weight: 400;
    line-height: 1.25;
    color: #d46018;
}

.newsletter-archive-section-head p,
.newsletter-archive-year-head p,
.newsletter-archive-article-head p {
    margin: 6px 0 0;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    color: #727272;
}

.newsletter-archive-card-grid {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 24px;
}

.newsletter-archive-card {
    display: flex;
    flex-direction: column;
    height: 100%;
    overflow: hidden;
    background: #ffffff;
    border: 1px solid #ece4d8;
    border-radius: 16px;
    box-shadow: 0 12px 24px rgba(53, 45, 34, 0.06);
    transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.newsletter-archive-card:hover {
    transform: translateY(-4px);
    border-color: #dfcfbb;
    box-shadow: 0 18px 32px rgba(53, 45, 34, 0.12);
}

.newsletter-archive-card-media {
    display: block;
    width: 100%;
    aspect-ratio: 16 / 9;
    background: linear-gradient(135deg, #c9b39c 0%, #8b6e59 100%);
    overflow: hidden;
}

.newsletter-archive-card-media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.28s ease;
}

.newsletter-archive-card:hover .newsletter-archive-card-media img {
    transform: scale(1.04);
}

.newsletter-archive-card-body {
    padding: 20px;
    display: flex;
    flex: 1;
    flex-direction: column;
}

.newsletter-archive-card-kicker.newsletter-archive-detail-kicker {
    margin: 0 0 12px;
    font-size: var(--archive-fs-card-grid-kicker);
    gap: 0.14em;
    letter-spacing: 0.06em;
}

.newsletter-archive-card-title {
    margin: 0 0 12px;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-card-title);
    font-weight: 400;
    line-height: 1.4;
}

.newsletter-archive-card-title a {
    color: #111;
    text-decoration: none;
}

.newsletter-archive-card-title a:hover {
    text-decoration: none;
    color: #000;
}

.newsletter-archive-card-copy {
    min-height: 72px;
    margin: 0 0 18px;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body);
    line-height: var(--archive-fs-body-line);
    color: #666666;
    flex: 1;
}

.newsletter-archive-card-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    margin-top: auto;
    padding-top: 16px;
    border-top: 1px solid #f1e7db;
}

.newsletter-archive-card-published {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-caption);
    line-height: 1.5;
    color: #8a7a66;
}

.newsletter-archive-link {
    display: inline-flex;
    align-items: center;
    justify-content: flex-end;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    color: #7d3510;
    font-size: var(--archive-fs-body-sm);
    font-weight: 600;
    white-space: nowrap;
    text-decoration: none;
}

.newsletter-archive-link:hover {
    color: #5f2709;
    text-decoration: none;
}

.newsletter-archive-year-section {
    /* Fixed thumbnail height for all topic cards (tune in one place). */
    --archive-year-topic-thumb-h: 250px;
    padding: 32px;
    margin-bottom: 28px;
    border: 1px solid #eee4d7;
}

.newsletter-archive-year-pagination {
    display: flex;
    justify-content: flex-end;
    margin-top: 22px;
    padding-top: 2px;
}

.newsletter-archive-year-pagination-inner {
    display: inline-flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: flex-end;
    gap: 0.45rem 0.75rem;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: 0.9375rem;
    font-weight: 300;
    letter-spacing: 0.04em;
    color: #3a3a3a;
}

.newsletter-archive-year-pagination-step,
.newsletter-archive-year-pagination-num {
    color: #333333;
    text-decoration: none;
    line-height: 1;
    border: 0;
    background: transparent;
    padding: 0.12rem 0.08rem;
}

.newsletter-archive-year-pagination-step:hover,
.newsletter-archive-year-pagination-num:hover {
    color: #972626;
    text-decoration: none;
}

.newsletter-archive-year-pagination-num.is-current {
    font-weight: 600;
    color: #1a1a1a;
    cursor: default;
}

.newsletter-archive-year-pagination-ellipsis {
    color: #6b6b6b;
    user-select: none;
    padding: 0 0.12rem;
    font-weight: 300;
}

.newsletter-archive-year-anchor {
    display: block;
    height: 0;
    position: relative;
    top: -96px;
    visibility: hidden;
}

.newsletter-archive-year-count {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 84px;
    padding: 10px 14px;
    border-radius: 999px;
    background: #f6efe4;
    color: #8b582a;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body-xs);
    font-weight: 600;
}

/* Year section — topic cards: deep red, square box; rounded thumb; copy + pill CTA (per design mockup). */
.newsletter-archive-year-section .newsletter-archive-card--year-topic {
    position: relative;
    display: flex;
    flex-direction: column;
    background: #972626;
    border: 0;
    border-radius: 0;
    box-shadow: 0 4px 14px rgba(40, 10, 8, 0.28);
    padding: 16px 16px 20px;
    gap: 0;
    overflow: hidden;
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic:hover {
    transform: translateY(-3px);
    box-shadow: 0 10px 24px rgba(30, 8, 6, 0.38);
    border-color: transparent;
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-media {
    position: relative;
    flex: 0 0 auto;
    display: block;
    width: 100%;
    height: var(--archive-year-topic-thumb-h, 250px);
    min-height: var(--archive-year-topic-thumb-h, 250px);
    max-height: var(--archive-year-topic-thumb-h, 250px);
    margin: 0;
    padding: 0;
    background: transparent;
    overflow: hidden;
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-media-frame {
    position: relative;
    display: block;
    width: 100%;
    height: 100%;
    min-height: 0;
    border-radius: 22px;
    overflow: hidden;
    line-height: 0;
    background: #972626;
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-media-frame img {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 100%;
    object-fit: cover;
    object-position: center;
    transform: none;
    transition: transform 0.28s ease;
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic:hover .newsletter-archive-card-media-frame img {
    transform: scale(1.04);
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-media-placeholder {
    display: block;
    width: 100%;
    height: 100%;
    min-height: 0;
    background: linear-gradient(150deg, #3d1a1c 0%, #1f0808 100%);
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-body {
    display: flex;
    flex: 1;
    flex-direction: column;
    margin: 14px 0 0;
    padding: 0;
    gap: 0;
    min-height: 0;
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-kickerline {
    margin: 0 0 10px;
    padding: 0;
    font-family: 'Cormorant Garamond', Georgia, 'Times New Roman', serif;
    font-size: var(--archive-fs-year-kickerline);
    font-weight: 500;
    font-style: normal;
    line-height: 1.35;
    color: #ffffff;
    text-align: left;
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-copy {
    flex: 1;
    min-height: 0;
    margin: 0 0 18px;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-size: var(--archive-fs-body);
    line-height: var(--archive-fs-body-line);
    color: #DBCBB9;
}

.newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-footer--year-topic {
    display: flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    margin-top: auto;
    padding: 0;
    border-top: 0;
    gap: 0;
}

.newsletter-archive-year-section .newsletter-archive-link--year-pill {
    display: inline-block;
    padding: 9px 26px;
    border-radius: 999px;
    background: #d46018;
    color: #111111;
    font-size: var(--archive-fs-body-sm);
    font-style: italic;
    font-weight: 700;
    font-stretch: normal;
    line-height: 1.2;
    text-align: center;
    text-decoration: none;
    white-space: nowrap;
    box-shadow: 0 2px 0 rgba(0, 0, 0, 0.1);
    transition: background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}

.newsletter-archive-year-section .newsletter-archive-link--year-pill:hover {
    background: #b54f14;
    color: #ffffff;
    text-decoration: none;
}

.newsletter-archive-banner-message {
    margin-bottom: 28px;
}

.newsletter-archive-banner-message .alert {
    margin: 0;
    border: 0;
    border-radius: 16px;
    box-shadow: 0 12px 24px rgba(53, 45, 34, 0.08);
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
}

.newsletter-archive-article {
    padding: 30px;
}

.newsletter-archive-back-link {
    display: inline-block;
    margin-bottom: 9px;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body-sm);
    font-weight: 600;
    color: #7d3510;
    text-decoration: none;
}

.newsletter-archive-back-link:hover {
    color: #5f2709;
    text-decoration: underline;
}

.newsletter-archive-article-content {
    display: grid;
    gap: 24px;
}

.newsletter-archive-content-block {
    display: flex;
    flex-direction: column;
    padding: 30px;
    background: #faf8f4;
    border: 1px solid #efe7db;
    border-radius: 16px;
}

.newsletter-archive-content-block-intro {
    text-align: center;
}

.newsletter-archive-detail-kicker {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center;
    gap: 0.16em;
    margin: 0 0 12px;
    font-family: 'Cinzel', 'Times New Roman', serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-detail-kicker);
    font-weight: 500;
    letter-spacing: 0.08em;
    word-spacing: 0;
    text-transform: uppercase;
    line-height: 1.35;
    color: #d46018;
}

.newsletter-archive-detail-kicker-dot {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    flex: 0 0 auto;
    margin: 0;
    line-height: 1;
    color: #d46018;
}

.newsletter-archive-detail-kicker-dot i {
    display: block;
    font-size: 0.3rem;
}

.newsletter-archive-detail-title {
    margin: 0 auto 5px;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-detail-title);
    font-weight: 600;
    line-height: 1.4;
    color: #4B4B4B;
}

.newsletter-archive-detail-intro {
    max-width: 760px;
    margin: 0 auto 0;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body);
    line-height: var(--archive-fs-body-line);
    color: #5d5d5d;
}

.newsletter-archive-content-heading {
    margin-bottom: 45px;
    font-family: 'Montserrat', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-content-heading);
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    text-align: center;
    color: #d46018;
    line-height: 1.4;
}

.newsletter-archive-content-heading-pipe {
    color: #2e2e2e;
}

.newsletter-archive-content-subtitle {
    margin: 0 auto 5px;
    max-width: 860px;
    font-family: 'Inter', system-ui, sans-serif;
    font-size: var(--archive-fs-detail-title);
    font-weight: 600;
    line-height: 1.4;
    text-align: center;
    color: #4B4B4B;
}

.newsletter-archive-content-subtitle + .newsletter-archive-richtext > :first-child {
    margin-top: 0;
}

.newsletter-archive-richtext {
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body);
    line-height: var(--archive-fs-body-line);
    color: #5D5D5D;
}

.newsletter-archive-richtext strong,
.newsletter-archive-richtext b {
    font-weight: 700;
}
.newsletter-archive-richtext strong *,
.newsletter-archive-richtext b * {
    font-weight: inherit;
}

.newsletter-archive-richtext h1 {
    font-family: 'Cinzel', 'Times New Roman', serif;
    font-size: 1.65em;
    font-weight: 400;
    line-height: 1.25;
    color: #d46018;
}

.newsletter-archive-richtext h2 {
    font-family: 'Cinzel', 'Times New Roman', serif;
    font-size: 1.4em;
    font-weight: 400;
    line-height: 1.3;
    color: #d46018;
}

.newsletter-archive-richtext h3 {
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: 1.2em;
    font-weight: 500;
    line-height: 1.35;
    color: #2b2b2b;
}

.newsletter-archive-richtext h4 {
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: 1.1em;
    font-weight: 500;
    line-height: 1.35;
    color: #2b2b2b;
}

.newsletter-archive-richtext h5,
.newsletter-archive-richtext h6 {
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: 1em;
    font-weight: 500;
    line-height: 1.4;
    color: #2b2b2b;
}

.newsletter-archive-richtext img {
    max-width: 100%;
    height: auto;
}

.newsletter-archive-empty-copy {
    padding: 18px 20px;
    border-radius: 14px;
    background: #faf7f1;
    border: 1px dashed #e3d6c6;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    color: #8a8a8a;
}

.newsletter-archive-content-block > .newsletter-archive-image-grid {
    margin-top: 22px;
}

.newsletter-archive-content-block > .newsletter-archive-cta-wrap {
    margin-top: 22px;
    text-align: center;
}

.newsletter-archive-cta-link {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 12px 28px;
    border-radius: 6px;
    background: #823133;
    color: #ffffff;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body-sm);
    font-weight: 600;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    text-decoration: none;
}

.newsletter-archive-cta-link:hover {
    color: #ffffff;
    text-decoration: none;
    background: #d46018;
}

.newsletter-archive-image-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 18px;
}

.newsletter-archive-image-grid-single {
    grid-template-columns: minmax(0, 1fr);
}

/* Product Update: 2nd & 3rd uploads as a side-by-side pair (1st = hero above). */
.newsletter-archive-image-grid--product-pair {
    grid-template-columns: repeat(2, minmax(0, 1fr));
}

/* Travel Update: one full-width or two columns (upload 1 or 2). */
.newsletter-archive-image-grid--travel.newsletter-archive-image-grid-single {
    max-width: 100%;
}

.newsletter-archive-image-card {
    overflow: hidden;
    border-radius: 14px;
    background: #e8ddd0;
    aspect-ratio: 3 / 2;
}

.newsletter-archive-image-card img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.newsletter-archive-image-grid--travel .newsletter-archive-image-card {
    aspect-ratio: 21 / 9;
}

.newsletter-archive-state {
    padding: 38px 32px;
    text-align: center;
}

.newsletter-archive-state h2 {
    margin: 0 0 10px;
    font-family: 'Cinzel', 'Times New Roman', serif;
    font-size: 1.75rem;
    font-weight: 400;
    color: #d46018;
}

.newsletter-archive-state p {
    margin: 0;
    font-family: 'DM Sans', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: var(--archive-fs-body);
    color: #6a6a6a;
    line-height: var(--archive-fs-body-line);
}

.newsletter-archive-footer-top {
    padding: 48px 0 34px;
    background: #823133;
    color: #ffffff;
}

.newsletter-archive-footer-container {
    width: 100%;
    max-width: var(--archive-layout-max);
    margin: 0 auto;
    padding: 0 var(--archive-header-pad-x);
}

.newsletter-archive-footer-grid {
    display: grid;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 28px;
    align-items: start;
}

.newsletter-archive-footer-col {
    padding: 0 24px 24px;
    min-width: 0;
}

.newsletter-archive-footer-col h3 {
    margin: 0 0 18px;
    font-family: 'Inter', system-ui, sans-serif;
    font-optical-sizing: auto;
    font-size: 1.5rem;
    font-weight: 500;
    color: #ffffff;
}


.newsletter-archive-footer-col a,
.newsletter-archive-footer-contact div {
    display: block;
    margin-bottom: 6px;
    color: rgba(255, 255, 255, 0.88);
    text-decoration: none;
    line-height: 1.3;
    font-size: var(--archive-fs-body-xs);
}

.newsletter-archive-footer-col a.newsletter-archive-footer-map-link {
    display: inline;
    margin-bottom: 0;
    vertical-align: -0.15em;
}

.newsletter-archive-footer-menu a {
    padding-left: 18px;
}

.newsletter-archive-footer-useful a {
    display: flex;
    align-items: flex-start;
    gap: 7px;
    margin-bottom: 4px;
    padding-left: 0;
    color: rgba(255, 255, 255, 0.92);
    text-decoration: none;
    line-height: 1.25;
    font-size: var(--archive-fs-body-xs);
}

.newsletter-archive-footer-useful a i {
    flex: 0 0 10px;
    width: 10px;
    margin-top: 3px;
    font-size: 0.5625rem;
    line-height: 1;
    opacity: 0.48;
    color: #ffffff;
}

.newsletter-archive-footer-useful a span {
    display: inline-block;
}

.newsletter-archive-footer-col a:hover {
    color: #ffffff;
    text-decoration: none;
}

.newsletter-archive-footer-logo {
    display: inline-block;
    margin-bottom: 14px;
}

.newsletter-archive-footer-logo img {
    display: block;
    width: auto;
    height: var(--archive-header-logo-h, 59px);
    max-height: var(--archive-header-logo-h, 59px);
}

.newsletter-archive-footer-bottom {
    background: #000;
    color: #ffffff;
}

.newsletter-archive-footer-bottom-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    min-height: 72px;
    padding: 0 var(--archive-header-pad-x);
}

.newsletter-archive-footer-socials {
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.newsletter-archive-footer-social-image {
    display: block;
    width: auto;
    height: auto;
}

.newsletter-archive-footer-bottom-links {
    display: flex;
    align-items: center;
    gap: 18px;
}

.newsletter-archive-footer-bottom-links a {
    color: rgba(255, 255, 255, 0.88);
    text-decoration: none;
}

.newsletter-archive-footer-bottom-links a:hover {
    color: #ffffff;
    text-decoration: none;
}

@media (max-width: 1199px) {
    .newsletter-archive-card-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 991px) {
    body.newsletter-archive-page {
        /* Same bar height as wide view; only horizontal padding narrows. */
        --archive-header-pad-x: 16px;
        --archive-fs-insights-date: 1.3rem;
        --archive-fs-detail-kicker: 1.3rem;
        --archive-fs-card-grid-kicker: 1.02rem;
        --archive-fs-detail-title: 1.1rem;
        --archive-fs-content-heading: 1.25rem;
    }

    .newsletter-archive-footer-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
        gap: 20px;
    }

    .newsletter-archive-edition-trigger {
        font-size: var(--archive-fs-body-sm);
    }

    a.newsletter-archive-toolbar-link {
        font-size: var(--archive-fs-body-sm);
    }

    .newsletter-archive-shell {
        padding: 26px 16px 40px;
    }

    .newsletter-archive-insights-combo {
        margin-bottom: 22px;
    }

    .newsletter-archive-insights-edition {
        font-size: var(--archive-fs-body-sm);
    }

    .newsletter-archive-insights-card {
        padding: 20px 18px 22px;
        border-radius: 16px;
    }

    .newsletter-archive-page-title {
        font-size: 1.75rem;
    }

    .newsletter-archive-detail-kicker {
        gap: 0.14em;
        letter-spacing: 0.07em;
    }

    .newsletter-archive-card-kicker.newsletter-archive-detail-kicker {
        gap: 0.12em;
        letter-spacing: 0.055em;
    }

    .newsletter-archive-card-grid {
        grid-template-columns: minmax(0, 1fr);
    }

    .newsletter-archive-image-grid,
    .newsletter-archive-image-grid-single {
        grid-template-columns: minmax(0, 1fr);
    }

    .newsletter-archive-footer-bottom-inner {
        flex-direction: column;
        justify-content: center;
        padding: 18px 16px;
        text-align: center;
    }
}

@media (max-width: 575px) {
    body.newsletter-archive-page {
        --archive-fs-insights-gtt: 2.25rem;
        --archive-fs-insights-sights: 2.25rem;
        --archive-fs-banner-h1: 1.875rem;
    }

    .newsletter-archive-hero,
    .newsletter-archive-latest,
    .newsletter-archive-year-section,
    .newsletter-archive-article,
    .newsletter-archive-state,
    .newsletter-archive-content-block {
        padding: 22px;
    }

    .newsletter-archive-section-head,
    .newsletter-archive-year-head,
    .newsletter-archive-article-head {
        display: block;
    }

    .newsletter-archive-section-head h2,
    .newsletter-archive-year-head h2,
    .newsletter-archive-article-head h1 {
        font-size: 1.5rem;
    }

    .newsletter-archive-page-title {
        font-size: 1.5rem;
    }

    .newsletter-archive-card-footer {
        align-items: flex-start;
        flex-direction: column;
    }

    .newsletter-archive-year-section .newsletter-archive-card--year-topic .newsletter-archive-card-footer--year-topic {
        align-items: center;
    }

    .newsletter-archive-footer-grid {
        grid-template-columns: 1fr;
    }
}
