/* ============================================
   COLORADO SUDANESE COMMUNITY — DESIGN SYSTEM
   ============================================
   
   Structure:
   1. Config (tokens)
   2. Base (reset + defaults)
   3. Typography
   4. Spacing
   5. Layout
   6. Components
   7. Utilities
   
   ============================================ */

/* --------------------------------------------
   LAYER 1: CONFIGURATION & TOKENS
   -------------------------------------------- */
@layer config {
  :root,
  [data-theme="light"] {
    /* Colors - Warm Earth Tones */
    --color-bg: #F7F3ED;
    --color-text: #2D2A26;
    --color-accent: #B54A32;
    --color-accent-hover: #943D29;
    --color-muted: #6B635B;
    --color-surface: #FFFFFF;
    --color-border: #E0D9CF;

    /* Semantic Colors */
    --color-link: var(--color-accent);
    --color-link-hover: var(--color-accent-hover);

    /* Typography - Editorial Warmth */
    --font-heading: "Fraunces", Georgia, serif;
    --font-body: "Source Serif 4", Georgia, serif;
    --font-arabic: "Noto Naskh Arabic", serif;
    --font-ui: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    --font-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;

    /* Type Scale - Traditional Names */
    --text-great-primer: clamp(1.125rem, 1rem + 0.5vw, 1.25rem);   /* Body */
    --text-columbian: clamp(1.25rem, 1.1rem + 0.6vw, 1.5rem);      /* Lead/intro */
    --text-paragon: clamp(1.5rem, 1.25rem + 1vw, 2rem);            /* H4 */
    --text-double-pica: clamp(1.75rem, 1.4rem + 1.5vw, 2.5rem);    /* H3 */
    --text-canon: clamp(2.25rem, 1.75rem + 2vw, 3.25rem);          /* H2 */
    --text-double-canon: clamp(2.75rem, 2rem + 3vw, 4.5rem);       /* H1 */

    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --leading: 1.5;
    --leading-tight: 1.2;

    /* Spacing - Character-based */
    --gutter: clamp(1ch, 2.5vw, 2ch);
    --stack: clamp(1.5ex, 3vw, 3ex);
    --line-length: 65ch;
    --page-padding: clamp(1rem, 5vw, 4rem);

    /* Borders */
    --border-width: 1px;
    --border-radius: 0.25rem;
    --border-radius-lg: 0.375rem;

    /* Transitions */
    --transition-fast: 150ms ease;
    --transition-normal: 250ms ease;

    color-scheme: light;
  }

  [data-theme="dark"] {
    --color-bg: #1C1917;
    --color-text: #F5F0E8;
    --color-accent: #D4785C;
    --color-accent-hover: #E89A7A;
    --color-muted: #A39E96;
    --color-surface: #292524;
    --color-border: #3D3835;
    --font-weight-regular: 400;
    color-scheme: dark;
  }

  @media (prefers-color-scheme: dark) {
    :root:not([data-theme="light"]) {
      --color-bg: #1C1917;
      --color-text: #F5F0E8;
      --color-accent: #D4785C;
      --color-accent-hover: #E89A7A;
      --color-muted: #A39E96;
      --color-surface: #292524;
      --color-border: #3D3835;
      --font-weight-regular: 400;
      color-scheme: dark;
    }
  }

  @media (prefers-contrast: more) {
    :root, [data-theme="light"] {
      --color-bg: white;
      --color-text: black;
      --color-surface: white;
      --color-border: black;
    }
    [data-theme="dark"] {
      --color-bg: black;
      --color-text: white;
      --color-surface: black;
      --color-border: white;
    }
  }
}

/* --------------------------------------------
   LAYER 2: RESET & BASE
   -------------------------------------------- */
@layer base {
  *, *::before, *::after {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
  }

  html {
    -webkit-text-size-adjust: 100%;
    text-size-adjust: 100%;
  }

  body {
    min-height: 100dvh;
    font-family: var(--font-body);
    font-size: var(--text-great-primer);
    font-weight: var(--font-weight-regular);
    line-height: var(--leading);
    color: var(--color-text);
    background-color: var(--color-bg);
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
  }

  /* RTL + Arabic font */
  html[lang="ar"] {
    direction: rtl;
  }

  html[lang="ar"] body,
  [lang="ar"] {
    font-family: var(--font-arabic);
    line-height: 1.6; /* Arabic needs slightly more */
  }

  /* Bilingual switching */
  html[lang="en"] [lang="ar"]:not([data-show-both]) { display: none; }
  html[lang="ar"] [lang="en"]:not([data-show-both]) { display: none; }

  img, picture, video, svg {
    display: block;
    max-width: 100%;
    height: auto;
  }

  input, button, textarea, select {
    font: inherit;
    color: inherit;
  }

  ul, ol {
    list-style: none;
  }

  a {
    color: var(--color-accent);
    text-decoration: underline;
    text-decoration-thickness: var(--border-width);
    text-underline-offset: 0.15em;
    transition: color var(--transition-fast);
  }

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

  a:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
    border-radius: 2px;
  }

  ::selection {
    background-color: var(--color-accent);
    color: white;
  }
}

/* --------------------------------------------
   LAYER 3: TYPOGRAPHY
   -------------------------------------------- */
@layer typography {
  h1, h2, h3, h4, h5, h6 {
    font-family: var(--font-heading);
    font-weight: var(--font-weight-semibold);
    line-height: var(--leading-tight);
    text-wrap: balance;
  }

  h1 { font-size: var(--text-double-canon); font-weight: var(--font-weight-bold); }
  h2 { font-size: var(--text-canon); }
  h3 { font-size: var(--text-double-pica); }
  h4 { font-size: var(--text-paragon); }
  h5 { font-size: var(--text-columbian); }
  h6 { font-size: 0.875rem; text-transform: uppercase; letter-spacing: 0.05em; font-family: var(--font-ui); }

  p, ul, ol, dl, blockquote, pre, figure, table {
    max-width: var(--line-length);
  }

  .lead, big { font-size: var(--text-columbian); line-height: 1.5; }
  small, .small { font-size: 0.85em; }
  strong, b { font-weight: var(--font-weight-semibold); }
  em, i, cite { font-style: italic; }

  code, kbd, samp {
    font-family: var(--font-mono);
    font-size: 0.875em;
    background-color: var(--color-surface);
    padding: 0.125em 0.375em;
    border-radius: var(--border-radius);
    border: var(--border-width) solid var(--color-border);
  }

  pre {
    font-family: var(--font-mono);
    font-size: 0.85rem;
    background-color: var(--color-surface);
    padding: var(--gutter);
    border-radius: var(--border-radius-lg);
    border: var(--border-width) solid var(--color-border);
    overflow-x: auto;
    white-space: pre-wrap;
    word-wrap: break-word;
  }

  pre code {
    background: none;
    padding: 0;
    border: none;
    font-size: inherit;
  }

  blockquote {
    font-size: 1.15em;
    font-style: italic;
    padding-inline-start: var(--gutter);
    border-inline-start: 3px solid var(--color-accent);
    color: var(--color-muted);
  }

  blockquote cite {
    display: block;
    margin-block-start: 0.5em;
    font-size: 0.85em;
    font-style: normal;
  }

  .muted { color: var(--color-muted); }

  /* UI elements use sans-serif */
  button, .btn, nav, .site-header, .site-footer {
    font-family: var(--font-ui);
  }
}

/* --------------------------------------------
   LAYER 4: SPACING
   -------------------------------------------- */
@layer spacing {
  .stack > * + * { margin-block-start: var(--stack); }
  .stack-sm > * + * { margin-block-start: calc(var(--stack) * 0.5); }
  .stack-lg > * + * { margin-block-start: calc(var(--stack) * 2); }
  
  section, article { padding-block: calc(var(--stack) * 0.75); }
  
  h2, h3, h4, h5, h6 { margin-block-start: calc(var(--stack) * 1.5); }
  :is(h1, h2, h3, h4, h5, h6):first-child { margin-block-start: 0; }
  :is(h1, h2, h3, h4, h5, h6) + * { margin-block-start: calc(var(--stack) * 0.5); }
}

/* --------------------------------------------
   LAYER 5: LAYOUT
   -------------------------------------------- */
@layer layout {
  .page {
    display: grid;
    grid-template-rows: auto 1fr auto;
    min-height: 100dvh;
  }

  .container {
    width: 100%;
    max-width: calc(var(--line-length) + var(--page-padding) * 2);
    margin-inline: auto;
    padding-inline: var(--page-padding);
    padding-block-end: calc(var(--stack) * 2);
  }

  .container-wide {
    max-width: calc(75rem + var(--page-padding) * 2);
  }

  .grid {
    display: grid;
    gap: var(--gutter);
    grid-template-columns: repeat(auto-fit, minmax(min(100%, var(--grid-min, 18rem)), 1fr));
  }

  .flag {
    display: grid;
    gap: var(--gutter);
    grid-template-columns: auto 1fr;
    align-items: start;
  }

  html[dir="rtl"] .flag { grid-template-columns: 1fr auto; }
  .flag > :first-child { max-width: 8rem; }

  @media (max-width: 30rem) {
    .flag { grid-template-columns: 1fr; }
    .flag > :first-child { max-width: 6rem; }
  }

  .cluster {
    display: flex;
    flex-wrap: wrap;
    gap: var(--gutter);
    align-items: center;
  }

  .cluster-between { justify-content: space-between; }
}

/* --------------------------------------------
   LAYER 6: COMPONENTS
   -------------------------------------------- */
@layer components {
  /* Skip Link - visually hidden until focused */
  .skip-link {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 9999;
    padding: 0.75rem 1rem;
    background-color: var(--color-accent);
    color: white;
    text-decoration: none;
    font-weight: var(--font-weight-medium);
    border-radius: var(--border-radius);
    /* Visually hidden but focusable */
    clip: rect(0, 0, 0, 0);
    clip-path: inset(50%);
    height: 1px;
    width: 1px;
    overflow: hidden;
    white-space: nowrap;
  }

  .skip-link:focus {
    /* Reveal on focus */
    clip: auto;
    clip-path: none;
    height: auto;
    width: auto;
    overflow: visible;
    white-space: normal;
    outline: 2px solid var(--color-text);
    outline-offset: 2px;
  }
  
  /* Site Header */
  .site-header {
    padding: calc(var(--stack) * 0.5) var(--page-padding);
    border-block-end: var(--border-width) solid var(--color-border);
    background-color: var(--color-bg);
    position: sticky;
    top: 0;
    z-index: 100;
  }

  .site-header .container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: var(--gutter);
    max-width: calc(75rem + var(--page-padding) * 2);
    padding-block-end: 0;
  }

  .site-title {
    font-family: var(--font-heading);
    font-size: var(--text-columbian);
    font-weight: var(--font-weight-semibold);
    line-height: var(--leading-tight);
    text-decoration: none;
    color: var(--color-text);
  }

  .site-title:hover { color: var(--color-accent); }
  .site-title span { display: block; }

  /* Primary Navigation */
  .primary-nav {
    display: flex;
    align-items: center;
    gap: calc(var(--gutter) * 0.5);
  }

  .primary-nav a {
    text-decoration: none;
    color: var(--color-muted);
    font-size: 0.9375rem;
    font-weight: var(--font-weight-medium);
    padding: 0.5ex 1ch;
    border-radius: var(--border-radius);
    transition: color var(--transition-fast);
  }

  .primary-nav a:hover {
    color: var(--color-text);
  }

  .primary-nav a[aria-current="page"] {
    color: var(--color-text);
    font-weight: var(--font-weight-semibold);
  }
  
  /* Mobile Menu */
  .menu-toggle {
    display: none;
    background: none;
    border: none;
    padding: 0.5rem;
    cursor: pointer;
    color: var(--color-text);
  }
  
  .menu-toggle svg { width: 1.5rem; height: 1.5rem; }
  
  @media (max-width: 50rem) {
    /* Fix header layout on mobile - prevent flex-wrap issues */
    .site-header .container {
      flex-wrap: nowrap;
    }

    .site-title {
      flex: 1;
      min-width: 0;
      overflow: hidden;
    }

    .menu-toggle {
      display: block;
      flex-shrink: 0;
    }

    .header-controls {
      flex-shrink: 0;
    }

    .primary-nav {
      display: none;
      position: absolute;
      top: 100%;
      left: 0;
      right: 0;
      flex-direction: column;
      align-items: stretch;
      padding: var(--gutter);
      background-color: var(--color-bg);
      border-block-end: var(--border-width) solid var(--color-border);
      box-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1);
    }
    
    .primary-nav a { padding: 0.75rem; }
    .primary-nav[data-open="true"] { display: flex; }
  }
  
  /* Header Controls */
  .header-controls {
    display: flex;
    align-items: center;
    gap: 0.5rem;
  }
  
  .toggle-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.375rem;
    padding: 0.5rem 0.75rem;
    background-color: var(--color-surface);
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--border-radius);
    font-size: 0.875rem;
    font-weight: var(--font-weight-medium);
    cursor: pointer;
    transition: border-color var(--transition-fast);
  }
  
  .toggle-btn:hover { border-color: var(--color-accent); }
  
  .toggle-btn:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
  }
  
  .toggle-btn svg { width: 1.125rem; height: 1.125rem; }
  
  /* Section Navigation */
  .section-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    padding: var(--gutter);
    background-color: var(--color-surface);
    border-radius: var(--border-radius-lg);
    border: var(--border-width) solid var(--color-border);
  }
  
  .section-nav a {
    padding: 0.5rem 0.875rem;
    text-decoration: none;
    color: var(--color-text);
    font-size: 0.875rem;
    font-weight: var(--font-weight-medium);
    border-radius: var(--border-radius);
    transition: background-color var(--transition-fast);
  }
  
  .section-nav a:hover { background-color: var(--color-bg); }
  
  .section-nav a[aria-current="page"] {
    background-color: var(--color-accent);
    color: white;
  }
  
  /* Back Link */
  .back-link {
    display: inline-flex;
    align-items: center;
    gap: 0.375rem;
    font-size: 0.9375rem;
    color: var(--color-muted);
  }
  
  .back-link:hover { color: var(--color-accent); }
  html[dir="rtl"] .back-link svg { transform: scaleX(-1); }
  
  /* Site Footer */
  .site-footer {
    margin-block-start: auto;
    padding-block: calc(var(--stack) * 1.5);
    background-color: var(--color-surface);
    border-block-start: var(--border-width) solid var(--color-border);
  }
  
  .site-footer .container {
    max-width: calc(80rem + var(--page-padding) * 2);
  }
  
  .footer-grid {
    display: grid;
    gap: calc(var(--gutter) * 2);
    grid-template-columns: repeat(auto-fit, minmax(min(100%, 12rem), 1fr));
  }
  
  .footer-section h2 {
    font-size: 0.875rem;
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-muted);
    margin-block-end: var(--stack);
  }
  
  .footer-section ul {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }
  
  .footer-section a {
    color: var(--color-text);
    text-decoration: none;
    font-size: 0.9375rem;
  }
  
  .footer-section a:hover {
    color: var(--color-accent);
    text-decoration: underline;
  }
  
  .footer-bottom {
    margin-block-start: calc(var(--stack) * 2);
    padding-block-start: var(--stack);
    border-block-start: var(--border-width) solid var(--color-border);
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    gap: var(--gutter);
    font-size: 0.875rem;
    color: var(--color-muted);
  }
  
  .social-links {
    display: flex;
    gap: 0.75rem;
  }
  
  .social-links a {
    color: var(--color-muted);
    transition: color var(--transition-fast);
  }
  
  .social-links a:hover { color: var(--color-accent); }
  .social-links svg { width: 1.25rem; height: 1.25rem; }
  
  /* Buttons */
  .btn {
    font-family: var(--font-ui);
    font-size: 0.9375rem;
    font-weight: var(--font-weight-medium);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.5rem;
    padding: 0.625em 1.25em;
    text-decoration: none;
    border: var(--border-width) solid transparent;
    border-radius: var(--border-radius);
    cursor: pointer;
    transition: all var(--transition-fast);
  }

  .btn:focus-visible {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
  }

  .btn-primary {
    background-color: var(--color-accent);
    color: white;
    border-color: var(--color-accent);
  }

  .btn-primary:hover {
    background-color: var(--color-accent-hover);
    border-color: var(--color-accent-hover);
    color: white;
  }

  .btn-secondary {
    background-color: transparent;
    color: var(--color-text);
    border-color: var(--color-border);
  }

  .btn-secondary:hover {
    border-color: var(--color-text);
  }

  .btn:disabled {
    opacity: 0.5;
    cursor: not-allowed;
  }
  
  /* Cards */
  .card {
    background-color: var(--color-surface);
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--border-radius-lg);
    padding: calc(var(--gutter) * 1.5);
    transition: transform var(--transition-fast), box-shadow var(--transition-fast), border-color var(--transition-fast);
  }

  .card-link {
    text-decoration: none;
    color: inherit;
    display: block;
  }

  .card-link:hover .card {
    transform: translateY(-2px);
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    border-color: var(--color-accent);
  }

  .card-link:focus-visible { outline: none; }

  .card-link:focus-visible .card {
    outline: 2px solid var(--color-accent);
    outline-offset: 2px;
  }

  .card h3 {
    font-size: var(--text-columbian);
    margin-block-start: 0;
    margin-block-end: 0.5ex;
  }

  .card p {
    margin-block-start: 0;
    color: var(--color-muted);
    font-size: 0.9375rem;
  }
  
  /* Person Card */
  .person-card { text-align: center; }
  
  .person-card .avatar {
    width: 6rem;
    height: 6rem;
    border-radius: 50%;
    object-fit: cover;
    margin-inline: auto;
    margin-block-end: var(--stack);
    background-color: var(--color-border);
  }
  
  .person-card h3 { font-size: 1.125rem; margin-block-start: 0; }
  .person-card .title { font-size: 0.875rem; color: var(--color-muted); margin-block-start: 0.25rem; }
  .person-card .bio { font-size: 0.9375rem; margin-block-start: 0.75rem; text-align: start; }
  
  /* Article Preview */
  .article-preview {
    padding-block: var(--stack);
    border-block-end: var(--border-width) solid var(--color-border);
  }
  
  .article-preview:last-child { border-block-end: none; }
  
  .article-preview time {
    font-size: 0.8125rem;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
  }
  
  .article-preview h2,
  .article-preview h3 { margin-block-start: 0.375rem; font-size: 1.25rem; }
  .article-preview h2 a,
  .article-preview h3 a { color: var(--color-text); text-decoration: none; }
  .article-preview h2 a:hover,
  .article-preview h3 a:hover { color: var(--color-accent); }
  .article-preview p { margin-block-start: 0.5rem; color: var(--color-muted); }

  /* Spotlight Preview (Creative Works Feed) */
  .spotlight-preview {
    padding-block: var(--stack);
    border-block-end: var(--border-width) solid var(--color-border);
  }

  .spotlight-preview:last-child { border-block-end: none; }

  .spotlight-meta {
    display: flex;
    align-items: center;
    gap: 1ch;
    font-size: 0.8125rem;
    color: var(--color-muted);
  }

  .spotlight-meta time {
    text-transform: uppercase;
    letter-spacing: 0.03em;
  }

  .spotlight-preview h2,
  .spotlight-preview h3 { margin-block-start: 0.375rem; font-size: 1.25rem; }
  .spotlight-preview h2 a,
  .spotlight-preview h3 a { color: var(--color-text); text-decoration: none; }
  .spotlight-preview h2 a:hover,
  .spotlight-preview h3 a:hover { color: var(--color-accent); }

  .spotlight-preview .byline {
    margin-block-start: 0.25rem;
    font-size: 0.9375rem;
    color: var(--color-muted);
    font-style: italic;
  }

  .spotlight-preview .excerpt {
    margin-block-start: 0.5rem;
    color: var(--color-muted);
  }

  /* Event Preview (Past Events) */
  .event-preview {
    padding-block: var(--stack);
    border-block-end: var(--border-width) solid var(--color-border);
  }

  .event-preview:last-child { border-block-end: none; }

  .event-preview time {
    font-size: 0.8125rem;
    color: var(--color-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
  }

  .event-preview h2,
  .event-preview h3 { margin-block-start: 0.375rem; font-size: 1.25rem; }
  .event-preview h2 a,
  .event-preview h3 a { color: var(--color-text); text-decoration: none; }
  .event-preview h2 a:hover,
  .event-preview h3 a:hover { color: var(--color-accent); }

  .event-preview .location {
    margin-block-start: 0.25rem;
    font-size: 0.9375rem;
    color: var(--color-muted);
  }

  .event-preview .excerpt {
    margin-block-start: 0.5rem;
    color: var(--color-muted);
  }

  /* Event Page (Individual Event Details) */
  .event-type {
    font-size: 0.8125rem;
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    color: var(--color-accent);
    margin-block-end: 0;
  }

  .event-type + h1 {
    margin-block-start: 0.5rem;
  }

  .event-details {
    display: flex;
    flex-direction: column;
    width: fit-content;
    margin-inline: auto;
    gap: 0.375rem;
    padding: 0.625rem 1rem;
    background-color: transparent;
    border-radius: 0.375rem;
    border: 1px solid var(--color-border);
  }

  .event-datetime,
  .event-location {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    font-size: 0.9375rem;
  }

  .event-datetime svg,
  .event-location svg {
    flex-shrink: 0;
    color: var(--color-accent);
  }

  .event-location .address {
    font-size: 0.875rem;
    color: var(--color-muted);
  }

  .event-flyer {
    margin: 0;
    margin-block-start: 1.5rem;
    display: flex;
    justify-content: center;
  }

  .event-flyer img {
    max-width: 100%;
    height: auto;
    border-radius: 0.5rem;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
  }

  @media (min-width: 40rem) {
    .event-flyer img {
      max-width: 28rem;
    }
  }

  /* Type Tags */
  .type-tag {
    display: inline-block;
    padding: 0.125em 0.5em;
    font-size: 0.75rem;
    font-weight: var(--font-weight-medium);
    text-transform: uppercase;
    letter-spacing: 0.05em;
    border-radius: 0.25rem;
    background-color: var(--color-surface);
    border: 1px solid var(--color-border);
  }

  .type-tag.type-writing {
    background-color: #F0E8D9;
    border-color: #D4C4A8;
    color: #6B5A3E;
  }
  .type-tag.type-art {
    background-color: #E8E4F0;
    border-color: #C8BED4;
    color: #5A4E6B;
  }
  .type-tag.type-media {
    background-color: #E4F0E8;
    border-color: #BED4C8;
    color: #4E6B5A;
  }

  [data-theme="dark"] .type-tag.type-writing {
    background-color: #3D3527;
    border-color: #5A4E3D;
    color: #D4C4A8;
  }
  [data-theme="dark"] .type-tag.type-art {
    background-color: #352D3D;
    border-color: #4E455A;
    color: #C8BED4;
  }
  [data-theme="dark"] .type-tag.type-media {
    background-color: #2D3D35;
    border-color: #455A4E;
    color: #BED4C8;
  }

  /* Spotlight Piece Page */
  .spotlight-piece .spotlight-header {
    margin-block-end: calc(var(--stack) * 2);
  }

  .spotlight-piece .byline {
    font-size: 1.125rem;
    color: var(--color-muted);
    font-style: italic;
  }

  .spotlight-content {
    font-size: var(--text-great-primer);
  }

  .spotlight-image {
    margin-block: calc(var(--stack) * 1.5);
  }

  .spotlight-image img {
    max-width: 100%;
    height: auto;
    border-radius: var(--border-radius);
  }

  .spotlight-image figcaption {
    margin-block-start: 0.75rem;
    font-size: 0.9375rem;
    color: var(--color-muted);
    font-style: italic;
  }

  .media-embed {
    margin-block: calc(var(--stack) * 1.5);
  }

  .media-embed iframe,
  .media-embed video,
  .media-embed audio {
    max-width: 100%;
    border-radius: var(--border-radius);
  }

  .creator-bio {
    margin-block-start: calc(var(--stack) * 2);
    padding-block-start: var(--stack);
    border-block-start: var(--border-width) solid var(--color-border);
    font-size: 0.9375rem;
    color: var(--color-muted);
  }

  /* Link List */
  .link-list {
    display: flex;
    flex-direction: column;
    gap: var(--stack);
  }
  
  .link-list-item {
    display: block;
    padding: var(--gutter);
    background-color: var(--color-surface);
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--border-radius);
    text-decoration: none;
    color: inherit;
    transition: border-color var(--transition-fast);
  }
  
  .link-list-item:hover { border-color: var(--color-accent); }
  .link-list-item h3 { font-size: 1rem; margin-block-start: 0; color: var(--color-accent); }
  .link-list-item p { font-size: 0.9375rem; color: var(--color-muted); margin-block-start: 0.25rem; }
  
  /* Forms */
  .form-group {
    display: flex;
    flex-direction: column;
    gap: 0.375rem;
  }
  
  label {
    font-weight: var(--font-weight-medium);
    font-size: 0.9375rem;
  }
  
  input[type="text"],
  input[type="email"],
  input[type="tel"],
  input[type="search"],
  textarea,
  select {
    width: 100%;
    padding: 0.75rem;
    background-color: var(--color-bg);
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--border-radius);
    transition: border-color var(--transition-fast), box-shadow var(--transition-fast);
  }
  
  input:focus,
  textarea:focus,
  select:focus {
    outline: none;
    border-color: var(--color-accent);
    box-shadow: 0 0 0 3px color-mix(in srgb, var(--color-accent) 20%, transparent);
  }
  
  textarea { min-height: 8rem; resize: vertical; }
  
  .checkbox-group,
  .radio-group {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
  }
  
  input[type="checkbox"],
  input[type="radio"] {
    width: 1.25rem;
    height: 1.25rem;
    margin-block-start: 0.125rem;
    accent-color: var(--color-accent);
  }
  
  /* Accordion (Details/Summary) */
  details {
    background-color: var(--color-surface);
    border: var(--border-width) solid var(--color-border);
    border-radius: var(--border-radius);
  }
  
  details + details { margin-block-start: 0.5rem; }
  
  summary {
    padding: var(--gutter);
    cursor: pointer;
    font-weight: var(--font-weight-medium);
    list-style: none;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: var(--gutter);
  }
  
  summary::-webkit-details-marker { display: none; }
  
  summary::after {
    content: "+";
    font-size: 1.25rem;
    font-weight: var(--font-weight-regular);
    color: var(--color-muted);
    transition: transform var(--transition-fast);
  }
  
  details[open] summary::after { content: "−"; }
  summary:hover { color: var(--color-accent); }
  details > :not(summary) { padding: 0 var(--gutter) var(--gutter); }

  /* Pull Quote - Editorial flourish */
  .pull-quote {
    font-family: var(--font-heading);
    font-size: var(--text-double-pica);
    font-style: italic;
    color: var(--color-accent);
    border-inline-start: 3px solid var(--color-accent);
    padding-inline-start: 1ch;
    margin-block: var(--stack);
    max-width: var(--line-length);
  }

  /* Horizontal Rules */
  hr {
    border: none;
    border-top: 1px solid var(--color-border);
    margin-block: calc(var(--stack) * 2);
  }

  /* Decorative HR variant */
  hr.decorative {
    border: none;
    text-align: center;
  }

  hr.decorative::before {
    content: "✦";
    color: var(--color-muted);
    font-size: 0.875rem;
  }
}

/* --------------------------------------------
   LAYER 7: UTILITIES
   -------------------------------------------- */
@layer utilities {
  .visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
  }
  
  .text-center { text-align: center; }
  .text-start { text-align: start; }
  .text-end { text-align: end; }
}
