/* Shared journal article treatment: match archive/conference-memory-frameworks.html */
:root {
    --memory-bg: rgb(12, 11, 10);
    --memory-fg: rgb(235, 225, 210);
    --memory-muted: rgb(150, 140, 125);
    --memory-border: rgb(45, 40, 35);
    --memory-accent: rgb(210, 180, 130);
    --memory-accent-dim: rgb(160, 135, 95);
    --memory-display: "Iowan Old Style", "Charter", Georgia, serif;
    --memory-mono: "SF Mono", "Menlo", "Monaco", "Cousine", monospace;
    --memory-col: 40rem;
    --memory-pad: clamp(1.25rem, 4vw, 3rem);
}

html {
    background: var(--memory-bg);
}

body.article-page {
    margin: 0 !important;
    background: var(--memory-bg) !important;
    color: var(--memory-fg) !important;
    font-family: var(--memory-display) !important;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

body.article-page::before {
    display: none !important;
}

body.article-page .header,
body.article-page .article-hero,
body.article-page .layout,
body.article-page .footer,
body.article-page .article-footer {
    width: 100% !important;
    max-width: var(--memory-col) !important;
    margin-left: auto !important;
    margin-right: auto !important;
    padding-left: var(--memory-pad) !important;
    padding-right: var(--memory-pad) !important;
    box-sizing: border-box !important;
    background: transparent !important;
    border-color: var(--memory-border) !important;
    box-shadow: none !important;
    color: var(--memory-fg) !important;
}

body.article-page .header {
    padding-top: 2rem !important;
    padding-bottom: 1.5rem !important;
    border-bottom: 1px solid var(--memory-border) !important;
}

body.article-page .header-inner {
    max-width: none !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    align-items: center !important;
    gap: 1rem !important;
}

body.article-page .observer-eye,
body.article-page .article-tegaki,
body.article-page .article-body-stage,
body.article-page .article-mobile-body,
body.article-page .sidebar {
    display: none !important;
}

body.article-page .header-brand,
body.article-page .header-brand-link,
body.article-page .site-title,
body.article-page .site-title a,
body.article-page .lang-switcher,
body.article-page .article-hero-meta,
body.article-page .article-footer,
body.article-page .footer,
body.article-page .fm-nav,
body.article-page .fm-left,
body.article-page .fm-right {
    font-family: var(--memory-mono) !important;
}

body.article-page .site-title,
body.article-page .site-title a,
body.article-page .header-brand-link {
    color: var(--memory-fg) !important;
    font-size: 0.75rem !important;
    letter-spacing: 0.04em !important;
    text-transform: none !important;
    text-decoration: none !important;
}

body.article-page .lang-switcher {
    display: flex !important;
    gap: 0.55rem !important;
    align-items: center !important;
    color: var(--memory-muted) !important;
}

body.article-page .lang-switcher button {
    appearance: none !important;
    border: 1px solid var(--memory-border) !important;
    background: transparent !important;
    color: var(--memory-muted) !important;
    border-radius: 0 !important;
    padding: 0.38rem 0.55rem !important;
    font: inherit !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.02em !important;
    text-transform: uppercase !important;
}

body.article-page .lang-switcher button:hover,
body.article-page .lang-switcher button.active,
body.article-page .lang-switcher button[aria-pressed="true"] {
    border-color: var(--memory-accent-dim) !important;
    color: var(--memory-accent) !important;
}

body.article-page .article-hero {
    padding-top: 3rem !important;
    padding-bottom: 1.5rem !important;
    margin: 0 auto !important;
    border-bottom: 0 !important;
}

body.article-page .article-hero-meta {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.65rem !important;
    margin-bottom: 1rem !important;
    color: var(--memory-muted) !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
}

body.article-page .article-section,
body.article-page .article-date,
body.article-page .article-reading-time {
    color: var(--memory-muted) !important;
}

body.article-page .article-section::after,
body.article-page .article-date::after {
    content: "/" !important;
    margin-left: 0.65rem !important;
    color: var(--memory-border) !important;
}

body.article-page .article-hero-title {
    margin: 0 !important;
    color: var(--memory-fg) !important;
    font-family: var(--memory-display) !important;
    font-size: clamp(2.4rem, 8vw, 5rem) !important;
    line-height: 0.95 !important;
    letter-spacing: 0 !important;
    font-weight: 400 !important;
    text-wrap: balance;
}

body.article-page .section-heading {
    max-width: var(--memory-col) !important;
    margin: 0 0 2rem !important;
    padding: 3rem 0 0 !important;
    color: var(--memory-fg) !important;
    font-family: var(--memory-display) !important;
    font-size: clamp(2.4rem, 8vw, 5rem) !important;
    line-height: 0.95 !important;
    letter-spacing: 0 !important;
    font-weight: 400 !important;
    text-wrap: balance;
}

body.article-page .article-meta-mobile {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 0.65rem !important;
    margin: 3rem 0 1rem !important;
    color: var(--memory-muted) !important;
    font-family: var(--memory-mono) !important;
    font-size: 0.72rem !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
}

body.article-page .article-meta-mobile p {
    margin: 0 !important;
    color: var(--memory-muted) !important;
    font: inherit !important;
}

body.article-page .article-meta-mobile p::after {
    content: none !important;
}

body.article-page .article-meta-mobile p + p::before {
    content: "/ " !important;
    margin-right: 0.65rem !important;
    color: var(--memory-border) !important;
}

body.article-page .layout {
    display: block !important;
    max-width: var(--memory-col) !important;
    padding-top: 0 !important;
    padding-bottom: 2rem !important;
    border: 0 !important;
    backdrop-filter: none !important;
}

body.article-page .content,
body.article-page .article-content,
body.article-page .section-content,
body.article-page .personal-section,
body.article-page .personal-section.first-section {
    display: block !important;
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    color: var(--memory-fg) !important;
    border: 0 !important;
    box-shadow: none !important;
    font-family: var(--memory-display) !important;
}

body.article-page .section-content p,
body.article-page .section-content li,
body.article-page .article-content p,
body.article-page .article-content li {
    margin: 0 0 1.45rem !important;
    color: var(--memory-fg) !important;
    font-family: var(--memory-display) !important;
    font-size: clamp(1.25rem, 2.25vw, 1.78rem) !important;
    line-height: 1.68 !important;
    letter-spacing: 0 !important;
}

body.article-page .section-content > p:first-of-type::first-letter,
body.article-page .article-content > p:first-of-type::first-letter {
    float: left !important;
    margin: 0.15rem 0.6rem 0 0 !important;
    color: var(--memory-accent) !important;
    font-size: 4.8em !important;
    line-height: 0.8 !important;
}

body.article-page .section-content h2,
body.article-page .section-content h3,
body.article-page .article-content h2,
body.article-page .article-content h3,
body.article-page .article-footer-section h2,
body.article-page .article-footer-section h3 {
    margin: 4rem 0 1.35rem !important;
    padding: 0 !important;
    color: var(--memory-fg) !important;
    font-family: var(--memory-display) !important;
    font-size: clamp(1.5rem, 3.2vw, 2.15rem) !important;
    line-height: 1.18 !important;
    font-weight: 400 !important;
    letter-spacing: 0 !important;
}

body.article-page .section-content h2::before,
body.article-page .section-content h3::before,
body.article-page .article-content h2::before,
body.article-page .article-content h3::before {
    content: none !important;
}

body.article-page a,
body.article-page .section-content a,
body.article-page .article-content a,
body.article-page .footer a,
body.article-page .article-footer a {
    color: var(--memory-accent) !important;
    text-decoration: none !important;
    border-bottom: 1px solid var(--memory-accent-dim) !important;
}

body.article-page a:hover,
body.article-page .section-content a:hover,
body.article-page .article-content a:hover {
    border-bottom-color: var(--memory-accent) !important;
}

body.article-page .expandable-trigger {
    appearance: none !important;
    background: transparent !important;
    border: 0 !important;
    border-bottom: 1px dashed var(--memory-accent-dim) !important;
    border-radius: 0 !important;
    color: var(--memory-accent) !important;
    padding: 0 !important;
    font: inherit !important;
    cursor: pointer !important;
}

body.article-page .expandable-trigger:hover {
    border-bottom-style: solid !important;
}

body.article-page .expandable-content {
    display: none;
    margin: 1rem 0 2rem !important;
    padding: 0.35rem 0 0.35rem 1.4rem !important;
    border-left: 1px solid var(--memory-border) !important;
    background: transparent !important;
    color: var(--memory-muted) !important;
}

body.article-page .expandable-content.open,
body.article-page .expandable-content.expanded {
    display: block !important;
}

body.article-page .expandable-content p,
body.article-page .expandable-content li {
    color: var(--memory-muted) !important;
    font-size: clamp(1.05rem, 1.8vw, 1.35rem) !important;
    line-height: 1.65 !important;
}

body.article-page .pullquote,
body.article-page blockquote {
    margin: 2.5rem 0 !important;
    padding: 0.2rem 0 0.2rem 1.5rem !important;
    border-left: 1px solid var(--memory-accent) !important;
    background: transparent !important;
}

body.article-page .pullquote p,
body.article-page .pullquote-text,
body.article-page blockquote p {
    margin: 0 !important;
    color: var(--memory-accent) !important;
    font-size: clamp(1.35rem, 2.5vw, 1.85rem) !important;
    line-height: 1.45 !important;
    font-style: normal !important;
}

body.article-page .infobox,
body.article-page .film-info-box,
body.article-page .media-placeholder,
body.article-page .audio-embed,
body.article-page .document-embed {
    margin: 2rem 0 !important;
    padding: 1.15rem !important;
    border: 1px solid var(--memory-border) !important;
    background: transparent !important;
    color: var(--memory-muted) !important;
    box-shadow: none !important;
}

body.article-page .infobox-title,
body.article-page .film-info-box h4 {
    margin: 0 0 0.7rem !important;
    color: var(--memory-accent) !important;
    font-family: var(--memory-mono) !important;
    font-size: 0.75rem !important;
    font-weight: 400 !important;
    letter-spacing: 0.04em !important;
    text-transform: uppercase !important;
}

body.article-page .infobox-content,
body.article-page .infobox p,
body.article-page .film-info-label,
body.article-page .film-info-value,
body.article-page .source-description,
body.article-page .image-caption,
body.article-page .image-source,
body.article-page .section-content em {
    color: var(--memory-muted) !important;
    font-family: var(--memory-display) !important;
}

body.article-page .infobox-content,
body.article-page .infobox p,
body.article-page .film-info-label,
body.article-page .film-info-value,
body.article-page .source-description {
    font-size: clamp(1.05rem, 1.8vw, 1.35rem) !important;
    line-height: 1.65 !important;
}

body.article-page .article-image,
body.article-page .article-figure {
    margin: 2.5rem 0 !important;
    padding: 0 !important;
    max-width: none !important;
    border-top: 1px solid var(--memory-border) !important;
    border-bottom: 1px solid var(--memory-border) !important;
    background: transparent !important;
    text-align: left !important;
}

body.article-page .article-image img,
body.article-page .article-figure img,
body.article-page .article-content img {
    width: 100% !important;
    max-width: 100% !important;
    height: auto !important;
    margin: 0 !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    filter: grayscale(0.12) contrast(1.03) !important;
}

body.article-page .image-caption,
body.article-page .article-figure figcaption {
    max-width: none !important;
    margin: 0 !important;
    padding: 0.8rem 0 0.9rem !important;
    color: var(--memory-muted) !important;
    font-family: var(--memory-mono) !important;
    font-size: 0.76rem !important;
    line-height: 1.55 !important;
    text-align: left !important;
}

body.article-page .article-footer-section {
    margin-top: 3.5rem !important;
    padding-top: 2rem !important;
    border-top: 1px solid var(--memory-border) !important;
}

body.article-page .article-footer {
    padding-top: 2rem !important;
    padding-bottom: 2.5rem !important;
    border-top: 1px solid var(--memory-border) !important;
}

body.article-page .footer {
    padding-top: 2rem !important;
    padding-bottom: 2.5rem !important;
    border-top: 1px solid var(--memory-border) !important;
}

body.article-page .fm-wrap {
    max-width: none !important;
    padding: 0 !important;
    display: flex !important;
    justify-content: space-between !important;
    gap: 1rem !important;
    color: var(--memory-muted) !important;
    font-size: 0.72rem !important;
}

body.article-page .fm-nav {
    display: flex !important;
    gap: 1rem !important;
    flex-wrap: wrap !important;
}

body.article-page .fm-nav a,
body.article-page .fm-right a {
    color: var(--memory-muted) !important;
    border-bottom-color: transparent !important;
}

body.article-page .fm-nav a:hover,
body.article-page .fm-right a:hover {
    color: var(--memory-accent) !important;
}

@media (max-width: 720px) {
    body.article-page .header,
    body.article-page .article-hero,
    body.article-page .layout,
    body.article-page .footer,
    body.article-page .article-footer {
        padding-left: 1.15rem !important;
        padding-right: 1.15rem !important;
    }

    body.article-page .header-inner,
    body.article-page .fm-wrap {
        align-items: flex-start !important;
        flex-direction: column !important;
    }

    body.article-page .article-hero {
        padding-top: 2.4rem !important;
    }
}
