/* ============================================================
   THE IARI TIMES — Newspaper Layout & Components
   Grid system, masthead, article blocks, sections
   ============================================================ */

/* ====== NEWSPAPER GRID SYSTEM ====== */

.newspaper-container {
    width: 900px;
    max-width: 100%;
    margin: 0 auto;
    padding: 24px var(--space-outer-margin) 60px;
    background: var(--color-card-bg, #fdfbf7);
    box-shadow: 0 30px 100px rgba(0,0,0,0.15);
}

/* Builder Layout Grid (Live View) */
.ck-builder-grid {
    position: relative;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-auto-rows: minmax(40px, auto);
    gap: var(--space-gutter, 16px);
    align-content: start;
    padding: var(--space-md) 0 var(--space-md);
    min-height: 200px;
}

.ck-block-wrapper {
    position: absolute;
    top: var(--desktop-top, 0);
    width: 100%;
    border-radius: var(--radius-sm, 4px);
    margin: 0;
}

/* Interactive Article Blocks (Parity with Editor's .vb-placed-block) */
.ck-interactive-block {
    cursor: pointer;
    transition: transform var(--transition-base, 200ms ease), box-shadow var(--transition-base, 200ms ease);
}

.ck-interactive-block:hover {
    z-index: 2;
    transform: translateY(-2px);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02), 0 4px 12px rgba(0,0,0,0.04);
}

/* Match Editor Hover Border (no layout reflow) */
.ck-interactive-block::after {
    content: '';
    position: absolute;
    inset: -3px;
    border: 2px solid transparent;
    border-radius: 6px;
    pointer-events: none;
    transition: border-color .15s;
}

.ck-interactive-block:hover::after {
    border-color: rgba(61,125,85,.25);
}

/* Typography Constraints to prevent overflow */
.ed-headline, .ed-excerpt, .ed-meta, .ed-category, .ed-venue, .ed-company, .ed-role, .ed-journal, .ed-doi {
    word-break: break-word;
    overflow-wrap: break-word;
    white-space: normal;
    overflow: hidden;
}

/* ====== CANVAS VIEWPORT ====== */

.canvas-viewport {
    width: 100%;
    height: calc(100vh - 48px);
    overflow: hidden;
    position: relative;
    background: #c8c5be; /* Warm broadsheet grey */
    cursor: grab;
    user-select: none;
    -webkit-user-select: none;
}

.canvas-viewport:active {
    cursor: grabbing;
}

.newspaper-canvas {
    position: absolute;
    top: 0;
    left: 0;
    transform-origin: 0 0;
    transition: none; /* We handle smoothing in JS */
    
    /* Sharpness fixes */
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    transform-style: preserve-3d;
    will-change: transform;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    image-rendering: -webkit-optimize-contrast;
    image-rendering: crisp-edges;
}

/* Zoom Controls */
.canvas-controls {
    position: fixed;
    bottom: 32px;
    right: 32px;
    display: flex;
    flex-direction: column;
    gap: 8px;
    z-index: 100;
}

.canvas-controls button {
    width: 48px;
    height: 48px;
    border-radius: 24px;
    border: 1px solid var(--color-rule-line);
    background: #fff;
    color: var(--color-ink-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    transition: all 0.2s;
}

.canvas-controls button:hover {
    background: var(--color-surface-container-high);
    transform: scale(1.05);
}

.canvas-controls button .material-symbols-outlined {
    font-size: 24px;
}

.canvas-ctrl-btn {
    width: 48px;
    height: 48px;
    border-radius: 24px;
    border: 1px solid var(--color-rule-line);
    background: #fff;
    color: var(--color-ink-primary);
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
    box-shadow: 0 4px 12px rgba(0,0,0,0.1);
    transition: all 0.2s;
}

.canvas-ctrl-btn:hover {
    background: var(--color-surface-container-high);
    transform: scale(1.05);
}

.canvas-zoom-level {
    font-family: var(--font-ui);
    font-size: 11px;
    font-weight: 600;
    color: var(--color-on-surface-variant);
    text-align: center;
    padding: 4px 0;
    user-select: none;
}

.canvas-ctrl-divider {
    width: 32px;
    height: 1px;
    background: var(--color-rule-line);
    margin: 4px auto;
}

/* ====== SECTION REVEAL ANIMATION ====== */

.section-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity 0.6s cubic-bezier(0.4, 0, 0.2, 1),
                transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}

.section-reveal.visible {
    opacity: 1;
    transform: translateY(0);
}

/* ====== EMPTY NEWSPAPER STATE ====== */

.ck-empty-newspaper {
    text-align: center;
    padding: 80px 40px;
}

.newspaper-grid {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: var(--space-gutter);
}

/* Column span utilities */
.col-span-2 { grid-column: span 2; }
.col-span-3 { grid-column: span 3; }
.col-span-4 { grid-column: span 4; }
.col-span-5 { grid-column: span 5; }
.col-span-6 { grid-column: span 6; }
.col-span-7 { grid-column: span 7; }
.col-span-8 { grid-column: span 8; }
.col-span-9 { grid-column: span 9; }
.col-span-10 { grid-column: span 10; }
.col-span-12 { grid-column: span 12; }

/* ====== MASTHEAD ====== */

.newspaper-masthead {
    text-align: center;
    padding: var(--space-lg) 0 var(--space-md);
    border-bottom: 3px double var(--color-primary);
    margin-bottom: var(--space-sm);
    position: relative;
}

.newspaper-masthead::before {
    content: '';
    display: block;
    height: 1px;
    background: var(--color-primary);
    margin-bottom: 3px;
}

.newspaper-masthead .masthead-title {
    font-family: var(--font-masthead);
    font-size: var(--text-masthead-size);
    font-weight: 400;
    line-height: var(--text-masthead-line-height);
    letter-spacing: -0.01em;
    color: var(--color-ink-primary);
    margin: 0;
}

.newspaper-masthead .masthead-title .the {
    font-style: italic;
    font-weight: inherit;
    margin-right: 0.04em;
}

.newspaper-masthead .masthead-tagline {
    font-family: var(--font-ui);
    font-size: 11px;
    font-weight: 500;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--color-on-surface-variant);
    margin-top: var(--space-xs);
}

/* ====== EDITION BAR ====== */

.edition-bar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-sm) 0;
    border-bottom: 1px solid var(--color-rule-line);
    margin-bottom: var(--space-lg);
    font-family: var(--font-ui);
    font-size: var(--text-meta-size);
    color: var(--color-on-surface-variant);
}

.edition-bar .edition-date {
    font-weight: 500;
}

.edition-bar .edition-number {
    font-weight: 400;
}

.edition-bar .edition-cta {
    display: inline-flex;
    align-items: center;
    gap: var(--space-xs);
    padding: 6px 14px;
    background: var(--color-accent);
    color: var(--color-on-secondary);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-transform: uppercase;
    border-radius: var(--radius-default);
    border: none;
    cursor: pointer;
    transition: background var(--transition-base);
    text-decoration: none;
}

.edition-bar .edition-cta:hover {
    background: var(--color-accent-hover);
    color: var(--color-on-secondary);
}

/* ====== SECTION HEADERS ====== */

.section-header {
    padding: var(--space-md) 0 var(--space-sm);
    margin-top: var(--space-3xl);
    margin-bottom: var(--space-lg);
    border-top: 2px solid var(--color-primary);
    position: relative;
}

.section-header .section-label {
    font-family: var(--font-ui);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-accent);
    display: inline-block;
}

.section-header .section-title {
    font-family: var(--font-headline);
    font-size: var(--text-h2-size);
    font-weight: var(--text-h2-weight);
    line-height: var(--text-h2-line-height);
    color: var(--color-ink-primary);
    margin-top: var(--space-xs);
}

.section-header .section-rule {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 1px;
    background: var(--color-rule-line);
}

/* ====== ARTICLE CARD COMPONENTS ====== */

/* Hero Article (Full-width feature) */
.article-hero {
    position: relative;
    cursor: pointer;
    transition: transform var(--transition-slow);
    background: #fdfbf7;
    border: 1px solid #e2ddd3;
    padding: var(--space-md);
    border-radius: var(--radius-sm);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02);
}

.article-hero:hover {
    transform: translateY(-2px);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02), 0 4px 12px rgba(0,0,0,0.04);
}

.article-hero .article-image {
    width: 100%;
    height: 400px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-md);
}

.article-hero .article-category {
    font-family: var(--font-ui);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: var(--space-sm);
    display: inline-block;
}

.article-hero .article-title {
    font-family: var(--font-headline);
    font-size: var(--text-h1-size);
    font-weight: var(--text-h1-weight);
    line-height: var(--text-h1-line-height);
    color: var(--color-ink-primary);
    margin-bottom: var(--space-sm);
}

.article-hero .article-excerpt {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    line-height: var(--text-body-line-height);
    color: var(--color-ink-secondary);
    margin-bottom: var(--space-md);
}

.article-hero .article-meta {
    font-family: var(--font-ui);
    font-size: var(--text-meta-size);
    color: var(--color-on-surface-variant);
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.article-hero .article-meta .meta-separator {
    width: 4px;
    height: 4px;
    background: var(--color-outline-variant);
    border-radius: 50%;
}

/* Featured Article (Medium card) */
.article-featured {
    cursor: pointer;
    padding: var(--space-md);
    background: #fdfbf7;
    border: 1px solid #e2ddd3;
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-md);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02);
    transition: all var(--transition-base);
}

.article-featured:last-child {
    margin-bottom: 0;
}

.article-featured:hover {
    transform: translateY(-2px);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02), 0 4px 12px rgba(0,0,0,0.04);
}

.article-featured .article-image {
    width: 100%;
    height: 200px;
    object-fit: cover;
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-sm);
}

.article-featured .article-category {
    font-family: var(--font-ui);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 4px;
    display: inline-block;
}

.article-featured .article-title {
    font-family: var(--font-headline);
    font-size: var(--text-h3-size);
    font-weight: var(--text-h3-weight);
    line-height: var(--text-h3-line-height);
    color: var(--color-ink-primary);
    margin-bottom: var(--space-xs);
}

.article-featured .article-excerpt {
    font-family: var(--font-body);
    font-size: var(--text-column-size);
    line-height: var(--text-column-line-height);
    color: var(--color-ink-secondary);
    margin-bottom: var(--space-sm);
}

.article-featured .article-meta {
    font-family: var(--font-ui);
    font-size: 11px;
    color: var(--color-on-surface-variant);
}

/* Compact Article (Small card, sidebar items) */
.article-compact {
    cursor: pointer;
    padding: var(--space-md);
    background: #fdfbf7;
    border: 1px solid #e2ddd3;
    border-radius: var(--radius-sm);
    margin-bottom: var(--space-md);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02);
    transition: all var(--transition-base);
}

.article-compact:last-child {
    margin-bottom: 0;
}

.article-compact:hover {
    transform: translateY(-2px);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02), 0 4px 12px rgba(0,0,0,0.04);
}

.article-compact .article-category {
    font-family: var(--font-ui);
    font-size: 10px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 2px;
    display: inline-block;
}

.article-compact .article-title {
    font-family: var(--font-headline);
    font-size: 17px;
    font-weight: 600;
    line-height: 1.3;
    color: var(--color-ink-primary);
    margin-bottom: 4px;
}

.article-compact .article-excerpt {
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.5;
    color: var(--color-ink-secondary);
}

/* ====== COLUMN DIVIDERS ====== */

.column-divider {
    width: 1px;
    background: var(--color-rule-line);
    align-self: stretch;
}

.column-divider-horizontal {
    height: 1px;
    background: var(--color-rule-line);
    grid-column: 1 / -1;
    margin: var(--space-md) 0;
}

/* ====== CAMPUS PULSE STRIP ====== */

.pulse-strip {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: var(--space-gutter);
    padding: var(--space-md) 0;
}

.pulse-item {
    display: flex;
    gap: var(--space-sm);
    padding: var(--space-sm);
    border-left: 3px solid var(--color-accent);
    cursor: pointer;
    transition: background var(--transition-base);
    border-radius: 0 var(--radius-default) var(--radius-default) 0;
}

.pulse-item:hover {
    background: var(--color-surface-container-low);
}

.pulse-item .pulse-icon {
    color: var(--color-accent);
    font-size: 20px;
    flex-shrink: 0;
    margin-top: 2px;
}

.pulse-item .pulse-title {
    font-family: var(--font-headline);
    font-size: 15px;
    font-weight: 600;
    line-height: 1.3;
    color: var(--color-ink-primary);
    margin-bottom: 2px;
}

.pulse-item .pulse-text {
    font-family: var(--font-body);
    font-size: 13px;
    line-height: 1.5;
    color: var(--color-ink-secondary);
}

/* ====== STUDENT VOICES — STYLED QUOTE ====== */

.voice-card {
    background: #fdfbf7;
    border: 1px solid #e2ddd3;
    border-radius: var(--radius-sm);
    padding: var(--space-md);
    position: relative;
    cursor: pointer;
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02);
    transition: all var(--transition-base);
}

.voice-card:hover {
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02), 0 4px 12px rgba(0,0,0,0.04);
    transform: translateY(-2px);
}

.voice-card .voice-quote-mark {
    font-family: var(--font-headline);
    font-size: 64px;
    font-weight: 700;
    color: var(--color-accent);
    opacity: 0.25;
    line-height: 0.5;
    position: absolute;
    top: var(--space-md);
    left: var(--space-md);
}

.voice-card .voice-content {
    font-family: var(--font-body);
    font-size: var(--text-column-size);
    font-style: italic;
    line-height: 1.6;
    color: var(--color-ink-primary);
    margin-bottom: var(--space-md);
    padding-top: var(--space-md);
}

.voice-card .voice-author {
    font-family: var(--font-ui);
    font-size: 12px;
    font-weight: 600;
    color: var(--color-on-surface-variant);
    text-transform: uppercase;
    letter-spacing: 0.05em;
}

.voice-card .voice-type {
    font-family: var(--font-ui);
    font-size: 10px;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: var(--space-xs);
    display: inline-block;
}

/* ====== ARTICLE OVERLAY / MODAL ====== */

.article-overlay {
    position: fixed;
    inset: 0;
    z-index: var(--z-overlay-backdrop);
    background: var(--color-overlay-dim);
    display: flex;
    justify-content: center;
    align-items: flex-start;
    padding: var(--space-3xl) var(--space-md);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    opacity: 0;
    visibility: hidden;
    transition: opacity var(--transition-smooth), visibility var(--transition-smooth);
}

.article-overlay.active {
    opacity: 1;
    visibility: visible;
}



.article-overlay .newspaper-container {
    background: var(--color-card-bg);
    max-width: 100%;
    width: 900px; /* Base newspaper width */
    margin: 0 auto;
    padding: 24px var(--space-outer-margin) 60px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.06);
    position: relative;
    border-radius: 2px;
}

.article-overlay .overlay-content {
    background: var(--color-paper-base);
    width: 100%;
    max-width: 800px;
    margin: auto;
    border-radius: var(--radius-md);
    padding: var(--space-2xl);
    position: relative;
    transform: translateY(20px) scale(0.98);
    transition: transform var(--transition-smooth);
    box-shadow: var(--shadow-xl);
}

.article-overlay.active .overlay-content {
    transform: translateY(0) scale(1);
}

.article-overlay .overlay-close {
    position: absolute;
    top: var(--space-md);
    right: var(--space-md);
    width: 36px;
    height: 36px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--color-surface-container);
    border: none;
    border-radius: var(--radius-full);
    cursor: pointer;
    color: var(--color-on-surface-variant);
    transition: all var(--transition-base);
    z-index: 1;
}

.article-overlay .overlay-close:hover {
    background: var(--color-surface-container-high);
    color: var(--color-on-surface);
}

.article-overlay .overlay-image {
    width: calc(100% + 2 * var(--space-2xl));
    margin: calc(-1 * var(--space-2xl));
    margin-bottom: var(--space-lg);
    height: 350px;
    object-fit: cover;
    border-radius: var(--radius-default) var(--radius-default) 0 0;
}

.article-overlay .overlay-category {
    font-family: var(--font-ui);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: var(--space-sm);
    display: inline-block;
}

.article-overlay .overlay-title {
    font-family: var(--font-headline);
    font-size: var(--text-h2-size);
    font-weight: var(--text-h2-weight);
    line-height: var(--text-h2-line-height);
    color: var(--color-ink-primary);
    margin-bottom: var(--space-md);
}

.article-overlay .overlay-meta {
    font-family: var(--font-ui);
    font-size: var(--text-meta-size);
    color: var(--color-on-surface-variant);
    padding-bottom: var(--space-md);
    margin-bottom: var(--space-lg);
    border-bottom: 1px solid var(--color-rule-line);
    display: flex;
    align-items: center;
    gap: var(--space-md);
}

.article-overlay .overlay-body {
    font-family: var(--font-body);
    font-size: var(--text-body-size);
    line-height: var(--text-body-line-height);
    color: var(--color-ink-primary);
}

.article-overlay .overlay-body p {
    margin-bottom: var(--space-md);
}

/* ====== NAVIGATION BAR ====== */

.navbar {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: var(--space-sm) var(--space-outer-margin);
    background: var(--color-surface-container-lowest);
    border-bottom: 1px solid var(--color-rule-line);
    position: sticky;
    top: 0;
    z-index: var(--z-nav);
    box-shadow: var(--shadow-sm);
}

.navbar .nav-brand {
    font-family: var(--font-masthead);
    font-size: 24px;
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--color-ink-primary);
    text-decoration: none;
}

.navbar .nav-brand .the {
    font-style: italic;
}

.newspaper-footer .footer-brand .the {
    font-style: italic;
}

.navbar .nav-links {
    display: flex;
    align-items: center;
    gap: var(--space-lg);
    list-style: none;
}

.navbar .nav-links a {
    font-family: var(--font-ui);
    font-size: 11px;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-on-surface-variant);
    text-decoration: none;
    padding: var(--space-sm) 0;
    border-bottom: 2px solid transparent;
    transition: all var(--transition-base);
}

.navbar .nav-links a:hover,
.navbar .nav-links a.active {
    color: var(--color-on-surface);
    border-bottom-color: var(--color-primary);
}

.navbar .nav-actions {
    display: flex;
    align-items: center;
    gap: var(--space-sm);
}

/* ====== FOOTER ====== */

.newspaper-footer {
    margin-top: var(--space-3xl);
    padding: var(--space-2xl) 0;
    border-top: 2px solid var(--color-primary);
    text-align: center;
}

.newspaper-footer .footer-brand {
    font-family: var(--font-masthead);
    font-size: 28px;
    font-weight: 400;
    letter-spacing: -0.01em;
    color: var(--color-ink-primary);
    margin-bottom: var(--space-sm);
}

.newspaper-footer .footer-tagline {
    font-family: var(--font-ui);
    font-size: 11px;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--color-on-surface-variant);
    margin-bottom: var(--space-lg);
}

.newspaper-footer .footer-links {
    display: flex;
    justify-content: center;
    gap: var(--space-lg);
    list-style: none;
    margin-bottom: var(--space-md);
}

.newspaper-footer .footer-links a {
    font-family: var(--font-ui);
    font-size: 12px;
    font-weight: 500;
    color: var(--color-on-surface-variant);
    text-decoration: none;
    transition: color var(--transition-base);
}

.newspaper-footer .footer-links a:hover {
    color: var(--color-accent);
}

.newspaper-footer .footer-copyright {
    font-family: var(--font-ui);
    font-size: 11px;
    color: var(--color-outline);
}

/* ====== WEEKLY HIGHLIGHTS GRID ====== */

.highlights-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: var(--space-gutter);
}

.highlight-card {
    background: var(--color-paper-base);
    border: 1px solid var(--color-surface-dim);
    border-radius: var(--radius-sm);
    overflow: hidden;
    cursor: pointer;
    transition: all var(--transition-base);
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02);
}

.highlight-card:hover {
    box-shadow: inset 0 0 10px rgba(0,0,0,0.02), 0 4px 12px rgba(0,0,0,0.04);
    transform: translateY(-3px);
}

.highlight-card .card-image {
    width: 100%;
    height: 160px;
    object-fit: cover;
}

.highlight-card .card-body {
    padding: var(--space-md);
}

.highlight-card .card-category {
    font-family: var(--font-ui);
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: var(--color-accent);
    margin-bottom: 4px;
}

.highlight-card .card-title {
    font-family: var(--font-headline);
    font-size: 17px;
    font-weight: 600;
    line-height: 1.3;
    color: var(--color-ink-primary);
    margin-bottom: var(--space-xs);
}

.highlight-card .card-excerpt {
    font-family: var(--font-body);
    font-size: 14px;
    line-height: 1.5;
    color: var(--color-ink-secondary);
}

.highlight-card .card-meta {
    font-family: var(--font-ui);
    font-size: 11px;
    color: var(--color-on-surface-variant);
    margin-top: var(--space-sm);
}

/* ====== MOBILE RESPONSIVE — CARD-BASED ARTICLE VIEWER ====== */
@media (max-width: 768px) {

    /* --- Canvas & Container: disable pan/zoom, native scroll --- */
    .canvas-viewport {
        height: auto !important;
        overflow: visible !important;
        cursor: default !important;
        position: relative !important;
        background: var(--color-surface, #faf8f4) !important;
        user-select: auto !important;
        -webkit-user-select: auto !important;
        touch-action: auto !important;
    }
    .canvas-viewport:active { cursor: default !important; }

    .newspaper-canvas {
        position: relative !important;
        top: auto !important;
        left: auto !important;
        transform: none !important;
        width: 100% !important;
    }

    .newspaper-container {
        padding: 16px 12px 80px 12px !important;
        width: 100% !important;
        max-width: 100% !important;
        box-shadow: none !important;
        margin: 0 !important;
        background: var(--color-surface, #faf8f4) !important;
    }

    /* --- Masthead: single centered title --- */
    .newspaper-masthead {
        padding: 16px 0 12px 0;
        text-align: center;
    }
    .masthead-title {
        font-size: 26px !important;
        letter-spacing: 0 !important;
        line-height: 1.2 !important;
    }
    .masthead-tagline {
        font-size: 11px !important;
        margin-top: 4px;
    }

    /* --- Edition Bar --- */
    .edition-bar {
        flex-direction: column !important;
        gap: 6px !important;
        align-items: center !important;
        padding: 12px 0 !important;
        font-size: 11px;
    }
    .edition-date, .ck-masthead-brand {
        position: static !important;
    }
    .edition-meta {
        flex-direction: column !important;
        gap: 2px !important;
        align-items: center !important;
    }

    /* --- Grid: collapse to single column card feed --- */
    .newspaper-grid {
        display: flex !important;
        flex-direction: column !important;
        gap: 16px !important;
    }
    .col-span-2, .col-span-3, .col-span-4, .col-span-5, .col-span-6,
    .col-span-7, .col-span-8, .col-span-9, .col-span-10, .col-span-12 {
        grid-column: auto !important;
        width: 100% !important;
    }

    /* --- Article blocks as tappable cards --- */
    .article-hero, .article-featured, .article-compact {
        background: #fff !important;
        border-radius: 12px !important;
        box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
        border: 1px solid rgba(0,0,0,0.06) !important;
        padding: 16px !important;
        cursor: pointer;
        transition: transform 0.15s ease, box-shadow 0.15s ease;
        -webkit-tap-highlight-color: transparent;
    }
    .article-hero:active, .article-featured:active, .article-compact:active {
        transform: scale(0.98);
        box-shadow: 0 1px 4px rgba(0,0,0,0.08) !important;
    }
    .article-hero .article-image, .article-featured .article-image, .article-compact .article-image {
        border-radius: 8px !important;
        margin-bottom: 12px !important;
        height: auto !important;
        max-height: 200px !important;
        object-fit: cover !important;
        width: 100% !important;
    }
    .article-hero .article-title, .article-featured .article-title, .article-compact .article-title {
        font-size: 18px !important;
        line-height: 1.3 !important;
        margin-bottom: 8px !important;
    }
    .article-hero .article-excerpt, .article-featured .article-excerpt, .article-compact .article-excerpt {
        font-size: 14px !important;
        line-height: 1.55 !important;
        color: var(--color-ink-secondary) !important;
        display: -webkit-box !important;
        -webkit-line-clamp: 3 !important;
        line-clamp: 3 !important;
        -webkit-box-orient: vertical !important;
        overflow: hidden !important;
    }
    .article-hero .article-meta, .article-featured .article-meta, .article-compact .article-meta {
        font-size: 11px !important;
        margin-top: 10px !important;
        color: var(--color-on-surface-variant) !important;
    }

    /* Hero article — still prominent on mobile */
    .article-hero {
        padding: 16px !important;
    }
    .article-hero .article-image {
        width: calc(100% + 32px) !important;
        margin: -16px -16px 16px -16px !important;
        border-radius: 12px 12px 0 0 !important;
        max-height: 220px !important;
    }
    .article-hero .article-title {
        font-size: 22px !important;
    }

    /* Highlight cards */
    .highlight-card {
        border-radius: 12px !important;
        padding: 16px !important;
        box-shadow: 0 2px 8px rgba(0,0,0,0.06) !important;
        border: 1px solid rgba(0,0,0,0.06) !important;
    }

    /* Section headers */
    .section-header {
        font-size: 14px !important;
        padding: 8px 0 !important;
        margin-bottom: 12px !important;
    }

    /* --- Article Overlay: full-screen slide-up viewer --- */
    .article-overlay {
        padding: 0 !important;
        align-items: stretch !important;
        justify-content: flex-end !important;
        overflow: hidden !important;
    }
    .article-overlay .overlay-content {
        max-width: 100% !important;
        width: 100% !important;
        min-height: 100vh;
        min-height: 100dvh;
        border-radius: 0 !important;
        margin: 0 !important;
        padding: 64px 20px 100px 20px !important;
        overflow-y: auto !important;
        -webkit-overflow-scrolling: touch;
    }
    .article-overlay .overlay-image {
        width: calc(100% + 40px);
        margin: -64px -20px 24px -20px;
        border-radius: 0;
        max-height: 280px;
        object-fit: cover;
    }
    .article-overlay .overlay-close {
        position: fixed !important;
        top: max(20px, env(safe-area-inset-top, 20px)) !important;
        right: max(20px, env(safe-area-inset-right, 20px)) !important;
        width: 44px;
        height: 44px;
        min-width: 44px;
        min-height: 44px;
        background: rgba(255, 255, 255, 0.95) !important;
        box-shadow: 0 4px 16px rgba(0,0,0,0.2);
        z-index: 10001 !important;
        border-radius: 50%;
        display: flex;
        align-items: center;
        justify-content: center;
        touch-action: manipulation;
        -webkit-tap-highlight-color: transparent;
    }
    .overlay-title {
        font-size: 22px !important;
        line-height: 1.25 !important;
    }
    .overlay-body p {
        font-size: 15px !important;
        line-height: 1.7 !important;
    }

    /* --- FAB: hidden on mobile, use bottom nav --- */
    .ck-fab-wrapper {
        display: none !important;
    }

    /* --- Canvas Controls: hidden on mobile --- */
    .canvas-controls {
        display: none !important;
    }

    /* --- Footer --- */
    .newspaper-footer {
        padding: 24px 0 80px 0;
        text-align: center;
    }
    .footer-brand { font-size: 18px !important; }
    .footer-links { flex-wrap: wrap; justify-content: center; gap: 12px; }

    /* --- Sections: no reveal animation --- */
    .section-reveal {
        opacity: 1 !important;
        transform: none !important;
    }
}

/* ====== MOBILE BOTTOM NAV BAR ====== */
.ck-mobile-nav {
    display: none;
}

@media (max-width: 768px) {
    .ck-mobile-nav {
        display: flex;
        position: fixed;
        bottom: 0;
        left: 0;
        right: 0;
        background: rgba(255, 255, 255, 0.97);
        backdrop-filter: blur(12px);
        -webkit-backdrop-filter: blur(12px);
        border-top: 1px solid rgba(0,0,0,0.08);
        z-index: 900;
        justify-content: space-around;
        align-items: center;
        padding: 6px 0;
        padding-bottom: max(6px, env(safe-area-inset-bottom));
    }

    .ck-mobile-nav-item {
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 2px;
        padding: 6px 12px;
        text-decoration: none;
        color: var(--color-on-surface-variant);
        font-size: 10px;
        font-weight: 500;
        font-family: var(--font-ui);
        transition: color 0.2s;
        border-radius: 8px;
        touch-action: manipulation;
        -webkit-tap-highlight-color: transparent;
    }

    .ck-mobile-nav-item .material-symbols-outlined {
        font-size: 22px;
    }

    .ck-mobile-nav-item:active,
    .ck-mobile-nav-item.ck-mobile-nav-submit {
        color: var(--color-accent, #b0570c);
    }
}

/* ====== SUBSCRIPTION WIDGET MOBILE FIX ====== */
@media (max-width: 768px) {
    .ck-subscription-widget {
        top: auto !important;
        bottom: -100% !important;
        left: 16px !important;
        right: 16px !important;
        width: auto !important;
        transform: none !important;
        z-index: 9999 !important;
        transition: bottom 0.4s cubic-bezier(0.34, 1.56, 0.64, 1) !important;
    }
    .ck-subscription-widget.visible {
        bottom: 80px !important;
        transform: none !important;
    }
}

/* Typography Enhancements */
.has-dropcap .ed-excerpt:first-of-type::first-letter, .has-dropcap p:first-of-type::first-letter { float: left; font-size: 4em; line-height: 0.8; margin-right: 0.1em; font-family: var(--font-masthead, 'Playfair Display', serif); font-weight: bold; color: var(--color-ink-primary); padding-top: 4px; padding-bottom: 4px; }
