.newsletter-archive,
.newsletter-edition,
.account-page {
    background: #1b1510;
    color: #f5ecd9;
    min-height: 70vh;
    padding: 48px 0 72px;
}

.newsletter-shell,
.newsletter-edition {
    width: min(1120px, calc(100% - 32px));
    margin: 0 auto;
}

.newsletter-kicker {
    color: #d0a05f;
    font: 800 0.78rem/1.2 Inter, system-ui, sans-serif;
    letter-spacing: 0.16em;
    text-transform: uppercase;
}

.newsletter-archive h1,
.newsletter-hero h1,
.account-page h1 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(2.5rem, 7vw, 5.4rem);
    line-height: 0.98;
    margin: 10px 0 14px;
}

.newsletter-lede,
.newsletter-hero__text > p {
    color: #d7c9ae;
    font-size: clamp(1.05rem, 2vw, 1.35rem);
    line-height: 1.5;
    max-width: 720px;
}

.newsletter-grid {
    display: grid;
    gap: 22px;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    margin-top: 36px;
}

.newsletter-card {
    background: #2a2118;
    border: 1px solid rgba(245, 236, 217, 0.14);
    border-radius: 8px;
    overflow: hidden;
}

.newsletter-card__image {
    aspect-ratio: 16 / 10;
    display: block;
    overflow: hidden;
}

.newsletter-card__image img,
.newsletter-hero__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.newsletter-card__body {
    padding: 20px;
}

.newsletter-card__meta,
.newsletter-card__love {
    color: #9f8d72;
    font: 700 0.78rem/1 Inter, system-ui, sans-serif;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.newsletter-card h2 {
    font-family: Georgia, "Times New Roman", serif;
    font-size: 1.65rem;
    line-height: 1.1;
    margin: 10px 0;
}

.newsletter-card a {
    color: #f8efd8;
    text-decoration: none;
}

.newsletter-card p {
    color: #d7c9ae;
}

.newsletter-hero {
    display: grid;
    gap: 32px;
    grid-template-columns: minmax(0, 1fr) minmax(320px, 0.8fr);
    align-items: end;
    margin-bottom: 46px;
}

.newsletter-hero__image {
    aspect-ratio: 4 / 5;
    border-radius: 8px;
    overflow: hidden;
    border: 1px solid rgba(245, 236, 217, 0.16);
}

.newsletter-byline {
    align-items: center;
    color: #b9a98d;
    display: flex;
    flex-wrap: wrap;
    gap: 9px;
    margin: 18px 0;
}

.newsletter-byline img {
    border-radius: 999px;
    height: 36px;
    width: 36px;
}

.newsletter-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.newsletter-love,
.newsletter-share {
    border: 1px solid rgba(208, 160, 95, 0.5);
    border-radius: 999px;
    background: transparent;
    color: #f5ecd9;
    font-weight: 700;
    padding: 10px 16px;
}

.newsletter-share:disabled {
    cursor: wait;
    opacity: 0.72;
}

.newsletter-love--active,
.newsletter-share {
    background: #d0a05f;
    color: #1b1510;
}

.newsletter-share-status {
    align-self: center;
    color: #d7c9ae;
    font: 700 0.78rem/1.2 Inter, system-ui, sans-serif;
    min-height: 1em;
}

.newsletter-body {
    color: #f8efd8;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1.1rem, 2vw, 1.35rem);
    line-height: 1.78;
    margin: 0 auto;
    max-width: 760px;
}

.newsletter-body h2,
.newsletter-body h3 {
    color: #f5ecd9;
    line-height: 1.12;
    margin-top: 2em;
}

.newsletter-body a,
.newsletter-recipe span,
.newsletter-recipes a {
    color: #d0a05f;
}

.newsletter-recipes {
    border-top: 1px solid rgba(245, 236, 217, 0.16);
    margin: 56px auto 0;
    max-width: 860px;
    padding-top: 28px;
}

.newsletter-recipes__header {
    margin-bottom: 18px;
}

.newsletter-recipes__header h2 {
    color: #f8efd8;
    font-family: Georgia, "Times New Roman", serif;
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    line-height: 1;
    margin: 8px 0 0;
}

.newsletter-recipe-grid {
    display: grid;
    gap: 18px;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
}

.newsletter-recipe {
    background: #241c15;
    border: 1px solid rgba(245, 236, 217, 0.14);
    border-radius: 10px;
    display: grid;
    overflow: hidden;
    text-decoration: none;
    transition: border-color 0.16s ease, transform 0.16s ease;
}

.newsletter-recipe:hover {
    border-color: rgba(208, 160, 95, 0.5);
    transform: translateY(-2px);
}

.newsletter-recipe__media {
    aspect-ratio: 4 / 3;
    background: #15100c;
    overflow: hidden;
}

.newsletter-recipe__media img {
    display: block;
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.newsletter-recipe__body {
    display: grid;
    gap: 8px;
    padding: 16px;
}

.newsletter-recipe__title {
    color: #f8efd8;
    font-family: Georgia, "Times New Roman", serif;
    font-size: 1.25rem;
    font-weight: 700;
    line-height: 1.16;
}

.newsletter-recipe__body p {
    color: #cbbda5;
    display: -webkit-box;
    font-size: 0.95rem;
    line-height: 1.45;
    margin: 0;
    overflow: hidden;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 3;
}

.newsletter-recipe__cta {
    color: #d0a05f;
    font: 800 0.72rem/1.2 Inter, system-ui, sans-serif;
    letter-spacing: 0.12em;
    margin-top: 4px;
    text-transform: uppercase;
}

.account-shell {
    max-width: 760px;
}

.account-panel {
    background: #2a2118;
    border: 1px solid rgba(245, 236, 217, 0.14);
    border-radius: 8px;
    margin-top: 30px;
    padding: 24px;
}

.account-panel h2 {
    font-family: Georgia, "Times New Roman", serif;
}

.account-panel p,
.account-checkbox {
    color: #d7c9ae;
}

.account-checkbox {
    align-items: center;
    display: flex;
    gap: 10px;
    margin: 16px 0;
}

@media (max-width: 820px) {
    .newsletter-hero {
        grid-template-columns: 1fr;
    }
    .newsletter-hero__image {
        aspect-ratio: 16 / 10;
        order: -1;
    }
    .newsletter-recipe-grid {
        grid-template-columns: 1fr;
    }
}
