/* ================================================================
   MAGAZINE V1 — Premium Editorial Template
   A warm, sophisticated magazine layout for thematic niche sites.
   Inspired by Monocle, Kinfolk, Cereal magazine aesthetics.
   ================================================================ */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,800;0,9..144,900;1,9..144,400;1,9..144,500;1,9..144,700&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=Source+Serif+4:ital,opsz,wght@0,8..60,300;0,8..60,400;0,8..60,500;0,8..60,600;1,8..60,400;1,8..60,500&display=swap');

/* ============================================
   1. CSS VARIABLES
   ============================================ */
:root {
    /* Palette — Warm Editorial */
    --color-accent: #B85C38;
    --color-accent-light: #D4845E;
    --color-accent-dark: #9A4A2E;
    --color-accent-muted: rgba(184, 92, 56, 0.08);

    --color-forest: #2C3930;
    --color-forest-light: #3D4F44;

    --color-orange: #C77B3F;
    --color-orange-light: #F5EDE8;
    --color-orange-dark: #A86530;

    /* Slate palette */
    --color-slate-50: #FAF7F2;
    --color-slate-100: #F5F0E8;
    --color-slate-200: #E8E2D8;
    --color-slate-300: #D4CEC4;
    --color-slate-400: #A8A298;
    --color-slate-500: #78736A;
    --color-slate-600: #5A564F;
    --color-slate-700: #3D3A35;
    --color-slate-800: #2D2A26;
    --color-slate-900: #1E1C19;
    --color-slate-950: #121110;

    /* Semantic */
    --color-text: #2D2A26;
    --color-text-light: #5A564F;
    --color-text-muted: #78736A;
    --color-bg: #FAF7F2;
    --color-bg-light: #FFFFFF;
    --color-bg-alt: #F0EBE3;
    --color-bg-warm: #F5EDE8;
    --color-border: #E8E2D8;
    --color-border-light: #F0EBE3;

    --color-success: #4A7C59;
    --color-error: #C4453C;

    /* Typography */
    --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
    --font-sans: 'DM Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
    --font-serif: 'Source Serif 4', Georgia, 'Times New Roman', serif;

    /* Spacing */
    --max-width: 1320px;
    --content-width: 780px;
    --header-height: 80px;
    --header-height-scrolled: 64px;

    /* Radius */
    --radius: 6px;
    --radius-lg: 12px;
    --radius-xl: 20px;
    --radius-2xl: 28px;

    /* Shadows */
    --shadow-sm: 0 1px 3px rgba(45, 42, 38, 0.04);
    --shadow-md: 0 4px 12px rgba(45, 42, 38, 0.06);
    --shadow-lg: 0 8px 24px rgba(45, 42, 38, 0.08);
    --shadow-xl: 0 16px 40px rgba(45, 42, 38, 0.1);
    --shadow-2xl: 0 24px 56px rgba(45, 42, 38, 0.14);
    --shadow-accent: 0 8px 32px rgba(184, 92, 56, 0.18);

    /* Transitions */
    --transition-fast: 0.15s ease;
    --transition: 0.25s ease;
    --transition-slow: 0.4s ease;
    --transition-slower: 0.6s cubic-bezier(0.22, 1, 0.36, 1);

    /* Gradient */
    --gradient-accent: linear-gradient(135deg, var(--color-accent) 0%, var(--color-orange) 100%);
}

/* ============================================
   2. DARK MODE
   ============================================ */
@media (prefers-color-scheme: dark) {
    :root {
        --color-accent: #D4845E;
        --color-accent-light: #E8A57E;
        --color-accent-dark: #B85C38;
        --color-accent-muted: rgba(212, 132, 94, 0.12);

        --color-text: #E8E2D8;
        --color-text-light: #A8A298;
        --color-text-muted: #78736A;
        --color-bg: #1A1917;
        --color-bg-light: #242220;
        --color-bg-alt: #2A2826;
        --color-bg-warm: #2A2523;
        --color-border: #3D3A35;
        --color-border-light: #2D2A26;
    }
}

/* ============================================
   3. RESET & BASE
   ============================================ */
*, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
}

html {
    scroll-behavior: smooth;
    overflow-x: hidden;
}

body {
    font-family: var(--font-sans);
    color: var(--color-text);
    background: var(--color-bg);
    line-height: 1.65;
    font-size: 1rem;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-optical-sizing: auto;
}

/* Subtle paper grain texture */
body::before {
    content: '';
    position: fixed;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.015'/%3E%3C/svg%3E");
    pointer-events: none;
    z-index: 9999;
}

a {
    color: var(--color-accent);
    text-decoration: none;
    transition: color var(--transition);
}
a:hover {
    color: var(--color-accent-dark);
}

img {
    max-width: 100%;
    height: auto;
    display: block;
}

/* ============================================
   4. LAYOUT
   ============================================ */
.container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

@media (min-width: 1024px) {
    .container {
        padding: 0 3rem;
    }
}

/* Fullwidth breakout */
.dc-fullwidth,
.mag-fullwidth {
    width: 100vw;
    position: relative;
    left: 50%;
    margin-left: -50vw;
}

/* Decorative rule motif — used throughout */
.mag-rule {
    display: block;
    width: 48px;
    height: 2px;
    background: var(--color-accent);
    border: none;
    margin: 1.5rem 0;
}

.mag-rule--center {
    margin-left: auto;
    margin-right: auto;
}

/* Section label — small uppercase category-style text */
.mag-label {
    font-family: var(--font-sans);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--color-accent);
}

/* ============================================
   5. HEADER
   ============================================ */
.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 100;
    padding: 0;
    background: rgba(250, 247, 242, 0.92);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--color-border);
    transition: all var(--transition-slow);
    height: var(--header-height);
    display: flex;
    align-items: center;
}

.site-header.scrolled {
    height: var(--header-height-scrolled);
    box-shadow: var(--shadow-sm);
}

@media (prefers-color-scheme: dark) {
    .site-header {
        background: rgba(26, 25, 23, 0.92);
    }
}

.header-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    width: 100%;
}

/* Logo */
.site-logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--color-text);
    font-family: var(--font-display);
    font-size: 1.375rem;
    font-weight: 700;
    letter-spacing: -0.02em;
    transition: color var(--transition);
    flex-shrink: 0;
}
.site-logo:hover {
    color: var(--color-accent);
}

.site-logo__icon {
    position: relative;
    width: 36px;
    height: 36px;
}
.site-logo__icon-bg {
    width: 36px;
    height: 36px;
    background: var(--color-text);
    border-radius: var(--radius);
    transition: all var(--transition-slow);
}
.site-logo:hover .site-logo__icon-bg {
    background: var(--color-accent);
    border-radius: 50%;
}
@media (prefers-color-scheme: dark) {
    .site-logo__icon-bg {
        background: var(--color-slate-200);
    }
}
.site-logo__icon-letter {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-bg);
    font-size: 1rem;
    font-weight: 800;
    font-family: var(--font-display);
}
@media (prefers-color-scheme: dark) {
    .site-logo__icon-letter {
        color: var(--color-slate-900);
    }
}

.site-logo__text {
    display: flex;
    align-items: baseline;
}
.site-logo__dot {
    color: var(--color-accent);
}

.site-logo__img {
    height: 40px;
    width: auto;
    transition: transform var(--transition);
}
.site-logo:hover .site-logo__img {
    transform: scale(1.05);
}

/* Navigation — Elegant underline style */
.site-nav {
    display: none;
    align-items: center;
    gap: 0.25rem;
}

@media (min-width: 1024px) {
    .site-nav {
        display: flex;
    }
}

.site-nav a {
    position: relative;
    font-family: var(--font-sans);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text-light);
    padding: 0.5rem 0.875rem;
    transition: color var(--transition);
}
.site-nav a::after {
    content: '';
    position: absolute;
    bottom: 0.25rem;
    left: 0.875rem;
    right: 0.875rem;
    height: 1px;
    background: var(--color-accent);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform var(--transition-slow);
}
.site-nav a:hover,
.site-nav a.active {
    color: var(--color-text);
}
.site-nav a:hover::after,
.site-nav a.active::after {
    transform: scaleX(1);
    transform-origin: left;
}

/* Nav dropdown (mega menu) */
.nav-item {
    position: relative;
}
.nav-item::after {
    content: '';
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    height: 1rem;
}
.nav-dropdown {
    display: none;
    position: absolute;
    top: calc(100% + 0.75rem);
    left: 50%;
    transform: translateX(-50%);
    min-width: 480px;
    padding: 1.25rem;
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    box-shadow: var(--shadow-xl);
    z-index: 1000;
    animation: magDropdown 0.3s var(--transition-slower);
}

@keyframes magDropdown {
    from { opacity: 0; transform: translateX(-50%) translateY(-6px); }
    to { opacity: 1; transform: translateX(-50%) translateY(0); }
}

.nav-item:hover .nav-dropdown {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 0.25rem;
}

.nav-dropdown a {
    display: block;
    padding: 0.75rem 1rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text);
    border-radius: var(--radius-lg);
    transition: all var(--transition-fast);
}
.nav-dropdown a::after {
    display: none;
}
.nav-dropdown a:hover {
    background: var(--color-bg-warm);
    color: var(--color-accent);
}

/* Header actions */
.header-actions {
    display: flex;
    align-items: center;
    gap: 1rem;
    flex-shrink: 0;
}

.header-search {
    display: none;
    align-items: center;
    gap: 0.5rem;
    color: var(--color-text-light);
    font-size: 0.8125rem;
    font-weight: 500;
    cursor: pointer;
    transition: color var(--transition);
}
.header-search:hover {
    color: var(--color-text);
}

@media (min-width: 640px) {
    .header-search {
        display: flex;
    }
}

.header-search svg {
    transition: transform var(--transition);
}
.header-search:hover svg {
    transform: scale(1.1);
}
.header-search input {
    display: none;
}

.header-divider {
    display: none;
    width: 1px;
    height: 20px;
    background: var(--color-border);
}

@media (min-width: 640px) {
    .header-divider {
        display: block;
    }
}

.header-cta {
    display: none;
    padding: 0.5rem 1.25rem;
    background: var(--color-text);
    color: var(--color-bg);
    font-family: var(--font-sans);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.04em;
    border-radius: 9999px;
    border: none;
    cursor: pointer;
    transition: all var(--transition);
}
.header-cta:hover {
    background: var(--color-accent);
    color: #ffffff;
    transform: translateY(-1px);
}

@media (min-width: 640px) {
    .header-cta {
        display: block;
    }
}

@media (prefers-color-scheme: dark) {
    .header-cta {
        background: var(--color-slate-200);
        color: var(--color-slate-900);
    }
    .header-cta:hover {
        background: var(--color-accent);
        color: #ffffff;
    }
}

/* Mobile toggle */
.mobile-toggle {
    display: flex;
    flex-direction: column;
    gap: 5px;
    background: none;
    border: none;
    cursor: pointer;
    padding: 4px;
}

@media (min-width: 1024px) {
    .mobile-toggle {
        display: none;
    }
}

.mobile-toggle span {
    width: 22px;
    height: 1.5px;
    background: var(--color-text);
    border-radius: 2px;
    transition: all var(--transition);
}

/* Mobile menu */
.mobile-menu {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    z-index: 200;
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    padding: 2rem;
    box-shadow: var(--shadow-xl);
}
.mobile-menu.open {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
}
.mobile-menu a {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 500;
    color: var(--color-text);
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--color-border-light);
    transition: color var(--transition);
}
.mobile-menu a:last-child {
    border-bottom: none;
}
.mobile-menu a:hover {
    color: var(--color-accent);
}

@media (min-width: 1024px) {
    .mobile-menu {
        display: none !important;
    }
}

/* Language switcher */
.lang-switcher {
    appearance: none;
    padding: 0.25rem 0.5rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius);
    background: transparent;
    font-size: 0.75rem;
    cursor: pointer;
    color: var(--color-text);
    font-family: var(--font-sans);
}

/* ============================================
   6. MAIN CONTENT
   ============================================ */
.site-main {
    padding-top: calc(var(--header-height) + 2rem);
    min-height: 60vh;
    animation: magPageEnter 0.6s ease-out;
}

@keyframes magPageEnter {
    from { opacity: 0; }
    to { opacity: 1; }
}

/* ============================================
   7. HOMEPAGE — MAG HERO
   ============================================ */
.mag-hero {
    padding: 4rem 0 5rem;
    border-bottom: 1px solid var(--color-border);
}

.mag-hero__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
    align-items: center;
}

@media (min-width: 768px) {
    .mag-hero__container {
        grid-template-columns: 1fr 1fr;
        gap: 4rem;
    }
}

@media (min-width: 1024px) {
    .mag-hero__container {
        gap: 5rem;
    }
}

.mag-hero__text {
    order: 2;
}

@media (min-width: 768px) {
    .mag-hero__text {
        order: 1;
    }
}

.mag-hero__label {
    font-family: var(--font-sans);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.14em;
    color: var(--color-accent);
    margin-bottom: 1.25rem;
    display: block;
}

.mag-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.25rem, 4vw, 3.75rem);
    font-weight: 800;
    line-height: 1.1;
    color: var(--color-text);
    margin-bottom: 1.5rem;
    letter-spacing: -0.02em;
    font-variation-settings: "opsz" 72;
}

.mag-hero__title em {
    font-style: italic;
    color: var(--color-accent);
    font-variation-settings: "opsz" 72;
}

.mag-hero__desc {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--color-text-light);
    line-height: 1.75;
    max-width: 32rem;
    margin-bottom: 2rem;
}

.mag-hero__nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 1rem;
    margin-bottom: 2rem;
}

.mag-hero__nav a {
    font-family: var(--font-sans);
    font-size: 0.8125rem;
    font-weight: 500;
    color: var(--color-text-muted);
    text-decoration: none;
    padding: 0.375rem 0.875rem;
    border: 1px solid var(--color-border);
    border-radius: 9999px;
    transition: all var(--transition);
}

.mag-hero__nav a:hover {
    color: var(--color-accent);
    border-color: var(--color-accent);
    background: var(--color-accent-muted);
}

.mag-hero__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    background: var(--color-text);
    color: var(--color-bg);
    padding: 0.875rem 2rem;
    border-radius: 9999px;
    font-family: var(--font-sans);
    font-size: 0.875rem;
    font-weight: 600;
    transition: all var(--transition);
}

.mag-hero__cta:hover {
    background: var(--color-accent);
    color: #ffffff;
    transform: translateY(-2px);
    box-shadow: var(--shadow-accent);
}

.mag-hero__cta svg {
    transition: transform var(--transition-fast);
}
.mag-hero__cta:hover svg {
    transform: translateX(4px);
}

.mag-hero__ctas {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem;
    align-items: center;
}

.mag-hero__cta--ghost {
    background: transparent;
    color: var(--color-text);
    border: 1px solid var(--color-border);
}
.mag-hero__cta--ghost:hover {
    background: var(--color-bg-alt);
    color: var(--color-accent);
    border-color: var(--color-accent);
    box-shadow: none;
}

/* Hero featured article */
.mag-hero__featured {
    order: 1;
}

@media (min-width: 768px) {
    .mag-hero__featured {
        order: 2;
    }
}

.mag-hero__card {
    display: block;
    border-radius: var(--radius-xl);
    overflow: hidden;
    background: var(--color-bg-light);
    box-shadow: var(--shadow-lg);
    transition: all var(--transition-slow);
    border: 1px solid var(--color-border);
}

.mag-hero__card:hover {
    box-shadow: var(--shadow-xl);
    transform: translateY(-4px);
}

.mag-hero__card-image {
    aspect-ratio: 4/3;
    overflow: hidden;
}

.mag-hero__card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slower);
}

.mag-hero__card:hover .mag-hero__card-image img {
    transform: scale(1.04);
}

.mag-hero__card-body {
    padding: 1.5rem;
}

.mag-hero__card-category {
    font-family: var(--font-sans);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-accent);
    margin-bottom: 0.5rem;
    display: inline-block;
}

.mag-hero__card-title {
    font-family: var(--font-display);
    font-size: 1.375rem;
    font-weight: 700;
    line-height: 1.25;
    color: var(--color-text);
    margin-bottom: 0.75rem;
}

.mag-hero__card-excerpt {
    font-size: 0.9375rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

/* ============================================
   8. HOMEPAGE — FEATURED ARTICLES
   ============================================ */
.mag-featured {
    padding: 5rem 0;
    border-bottom: 1px solid var(--color-border);
}

.mag-featured__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

.mag-featured__header {
    display: flex;
    align-items: flex-end;
    justify-content: space-between;
    margin-bottom: 3rem;
    gap: 1rem;
}

.mag-featured__header h2 {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.mag-featured__link {
    font-family: var(--font-sans);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-text-light);
    display: flex;
    align-items: center;
    gap: 0.375rem;
    transition: color var(--transition);
    flex-shrink: 0;
}
.mag-featured__link:hover {
    color: var(--color-accent);
}

.mag-featured__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 640px) {
    .mag-featured__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .mag-featured__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Featured card */
.mag-card {
    display: flex;
    flex-direction: column;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    transition: all var(--transition);
}

.mag-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-3px);
    border-color: var(--color-border);
}

.mag-card__image {
    aspect-ratio: 3/2;
    overflow: hidden;
    flex-shrink: 0;
}

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

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

.mag-card__body {
    padding: 1.25rem;
    flex: 1;
}

.mag-card__category {
    font-family: var(--font-sans);
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-accent);
    margin-bottom: 0.5rem;
    display: inline-block;
}

.mag-card__title {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.3;
    color: var(--color-text);
    margin-bottom: 0.5rem;
}

.mag-card__excerpt {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.mag-card__meta {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-top: 0.75rem;
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

/* ============================================
   9. HOMEPAGE — GUIDES (Pillar pages)
   ============================================ */
.mag-guides {
    padding: 6rem 0;
    background: var(--color-bg-warm);
}

.mag-guides__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

.mag-guides__header {
    text-align: center;
    margin-bottom: 3.5rem;
}

.mag-guides__header h2 {
    font-family: var(--font-display);
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0.75rem;
    letter-spacing: -0.01em;
}

.mag-guides__header p {
    font-family: var(--font-serif);
    font-size: 1.0625rem;
    color: var(--color-text-light);
    max-width: 32rem;
    margin: 0 auto;
}

.mag-guides__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 640px) {
    .mag-guides__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .mag-guides__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Guide card */
.mag-guide-card {
    position: relative;
    display: block;
    height: 22rem;
    border-radius: var(--radius-xl);
    overflow: hidden;
    cursor: pointer;
    color: white;
}

.mag-guide-card img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slower);
}

.mag-guide-card:hover img {
    transform: scale(1.08);
}

.mag-guide-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(45, 42, 38, 0.75) 0%, rgba(45, 42, 38, 0.1) 55%, transparent 100%);
    transition: background var(--transition);
}

.mag-guide-card:hover::after {
    background: linear-gradient(to top, rgba(184, 92, 56, 0.8) 0%, rgba(184, 92, 56, 0.15) 55%, transparent 100%);
}

.mag-guide-card__content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1.75rem;
    color: white;
    z-index: 1;
}

.mag-guide-card__content h3 {
    font-family: var(--font-display);
    font-size: 1.375rem;
    font-weight: 700;
    margin-bottom: 0.375rem;
    line-height: 1.2;
}

.mag-guide-card__content p {
    font-size: 0.875rem;
    opacity: 0.85;
    line-height: 1.5;
}

/* ============================================
   10a. HOMEPAGE — CATEGORY SECTIONS (Magazine layout)
   ============================================ */
.mag-section {
    padding: 5rem 0;
    border-bottom: 1px solid var(--color-border);
}

.mag-section--alt {
    background: var(--color-bg-warm);
}

.mag-section__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

.mag-section__header {
    display: flex;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 3rem;
    padding-bottom: 1rem;
    border-bottom: 2px solid var(--color-text);
}

.mag-section__header h2 {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.mag-section__link {
    font-family: var(--font-sans);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-text-light);
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    transition: color var(--transition);
    flex-shrink: 0;
    text-decoration: none;
}
.mag-section__link:hover {
    color: var(--color-accent);
}

.mag-section__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 768px) {
    .mag-section__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .mag-section__grid {
        grid-template-columns: repeat(3, 1fr);
    }

    /* First article of each category: horizontal layout spanning 2 cols */
    .mag-section__grid > .mag-card:first-child {
        grid-column: 1 / 3;
        display: flex;
        flex-direction: row;
    }
    .mag-section__grid > .mag-card:first-child .mag-card__image {
        aspect-ratio: auto;
        width: 55%;
        flex-shrink: 0;
    }
    .mag-section__grid > .mag-card:first-child .mag-card__body {
        display: flex;
        flex-direction: column;
        justify-content: center;
        padding: 2rem;
    }
    .mag-section__grid > .mag-card:first-child .mag-card__title {
        font-size: 1.5rem;
    }
    .mag-section__grid > .mag-card:first-child .mag-card__excerpt {
        -webkit-line-clamp: 4;
    }
}

/* ============================================
   10b. HOMEPAGE — LATEST ARTICLES (legacy grid, used by category.php)
   ============================================ */
.mag-latest {
    padding: 5rem 0;
}

.mag-latest__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

.mag-latest__header {
    display: flex;
    align-items: center;
    gap: 1.5rem;
    margin-bottom: 3rem;
}

.mag-latest__header h2 {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-text);
    letter-spacing: -0.01em;
    white-space: nowrap;
}

.mag-latest__header::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

/* Magazine grid: first article large, rest standard */
.mag-latest__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 768px) {
    .mag-latest__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .mag-latest__grid {
        grid-template-columns: repeat(3, 1fr);
    }
    .mag-latest__grid > .mag-card:first-child {
        grid-column: 1 / 3;
        display: flex;
        flex-direction: row;
    }
    .mag-latest__grid > .mag-card:first-child .mag-card__image {
        aspect-ratio: auto;
        width: 55%;
        flex-shrink: 0;
        min-height: 280px;
    }
    .mag-latest__grid > .mag-card:first-child .mag-card__body {
        display: flex;
        flex-direction: column;
        justify-content: center;
        padding: 2rem;
    }
    .mag-latest__grid > .mag-card:first-child .mag-card__title {
        font-size: 1.75rem;
    }
    .mag-latest__grid > .mag-card:first-child .mag-card__excerpt {
        -webkit-line-clamp: 4;
    }
}

.mag-latest__more {
    text-align: center;
    margin-top: 3.5rem;
}

.mag-latest__more a {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 2rem;
    border: 1px solid var(--color-border);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: 0.875rem;
    font-weight: 600;
    border-radius: 9999px;
    transition: all var(--transition);
}

.mag-latest__more a:hover {
    background: var(--color-text);
    color: var(--color-bg);
    border-color: var(--color-text);
    transform: translateY(-1px);
}

/* ============================================
   11. HOMEPAGE — NEWSLETTER CTA
   ============================================ */
.mag-newsletter {
    padding: 5rem 0;
    background: var(--color-bg-alt);
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

.mag-newsletter__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
    text-align: center;
}

.mag-newsletter__title {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0.75rem;
}

.mag-newsletter__desc {
    font-family: var(--font-serif);
    font-size: 1.0625rem;
    color: var(--color-text-light);
    max-width: 28rem;
    margin: 0 auto 2rem;
}

.mag-newsletter .cms-newsletter-form {
    display: flex;
    gap: 0.75rem;
    max-width: 28rem;
    margin: 0 auto;
}

@media (max-width: 480px) {
    .mag-newsletter .cms-newsletter-form {
        flex-direction: column;
    }
}

.mag-newsletter .cms-newsletter-form input[type="email"] {
    flex: 1;
    padding: 0.875rem 1.25rem;
    border: 1px solid var(--color-border);
    border-radius: 9999px;
    background: var(--color-bg-light);
    font-family: var(--font-sans);
    font-size: 0.9375rem;
    color: var(--color-text);
    transition: border-color var(--transition);
}

.mag-newsletter .cms-newsletter-form input[type="email"]:focus {
    outline: none;
    border-color: var(--color-accent);
}

.mag-newsletter .cms-newsletter-form button {
    padding: 0.875rem 2rem;
    background: var(--color-accent);
    color: #ffffff;
    border: none;
    border-radius: 9999px;
    font-family: var(--font-sans);
    font-size: 0.875rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition);
    flex-shrink: 0;
}

.mag-newsletter .cms-newsletter-form button:hover {
    background: var(--color-accent-dark);
    transform: translateY(-1px);
    box-shadow: var(--shadow-accent);
}

/* ============================================
   12. DC ARTICLE CARDS (shared across pages)
   ============================================ */
.dc-actualites {
    padding: 5rem 0;
}

.dc-actualites__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

.dc-actualites__title {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-text);
    border-left: 3px solid var(--color-accent);
    padding-left: 1rem;
    margin-bottom: 3rem;
}

.dc-actualites__grid {
    columns: 1;
    column-gap: 2rem;
}

@media (min-width: 768px) {
    .dc-actualites__grid {
        columns: 2;
    }
}

@media (min-width: 1024px) {
    .dc-actualites__grid {
        columns: 3;
    }
}

/* Standard article card */
.dc-article-card {
    break-inside: avoid;
    background: var(--color-bg-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    margin-bottom: 2rem;
    transition: all var(--transition);
}

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

.dc-article-card img {
    width: 100%;
    height: auto;
    object-fit: cover;
    transition: transform var(--transition-slower);
}

.dc-article-card:hover img {
    transform: scale(1.03);
}

.dc-article-card__body {
    padding: 1.5rem;
}

.dc-article-card__category {
    display: inline-block;
    font-family: var(--font-sans);
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-accent);
    margin-bottom: 0.5rem;
    transition: color var(--transition-fast);
}

.dc-article-card__category:hover {
    color: var(--color-accent-dark);
}

.dc-article-card h3 {
    font-family: var(--font-display);
    font-size: 1.1875rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.75rem;
    line-height: 1.3;
}

.dc-article-card h3 a {
    color: inherit;
    transition: color var(--transition-fast);
}

.dc-article-card h3 a:hover {
    color: var(--color-accent);
}

.dc-article-card p {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    line-height: 1.6;
}

.dc-actualites .no-content {
    text-align: center;
    color: var(--color-text-muted);
    font-size: 1rem;
    padding: 3rem 0;
}

/* ============================================
   13. DC OUTILS / WIDGETS (kept for compatibility)
   ============================================ */
.dc-outils {
    padding: 6rem 0;
    position: relative;
    overflow: hidden;
}

.dc-outils::before,
.dc-outils::after {
    content: '';
    position: absolute;
    width: 24rem;
    height: 24rem;
    border-radius: 50%;
    filter: blur(80px);
    z-index: 0;
    mix-blend-mode: multiply;
    pointer-events: none;
}

.dc-outils::before {
    top: 5rem;
    left: -6rem;
    background: rgba(184, 92, 56, 0.12);
}

.dc-outils::after {
    bottom: 5rem;
    right: -6rem;
    background: rgba(199, 123, 63, 0.1);
}

.dc-outils__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
    position: relative;
    z-index: 1;
}

.dc-outils__header {
    text-align: center;
    margin-bottom: 4rem;
}

.dc-outils__header span {
    display: block;
    font-family: var(--font-sans);
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--color-accent);
    letter-spacing: 0.14em;
    text-transform: uppercase;
    margin-bottom: 0.75rem;
}

.dc-outils__header h2 {
    font-family: var(--font-display);
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0.5rem;
}

.dc-outils__header p {
    color: var(--color-text-muted);
}

.dc-outils__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 1024px) {
    .dc-outils__grid {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Widget Card */
.dc-widget {
    background: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 2rem;
    box-shadow: var(--shadow-md);
}

.dc-widget__header {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    margin-bottom: 1.5rem;
}

.dc-widget__icon {
    width: 40px;
    height: 40px;
    border-radius: var(--radius-lg);
    display: flex;
    align-items: center;
    justify-content: center;
}

.dc-widget__icon--orange {
    background: var(--color-orange-light);
    color: var(--color-accent);
}

.dc-widget__icon--blue {
    background: #E8EEF5;
    color: #4A6FA5;
}

.dc-widget__icon--green {
    background: #E5F0E8;
    color: var(--color-forest);
}

.dc-widget__header h3 {
    font-family: var(--font-display);
    font-weight: 600;
    color: var(--color-text);
}

.dc-widget__field {
    margin-bottom: 1rem;
}

.dc-widget__label {
    display: block;
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-bottom: 0.5rem;
}

.dc-widget__slider {
    width: 100%;
    height: 6px;
    background: var(--color-border);
    border-radius: 9999px;
    appearance: none;
    -webkit-appearance: none;
    cursor: pointer;
    margin-top: 0.5rem;
}

.dc-widget__slider::-webkit-slider-thumb {
    appearance: none;
    width: 18px;
    height: 18px;
    background: var(--color-accent);
    border-radius: 50%;
    cursor: pointer;
    box-shadow: 0 2px 6px rgba(184, 92, 56, 0.3);
}

.dc-widget__slider--green::-webkit-slider-thumb {
    background: var(--color-forest);
    box-shadow: 0 2px 6px rgba(44, 57, 48, 0.3);
}

.dc-widget__slider::-moz-range-thumb {
    width: 18px;
    height: 18px;
    background: var(--color-accent);
    border-radius: 50%;
    cursor: pointer;
    border: none;
}

.dc-widget__slider--green::-moz-range-thumb {
    background: var(--color-forest);
}

.dc-widget__value {
    text-align: right;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text);
}

.dc-widget__result {
    padding-top: 1rem;
    margin-top: 1rem;
    border-top: 1px solid var(--color-border);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dc-widget__result span {
    font-size: 0.875rem;
    color: var(--color-text-light);
}

.dc-widget__result strong {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-accent);
}

.dc-widget__intro {
    font-size: 0.875rem;
    color: var(--color-text-light);
    text-align: left;
    margin-bottom: 1.5rem;
}

/* Score Widget */
.dc-score {
    text-align: center;
}

.dc-score p {
    font-size: 0.875rem;
    color: var(--color-text-light);
    text-align: left;
    margin-bottom: 1.5rem;
}

.dc-score__counter {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 1rem;
    margin-bottom: 1.5rem;
}

.dc-score__btn {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: var(--color-bg-light);
    box-shadow: var(--shadow-sm);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.25rem;
    color: var(--color-text-light);
    cursor: pointer;
    border: 1px solid var(--color-border);
    transition: all var(--transition-fast);
}

.dc-score__btn:hover {
    background: var(--color-bg-alt);
    border-color: var(--color-accent);
}

.dc-score__value {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 700;
    color: var(--color-text);
    min-width: 3rem;
}

.dc-score__level {
    font-size: 1rem;
    font-weight: 600;
    margin-bottom: 1rem;
    transition: color 0.3s ease;
}

.dc-score__level.level-low { color: var(--color-text-muted); }
.dc-score__level.level-mid { color: var(--color-accent); }
.dc-score__level.level-high { color: var(--color-forest); }

.dc-score__bar {
    width: 100%;
    height: 8px;
    background: var(--color-border);
    border-radius: 9999px;
    overflow: hidden;
}

.dc-score__bar-fill {
    height: 100%;
    background: var(--color-accent);
    border-radius: 9999px;
    transition: width 0.5s ease;
}

/* Renov Widget */
.dc-renov__labels {
    display: flex;
    justify-content: space-between;
    font-size: 0.6875rem;
    font-weight: 600;
    color: var(--color-text-muted);
    text-transform: uppercase;
    letter-spacing: 0.04em;
    margin-top: 1rem;
    margin-bottom: 0.5rem;
}

.dc-renov__value {
    text-align: center;
    font-weight: 500;
    color: var(--color-text);
    margin: 1rem 0;
}

.dc-renov__result {
    background: var(--color-bg-alt);
    padding: 0.875rem 1rem;
    border-radius: var(--radius-lg);
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.dc-renov__result span {
    font-size: 0.875rem;
    color: var(--color-text-light);
}

.dc-renov__result strong {
    font-weight: 700;
    color: var(--color-accent);
}

/* ============================================
   14. DC PILIERS (Compatibility — uses same as mag-guides)
   ============================================ */
.dc-piliers {
    background: var(--color-bg-warm);
    padding: 6rem 0;
}

.dc-piliers__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

.dc-piliers__header {
    display: flex;
    flex-direction: column;
    gap: 1rem;
    margin-bottom: 3rem;
}

@media (min-width: 768px) {
    .dc-piliers__header {
        flex-direction: row;
        justify-content: space-between;
        align-items: flex-end;
    }
}

.dc-piliers__header h2 {
    font-family: var(--font-display);
    font-size: 2.25rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0.5rem;
}

.dc-piliers__header p {
    color: var(--color-text-light);
    font-family: var(--font-serif);
}

.dc-piliers__link {
    display: flex;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.875rem;
    font-weight: 600;
    color: var(--color-text);
    transition: color var(--transition-fast);
}

.dc-piliers__link:hover {
    color: var(--color-accent);
}

.dc-piliers__grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
}

@media (min-width: 640px) {
    .dc-piliers__grid {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .dc-piliers__grid {
        grid-template-columns: repeat(4, 1fr);
    }
}

/* Pilier Card */
.dc-pilier-card {
    position: relative;
    display: block;
    height: 22rem;
    border-radius: var(--radius-xl);
    overflow: hidden;
    cursor: pointer;
    color: white;
}

.dc-pilier-card img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--transition-slower);
}

.dc-pilier-card:hover img {
    transform: scale(1.08);
}

.dc-pilier-card::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(to top, rgba(45, 42, 38, 0.75) 0%, transparent 60%);
}

.dc-pilier-card__content {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 1.75rem;
    color: white;
    z-index: 1;
}

.dc-pilier-card__content h3 {
    font-family: var(--font-display);
    font-size: 1.375rem;
    font-weight: 700;
    margin-bottom: 0.25rem;
    line-height: 1.2;
}

.dc-pilier-card__content p {
    font-size: 0.875rem;
    opacity: 0.85;
}

/* ============================================
   15. HERO (kept for compatibility)
   ============================================ */
.dc-hero {
    padding-top: 4rem;
    padding-bottom: 5rem;
}

.dc-hero__container {
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
    display: flex;
    flex-direction: column;
    gap: 3rem;
}

@media (min-width: 768px) {
    .dc-hero__container {
        flex-direction: row;
        align-items: center;
        gap: 4rem;
    }
}

.dc-hero__content {
    flex: 1;
}

.dc-hero__badge {
    display: inline-block;
    padding: 0.375rem 0.75rem;
    background: var(--color-accent-muted);
    color: var(--color-accent);
    font-family: var(--font-sans);
    font-size: 0.6875rem;
    font-weight: 600;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    border-radius: 9999px;
    margin-bottom: 1.5rem;
}

.dc-hero__title {
    font-family: var(--font-display);
    font-size: clamp(2.5rem, 5vw, 4rem);
    font-weight: 800;
    line-height: 1.1;
    color: var(--color-text);
    margin-bottom: 1.5rem;
    letter-spacing: -0.02em;
}

.dc-hero__title em {
    font-style: italic;
    color: var(--color-accent);
}

.dc-hero__desc {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--color-text-light);
    line-height: 1.75;
    max-width: 28rem;
    margin-bottom: 2rem;
}

.dc-hero__cta {
    display: inline-flex;
    align-items: center;
    gap: 0.75rem;
    background: var(--color-text);
    color: var(--color-bg);
    padding: 0.875rem 2rem;
    border-radius: 9999px;
    font-family: var(--font-sans);
    font-size: 0.9375rem;
    font-weight: 600;
    box-shadow: var(--shadow-lg);
    transition: all var(--transition);
}

.dc-hero__cta:hover {
    background: var(--color-accent);
    color: #ffffff;
    transform: translateY(-2px);
}

.dc-hero__cta svg {
    transition: transform var(--transition-fast);
}

.dc-hero__cta:hover svg {
    transform: translateX(4px);
}

/* Hero Visual */
.dc-hero__visual {
    flex: 1;
    position: relative;
}

.dc-hero__image-wrapper {
    aspect-ratio: 4/5;
    border-radius: var(--radius-xl);
    overflow: hidden;
    box-shadow: var(--shadow-xl);
}

@media (min-width: 768px) {
    .dc-hero__image-wrapper {
        aspect-ratio: 1;
    }
}

.dc-hero__image-wrapper img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform 0.7s ease;
}

.dc-hero__image-wrapper:hover img {
    transform: scale(1.04);
}

.dc-hero__quote {
    display: none;
    position: absolute;
    bottom: -1.5rem;
    left: -1.5rem;
    background: var(--color-bg-light);
    padding: 1.5rem;
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    max-width: 280px;
    border: 1px solid var(--color-border);
}

@media (min-width: 768px) {
    .dc-hero__quote {
        display: block;
    }
}

.dc-hero__quote p {
    font-family: var(--font-display);
    font-style: italic;
    font-size: 1.0625rem;
    color: var(--color-text);
    margin-bottom: 0.75rem;
}

.dc-hero__quote-meta {
    display: flex;
    align-items: center;
    gap: 0.5rem;
}

.dc-hero__avatars {
    display: flex;
}

.dc-hero__avatars span {
    width: 28px;
    height: 28px;
    border-radius: 50%;
    border: 2px solid var(--color-bg-light);
    margin-left: -8px;
}

.dc-hero__avatars span:first-child { margin-left: 0; }
.dc-hero__avatars span:nth-child(1) { background: var(--color-slate-300); }
.dc-hero__avatars span:nth-child(2) { background: var(--color-slate-400); }
.dc-hero__avatars span:nth-child(3) { background: var(--color-slate-500); }

.dc-hero__quote-meta small {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    font-weight: 500;
}

/* ============================================
   16. CATEGORY PAGE
   ============================================ */

/* Breadcrumb */
.dc-breadcrumb {
    padding: 1rem 0;
    margin-bottom: 1.5rem;
}

.dc-breadcrumb__list {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    list-style: none;
    font-size: 0.8125rem;
    padding: 0;
    margin: 0;
}

.dc-breadcrumb__item a {
    color: var(--color-text-muted);
    transition: color var(--transition-fast);
}

.dc-breadcrumb__item a:hover {
    color: var(--color-accent);
}

.dc-breadcrumb__item--current span {
    color: var(--color-text);
    font-weight: 500;
}

.dc-breadcrumb__sep {
    display: flex;
    align-items: center;
    color: var(--color-text-muted);
    opacity: 0.4;
}

/* Category Hero */
.dc-category-hero {
    position: relative;
    padding: 6rem 0 3rem;
    background: linear-gradient(135deg, var(--color-bg) 0%, var(--color-bg-alt) 100%);
}

.dc-category-hero__bg {
    position: absolute;
    inset: 0;
    overflow: hidden;
}

.dc-category-hero__bg img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.dc-category-hero__bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg, rgba(250, 247, 242, 0.6) 0%, rgba(240, 235, 227, 0.65) 100%);
}

.dc-category-hero__container {
    position: relative;
    z-index: 1;
    max-width: var(--max-width);
    margin: 0 auto;
    padding: 0 1.5rem;
}

.dc-category-hero__content {
    max-width: 700px;
}

.dc-category-badge {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.5rem 1rem;
    background: var(--color-accent);
    color: white;
    border-radius: 9999px;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    margin-bottom: 1.5rem;
}

.dc-category-badge svg {
    opacity: 0.85;
}

.dc-category-hero h1 {
    font-family: var(--font-display);
    font-size: clamp(2rem, 5vw, 3rem);
    font-weight: 700;
    line-height: 1.15;
    color: var(--color-text);
    margin-bottom: 1rem;
}

.dc-category-hero__desc {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--color-text-light);
    line-height: 1.7;
    margin-bottom: 1.5rem;
}

.dc-category-meta {
    display: flex;
    align-items: center;
    gap: 1.5rem;
}

.dc-category-count {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9375rem;
    color: var(--color-text-muted);
}

.dc-category-count svg {
    color: var(--color-accent);
}

/* Category Articles Grid */
.dc-category-articles {
    padding: 3rem 0;
}

.dc-category-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
    gap: 2rem;
}

/* Featured Card (first article) */
.dc-category-card--featured {
    grid-column: 1 / -1;
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    background: var(--color-bg-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-md);
    border: 1px solid var(--color-border);
}

@media (min-width: 768px) {
    .dc-category-card--featured {
        grid-template-columns: 1.2fr 1fr;
        gap: 2rem;
    }
}

.dc-category-card--featured .dc-category-card__image {
    aspect-ratio: 16/10;
}

.dc-category-card--featured .dc-category-card__content {
    padding: 2rem;
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.dc-category-card--featured .dc-category-card__title {
    font-size: 1.75rem;
}

.dc-category-card--featured .dc-category-card__excerpt {
    font-size: 1rem;
    -webkit-line-clamp: 4;
}

/* Standard Category Card */
.dc-category-card {
    background: var(--color-bg-light);
    border-radius: var(--radius-lg);
    overflow: hidden;
    box-shadow: var(--shadow-sm);
    border: 1px solid var(--color-border);
    transition: all var(--transition);
}

.dc-category-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--shadow-lg);
}

.dc-category-card__image {
    display: block;
    aspect-ratio: 16/9;
    overflow: hidden;
}

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

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

.dc-category-card__content {
    padding: 1.5rem;
}

.dc-category-card__meta {
    display: flex;
    align-items: center;
    gap: 1rem;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    margin-bottom: 0.75rem;
}

.dc-category-card__meta time {
    display: flex;
    align-items: center;
    gap: 0.375rem;
}

.dc-category-card__meta svg {
    opacity: 0.6;
}

.dc-category-card__title {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    line-height: 1.3;
    margin-bottom: 0.75rem;
}

.dc-category-card__title a {
    color: var(--color-text);
    transition: color var(--transition-fast);
}

.dc-category-card__title a:hover {
    color: var(--color-accent);
}

.dc-category-card__excerpt {
    font-family: var(--font-serif);
    font-size: 0.9375rem;
    color: var(--color-text-light);
    line-height: 1.6;
    margin-bottom: 1rem;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.dc-category-card__link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-accent);
    transition: gap var(--transition-fast);
}

.dc-category-card__link:hover {
    gap: 0.75rem;
}

/* No Posts */
.dc-no-posts {
    text-align: center;
    padding: 4rem 2rem;
    background: var(--color-bg-alt);
    border-radius: var(--radius-lg);
}

.dc-no-posts svg {
    color: var(--color-text-muted);
    margin-bottom: 1rem;
}

.dc-no-posts p {
    font-size: 1.125rem;
    color: var(--color-text-light);
    margin-bottom: 1.5rem;
}

.dc-back-home {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.5rem;
    background: var(--color-accent);
    color: white;
    border-radius: 9999px;
    font-weight: 600;
    transition: all var(--transition-fast);
}

.dc-back-home:hover {
    background: var(--color-accent-dark);
    color: white;
    transform: translateY(-2px);
}

/* Responsive Category */
@media (max-width: 900px) {
    .dc-category-card--featured {
        grid-template-columns: 1fr;
    }
    .dc-category-card--featured .dc-category-card__content {
        padding: 1.5rem;
    }
    .dc-category-card--featured .dc-category-card__title {
        font-size: 1.5rem;
    }
}

@media (max-width: 640px) {
    .dc-category-hero {
        padding: 5rem 0 2rem;
    }
    .dc-category-grid {
        grid-template-columns: 1fr;
    }
    .dc-category-card__content {
        padding: 1.25rem;
    }
}

/* ============================================
   17. ARTICLE SINGLE PAGE
   ============================================ */

/* Using styles from the existing article.php template */
/* These inherit from the base template structure */

/* ============================================
   18. SILO PAGES (page-parent, page-child)
   ============================================ */

/* Page parent */
.page-parent {
    padding: 2rem 0;
}

.page-parent__header {
    text-align: center;
    max-width: var(--content-width);
    margin: 0 auto 3rem;
}

.page-parent__title {
    font-family: var(--font-display);
    font-size: 2.75rem;
    font-weight: 800;
    color: var(--color-text);
    margin-bottom: 1rem;
    line-height: 1.15;
}

.page-parent__excerpt {
    font-family: var(--font-serif);
    font-size: 1.15rem;
    color: var(--color-text-light);
    line-height: 1.7;
}

.page-parent__image {
    border-radius: var(--radius-xl);
    overflow: hidden;
    margin-bottom: 3rem;
    box-shadow: var(--shadow-lg);
}

.page-parent__image img {
    width: 100%;
    height: auto;
    object-fit: cover;
}

.page-parent__content {
    max-width: var(--content-width);
    margin: 0 auto;
}

/* Silo nav */
.silo-nav {
    margin: 3rem 0;
}

.silo-nav__title {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 2rem;
}

.silo-nav__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.5rem;
}

.silo-card {
    display: flex;
    gap: 1rem;
    padding: 1.25rem;
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: all var(--transition);
    position: relative;
    overflow: hidden;
}

.silo-card::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    width: 3px;
    height: 100%;
    background: var(--gradient-accent);
    opacity: 0;
    transition: opacity 0.3s ease;
}

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

.silo-card:hover::before {
    opacity: 1;
}

.silo-card__image {
    width: 80px;
    height: 80px;
    border-radius: var(--radius);
    overflow: hidden;
    flex-shrink: 0;
}

.silo-card__image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.silo-card__number {
    width: 48px;
    height: 48px;
    border-radius: 50%;
    background: var(--color-accent-muted);
    color: var(--color-accent);
    display: flex;
    align-items: center;
    justify-content: center;
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    flex-shrink: 0;
}

.silo-card__title {
    font-family: var(--font-display);
    font-size: 1.0625rem;
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.25rem;
    line-height: 1.3;
}

.silo-card__title a {
    color: inherit;
    transition: color var(--transition-fast);
}

.silo-card__title a:hover {
    color: var(--color-accent);
}

.silo-card__excerpt {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    line-height: 1.5;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Silo TOC */
.silo-toc {
    margin: 3rem 0;
    padding: 2rem;
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
}

.silo-toc__title {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    margin-bottom: 1.5rem;
    color: var(--color-text);
}

.silo-toc__list {
    list-style: none;
    counter-reset: silo-counter;
    padding: 0;
    margin: 0;
}

.silo-toc__list li {
    counter-increment: silo-counter;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--color-border);
}

.silo-toc__list li:last-child {
    border-bottom: none;
}

.silo-toc__list li a {
    display: flex;
    align-items: center;
    gap: 1rem;
    color: var(--color-text);
    font-weight: 500;
    transition: color var(--transition-fast);
}

.silo-toc__list li a::before {
    content: counter(silo-counter, decimal-leading-zero);
    font-family: var(--font-display);
    font-size: 0.875rem;
    font-weight: 700;
    color: var(--color-accent);
    min-width: 2rem;
}

.silo-toc__list li a:hover {
    color: var(--color-accent);
}

/* Page child layout */
.page-child-layout {
    display: grid;
    grid-template-columns: 1fr;
    gap: 3rem;
}

@media (min-width: 1024px) {
    .page-child-layout {
        grid-template-columns: 1fr 280px;
    }
}

.page-child {
    min-width: 0;
}

.page-child__parent-link {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-accent);
    margin-bottom: 1.5rem;
    transition: gap var(--transition-fast);
}

.page-child__parent-link:hover {
    gap: 0.75rem;
}

.page-child__title {
    font-family: var(--font-display);
    font-size: 2.25rem;
    font-weight: 800;
    color: var(--color-text);
    line-height: 1.15;
    margin-bottom: 2rem;
}

/* Page nav (prev/next) */
.page-nav {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin-top: 3rem;
    padding-top: 2rem;
    border-top: 1px solid var(--color-border);
}

.page-nav__link {
    display: block;
    padding: 1.25rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    transition: all var(--transition);
}

.page-nav__link:hover {
    border-color: var(--color-accent);
    box-shadow: var(--shadow-sm);
}

.page-nav__prev {
    text-align: left;
}

.page-nav__next {
    text-align: right;
}

.page-nav__label {
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    margin-bottom: 0.375rem;
}

.page-nav__title {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-text);
    line-height: 1.3;
}

.page-nav__title a {
    color: inherit;
}

/* Silo sidebar */
.silo-sidebar {
    position: sticky;
    top: calc(var(--header-height) + 2rem);
}

.silo-sidebar__widget {
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    padding: 1.5rem;
}

.silo-sidebar__title {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 1rem;
    padding-bottom: 0.75rem;
    border-bottom: 1px solid var(--color-border);
}

.silo-sidebar__title a {
    color: inherit;
    transition: color var(--transition-fast);
}

.silo-sidebar__title a:hover {
    color: var(--color-accent);
}

.silo-sidebar__nav {
    list-style: none;
    padding: 0;
    margin: 0;
}

.silo-sidebar__nav li {
    margin-bottom: 0.25rem;
}

.silo-sidebar__nav a {
    display: block;
    padding: 0.625rem 0.75rem;
    font-size: 0.875rem;
    font-weight: 500;
    color: var(--color-text-light);
    border-radius: var(--radius);
    transition: all var(--transition-fast);
}

.silo-sidebar__nav a:hover {
    background: var(--color-bg-light);
    color: var(--color-accent);
}

.silo-sidebar__current a {
    background: var(--color-bg-light);
    color: var(--color-accent);
    font-weight: 600;
    border-left: 3px solid var(--color-accent);
}

.silo-children {
    margin-top: 2rem;
    padding-top: 2rem;
    border-top: 1px solid var(--color-border);
}

/* ============================================
   19. SIDEBAR (article pages)
   ============================================ */
.sidebar-widget {
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    padding: 1.5rem;
    margin-bottom: 2rem;
    position: relative;
    overflow: hidden;
}

.sidebar-widget::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 2px;
    background: var(--gradient-accent);
    opacity: 0.6;
}

.sidebar-widget__header-line {
    background: var(--gradient-accent);
    height: 2px;
}

/* Most read items */
.most-read-number {
    background: linear-gradient(180deg, var(--color-slate-200) 0%, var(--color-slate-300) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}

.most-read-item:hover .most-read-number {
    background: linear-gradient(180deg, var(--color-accent) 0%, var(--color-accent-dark) 100%);
    -webkit-background-clip: text;
    background-clip: text;
}

@media (prefers-color-scheme: dark) {
    .most-read-number {
        background: linear-gradient(180deg, var(--color-slate-700) 0%, var(--color-slate-800) 100%);
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        background-clip: text;
    }
    .most-read-item:hover .most-read-number {
        background: linear-gradient(180deg, var(--color-accent-light) 0%, var(--color-accent) 100%);
        -webkit-background-clip: text;
        background-clip: text;
    }
}

/* Category sidebar */
.sidebar-categories__count {
    background: var(--color-accent-muted);
    color: var(--color-accent);
    font-weight: 700;
    min-width: 28px;
    text-align: center;
    transition: all var(--transition);
}

.sidebar-categories a:hover .sidebar-categories__count {
    background: var(--color-accent);
    color: #ffffff;
}

/* ============================================
   20. PAGINATION
   ============================================ */
.pagination__link {
    position: relative;
    overflow: hidden;
}

.pagination__link::before {
    content: '';
    position: absolute;
    inset: 0;
    background: var(--color-accent-muted);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.3s ease;
    z-index: -1;
}

.pagination__link:hover::before {
    transform: scaleX(1);
    transform-origin: left;
}

/* ============================================
   21. CONTACT FORM
   ============================================ */
.contact-page {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: 2rem 0;
}

.contact-header {
    text-align: center;
    margin-bottom: 2.5rem;
}

.contact-header h1 {
    font-family: var(--font-display);
    font-size: 2.5rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0.75rem;
}

.contact-subtitle {
    font-family: var(--font-serif);
    font-size: 1.0625rem;
    color: var(--color-text-light);
}

.contact-alert {
    padding: 1rem 1.5rem;
    border-radius: var(--radius-lg);
    margin-bottom: 2rem;
    font-size: 0.9375rem;
}

.contact-alert--success {
    background: rgba(74, 124, 89, 0.1);
    color: var(--color-success);
    border: 1px solid rgba(74, 124, 89, 0.2);
}

.contact-alert--error {
    background: rgba(196, 69, 60, 0.1);
    color: var(--color-error);
    border: 1px solid rgba(196, 69, 60, 0.2);
}

.contact-form-wrapper {
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-xl);
    padding: 2.5rem;
    box-shadow: var(--shadow-md);
    position: relative;
    overflow: hidden;
}

.contact-form-wrapper::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--gradient-accent);
    opacity: 0.5;
}

.contact-form .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5rem;
    margin-bottom: 1.5rem;
}

@media (max-width: 640px) {
    .contact-form .form-row {
        grid-template-columns: 1fr;
    }
}

.contact-form label {
    display: block;
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.08em;
    color: var(--color-text-muted);
    margin-bottom: 0.5rem;
}

.contact-form input,
.contact-form textarea,
.contact-form select {
    width: 100%;
    padding: 0.875rem 1rem;
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    background: var(--color-bg);
    font-family: var(--font-sans);
    font-size: 0.9375rem;
    color: var(--color-text);
    transition: border-color var(--transition);
}

.contact-form input:focus,
.contact-form textarea:focus {
    outline: none;
    border-color: var(--color-accent);
}

.contact-form textarea {
    min-height: 160px;
    resize: vertical;
}

.contact-submit {
    width: 100%;
    padding: 1rem;
    margin-top: 1.5rem;
    background: var(--color-accent);
    color: #ffffff;
    border: none;
    border-radius: var(--radius-lg);
    font-family: var(--font-sans);
    font-size: 0.9375rem;
    font-weight: 600;
    cursor: pointer;
    transition: all var(--transition);
}

.contact-submit:hover {
    background: var(--color-accent-dark);
    transform: translateY(-1px);
    box-shadow: var(--shadow-accent);
}

/* ============================================
   22. SEARCH PAGE
   ============================================ */
.search-page {
    max-width: var(--content-width);
    margin: 0 auto;
    padding: 2rem 0;
}

.search-page h1 {
    font-family: var(--font-display);
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 2rem;
}

.search-form {
    display: flex;
    gap: 0.75rem;
    margin-bottom: 3rem;
}

.search-form input {
    flex: 1;
    padding: 0.875rem 1.25rem;
    border: 1px solid var(--color-border);
    border-radius: 9999px;
    font-size: 1rem;
    background: var(--color-bg-light);
    color: var(--color-text);
    font-family: var(--font-sans);
}

.search-form input:focus {
    outline: none;
    border-color: var(--color-accent);
}

.search-form button {
    padding: 0.875rem 1.5rem;
    background: var(--color-accent);
    color: white;
    border: none;
    border-radius: 9999px;
    font-weight: 600;
    cursor: pointer;
    transition: background var(--transition);
}

.search-form button:hover {
    background: var(--color-accent-dark);
}

/* Live search */
.live-search {
    position: relative;
}

.live-search__input {
    width: 100%;
    padding: 0.875rem 1.25rem;
    border: 1px solid var(--color-border);
    border-radius: 9999px;
    font-size: 1rem;
    background: var(--color-bg-light);
    color: var(--color-text);
    font-family: var(--font-sans);
}

.live-search__results {
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    border-radius: var(--radius-lg);
    box-shadow: var(--shadow-xl);
    margin-top: 0.5rem;
    z-index: 50;
    max-height: 400px;
    overflow-y: auto;
}

.live-search__item {
    display: flex;
    gap: 1rem;
    padding: 1rem;
    border-bottom: 1px solid var(--color-border-light);
    color: var(--color-text);
    transition: background var(--transition-fast);
}

.live-search__item:hover {
    background: var(--color-bg-alt);
}

.live-search__item:last-child {
    border-bottom: none;
}

.live-search__item-img {
    width: 60px;
    height: 60px;
    border-radius: var(--radius);
    object-fit: cover;
    flex-shrink: 0;
}

.live-search__item-title {
    font-family: var(--font-display);
    font-weight: 600;
    color: var(--color-text);
    margin-bottom: 0.25rem;
}

.live-search__item-excerpt {
    font-size: 0.8125rem;
    color: var(--color-text-muted);
    line-height: 1.4;
}

.live-search__item-meta {
    font-size: 0.75rem;
    color: var(--color-text-muted);
    margin-top: 0.25rem;
}

.live-search__empty {
    padding: 1.5rem;
    text-align: center;
    color: var(--color-text-muted);
}

/* ============================================
   23. 404 PAGE
   ============================================ */
.error-page {
    text-align: center;
    padding: 6rem 2rem;
}

.error-page__code {
    font-family: var(--font-display);
    font-size: 8rem;
    font-weight: 900;
    color: var(--color-accent-muted);
    line-height: 1;
    margin-bottom: 0.5rem;
    font-variation-settings: "opsz" 144;
}

.error-page__title {
    font-family: var(--font-display);
    font-size: 1.75rem;
    font-weight: 700;
    color: var(--color-text);
    margin-bottom: 0.75rem;
}

.error-page__message {
    font-family: var(--font-serif);
    font-size: 1.125rem;
    color: var(--color-text-light);
    margin-bottom: 2rem;
}

.error-page__actions {
    margin-top: 1rem;
}

/* Buttons */
.btn {
    display: inline-flex;
    align-items: center;
    gap: 0.5rem;
    padding: 0.75rem 1.75rem;
    border-radius: 9999px;
    font-family: var(--font-sans);
    font-size: 0.875rem;
    font-weight: 600;
    transition: all var(--transition);
    cursor: pointer;
    border: none;
}

.btn--primary {
    background: var(--color-accent);
    color: #ffffff;
}

.btn--primary:hover {
    background: var(--color-accent-dark);
    transform: translateY(-2px);
    box-shadow: var(--shadow-accent);
}

/* ============================================
   24. FOOTER
   ============================================ */
.site-footer {
    background: var(--color-slate-900);
    color: var(--color-slate-300);
    padding: 4rem 0 2rem;
    position: relative;
}

.site-footer::before {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--gradient-accent);
}

.footer-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2.5rem;
    margin-bottom: 3rem;
}

@media (min-width: 768px) {
    .footer-grid {
        grid-template-columns: 1fr 1fr 1fr;
        gap: 3rem;
    }
}

@media (min-width: 1024px) {
    .footer-grid {
        grid-template-columns: 1.2fr 1.5fr 0.8fr;
        gap: 4rem;
    }
}

/* Footer brand */
.footer-logo {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--color-slate-100);
    margin-bottom: 1rem;
}

.footer-logo img {
    height: 36px;
    width: auto;
}

.footer-logo span {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 700;
}

.footer-desc {
    font-size: 0.875rem;
    line-height: 1.6;
    color: var(--color-slate-400);
}

.footer-col h5 {
    font-family: var(--font-display);
    font-size: 1rem;
    font-weight: 600;
    color: var(--color-slate-100);
    margin-bottom: 1.25rem;
}

/* Footer articles */
.footer-articles-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-articles-list li {
    margin-bottom: 0.75rem;
}

.footer-article-item {
    display: flex;
    align-items: center;
    gap: 0.75rem;
    color: var(--color-slate-300);
    transition: color var(--transition-fast);
}

.footer-article-item:hover {
    color: var(--color-accent-light);
}

.footer-article-thumb {
    width: 48px;
    height: 48px;
    border-radius: var(--radius);
    overflow: hidden;
    flex-shrink: 0;
}

.footer-article-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.footer-article-thumb--empty {
    background: var(--color-slate-800);
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--color-slate-600);
}

.footer-article-title {
    font-size: 0.875rem;
    line-height: 1.4;
}

/* Footer links */
.footer-links {
    list-style: none;
    padding: 0;
    margin: 0;
}

.footer-links li {
    margin-bottom: 0.625rem;
}

.footer-links a {
    color: var(--color-slate-400);
    font-size: 0.875rem;
    transition: color var(--transition-fast);
    position: relative;
    display: inline;
}

.footer-links a::after {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--color-accent-light);
    transition: width 0.3s ease;
}

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

.footer-links a:hover::after {
    width: 100%;
}

.footer-bottom {
    padding-top: 2rem;
    border-top: 1px solid var(--color-slate-800);
    text-align: center;
}

.footer-bottom p {
    font-size: 0.8125rem;
    color: var(--color-slate-500);
}

/* ============================================
   25. ARTICLE PAGE
   ============================================ */

/* Breadcrumb */
.breadcrumb {
    margin-bottom: 2rem;
}

.breadcrumb ol {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.breadcrumb li {
    display: flex;
    align-items: center;
}

.breadcrumb li:not(:last-child)::after {
    content: '/';
    margin-left: 0.5rem;
    color: var(--color-border);
}

.breadcrumb a {
    color: var(--color-text-light);
    transition: color var(--transition-fast);
    position: relative;
}

.breadcrumb a:hover {
    color: var(--color-accent);
}

.breadcrumb a::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--color-accent);
    transition: width 0.25s ease;
}

.breadcrumb a:hover::after {
    width: 100%;
}

.breadcrumb span[aria-current] {
    color: var(--color-text);
    font-weight: 500;
}

/* Article layout */
.article-layout {
    max-width: 52rem;
    margin: 0 auto;
}

/* Article header */
.article-single__header {
    margin-bottom: 2.5rem;
    text-align: center;
}

.article-single__category {
    font-family: var(--font-sans);
    font-size: 0.6875rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.12em;
    color: var(--color-accent);
    display: inline-block;
    margin-bottom: 1rem;
    position: relative;
    padding-left: 1rem;
}

.article-single__category::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-accent);
}

.article-single__category:hover {
    color: var(--color-accent-dark);
}

.article-single__title {
    font-family: var(--font-display);
    font-size: clamp(1.75rem, 3.5vw, 2.75rem);
    font-weight: 800;
    line-height: 1.15;
    color: var(--color-text);
    margin-bottom: 1.25rem;
    letter-spacing: -0.02em;
    font-variation-settings: "opsz" 72;
}

.article-single__meta {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    gap: 1.25rem;
    font-size: 0.8125rem;
    color: var(--color-text-muted);
}

.article-single__meta-item {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
}

.article-single__meta-item svg {
    opacity: 0.5;
    flex-shrink: 0;
}

.article-single__author {
    font-weight: 500;
    color: var(--color-text-light);
}

/* Article featured image */
.article-single__image {
    margin: 0 0 3rem;
    border-radius: var(--radius-xl);
    overflow: hidden;
}

.article-single__image img {
    width: 100%;
    height: auto;
    display: block;
}

/* Article content grid (sidebar + content) */
.article-content-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 768px) {
    .article-content-grid {
        grid-template-columns: 3rem 1fr;
        gap: 2rem;
    }
}

/* Social sidebar */
.article-social-sidebar {
    display: none;
}

@media (min-width: 768px) {
    .article-social-sidebar {
        display: flex;
        flex-direction: column;
        gap: 0.75rem;
        position: sticky;
        top: 6rem;
        align-self: start;
    }
}

/* Article content typography */
.article-single__content {
    font-family: var(--font-serif);
    font-size: 1.0625rem;
    line-height: 1.85;
    color: var(--color-text);
}

.article-single__content h2 {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    margin: 2.5rem 0 1rem;
    color: var(--color-text);
    letter-spacing: -0.01em;
}

.article-single__content h3 {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    margin: 2rem 0 0.75rem;
    color: var(--color-text);
}

.article-single__content p {
    margin-bottom: 1.5rem;
}

.article-single__content img {
    max-width: 100%;
    height: auto;
    border-radius: var(--radius-lg);
    margin: 1.5rem 0;
}

.article-single__content blockquote {
    border-left: 3px solid var(--color-accent);
    margin: 2rem 0;
    padding: 1rem 1.5rem;
    font-style: italic;
    color: var(--color-text-light);
    background: var(--color-bg-alt);
    border-radius: 0 var(--radius) var(--radius) 0;
}

.article-single__content ul,
.article-single__content ol {
    margin-bottom: 1.5rem;
    padding-left: 1.5rem;
}

.article-single__content li {
    margin-bottom: 0.5rem;
}

.article-single__content a {
    color: var(--color-accent);
    text-decoration: underline;
    text-decoration-thickness: 1px;
    text-underline-offset: 2px;
    transition: color var(--transition-fast);
}

.article-single__content a:hover {
    color: var(--color-accent-dark);
}

.article-single__content pre {
    background: var(--color-slate-900);
    color: var(--color-slate-100);
    padding: 1.25rem;
    border-radius: var(--radius-lg);
    overflow-x: auto;
    margin: 1.5rem 0;
    font-size: 0.875rem;
    line-height: 1.6;
}

.article-single__content code {
    font-size: 0.9em;
    background: var(--color-bg-alt);
    padding: 0.15em 0.4em;
    border-radius: var(--radius-sm);
}

.article-single__content pre code {
    background: none;
    padding: 0;
}

.article-single__content table {
    width: 100%;
    border-collapse: collapse;
    margin: 1.5rem 0;
    font-size: 0.9375rem;
}

.article-single__content th,
.article-single__content td {
    padding: 0.75rem 1rem;
    border-bottom: 1px solid var(--color-border);
    text-align: left;
}

.article-single__content th {
    font-family: var(--font-sans);
    font-weight: 600;
    color: var(--color-text);
    background: var(--color-bg-alt);
}

/* Share buttons */
.share-btn {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 50%;
    background: var(--color-bg-alt);
    color: var(--color-text-muted);
    transition: all var(--transition);
    border: 1px solid var(--color-border);
}

.share-btn:hover {
    background: var(--color-accent);
    color: #ffffff;
    border-color: var(--color-accent);
    transform: translateY(-2px);
}

/* Mobile share bar */
.article-share {
    display: flex;
    align-items: center;
    gap: 1rem;
    padding: 1.5rem 0;
    margin: 2rem 0;
    border-top: 1px solid var(--color-border);
    border-bottom: 1px solid var(--color-border);
}

@media (min-width: 768px) {
    .article-share {
        display: none;
    }
}

.article-share__label {
    font-family: var(--font-sans);
    font-size: 0.8125rem;
    font-weight: 600;
    color: var(--color-text-light);
    white-space: nowrap;
}

.article-share__buttons {
    display: flex;
    gap: 0.5rem;
}

/* Author box */
.author-box {
    display: flex;
    gap: 1.25rem;
    padding: 2rem;
    margin: 3rem 0;
    background: var(--color-bg-alt);
    border-radius: var(--radius-xl);
    border-left: 3px solid transparent;
    border-image: var(--gradient-accent) 1;
    border-image-slice: 1;
}

.author-box__avatar {
    width: 4rem;
    height: 4rem;
    border-radius: 50%;
    object-fit: cover;
    flex-shrink: 0;
}

.author-box__label {
    font-size: 0.75rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-text-muted);
    display: block;
    margin-bottom: 0.25rem;
}

.author-box__name {
    font-family: var(--font-display);
    font-size: 1.125rem;
    color: var(--color-text);
    display: block;
    margin-bottom: 0.5rem;
}

.author-box__bio {
    font-size: 0.875rem;
    color: var(--color-text-light);
    line-height: 1.6;
}

/* Related articles */
.related-articles {
    margin: 4rem 0 2rem;
}

.section-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-bottom: 2rem;
}

.section-header h2 {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--color-text);
    white-space: nowrap;
}

.section-header-line {
    width: 3rem;
    height: 2px;
    background: var(--gradient-accent);
    flex-shrink: 0;
}

.section-header::after {
    content: '';
    flex: 1;
    height: 1px;
    background: var(--color-border);
}

/* Articles grid */
.articles-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 2rem;
}

@media (min-width: 640px) {
    .articles-grid--2col {
        grid-template-columns: repeat(2, 1fr);
    }
    .articles-grid--3col {
        grid-template-columns: repeat(2, 1fr);
    }
}

@media (min-width: 1024px) {
    .articles-grid--3col {
        grid-template-columns: repeat(3, 1fr);
    }
}

/* Article card (shared partial) */
.article-card {
    display: block;
    border-radius: var(--radius-lg);
    overflow: hidden;
    background: var(--color-bg-light);
    border: 1px solid var(--color-border);
    transition: all var(--transition);
}

.article-card:hover {
    box-shadow: var(--shadow-lg);
    transform: translateY(-3px);
}

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

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

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

.article-card__body {
    padding: 1.25rem;
}

.article-card__badge {
    font-family: var(--font-sans);
    font-size: 0.625rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: 0.1em;
    color: var(--color-accent);
    display: inline-block;
    margin-bottom: 0.5rem;
    transition: color var(--transition-fast);
}

.article-card__badge:hover {
    color: var(--color-accent-dark);
}

.article-card__title {
    font-family: var(--font-display);
    font-size: 1.125rem;
    font-weight: 600;
    line-height: 1.3;
    margin-bottom: 0.5rem;
}

.article-card__title a {
    color: var(--color-text);
    transition: color var(--transition-fast);
}

.article-card__title a:hover {
    color: var(--color-accent);
}

.article-card__excerpt {
    font-size: 0.875rem;
    color: var(--color-text-muted);
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.article-card__footer {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.75rem;
    font-size: 0.75rem;
    color: var(--color-text-muted);
}

.article-card__author {
    display: flex;
    align-items: center;
    gap: 0.375rem;
    font-weight: 500;
}

.article-card__avatar {
    width: 1.25rem;
    height: 1.25rem;
    border-radius: 50%;
    object-fit: cover;
}

.article-card--no-image .article-card__body {
    padding: 1.5rem;
}

/* No content placeholder */
.no-content {
    text-align: center;
    padding: 3rem 1rem;
    color: var(--color-text-muted);
    grid-column: 1 / -1;
}

.no-content svg {
    margin-bottom: 1rem;
    opacity: 0.4;
}

.no-content p {
    font-size: 1rem;
}

/* ============================================
   26. EDITORIAL ENHANCEMENTS
   ============================================ */

/* Dot grid pattern */
.editorial-section__bg::after {
    content: '';
    position: absolute;
    inset: 0;
    background-image: radial-gradient(circle, rgba(255,255,255,0.04) 1px, transparent 1px);
    background-size: 24px 24px;
}

/* CTA animated arrow */
.editorial-section__cta {
    position: relative;
    overflow: hidden;
}

.editorial-section__cta::before {
    content: '';
    position: absolute;
    bottom: -2px;
    left: 0;
    width: 100%;
    height: 1px;
    background: rgba(255,255,255,0.3);
    transform: scaleX(0);
    transform-origin: right;
    transition: transform 0.5s cubic-bezier(0.25, 0.46, 0.45, 0.94);
}

.editorial-section__cta:hover::before {
    transform: scaleX(1);
    transform-origin: left;
}

/* Section header enhancement */
.section-header-line {
    background: var(--gradient-accent);
    height: 2px;
}

/* Section header cross mark */
.section-header::after {
    content: '+';
    margin-left: auto;
    font-size: 0.75rem;
    font-weight: 300;
    color: var(--color-text-muted);
    opacity: 0.4;
}

/* Article single category dot */
.article-single__category {
    position: relative;
    padding-left: 1rem;
}

.article-single__category::before {
    content: '';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--color-accent);
}

/* Author box */
.author-box {
    border-left: 3px solid transparent;
    border-image: var(--gradient-accent) 1;
    border-image-slice: 1;
}

/* Related articles section */
.related-articles .section-header-line {
    background: var(--gradient-accent);
}

/* Hero image corner accents */
.hero-image {
    position: relative;
}

.hero-image::before {
    content: '';
    position: absolute;
    top: 12px;
    left: 12px;
    width: 24px;
    height: 24px;
    border-top: 2px solid rgba(255,255,255,0.4);
    border-left: 2px solid rgba(255,255,255,0.4);
    z-index: 2;
    border-radius: 2px 0 0 0;
    transition: all 0.5s ease;
}

.hero-grid:hover .hero-image::before {
    width: 32px;
    height: 32px;
    border-color: rgba(255,255,255,0.7);
}

/* Enhanced breadcrumbs */
.breadcrumb a {
    position: relative;
}

.breadcrumb a::after {
    content: '';
    position: absolute;
    bottom: -1px;
    left: 0;
    width: 0;
    height: 1px;
    background: var(--color-accent);
    transition: width 0.25s ease;
}

.breadcrumb a:hover::after {
    width: 100%;
}

/* ============================================
   26. SCROLL REVEAL ANIMATION
   ============================================ */
.reveal {
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 0.6s ease, transform 0.6s ease;
}

.revealed {
    opacity: 1;
    transform: translateY(0);
}

/* Staggered reveal */
.reveal:nth-child(2) { transition-delay: 0.1s; }
.reveal:nth-child(3) { transition-delay: 0.2s; }
.reveal:nth-child(4) { transition-delay: 0.3s; }
.reveal:nth-child(5) { transition-delay: 0.4s; }

/* ============================================
   27. PRINT STYLES
   ============================================ */
@media print {
    .site-header,
    .site-footer,
    .mobile-menu,
    .header-actions,
    .mag-newsletter,
    .dc-outils,
    .page-nav {
        display: none !important;
    }

    body {
        background: white;
        color: black;
        font-size: 12pt;
    }

    .site-main {
        padding-top: 0;
    }

    .dc-fullwidth,
    .mag-fullwidth {
        width: 100%;
        left: auto;
        margin-left: auto;
    }

    a {
        color: black;
        text-decoration: underline;
    }
}

/* ============================================
   28. REDUCED MOTION
   ============================================ */
@media (prefers-reduced-motion: reduce) {
    .reveal { opacity: 1; transform: none; }
    .reveal.revealed { animation: none; }
    .site-main { animation: none; }
    body::before { display: none; }
    * {
        transition-duration: 0.01ms !important;
        animation-duration: 0.01ms !important;
    }
}
