/**
 * NewsHub Pro — Layout Styles
 * Styles for all home, archive, and single post layout variants.
 *
 * @package NewsHub_Pro
 * @since 1.0.0
 */

/* =====================================================================
   CSS CUSTOM PROPERTIES
   ===================================================================== */

:root {
    --color-primary:       #e63946;
    --color-accent:        #457b9d;
    --color-dark:          #1e293b;
    --color-dark-mid:      #334155;
    --color-muted:         #64748b;
    --color-border:        #e2e8f0;
    --color-surface:       #f8fafc;
    --color-surface-alt:   #f1f5f9;
    --color-white:         #ffffff;
    --color-text:          #1e293b;
    --color-text-muted:    #64748b;

    --font-heading:        Georgia, "Times New Roman", serif;
    --font-body:           Inter, Arial, sans-serif;
    --font-size-base:      16px;
    --font-size-sm:        0.875rem;
    --font-size-xs:        0.75rem;
    --font-size-lg:        1.125rem;
    --font-size-xl:        1.25rem;
    --font-size-2xl:       1.5rem;
    --font-size-3xl:       1.875rem;
    --font-size-4xl:       2.25rem;

    --radius-sm:           4px;
    --radius-md:           6px;
    --radius-lg:           10px;
    --radius-xl:           16px;

    --shadow-sm:           0 1px 3px rgba(0,0,0,0.08);
    --shadow-md:           0 4px 12px rgba(0,0,0,0.10);
    --shadow-lg:           0 8px 24px rgba(0,0,0,0.12);
    --shadow-hover:        0 6px 20px rgba(0,0,0,0.14);

    --transition-fast:     0.15s ease;
    --transition-base:     0.25s ease;
    --transition-slow:     0.4s ease;

    --spacing-xs:          0.25rem;
    --spacing-sm:          0.5rem;
    --spacing-md:          1rem;
    --spacing-lg:          1.5rem;
    --spacing-xl:          2rem;
    --spacing-2xl:         3rem;
    --spacing-3xl:         4rem;

    --grid-cols:           3;
}

/* =====================================================================
   SHARED / UTILITY STYLES
   ===================================================================== */

.category-badge {
    display: inline-block;
    padding: 2px 8px;
    background-color: var(--color-primary);
    color: #fff;
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.06em;
    border-radius: var(--radius-sm);
    text-decoration: none;
    line-height: 1.6;
    transition: background-color var(--transition-fast);
}

.category-badge:hover {
    background-color: var(--color-primary-dark);
}

.entry-meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: var(--spacing-sm);
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.entry-meta a {
    color: inherit;
    text-decoration: none;
}

.entry-meta a:hover {
    color: var(--color-primary);
}

.entry-tags {
    display: flex;
    flex-wrap: wrap;
    gap: var(--spacing-xs);
    font-size: var(--font-size-sm);
}

.entry-tags a {
    display: inline-block;
    padding: 2px 10px;
    border: 1px solid var(--color-border);
    border-radius: 100px;
    color: var(--color-text-muted);
    text-decoration: none;
    font-size: var(--font-size-xs);
    transition: border-color var(--transition-fast), color var(--transition-fast), background-color var(--transition-fast);
}

.entry-tags a:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
    background-color: rgba(230,57,70,0.05);
}

.page-links {
    display: flex;
    align-items: center;
    gap: var(--spacing-sm);
    padding: var(--spacing-md) 0;
    font-size: var(--font-size-sm);
    font-weight: 600;
}

.page-links a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    color: var(--color-text);
    text-decoration: none;
    transition: background-color var(--transition-fast), color var(--transition-fast);
}

.page-links a:hover,
.page-links .post-page-numbers.current {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-white);
}

/* =====================================================================
   HOME HERO — CLASSIC LAYOUT
   ===================================================================== */

.home-hero {
    margin-bottom: var(--spacing-2xl);
}

.hero-card {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background-color: var(--color-dark);
    box-shadow: var(--shadow-lg);
}

.hero-card__image {
    position: relative;
    aspect-ratio: 16 / 7;
    overflow: hidden;
}

.hero-card__image a {
    display: block;
    height: 100%;
}

.hero-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.hero-card:hover .hero-card__image img {
    transform: scale(1.03);
}

.hero-card__image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        transparent 40%,
        rgba(15, 23, 42, 0.55) 75%,
        rgba(15, 23, 42, 0.85) 100%
    );
    pointer-events: none;
}

.hero-card__body {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--spacing-xl) var(--spacing-xl) var(--spacing-xl);
    color: var(--color-white);
    z-index: 2;
}

.hero-card__body .category-badge {
    margin-bottom: var(--spacing-sm);
}

.hero-card__title {
    font-family: var(--font-heading);
    font-size: clamp(var(--font-size-2xl), 3.5vw, var(--font-size-4xl));
    font-weight: 800;
    line-height: 1.2;
    margin: 0 0 var(--spacing-sm);
    text-shadow: 0 1px 4px rgba(0,0,0,0.4);
}

.hero-card__title a {
    color: inherit;
    text-decoration: none;
}

.hero-card__title a:hover {
    text-decoration: underline;
    text-underline-offset: 3px;
}

.hero-card__excerpt {
    font-size: var(--font-size-lg);
    color: rgba(255,255,255,0.85);
    margin: 0 0 var(--spacing-md);
    line-height: 1.6;
    max-width: 65ch;
}

.hero-card__meta {
    color: rgba(255,255,255,0.7);
}

.hero-card__meta .entry-meta {
    color: rgba(255,255,255,0.75);
}

.hero-card__meta .entry-meta a:hover {
    color: var(--color-white);
}

/* =====================================================================
   HOME GRID — CLASSIC LAYOUT (below hero)
   ===================================================================== */

.home-grid {
    margin-bottom: var(--spacing-2xl);
}

.home-grid__inner {
    display: grid;
    grid-template-columns: repeat(var(--grid-cols, 3), 1fr);
    gap: var(--spacing-xl);
}

/* Card component (used inside grids) */
.post-card {
    display: flex;
    flex-direction: column;
    background: var(--color-white);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
    overflow: hidden;
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.post-card:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
}

.post-card__image {
    aspect-ratio: 3 / 2;
    overflow: hidden;
}

.post-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.post-card:hover .post-card__image img {
    transform: scale(1.04);
}

.post-card__body {
    flex: 1;
    display: flex;
    flex-direction: column;
    padding: var(--spacing-md) var(--spacing-lg);
}

.post-card__category {
    margin-bottom: var(--spacing-xs);
}

.post-card__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-xl);
    font-weight: 700;
    line-height: 1.3;
    margin: 0 0 var(--spacing-sm);
}

.post-card__title a {
    color: var(--color-text);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.post-card__title a:hover {
    color: var(--color-primary);
}

.post-card__excerpt {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
    line-height: 1.65;
    margin: 0 0 auto;
    padding-bottom: var(--spacing-sm);
}

.post-card__meta {
    padding-top: var(--spacing-sm);
    border-top: 1px solid var(--color-border);
    margin-top: var(--spacing-md);
}

/* =====================================================================
   HOME MAGAZINE LAYOUT
   ===================================================================== */

.home-magazine {
    margin-bottom: var(--spacing-2xl);
}

.magazine-lead {
    display: grid;
    grid-template-columns: 2fr 1fr;
    grid-template-rows: auto auto;
    gap: var(--spacing-lg);
    margin-bottom: var(--spacing-2xl);
}

.magazine-lead__primary {
    grid-row: 1 / 3;
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-dark);
}

.magazine-lead__primary .magazine-lead__image {
    aspect-ratio: 4 / 3;
    overflow: hidden;
}

.magazine-lead__primary .magazine-lead__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.magazine-lead__primary:hover .magazine-lead__image img {
    transform: scale(1.03);
}

.magazine-lead__primary .magazine-lead__image::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, transparent 45%, rgba(15,23,42,0.8) 100%);
    pointer-events: none;
}

.magazine-lead__primary .magazine-lead__body {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: var(--spacing-xl);
    color: var(--color-white);
    z-index: 2;
}

.magazine-lead__primary .magazine-lead__title {
    font-family: var(--font-heading);
    font-size: clamp(var(--font-size-xl), 2.5vw, var(--font-size-3xl));
    font-weight: 800;
    color: var(--color-white);
    margin: var(--spacing-xs) 0 var(--spacing-sm);
    line-height: 1.25;
}

.magazine-lead__primary .magazine-lead__title a {
    color: inherit;
    text-decoration: none;
}

.magazine-lead__primary .magazine-lead__title a:hover {
    text-decoration: underline;
}

.magazine-lead__primary .magazine-lead__excerpt {
    color: rgba(255,255,255,0.82);
    font-size: var(--font-size-base);
    line-height: 1.6;
    margin: 0 0 var(--spacing-sm);
}

.magazine-lead__secondary {
    display: flex;
    flex-direction: row;
    gap: var(--spacing-md);
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: box-shadow var(--transition-base);
}

.magazine-lead__secondary:hover {
    box-shadow: var(--shadow-md);
}

.magazine-lead__secondary .magazine-lead__image {
    width: 120px;
    flex-shrink: 0;
    overflow: hidden;
}

.magazine-lead__secondary .magazine-lead__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.magazine-lead__secondary .magazine-lead__body {
    flex: 1;
    padding: var(--spacing-md);
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.magazine-lead__secondary .magazine-lead__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-base);
    font-weight: 700;
    line-height: 1.35;
    margin: var(--spacing-xs) 0 var(--spacing-xs);
    color: var(--color-text);
}

.magazine-lead__secondary .magazine-lead__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.magazine-lead__secondary .magazine-lead__title a:hover {
    color: var(--color-primary);
}

.magazine-secondary {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: var(--spacing-lg);
}

/* =====================================================================
   HOME COMPACT LAYOUT
   ===================================================================== */

.home-compact {
    margin-bottom: var(--spacing-2xl);
}

.compact-list {
    display: flex;
    flex-direction: column;
}

.compact-list__item {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    padding: var(--spacing-md) 0;
    border-bottom: 1px solid var(--color-border);
    transition: background-color var(--transition-fast);
}

.compact-list__item:last-child {
    border-bottom: none;
}

.compact-list__item:hover {
    background-color: var(--color-surface);
}

.compact-list__thumb {
    flex-shrink: 0;
    width: 90px;
    height: 68px;
    border-radius: var(--radius-sm);
    overflow: hidden;
    display: block;
}

.compact-list__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-base);
}

.compact-list__item:hover .compact-list__thumb img {
    transform: scale(1.04);
}

.compact-list__body {
    flex: 1;
    min-width: 0;
}

.compact-list__body .category-badge {
    margin-bottom: var(--spacing-xs);
}

.compact-list__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-lg);
    font-weight: 700;
    line-height: 1.35;
    margin: 0 0 var(--spacing-xs);
}

.compact-list__title a {
    color: var(--color-text);
    text-decoration: none;
    transition: color var(--transition-fast);
}

.compact-list__title a:hover {
    color: var(--color-primary);
}

.compact-list__meta {
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
}

/* =====================================================================
   HOME BREAKING LAYOUT
   ===================================================================== */

.home-breaking__alert {
    display: flex;
    align-items: center;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) var(--spacing-md);
    background-color: var(--color-primary);
    border-radius: var(--radius-md);
    margin-bottom: var(--spacing-lg);
    font-size: var(--font-size-sm);
    color: var(--color-white);
    overflow: hidden;
}

.breaking-badge {
    flex-shrink: 0;
    display: inline-flex;
    align-items: center;
    padding: 2px 10px;
    background-color: var(--color-white);
    color: var(--color-primary);
    font-size: var(--font-size-xs);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    border-radius: var(--radius-sm);
}

.home-breaking__alert a {
    color: var(--color-white);
    text-decoration: none;
    font-weight: 500;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

.home-breaking__alert a:hover {
    text-decoration: underline;
    text-underline-offset: 2px;
}

.home-breaking__layout {
    display: grid;
    grid-template-columns: 2fr 1fr;
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-2xl);
}

.home-breaking__main {
    position: relative;
}

.breaking-feature {
    position: relative;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-dark);
    height: 100%;
}

.breaking-feature__image {
    display: block;
    aspect-ratio: 16 / 10;
    overflow: hidden;
}

.breaking-feature__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.breaking-feature:hover .breaking-feature__image img {
    transform: scale(1.03);
}

.breaking-feature__body {
    padding: var(--spacing-lg);
    background: var(--color-white);
}

.breaking-feature__title {
    font-family: var(--font-heading);
    font-size: clamp(var(--font-size-xl), 2.2vw, var(--font-size-3xl));
    font-weight: 800;
    line-height: 1.25;
    margin: var(--spacing-sm) 0 var(--spacing-sm);
    color: var(--color-text);
}

.breaking-feature__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.breaking-feature__title a:hover {
    color: var(--color-primary);
}

.home-breaking__sidebar {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-md);
}

.breaking-side-item {
    display: flex;
    gap: var(--spacing-md);
    padding: var(--spacing-md);
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.breaking-side-item:hover {
    box-shadow: var(--shadow-md);
    transform: translateX(2px);
}

.breaking-side-item__thumb {
    flex-shrink: 0;
    width: 100px;
    height: 75px;
    border-radius: var(--radius-md);
    overflow: hidden;
    display: block;
}

.breaking-side-item__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.breaking-side-item__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-base);
    font-weight: 700;
    line-height: 1.35;
    margin: var(--spacing-xs) 0 var(--spacing-xs);
    color: var(--color-text);
}

.breaking-side-item__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.breaking-side-item__title a:hover {
    color: var(--color-primary);
}

.home-breaking__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-2xl);
}

/* =====================================================================
   HOME EDITORIAL LAYOUT
   ===================================================================== */

.home-editorial {
    margin-bottom: var(--spacing-2xl);
}

.editorial-section {
    margin-bottom: var(--spacing-2xl);
    padding-bottom: var(--spacing-2xl);
    border-bottom: 1px solid var(--color-border);
}

.editorial-section:last-child {
    border-bottom: none;
    margin-bottom: 0;
    padding-bottom: 0;
}

.editorial-section__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: var(--spacing-lg);
    padding-bottom: var(--spacing-sm);
    border-bottom: 3px solid var(--color-primary);
}

.editorial-section__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-2xl);
    font-weight: 800;
    margin: 0;
    color: var(--color-text);
}

.editorial-section__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.editorial-section__title a:hover {
    color: var(--color-primary);
}

.editorial-section__more {
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-primary);
    text-decoration: none;
    white-space: nowrap;
    transition: opacity var(--transition-fast);
}

.editorial-section__more:hover {
    opacity: 0.75;
    text-decoration: underline;
}

.editorial-section__posts {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: var(--spacing-xl);
}

/* =====================================================================
   ARCHIVE — GRID LAYOUT
   ===================================================================== */

.archive-grid {
    display: grid;
    grid-template-columns: repeat(var(--grid-cols, 3), 1fr);
    gap: var(--spacing-xl);
    margin-bottom: var(--spacing-2xl);
}

/* =====================================================================
   ARCHIVE — LIST LAYOUT
   ===================================================================== */

.archive-list {
    display: flex;
    flex-direction: column;
    margin-bottom: var(--spacing-2xl);
}

.archive-list__item {
    display: flex;
    gap: var(--spacing-lg);
    padding: var(--spacing-xl) 0;
    border-bottom: 1px solid var(--color-border);
    transition: background-color var(--transition-fast);
}

.archive-list__item:first-child {
    padding-top: 0;
}

.archive-list__item:last-child {
    border-bottom: none;
}

.archive-list__thumb {
    flex-shrink: 0;
    width: 220px;
    height: 148px;
    border-radius: var(--radius-md);
    overflow: hidden;
    display: block;
}

.archive-list__thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.archive-list__item:hover .archive-list__thumb img {
    transform: scale(1.04);
}

.archive-list__body {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    justify-content: center;
    gap: var(--spacing-xs);
}

.archive-list__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-2xl);
    font-weight: 800;
    line-height: 1.3;
    margin: var(--spacing-xs) 0 var(--spacing-sm);
    color: var(--color-text);
}

.archive-list__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.archive-list__title a:hover {
    color: var(--color-primary);
}

.archive-list__excerpt {
    font-size: var(--font-size-base);
    color: var(--color-text-muted);
    line-height: 1.65;
    margin: 0 0 var(--spacing-sm);
}

.archive-list__meta {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

/* =====================================================================
   ARCHIVE — MASONRY LAYOUT
   ===================================================================== */

.archive-masonry {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: 10px;
    column-gap: var(--spacing-xl);
    row-gap: 0;
    align-items: start;
    margin-bottom: var(--spacing-2xl);
}

.masonry-item {
    margin-bottom: var(--spacing-xl);
    background: var(--color-white);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: box-shadow var(--transition-base), transform var(--transition-base);
}

.masonry-item:hover {
    box-shadow: var(--shadow-hover);
    transform: translateY(-2px);
}

.masonry-item__image {
    display: block;
    overflow: hidden;
    aspect-ratio: unset;
}

.masonry-item__image img {
    display: block;
    width: 100%;
    height: auto;
    transition: transform var(--transition-slow);
}

.masonry-item:hover .masonry-item__image img {
    transform: scale(1.03);
}

.masonry-item__body {
    padding: var(--spacing-md) var(--spacing-lg);
}

.masonry-item__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-lg);
    font-weight: 700;
    line-height: 1.35;
    margin: var(--spacing-xs) 0 var(--spacing-xs);
    color: var(--color-text);
}

.masonry-item__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.masonry-item__title a:hover {
    color: var(--color-primary);
}

/* =====================================================================
   ARCHIVE — COMPACT LAYOUT
   ===================================================================== */

.archive-compact {
    display: flex;
    flex-direction: column;
    margin-bottom: var(--spacing-2xl);
}

.archive-compact__item {
    display: flex;
    align-items: baseline;
    gap: var(--spacing-md);
    padding: var(--spacing-sm) 0;
    border-bottom: 1px solid var(--color-border);
    transition: background-color var(--transition-fast);
}

.archive-compact__item:first-child {
    border-top: 1px solid var(--color-border);
}

.archive-compact__item:hover {
    background-color: var(--color-surface);
    padding-left: var(--spacing-sm);
}

.archive-compact__dot {
    flex-shrink: 0;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    background-color: var(--color-primary);
    margin-top: 2px;
    align-self: center;
}

.archive-compact__body {
    flex: 1;
    min-width: 0;
    display: flex;
    align-items: baseline;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.archive-compact__cat {
    flex-shrink: 0;
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-primary);
    text-decoration: none;
    transition: opacity var(--transition-fast);
}

.archive-compact__cat:hover {
    opacity: 0.7;
}

.archive-compact__title {
    font-family: var(--font-heading);
    font-size: var(--font-size-base);
    font-weight: 600;
    line-height: 1.4;
    margin: 0;
    color: var(--color-text);
}

.archive-compact__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.archive-compact__title a:hover {
    color: var(--color-primary);
}

.archive-compact__date {
    flex-shrink: 0;
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    white-space: nowrap;
    margin-left: auto;
    padding-left: var(--spacing-md);
}

/* =====================================================================
   ARCHIVE — FULL WIDTH LAYOUT
   ===================================================================== */

.archive-fullwidth {
    display: flex;
    flex-direction: column;
    gap: 0;
    margin-bottom: var(--spacing-2xl);
}

.fullwidth-item {
    display: flex;
    flex-direction: column;
    padding: var(--spacing-xl) 0;
    border-bottom: 1px solid var(--color-border);
}

.fullwidth-item:last-child {
    border-bottom: none;
}

.fullwidth-item__image {
    display: block;
    width: 100%;
    border-radius: var(--radius-md);
    overflow: hidden;
    margin-bottom: var(--spacing-lg);
    aspect-ratio: 21 / 7;
}

.fullwidth-item__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slow);
}

.fullwidth-item:hover .fullwidth-item__image img {
    transform: scale(1.02);
}

.fullwidth-item__body {
    max-width: 72ch;
}

.fullwidth-item__title {
    font-family: var(--font-heading);
    font-size: clamp(var(--font-size-2xl), 2.8vw, var(--font-size-3xl));
    font-weight: 800;
    line-height: 1.25;
    margin: var(--spacing-sm) 0 var(--spacing-md);
    color: var(--color-text);
}

.fullwidth-item__title a {
    color: inherit;
    text-decoration: none;
    transition: color var(--transition-fast);
}

.fullwidth-item__title a:hover {
    color: var(--color-primary);
}

.fullwidth-item__excerpt {
    font-size: var(--font-size-lg);
    color: var(--color-text-muted);
    line-height: 1.7;
    margin: 0 0 var(--spacing-md);
}

.fullwidth-item__meta {
    font-size: var(--font-size-sm);
}

/* =====================================================================
   SINGLE — STANDARD LAYOUT
   ===================================================================== */

.single-standard {
    display: grid;
    grid-template-columns: 1fr 300px;
    gap: var(--spacing-2xl);
    align-items: start;
}

.single-standard__content {
    min-width: 0;
}

.single-standard__sidebar {
    position: sticky;
    top: var(--spacing-xl);
}

.single-standard__sidebar .widget {
    margin-bottom: var(--spacing-xl);
    padding: var(--spacing-lg);
    background: var(--color-surface);
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border);
}

.single-standard__sidebar .widget-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-base);
    font-weight: 800;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin: 0 0 var(--spacing-md);
    padding-bottom: var(--spacing-sm);
    border-bottom: 2px solid var(--color-primary);
    color: var(--color-text);
}

/* =====================================================================
   SINGLE — WIDE LAYOUT
   ===================================================================== */

.single-wide {
    max-width: 860px;
    margin: 0 auto;
}

.single-wide__content {
    /* Inherits the full wide column */
}

/* =====================================================================
   SINGLE — FULL WIDTH LAYOUT
   ===================================================================== */

.single-fullwidth {
    /* Stretches full width; container handles margins */
}

.single-fullwidth__hero {
    position: relative;
    width: 100%;
    aspect-ratio: 21 / 8;
    overflow: hidden;
    border-radius: var(--radius-lg);
    margin-bottom: var(--spacing-2xl);
    background: var(--color-dark);
}

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

.single-fullwidth__hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        to bottom,
        transparent 25%,
        rgba(10, 15, 30, 0.55) 60%,
        rgba(10, 15, 30, 0.88) 100%
    );
    display: flex;
    align-items: flex-end;
}

.single-fullwidth__hero-body {
    padding: var(--spacing-2xl) var(--spacing-2xl);
    width: 100%;
    max-width: 80ch;
    color: var(--color-white);
}

.single-fullwidth__hero-body .category-badge {
    margin-bottom: var(--spacing-sm);
}

.single-fullwidth__title {
    font-family: var(--font-heading);
    font-size: clamp(var(--font-size-2xl), 4vw, 3.25rem);
    font-weight: 900;
    line-height: 1.15;
    margin: 0 0 var(--spacing-md);
    text-shadow: 0 2px 6px rgba(0,0,0,0.4);
    color: var(--color-white);
}

.single-fullwidth__header {
    padding: var(--spacing-2xl) 0;
    border-bottom: 1px solid var(--color-border);
    margin-bottom: var(--spacing-2xl);
}

.single-fullwidth__header .single-fullwidth__title {
    color: var(--color-text);
    text-shadow: none;
}

.single-fullwidth__meta {
    color: rgba(255,255,255,0.75);
    margin-top: var(--spacing-sm);
}

.single-fullwidth__content {
    max-width: 75ch;
    margin: 0 auto;
    font-size: var(--font-size-lg);
    line-height: 1.75;
}

.single-fullwidth__content .entry-content p {
    margin-bottom: var(--spacing-lg);
}

/* =====================================================================
   SINGLE — MAGAZINE LAYOUT
   ===================================================================== */

.single-magazine {
    max-width: 900px;
    margin: 0 auto;
}

.single-magazine__header {
    padding-bottom: var(--spacing-xl);
    margin-bottom: var(--spacing-xl);
    border-bottom: 1px solid var(--color-border);
}

.single-magazine__header .category-badge {
    margin-bottom: var(--spacing-sm);
}

.single-magazine__title {
    font-family: var(--font-heading);
    font-size: clamp(var(--font-size-2xl), 3.5vw, 3rem);
    font-weight: 900;
    line-height: 1.15;
    margin: var(--spacing-sm) 0 var(--spacing-md);
    color: var(--color-text);
}

.single-magazine__subtitle {
    font-size: var(--font-size-xl);
    color: var(--color-text-muted);
    font-style: italic;
    line-height: 1.55;
    margin: 0 0 var(--spacing-md);
    border-left: 4px solid var(--color-primary);
    padding-left: var(--spacing-md);
}

.single-magazine__meta {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.single-magazine__figure {
    margin: 0 0 var(--spacing-xl);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.single-magazine__figure img {
    display: block;
    width: 100%;
    height: auto;
    max-height: 520px;
    object-fit: cover;
}

.single-magazine__caption {
    display: block;
    padding: var(--spacing-sm) var(--spacing-md);
    background: var(--color-surface-alt);
    font-size: var(--font-size-xs);
    color: var(--color-text-muted);
    font-style: italic;
    border-bottom-left-radius: var(--radius-md);
    border-bottom-right-radius: var(--radius-md);
}

.single-magazine__content {
    font-size: var(--font-size-lg);
    line-height: 1.8;
    color: var(--color-text);
}

/* Drop cap effect */
.dropcap .entry-content > p:first-of-type::first-letter,
.single-magazine__content > p:first-of-type::first-letter {
    float: left;
    font-size: 4.5em;
    line-height: 0.75;
    padding: 4px 8px 0 0;
    font-family: var(--font-heading);
    font-weight: 900;
    color: var(--color-primary);
}

/* Pull quotes */
.single-magazine__content blockquote,
.dropcap blockquote {
    margin: var(--spacing-xl) 0;
    padding: var(--spacing-lg) var(--spacing-xl);
    border-left: 5px solid var(--color-primary);
    background: var(--color-surface);
    border-radius: 0 var(--radius-md) var(--radius-md) 0;
    font-size: var(--font-size-xl);
    font-style: italic;
    color: var(--color-dark-mid);
    line-height: 1.6;
}

.single-magazine__content blockquote p,
.dropcap blockquote p {
    margin: 0;
}

.single-magazine__footer {
    margin-top: var(--spacing-2xl);
    padding-top: var(--spacing-xl);
    border-top: 1px solid var(--color-border);
}

/* =====================================================================
   SINGLE — MINIMAL LAYOUT
   ===================================================================== */

.single-minimal {
    max-width: 65ch;
    margin: 0 auto;
    padding: var(--spacing-2xl) 0;
}

.single-minimal__header {
    text-align: center;
    padding-bottom: var(--spacing-xl);
}

.single-minimal__meta-top {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: var(--spacing-sm);
    margin-bottom: var(--spacing-md);
}

.single-minimal__title {
    font-family: var(--font-heading);
    font-size: clamp(var(--font-size-2xl), 3.2vw, 2.75rem);
    font-weight: 900;
    line-height: 1.2;
    margin: 0 0 var(--spacing-md);
    color: var(--color-text);
}

.single-minimal__byline {
    font-size: var(--font-size-sm);
    color: var(--color-text-muted);
}

.single-minimal__figure {
    margin: 0 0 var(--spacing-2xl);
    border-radius: var(--radius-md);
    overflow: hidden;
}

.single-minimal__figure img {
    display: block;
    width: 100%;
    height: auto;
}

.single-minimal__content {
    font-size: var(--font-size-lg);
    line-height: 1.82;
    color: var(--color-text);
}

.single-minimal__content p {
    margin-bottom: var(--spacing-lg);
}

.single-minimal__content h2,
.single-minimal__content h3,
.single-minimal__content h4 {
    font-family: var(--font-heading);
    font-weight: 800;
    line-height: 1.25;
    margin: var(--spacing-xl) 0 var(--spacing-sm);
    color: var(--color-text);
}

.single-minimal__content a {
    color: var(--color-accent);
    text-decoration: underline;
    text-underline-offset: 3px;
}

.single-minimal__content a:hover {
    color: var(--color-primary);
}

.single-minimal__divider {
    border: none;
    border-top: 1px solid var(--color-border);
    margin: var(--spacing-2xl) 0 var(--spacing-xl);
}

.single-minimal__footer {
    text-align: center;
    padding-bottom: var(--spacing-2xl);
}

/* =====================================================================
   ARCHIVE HEADER
   ===================================================================== */

.archive-header {
    margin-bottom: var(--spacing-2xl);
    padding: var(--spacing-xl);
    background: var(--color-surface);
    border-radius: var(--radius-lg);
    border-left: 5px solid var(--color-border);
    box-shadow: 0 1px 4px rgba(0,0,0,0.06);
}

.archive-header--colored {
    border-left-color: var(--archive-accent, var(--color-primary));
    background: color-mix(in srgb, var(--archive-accent, var(--color-primary)) 6%, var(--color-surface) 94%);
}

.archive-header__inner {
    margin-top: var(--spacing-sm);
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: var(--spacing-sm);
}

.archive-header__title-row {
    display: flex;
    align-items: flex-start;
    gap: var(--spacing-md);
    flex: 1;
    min-width: 0;
}

.archive-header__icon {
    color: var(--archive-accent, var(--color-primary));
    flex-shrink: 0;
    margin-top: 4px;
    opacity: 0.85;
    line-height: 0;
}

.archive-header__text {
    flex: 1;
    min-width: 0;
}

.archive-title {
    font-family: var(--font-heading);
    font-size: clamp(var(--font-size-2xl), 3vw, var(--font-size-4xl));
    font-weight: 900;
    margin: 0 0 var(--spacing-xs);
    color: var(--color-text);
}

.archive-description {
    font-size: var(--font-size-lg);
    color: var(--color-text-muted);
    line-height: 1.65;
    max-width: 65ch;
}

.archive-description p {
    margin: 0;
}

.archive-post-count {
    display: inline-flex;
    align-items: center;
    flex-shrink: 0;
    font-size: var(--font-size-sm);
    font-weight: 700;
    color: var(--archive-accent, var(--color-primary));
    background: color-mix(in srgb, var(--archive-accent, var(--color-primary)) 12%, transparent 88%);
    padding: 4px var(--spacing-sm);
    border-radius: var(--radius-full);
    border: 1px solid color-mix(in srgb, var(--archive-accent, var(--color-primary)) 25%, transparent 75%);
    white-space: nowrap;
}

/* =====================================================================
   POST NAVIGATION
   ===================================================================== */

.post-navigation {
    padding: var(--spacing-2xl) 0;
    border-top: 1px solid var(--color-border);
    margin-top: var(--spacing-2xl);
}

.nav-previous,
.nav-next {
    display: flex;
    flex-direction: column;
    gap: var(--spacing-xs);
}

.nav-next {
    text-align: right;
    align-items: flex-end;
}

.nav-label {
    font-size: var(--font-size-xs);
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
}

.nav-title {
    font-family: var(--font-heading);
    font-size: var(--font-size-base);
    font-weight: 700;
    color: var(--color-text);
    text-decoration: none;
    transition: color var(--transition-fast);
    line-height: 1.35;
}

.post-navigation a:hover .nav-title {
    color: var(--color-primary);
}

/* =====================================================================
   PAGINATION
   ===================================================================== */

.newshub-pagination,
.pagination,
.pagination .nav-links {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: var(--spacing-xs);
    padding: var(--spacing-xl) 0;
    flex-wrap: wrap;
}

.post-navigation .nav-links {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--spacing-xl);
}

.newshub-pagination a,
.newshub-pagination span,
.page-numbers {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 40px;
    height: 40px;
    padding: 0 var(--spacing-sm);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-sm);
    font-size: var(--font-size-sm);
    font-weight: 600;
    color: var(--color-text-muted);
    text-decoration: none;
    background: var(--color-white);
    transition: background-color var(--transition-fast), color var(--transition-fast), border-color var(--transition-fast);
}

.newshub-pagination a:hover,
.page-numbers:not(.current):hover {
    background-color: var(--color-surface-alt);
    border-color: var(--color-text-muted);
    color: var(--color-text);
}

.page-numbers.current {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: var(--color-white);
}

.page-numbers.dots {
    border-color: transparent;
    background: none;
}

/* =====================================================================
   NO RESULTS
   ===================================================================== */

.no-results {
    padding: var(--spacing-2xl);
    text-align: center;
    font-size: var(--font-size-lg);
    color: var(--color-text-muted);
    background: var(--color-surface);
    border-radius: var(--radius-md);
    border: 1px dashed var(--color-border);
}

/* =====================================================================
   CONTAINER VARIANTS
   ===================================================================== */

.container--wide {
    max-width: none;
}

/* =====================================================================
   RESPONSIVE — TABLET (≤ 1024px)
   ===================================================================== */

@media (max-width: 1024px) {

    /* Home Classic */
    .home-grid__inner {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Home Magazine */
    .magazine-lead {
        grid-template-columns: 1fr;
        grid-template-rows: auto;
    }

    .magazine-lead__primary {
        grid-row: auto;
    }

    .magazine-secondary {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Home Breaking */
    .home-breaking__layout {
        grid-template-columns: 1fr;
    }

    .home-breaking__sidebar {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
    }

    .home-breaking__grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Editorial */
    .editorial-section__posts {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Archive Grid */
    .archive-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Archive Masonry */
    .archive-masonry {
        grid-template-columns: repeat(2, 1fr);
    }

    /* Archive List */
    .archive-list__thumb {
        width: 160px;
        height: 110px;
    }

    /* Single Standard */
    .single-standard {
        grid-template-columns: 1fr 260px;
        gap: var(--spacing-xl);
    }

    /* Single Full Width */
    .single-fullwidth__hero {
        aspect-ratio: 16 / 7;
    }

    .single-fullwidth__hero-body {
        padding: var(--spacing-xl);
    }
}

/* =====================================================================
   RESPONSIVE — MOBILE (≤ 768px)
   ===================================================================== */

@media (max-width: 768px) {

    /* Home Classic */
    .hero-card__body {
        padding: var(--spacing-lg);
    }

    .hero-card__excerpt {
        display: none;
    }

    .home-grid__inner {
        grid-template-columns: 1fr;
    }

    /* Home Magazine */
    .magazine-secondary {
        grid-template-columns: 1fr;
    }

    .magazine-lead__secondary {
        flex-direction: column;
    }

    .magazine-lead__secondary .magazine-lead__image {
        width: 100%;
        height: 160px;
    }

    /* Home Compact */
    .compact-list__thumb {
        width: 72px;
        height: 54px;
    }

    /* Home Breaking */
    .home-breaking__sidebar {
        grid-template-columns: 1fr;
    }

    .home-breaking__grid {
        grid-template-columns: 1fr;
    }

    /* Editorial */
    .editorial-section__posts {
        grid-template-columns: 1fr;
    }

    .editorial-section__header {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-xs);
    }

    /* Archive Grid */
    .archive-grid {
        grid-template-columns: 1fr;
    }

    /* Archive List */
    .archive-list__item {
        flex-direction: column;
    }

    .archive-list__thumb {
        width: 100%;
        height: 200px;
    }

    /* Archive Masonry */
    .archive-masonry {
        grid-template-columns: 1fr;
        grid-auto-rows: auto;
    }

    /* Archive Compact */
    .archive-compact__item {
        flex-wrap: wrap;
    }

    .archive-compact__date {
        margin-left: 0;
        padding-left: var(--spacing-lg);
        width: 100%;
    }

    /* Archive Full Width */
    .fullwidth-item__image {
        aspect-ratio: 16 / 9;
    }

    .fullwidth-item__title {
        font-size: var(--font-size-xl);
    }

    /* Single Standard */
    .single-standard {
        grid-template-columns: 1fr;
    }

    .single-standard__sidebar {
        position: static;
    }

    /* Single Full Width */
    .single-fullwidth__hero {
        aspect-ratio: 4 / 3;
        border-radius: var(--radius-md);
    }

    .single-fullwidth__hero-body {
        padding: var(--spacing-md);
    }

    .single-fullwidth__content {
        font-size: var(--font-size-base);
    }

    /* Single Magazine */
    .single-magazine__title {
        font-size: var(--font-size-2xl);
    }

    .single-magazine__subtitle {
        font-size: var(--font-size-base);
    }

    /* Single Minimal */
    .single-minimal {
        max-width: 100%;
    }

    .single-minimal__title {
        font-size: var(--font-size-2xl);
    }

    /* Post navigation */
    .post-navigation .nav-links {
        grid-template-columns: 1fr;
    }

    .nav-next {
        text-align: left;
        align-items: flex-start;
    }
}

/* =====================================================================
   RESPONSIVE — SMALL MOBILE (≤ 480px)
   ===================================================================== */

@media (max-width: 480px) {

    .hero-card__title {
        font-size: var(--font-size-xl);
    }

    .hero-card__body {
        padding: var(--spacing-md);
    }

    .home-breaking__alert {
        font-size: var(--font-size-xs);
    }

    .breaking-side-item {
        flex-direction: column;
    }

    .breaking-side-item__thumb {
        width: 100%;
        height: 140px;
    }

    .single-fullwidth__title {
        font-size: var(--font-size-xl);
    }

    .archive-compact__body {
        flex-direction: column;
        align-items: flex-start;
        gap: var(--spacing-xs);
    }
}

/* =====================================================================
   DARK MODE — [data-theme="dark"]
   ===================================================================== */

[data-theme="dark"] {
    --color-dark:        #f1f5f9;
    --color-dark-mid:    #e2e8f0;
    --color-muted:       #94a3b8;
    --color-border:      #2d3748;
    --color-surface:     #1e2537;
    --color-surface-alt: #28334a;
    --color-white:       #0f172a;
    --color-text:        #e2e8f0;
    --color-text-muted:  #94a3b8;
}

[data-theme="dark"] body {
    background-color: #0f172a;
    color: #e2e8f0;
}

/* Hero Card — dark mode */
[data-theme="dark"] .hero-card {
    background-color: #1e2537;
}

[data-theme="dark"] .hero-card__body {
    color: #f1f5f9;
}

/* Post Cards — dark mode */
[data-theme="dark"] .post-card {
    background: #1e2537;
    border-color: #2d3748;
}

[data-theme="dark"] .post-card__title a {
    color: #e2e8f0;
}

[data-theme="dark"] .post-card__excerpt {
    color: #94a3b8;
}

[data-theme="dark"] .post-card__meta {
    border-top-color: #2d3748;
}

/* Magazine — dark mode */
[data-theme="dark"] .magazine-lead__secondary {
    background: #1e2537;
    border-color: #2d3748;
}

[data-theme="dark"] .magazine-lead__secondary .magazine-lead__title {
    color: #e2e8f0;
}

/* Compact List — dark mode */
[data-theme="dark"] .compact-list__item {
    border-bottom-color: #2d3748;
}

[data-theme="dark"] .compact-list__item:hover {
    background-color: #1e2537;
}

[data-theme="dark"] .compact-list__title a {
    color: #e2e8f0;
}

/* Breaking — dark mode */
[data-theme="dark"] .breaking-side-item {
    background: #1e2537;
    border-color: #2d3748;
}

[data-theme="dark"] .breaking-side-item__title a {
    color: #e2e8f0;
}

[data-theme="dark"] .breaking-feature__body {
    background: #1e2537;
}

[data-theme="dark"] .breaking-feature__title a {
    color: #e2e8f0;
}

/* Editorial — dark mode */
[data-theme="dark"] .editorial-section {
    border-bottom-color: #2d3748;
}

[data-theme="dark"] .editorial-section__header {
    border-bottom-color: var(--color-primary);
}

[data-theme="dark"] .editorial-section__title a {
    color: #e2e8f0;
}

/* Archive List — dark mode */
[data-theme="dark"] .archive-list__item {
    border-bottom-color: #2d3748;
}

[data-theme="dark"] .archive-list__title a {
    color: #e2e8f0;
}

[data-theme="dark"] .archive-list__excerpt {
    color: #94a3b8;
}

/* Archive Masonry — dark mode */
[data-theme="dark"] .masonry-item {
    background: #1e2537;
    border-color: #2d3748;
}

[data-theme="dark"] .masonry-item__title a {
    color: #e2e8f0;
}

/* Archive Compact — dark mode */
[data-theme="dark"] .archive-compact__item {
    border-bottom-color: #2d3748;
}

[data-theme="dark"] .archive-compact__item:first-child {
    border-top-color: #2d3748;
}

[data-theme="dark"] .archive-compact__item:hover {
    background-color: #1e2537;
}

[data-theme="dark"] .archive-compact__title a {
    color: #e2e8f0;
}

[data-theme="dark"] .archive-compact__date {
    color: #64748b;
}

/* Archive Full Width — dark mode */
[data-theme="dark"] .fullwidth-item {
    border-bottom-color: #2d3748;
}

[data-theme="dark"] .fullwidth-item__title a {
    color: #e2e8f0;
}

[data-theme="dark"] .fullwidth-item__excerpt {
    color: #94a3b8;
}

/* Single Standard — dark mode */
[data-theme="dark"] .single-standard__sidebar .widget {
    background: #1e2537;
    border-color: #2d3748;
}

[data-theme="dark"] .single-standard__sidebar .widget-title {
    color: #e2e8f0;
    border-bottom-color: var(--color-primary);
}

/* Single Magazine — dark mode */
[data-theme="dark"] .single-magazine__header {
    border-bottom-color: #2d3748;
}

[data-theme="dark"] .single-magazine__title {
    color: #f1f5f9;
}

[data-theme="dark"] .single-magazine__subtitle {
    color: #94a3b8;
}

[data-theme="dark"] .single-magazine__caption {
    background: #1e2537;
    color: #94a3b8;
}

[data-theme="dark"] .single-magazine__content {
    color: #cbd5e1;
}

[data-theme="dark"] .single-magazine__content blockquote,
[data-theme="dark"] .dropcap blockquote {
    background: #1e2537;
    color: #94a3b8;
}

[data-theme="dark"] .single-magazine__footer {
    border-top-color: #2d3748;
}

/* Single Minimal — dark mode */
[data-theme="dark"] .single-minimal__title {
    color: #f1f5f9;
}

[data-theme="dark"] .single-minimal__content {
    color: #cbd5e1;
}

[data-theme="dark"] .single-minimal__content h2,
[data-theme="dark"] .single-minimal__content h3,
[data-theme="dark"] .single-minimal__content h4 {
    color: #e2e8f0;
}

[data-theme="dark"] .single-minimal__content a {
    color: #7ec8e3;
}

[data-theme="dark"] .single-minimal__divider {
    border-top-color: #2d3748;
}

/* Single Full Width — dark mode */
[data-theme="dark"] .single-fullwidth__header {
    border-bottom-color: #2d3748;
}

[data-theme="dark"] .single-fullwidth__header .single-fullwidth__title {
    color: #f1f5f9;
}

[data-theme="dark"] .single-fullwidth__content {
    color: #cbd5e1;
}

/* Archive Header — dark mode */
[data-theme="dark"] .archive-header {
    background: #1e2537;
    border-left-color: var(--archive-accent, var(--color-primary));
}

[data-theme="dark"] .archive-header--colored {
    background: color-mix(in srgb, var(--archive-accent, var(--color-primary)) 12%, #1a1a2e 88%);
}

[data-theme="dark"] .archive-title {
    color: #f1f5f9;
}

[data-theme="dark"] .archive-description {
    color: #94a3b8;
}

[data-theme="dark"] .archive-post-count {
    background: rgba(255,255,255,0.08);
    border-color: rgba(255,255,255,0.15);
}

[data-theme="dark"] .archive-header__icon {
    opacity: 0.7;
}

/* Pagination — dark mode */
[data-theme="dark"] .page-numbers {
    background: #1e2537;
    border-color: #2d3748;
    color: #94a3b8;
}

[data-theme="dark"] .page-numbers:not(.current):hover {
    background: #28334a;
    border-color: #4a5568;
    color: #e2e8f0;
}

[data-theme="dark"] .page-numbers.current {
    background-color: var(--color-primary);
    border-color: var(--color-primary);
    color: #ffffff;
}

/* Post navigation — dark mode */
[data-theme="dark"] .post-navigation {
    border-top-color: #2d3748;
}

[data-theme="dark"] .nav-title {
    color: #e2e8f0;
}

/* Entry tags — dark mode */
[data-theme="dark"] .entry-tags a {
    border-color: #2d3748;
    color: #94a3b8;
}

[data-theme="dark"] .entry-tags a:hover {
    border-color: var(--color-primary);
    color: var(--color-primary);
}

/* No results — dark mode */
[data-theme="dark"] .no-results {
    background: #1e2537;
    border-color: #2d3748;
    color: #94a3b8;
}

/* =====================================================================
   DARK MODE — prefers-color-scheme (auto fallback)
   ===================================================================== */

@media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
        --color-border:      #2d3748;
        --color-surface:     #1e2537;
        --color-surface-alt: #28334a;
        --color-white:       #0f172a;
        --color-text:        #e2e8f0;
        --color-text-muted:  #94a3b8;
    }

    :root:not([data-theme="light"]) body {
        background-color: #0f172a;
        color: #e2e8f0;
    }

    :root:not([data-theme="light"]) .post-card {
        background: #1e2537;
        border-color: #2d3748;
    }

    :root:not([data-theme="light"]) .post-card__title a {
        color: #e2e8f0;
    }

    :root:not([data-theme="light"]) .archive-list__item {
        border-bottom-color: #2d3748;
    }

    :root:not([data-theme="light"]) .archive-list__title a {
        color: #e2e8f0;
    }

    :root:not([data-theme="light"]) .masonry-item {
        background: #1e2537;
        border-color: #2d3748;
    }

    :root:not([data-theme="light"]) .masonry-item__title a {
        color: #e2e8f0;
    }

    :root:not([data-theme="light"]) .compact-list__item {
        border-bottom-color: #2d3748;
    }

    :root:not([data-theme="light"]) .compact-list__title a {
        color: #e2e8f0;
    }

    :root:not([data-theme="light"]) .breaking-side-item {
        background: #1e2537;
        border-color: #2d3748;
    }

    :root:not([data-theme="light"]) .magazine-lead__secondary {
        background: #1e2537;
        border-color: #2d3748;
    }

    :root:not([data-theme="light"]) .archive-compact__item {
        border-bottom-color: #2d3748;
    }

    :root:not([data-theme="light"]) .archive-compact__title a {
        color: #e2e8f0;
    }

    :root:not([data-theme="light"]) .fullwidth-item {
        border-bottom-color: #2d3748;
    }

    :root:not([data-theme="light"]) .fullwidth-item__title a {
        color: #e2e8f0;
    }

    :root:not([data-theme="light"]) .single-magazine__title {
        color: #f1f5f9;
    }

    :root:not([data-theme="light"]) .single-minimal__title {
        color: #f1f5f9;
    }

    :root:not([data-theme="light"]) .page-numbers {
        background: #1e2537;
        border-color: #2d3748;
        color: #94a3b8;
    }

    :root:not([data-theme="light"]) .page-numbers.current {
        background-color: var(--color-primary);
        border-color: var(--color-primary);
        color: #ffffff;
    }

    :root:not([data-theme="light"]) .editorial-section {
        border-bottom-color: #2d3748;
    }

    :root:not([data-theme="light"]) .archive-header {
        border-bottom-color: #2d3748;
    }

    :root:not([data-theme="light"]) .archive-title {
        color: #f1f5f9;
    }

    :root:not([data-theme="light"]) .post-navigation {
        border-top-color: #2d3748;
    }

    :root:not([data-theme="light"]) .nav-title {
        color: #e2e8f0;
    }
}

/* =====================================================================
   FOCUS STATES — Accessibility
   ===================================================================== */

a:focus-visible,
button:focus-visible,
input:focus-visible,
[tabindex="0"]:focus-visible {
    outline: 3px solid var(--color-primary);
    outline-offset: 3px;
    border-radius: var(--radius-sm);
}

.hero-card__title a:focus-visible,
.post-card__title a:focus-visible,
.archive-list__title a:focus-visible,
.masonry-item__title a:focus-visible,
.compact-list__title a:focus-visible,
.fullwidth-item__title a:focus-visible,
.breaking-feature__title a:focus-visible,
.breaking-side-item__title a:focus-visible,
.archive-compact__title a:focus-visible,
.magazine-lead__title a:focus-visible {
    text-decoration: underline;
    text-underline-offset: 3px;
}

/* =====================================================================
   HOVER / INTERACTION STATES (extra polish)
   ===================================================================== */

/* Elevated card hover glow */
.post-card:hover,
.masonry-item:hover,
.breaking-side-item:hover {
    box-shadow:
        var(--shadow-hover),
        0 0 0 1px rgba(230, 57, 70, 0.06);
}

/* Archive compact highlight bar */
.archive-compact__item:hover .archive-compact__dot {
    transform: scale(1.4);
    transition: transform var(--transition-fast);
}

/* Transition on category badge hover for all layouts */
.archive-list__body .category-badge:hover,
.masonry-item__body .category-badge:hover,
.compact-list__body .category-badge:hover,
.fullwidth-item__body .category-badge:hover,
.breaking-feature__body .category-badge:hover,
.breaking-side-item .category-badge:hover,
.magazine-lead__body .category-badge:hover,
.editorial-section__posts .category-badge:hover {
    background-color: var(--color-dark-mid);
    transform: none;
}

/* Image overlay fade on hover */
.archive-list__thumb img,
.compact-list__thumb img,
.masonry-item__image img,
.fullwidth-item__image img,
.breaking-side-item__thumb img,
.magazine-lead__secondary .magazine-lead__image img {
    transition: transform var(--transition-slow), filter var(--transition-base);
}

.archive-list__item:hover .archive-list__thumb img,
.compact-list__item:hover .compact-list__thumb img,
.masonry-item:hover .masonry-item__image img,
.fullwidth-item:hover .fullwidth-item__image img,
.breaking-side-item:hover .breaking-side-item__thumb img,
.magazine-lead__secondary:hover .magazine-lead__image img {
    filter: brightness(0.92);
}

/* =====================================================================
   REDUCED MOTION — layouts
   ===================================================================== */
@media (prefers-reduced-motion: reduce) {
    .post-card__thumb img,
    .archive-list__thumb img,
    .masonry-item__image img,
    .fullwidth-item__image img,
    .breaking-side-item__thumb img,
    .magazine-lead__image img,
    .hero-card__image img {
        transition: none !important;
    }

    .post-card:hover .post-card__thumb img,
    .archive-list__item:hover .archive-list__thumb img,
    .masonry-item:hover .masonry-item__image img,
    .fullwidth-item:hover .fullwidth-item__image img,
    .breaking-side-item:hover .breaking-side-item__thumb img,
    .magazine-lead__secondary:hover .magazine-lead__image img {
        transform: none !important;
        filter: none !important;
    }

    .post-card,
    .masonry-item,
    .breaking-side-item,
    .archive-list__item,
    .post-card--featured {
        transition: none !important;
    }
}
