/* ============================================================
   historic.day -- The Record of Days That Mattered
   A broadsheet newspaper rendered for the web.
   Palette: cream, foxed edge, printer's ink, column rule, red ink.
   Typography: UnifrakturMaguntia, Playfair Display, Lora,
               Libre Baskerville, Special Elite.
   ============================================================ */

/* -- Color tokens & fundamentals --------------------------------- */
:root {
    --c-newsprint: #f5f0e0;
    --c-foxed: #e8dcc8;
    --c-ink: #1a1410;
    --c-worn-ink: #3a3228;
    --c-faded: #7a7060;
    --c-rule: #c0b8a0;
    --c-red: #8b2a1a;
    --c-illuminated: #4a3828;
    --c-telegram-bg: #ede5d0;
    --c-paper-edge: #c0b090;
    --c-grain: #a09080;

    --col-gap: 1.5rem;
    --rule-w: 1px;
    --rule-w-thick: 2px;

    --f-blackletter: 'UnifrakturMaguntia', 'Playfair Display', serif;
    --f-display: 'Playfair Display', 'Times New Roman', serif;
    --f-body: 'Lora', Georgia, serif;
    --f-meta: 'Libre Baskerville', Georgia, serif;
    --f-telegram: 'Special Elite', 'Courier New', monospace;
}

* { box-sizing: border-box; }

html, body {
    margin: 0;
    padding: 0;
    background: var(--c-newsprint);
    color: var(--c-ink);
    font-family: var(--f-body);
    font-size: 16px;
    line-height: 1.65;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
}

/* Newspaper paper ---------------------------------------------- */
.paper {
    position: relative;
    min-height: 100vh;
    padding: 0;
    background:
        /* fine warm grain */
        radial-gradient(circle at 17% 23%, rgba(160,144,128,0.07) 0 0.7px, transparent 1.2px),
        radial-gradient(circle at 73% 41%, rgba(160,144,128,0.08) 0 0.6px, transparent 1.1px),
        radial-gradient(circle at 38% 81%, rgba(160,144,128,0.06) 0 0.6px, transparent 1.1px),
        radial-gradient(circle at 89% 87%, rgba(160,144,128,0.07) 0 0.6px, transparent 1.0px),
        radial-gradient(circle at 11% 59%, rgba(160,144,128,0.06) 0 0.5px, transparent 1.0px),
        var(--c-newsprint);
    background-size:
        14px 14px,
        17px 19px,
        21px 23px,
        13px 15px,
        29px 27px,
        auto;
}

.texture-overlay {
    pointer-events: none;
    position: fixed;
    inset: 0;
    z-index: 1;
    background:
        repeating-linear-gradient(
            91deg,
            rgba(160,144,128,0.03) 0 1px,
            transparent 1px 4px
        ),
        repeating-linear-gradient(
            179deg,
            rgba(120,100,80,0.02) 0 1px,
            transparent 1px 6px
        );
    mix-blend-mode: multiply;
    opacity: 0.6;
}

.vignette {
    pointer-events: none;
    position: fixed;
    inset: 0;
    z-index: 2;
    background:
        radial-gradient(
            ellipse at center,
            transparent 55%,
            rgba(192,176,144,0.18) 90%,
            rgba(160,140,110,0.32) 100%
        );
    mix-blend-mode: multiply;
}

/* Broadsheet ---------------------------------------------- */
.broadsheet {
    position: relative;
    z-index: 3;
    max-width: 1380px;
    margin: 0 auto;
    padding: 3.5rem clamp(1.25rem, 3vw, 3.5rem) 4rem;
    display: block;
}

/* -- Rules (the structural backbone) --------------------------- */
.rule {
    border: 0;
    margin: 0;
    height: 0;
    background: transparent;
    border-top: var(--rule-w) solid var(--c-rule);
    width: 100%;
}
.rule-thin { border-top-width: 1px; }
.rule-thick-top { border-top-width: 2px; margin-top: 2.5rem; margin-bottom: 1.25rem; }
.rule-double-top {
    border-top-width: 1px;
    margin-top: 0.6rem;
    margin-bottom: 0;
}
.rule-double-bottom {
    border-top-width: 1px;
    margin-top: 3px;
    margin-bottom: 0.6rem;
}

/* ============================================================
   SECTION 1 -- THE MASTHEAD
   ============================================================ */
.masthead {
    text-align: center;
    margin-bottom: 2rem;
}

.masthead-inner {
    padding: 0.4rem 0 0.2rem;
}

.masthead-title {
    font-family: var(--f-blackletter);
    font-weight: 400;
    font-size: clamp(3.2rem, 8.4vw, 6.4rem);
    line-height: 1;
    margin: 0;
    color: var(--c-ink);
    letter-spacing: 0.005em;
    padding: 0.15em 0 0.05em;
}

.masthead-meta {
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.78rem;
    color: var(--c-worn-ink);
    letter-spacing: 0.06em;
    text-transform: uppercase;
    padding: 0.6rem 0.5rem 0.7rem;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.6rem 1rem;
}

.masthead-meta .meta-sep { color: var(--c-rule); font-style: normal; }

.featured-date {
    font-family: var(--f-display);
    font-weight: 900;
    font-size: clamp(1.3rem, 3.6vw, 2.6rem);
    color: var(--c-red);
    letter-spacing: 0.16em;
    text-transform: uppercase;
    padding: 0.85rem 0;
    line-height: 1.05;
}

.featured-date .date-text {
    display: inline-block;
}

.weather-bar {
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.78rem;
    color: var(--c-faded);
    padding: 0.55rem 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 0.4rem 1.5rem;
}

.weather-bar em { color: var(--c-worn-ink); }

/* ============================================================
   SECTION 2-3 -- THE LEAD STORY
   ============================================================ */
.lead-story {
    margin: 0 0 1rem;
    padding: 0.5rem 0 1.5rem;
}

.lead-headline-block {
    text-align: center;
    padding: 0.5rem 0 1rem;
}

.kicker {
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.82rem;
    color: var(--c-faded);
    text-transform: uppercase;
    letter-spacing: 0.18em;
    margin: 0 0 0.6rem;
    text-align: center;
}

.lead-headline {
    font-family: var(--f-display);
    font-weight: 900;
    font-size: clamp(2.2rem, 5.6vw, 4.4rem);
    line-height: 1.02;
    color: var(--c-ink);
    text-transform: uppercase;
    margin: 0 0 0.7rem;
    letter-spacing: -0.005em;
    max-width: 22ch;
    margin-left: auto;
    margin-right: auto;
}

.subhead {
    font-family: var(--f-display);
    font-weight: 700;
    font-style: italic;
    font-size: clamp(1rem, 1.5vw, 1.3rem);
    line-height: 1.4;
    color: var(--c-worn-ink);
    max-width: 62ch;
    margin: 0 auto 1.1rem;
    text-align: center;
}

.lead-byline {
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.85rem;
    color: var(--c-worn-ink);
    text-align: center;
    padding: 0.4rem 0 0.6rem;
}

.byline-mark {
    display: inline-block;
    width: 8px;
    height: 8px;
    background: var(--c-red);
    border-radius: 50%;
    margin-right: 0.5rem;
    vertical-align: middle;
    transform: translateY(-1px);
}

.dateline {
    font-family: var(--f-meta);
    font-style: normal;
    font-weight: 400;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    font-size: 0.78rem;
    color: var(--c-ink);
}

/* The actual columns + sidebar grid ---------------------------- */
.lead-body-grid {
    display: grid;
    grid-template-columns: 4fr 1fr;
    gap: 2rem;
    align-items: start;
    padding-top: 1rem;
}

.lead-columns {
    column-count: 3;
    column-gap: var(--col-gap);
    column-rule: 1px solid var(--c-rule);
    text-align: justify;
    hyphens: auto;
    -webkit-hyphens: auto;
    font-family: var(--f-body);
    font-size: clamp(0.95rem, 1.05vw, 1.05rem);
    line-height: 1.65;
    color: var(--c-ink);
}

.lead-columns p {
    margin: 0 0 0.85rem;
    text-indent: 1.3em;
}
.lead-columns p:first-child {
    text-indent: 0;
}

.paragraph-marker {
    color: var(--c-red);
    font-size: 0.7em;
    margin-right: 0.35em;
    vertical-align: 0.15em;
}

/* Pull-quote -- breaks the column flow */
.pull-quote {
    column-span: all;
    margin: 1.4rem 0 1.6rem;
    padding: 0.4rem 0 0.6rem 1.5rem;
    border-left: 3px solid var(--c-rule);
    border-top: 1px solid var(--c-rule);
    border-bottom: 1px solid var(--c-rule);
    padding-top: 1.2rem;
    padding-bottom: 1.2rem;
    font-family: var(--f-display);
    font-style: italic;
    font-weight: 700;
    font-size: clamp(1.3rem, 2vw, 1.85rem);
    line-height: 1.3;
    color: var(--c-worn-ink);
    text-align: left;
    text-indent: 0;
    transition: background-color 220ms ease;
    cursor: default;
}

.pull-quote:hover {
    background-color: var(--c-foxed);
}

.pull-quote cite {
    display: block;
    margin-top: 0.7rem;
    font-style: italic;
    font-family: var(--f-meta);
    font-weight: 400;
    font-size: 0.85rem;
    color: var(--c-faded);
    letter-spacing: 0.02em;
}

/* Sidebar */
.sidebar {
    background: var(--c-foxed);
    padding: 1rem 1.1rem 1.2rem;
    font-family: var(--f-body);
    font-size: 0.88rem;
    line-height: 1.55;
    color: var(--c-worn-ink);
    border-top: 2px solid var(--c-ink);
    border-bottom: 2px solid var(--c-ink);
}

.sidebar-head { margin: -0.3rem 0 0.5rem; }

.sidebar-title {
    font-family: var(--f-display);
    font-weight: 900;
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.18em;
    text-align: center;
    color: var(--c-ink);
    margin: 0.4rem 0 0.4rem;
}

.sidebar-item {
    padding: 0.6rem 0 0.7rem;
}

.sidebar-item-title {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 0.92rem;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    margin: 0 0 0.45rem;
    color: var(--c-ink);
}

.sidebar-list,
.sidebar-list-ordered {
    margin: 0;
    padding: 0 0 0 1.05rem;
    font-size: 0.85rem;
}

.sidebar-list li,
.sidebar-list-ordered li {
    margin-bottom: 0.3rem;
}

.sidebar-quote p {
    margin: 0.2rem 0;
    font-size: 0.88rem;
    text-align: center;
}

.sidebar-quote .cite {
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.78rem;
    color: var(--c-faded);
}

/* ============================================================
   SECTION 4 -- SECONDARY STORIES
   ============================================================ */
.secondary-stories {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 0 var(--col-gap);
    padding: 1.5rem 0 0.5rem;
    column-rule: 1px solid var(--c-rule);
    align-items: start;
}

.story {
    padding: 0.5rem 1rem 0.5rem 1rem;
    position: relative;
}

/* vertical column rules between stories */
.story-a { grid-column: 1 / span 2; padding-left: 0; border-right: 1px solid var(--c-rule); padding-right: 1.4rem; }
.story-b { grid-column: 3 / span 2; padding-right: 1.4rem; border-right: 1px solid var(--c-rule); padding-left: 1.4rem; }
.story-c { grid-column: 5 / span 1; padding-right: 0; padding-left: 1.4rem; }

.story-headline {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(1.15rem, 1.6vw, 1.55rem);
    line-height: 1.15;
    color: var(--c-ink);
    margin: 0.3rem 0 0.4rem;
    letter-spacing: 0.005em;
}

.story-byline {
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.78rem;
    color: var(--c-worn-ink);
    margin: 0 0 0.5rem;
}

.story-body {
    font-family: var(--f-body);
    font-size: 0.93rem;
    line-height: 1.6;
    color: var(--c-ink);
    text-align: justify;
    hyphens: auto;
    -webkit-hyphens: auto;
    margin: 0.55rem 0 0.7rem;
    text-indent: 1em;
}
.story-body:first-of-type { text-indent: 0; }

/* Telegram dispatch */
.telegram {
    background: var(--c-telegram-bg);
    padding: 1rem 1.25rem 1.05rem;
    border: 1px solid var(--c-rule);
    margin: 0.6rem 0 0.8rem;
    font-family: var(--f-telegram);
    font-size: 0.86rem;
    line-height: 1.55;
    color: var(--c-worn-ink);
    text-transform: uppercase;
    letter-spacing: 0.04em;
}

.telegram-header,
.telegram-footer {
    text-align: center;
    font-size: 0.76rem;
    color: var(--c-faded);
    letter-spacing: 0.1em;
    margin: 0;
    padding-bottom: 0.55rem;
    border-bottom: 1px dashed var(--c-rule);
}

.telegram-footer {
    border-bottom: 0;
    border-top: 1px dashed var(--c-rule);
    padding-bottom: 0;
    padding-top: 0.55rem;
    margin-top: 0.55rem;
}

.telegram-body {
    margin: 0.6rem 0;
    color: var(--c-ink);
    line-height: 1.7;
    word-spacing: 0.05em;
}

/* ============================================================
   SECTION 5 -- THE EDITORIAL
   ============================================================ */
.editorial {
    max-width: 48rem;
    margin: 1.5rem auto 1rem;
    padding: 0.5rem 1rem 0.5rem;
    text-align: left;
}

.editorial-head {
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.78rem;
    color: var(--c-faded);
    text-transform: uppercase;
    letter-spacing: 0.22em;
    text-align: center;
    margin: 0.5rem 0 0.4rem;
}

.editorial-title {
    font-family: var(--f-display);
    font-weight: 900;
    font-style: italic;
    font-size: clamp(1.8rem, 3.4vw, 2.8rem);
    line-height: 1.1;
    color: var(--c-ink);
    text-align: center;
    margin: 0 0 0.9rem;
    letter-spacing: 0.005em;
}

.editorial-rule { margin: 0.7rem auto 1rem; max-width: 12rem; }

.editorial-body {
    font-family: var(--f-body);
    font-size: 1.08rem;
    line-height: 1.78;
    color: var(--c-ink);
    text-align: justify;
    hyphens: auto;
    -webkit-hyphens: auto;
}

.editorial-body p {
    margin: 0 0 1.05rem;
    text-indent: 1.3em;
}
.editorial-first-paragraph { text-indent: 0 !important; }

.drop-cap {
    float: left;
    font-family: var(--f-blackletter);
    font-weight: 400;
    font-size: 4.8rem;
    line-height: 0.78;
    margin: 0.18rem 0.4rem 0 0;
    color: var(--c-illuminated);
    padding: 0;
}

.editorial-signoff {
    text-align: center;
    text-indent: 0 !important;
    margin-top: 1.6rem !important;
    font-size: 0.95rem;
    color: var(--c-worn-ink);
}

/* ============================================================
   SECTION 6 -- COLOPHON / FOOTER
   ============================================================ */
.colophon {
    background: var(--c-foxed);
    margin: 1.5rem -1rem 0;
    padding: 1.8rem clamp(1rem, 2.5vw, 2.5rem) 1.5rem;
    border-top: 2px solid var(--c-ink);
    border-bottom: 2px solid var(--c-ink);
}

.colophon-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    font-family: var(--f-body);
    font-size: 0.88rem;
    line-height: 1.6;
    color: var(--c-worn-ink);
}

.colophon-col p { margin: 0.4rem 0 0.6rem; }

.colophon-title {
    font-family: var(--f-display);
    font-weight: 900;
    font-size: 0.95rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--c-ink);
    margin: 0 0 0.4rem;
}

.colophon-list {
    list-style: none;
    margin: 0;
    padding: 0;
    font-size: 0.85rem;
}

.colophon-list li {
    padding: 0.18rem 0;
    border-bottom: 1px dotted var(--c-rule);
}

.colophon-list a {
    color: var(--c-ink);
    text-decoration: none;
    transition: color 200ms ease;
    display: block;
    padding: 0.05rem 0;
}

.colophon-list a:hover {
    color: var(--c-red);
}

.colophon-list a.archive-current {
    color: var(--c-red);
    font-weight: 500;
}

.colophon-list a.archive-current::before {
    content: '\25B8\00A0';
    color: var(--c-red);
}

/* swatches */
.swatch {
    display: inline-block;
    width: 0.9em;
    height: 0.9em;
    border: 1px solid var(--c-rule);
    vertical-align: -0.05em;
    margin: 0 0.1em;
}
.swatch-cream { background: var(--c-newsprint); }
.swatch-foxed { background: var(--c-foxed); }
.swatch-ink   { background: var(--c-ink); }
.swatch-red   { background: var(--c-red); }

/* Baldwin quote */
.baldwin-quote {
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.95rem;
    color: var(--c-worn-ink);
    text-align: center;
    margin: 1.5rem auto 1rem;
    max-width: 56rem;
    line-height: 1.5;
}

.baldwin-attr {
    display: block;
    margin-top: 0.4rem;
    font-size: 0.82rem;
    color: var(--c-faded);
    letter-spacing: 0.06em;
}

.impressum {
    text-align: center;
    font-family: var(--f-meta);
    font-style: italic;
    font-size: 0.78rem;
    color: var(--c-faded);
    margin: 0.7rem 0 0.2rem;
    letter-spacing: 0.06em;
}

/* ============================================================
   LINKS (general)
   ============================================================ */
a {
    color: var(--c-ink);
    text-decoration: none;
    transition: color 200ms ease;
}
a:hover { color: var(--c-red); }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 1200px) {
    .lead-body-grid {
        grid-template-columns: 1fr;
    }
    .lead-columns {
        column-count: 2;
    }
    .secondary-stories {
        grid-template-columns: repeat(2, 1fr);
        gap: 1.5rem;
    }
    .story-a { grid-column: 1 / 2; border-right: 0; padding-right: 0; padding-left: 0; border-bottom: 1px solid var(--c-rule); padding-bottom: 1.2rem; }
    .story-b { grid-column: 2 / 3; border-right: 0; padding-right: 0; padding-left: 1.4rem; border-left: 1px solid var(--c-rule); padding-bottom: 1.2rem; }
    .story-c { grid-column: 1 / 3; border-top: 1px solid var(--c-rule); padding: 1.2rem 0 0; }
    .colophon-grid { grid-template-columns: 1fr 1fr; }
    .colophon-col:nth-child(3) { grid-column: 1 / 3; }
}

@media (max-width: 768px) {
    .broadsheet { padding: 2rem 1.1rem 3rem; }
    .lead-columns {
        column-count: 1;
    }
    .secondary-stories {
        grid-template-columns: 1fr;
    }
    .story-a, .story-b, .story-c {
        grid-column: 1 / -1;
        border: 0;
        border-bottom: 1px solid var(--c-rule);
        padding: 1rem 0 1rem;
    }
    .story-c { border-bottom: 0; }
    .colophon-grid { grid-template-columns: 1fr; }
    .colophon-col:nth-child(3) { grid-column: 1 / 2; }
    .masthead-meta { font-size: 0.7rem; gap: 0.3rem 0.7rem; }
    .featured-date { letter-spacing: 0.1em; }
    .pull-quote { padding-left: 1rem; }
}

/* ============================================================
   PRINT (this site IS a printed page)
   ============================================================ */
@media print {
    .texture-overlay, .vignette { display: none; }
    .paper { background: #fff; }
    .colophon { background: #f5f0e0; }
}
