/* ============================================================
       QUELLEN PAGE — additive page-specific styles
       ============================================================ */

    /* ── HERO ── */
    .quellen-hero {
      position: relative;
      padding-top: calc(var(--space-16) + var(--space-16));
      padding-bottom: var(--space-16);
      background: var(--color-bg);
      overflow: hidden;
    }

    .quellen-hero::before {
      content: '';
      position: absolute;
      inset: 0;
      background-image:
        radial-gradient(
          ellipse 60% 50% at 25% 55%,
          color-mix(in oklab, var(--color-primary) 6%, transparent),
          transparent 70%
        );
      pointer-events: none;
      z-index: 0;
    }

    .quellen-hero__inner {
      position: relative;
      z-index: 1;
      max-width: var(--content-default);
      margin-inline: auto;
      padding-inline: var(--space-6);
    }

    .quellen-hero__headline {
      font-family: var(--font-display);
      font-size: var(--text-3xl);
      font-weight: 700;
      line-height: 1.0;
      letter-spacing: -0.03em;
      color: var(--color-text);
      margin-bottom: var(--space-6);
      max-width: 18ch;
    }

    .quellen-hero__subline {
      font-size: var(--text-base);
      color: var(--color-text-muted);
      line-height: 1.7;
      max-width: 56ch;
    }

    /* ── ALLGEMEINE SEKTION ── */
    .quellen-section {
      padding-block: clamp(var(--space-12), 6vw, var(--space-24));
    }

    .quellen-section--alt {
      background: var(--color-surface);
    }

    .quellen-section__inner {
      max-width: var(--content-default);
      margin-inline: auto;
      padding-inline: var(--space-6);
    }

    /* ── KRITERIEN-LISTE ── */
    .kriterien-block {
      display: flex;
      flex-direction: column;
      gap: var(--space-1);
      margin-top: var(--space-10);
    }

    /* ── ACCORDION (details/summary) ── */
    .kriterien-gruppe {
      border: 1px solid var(--color-divider);
      background: var(--color-bg);
    }

    .kriterien-gruppe summary {
      list-style: none;
    }
    .kriterien-gruppe summary::-webkit-details-marker { display: none; }

    .kriterien-gruppe__btn {
      width: 100%;
      display: flex;
      align-items: center;
      justify-content: space-between;
      gap: var(--space-4);
      padding: var(--space-5) var(--space-8);
      background: transparent;
      cursor: pointer;
      text-align: left;
      border-bottom: 1px solid transparent;
      transition: border-color var(--transition-interactive), background var(--transition-interactive);
    }

    .kriterien-gruppe__btn:hover {
      background: var(--color-surface);
    }

    .kriterien-gruppe[open] > .kriterien-gruppe__btn {
      border-bottom-color: var(--color-divider);
    }

    .kriterien-gruppe__btn-label {
      font-family: var(--font-body);
      font-size: var(--text-xs);
      font-weight: 700;
      letter-spacing: 0.14em;
      text-transform: uppercase;
      color: var(--color-primary);
    }

    .kriterien-gruppe__icon {
      width: 20px;
      height: 20px;
      flex-shrink: 0;
      color: var(--color-text-faint);
      transition: transform var(--transition-interactive);
    }

    .kriterien-gruppe[open] .kriterien-gruppe__icon {
      transform: rotate(45deg);
    }

    .kriterien-gruppe__body {
      padding-bottom: var(--space-2);
    }

    .kriterien-liste {
      list-style: none;
      padding: var(--space-4) var(--space-8) var(--space-6);
      display: flex;
      flex-direction: column;
      gap: var(--space-4);
    }

    .kriterien-liste li {
      display: grid;
      grid-template-columns: 1.5rem 1fr;
      gap: var(--space-3);
      align-items: baseline;
    }

    .kriterien-liste li::before {
      content: '—';
      color: var(--color-primary);
      font-family: var(--font-display);
      font-weight: 700;
      font-size: var(--text-base);
    }

    .kriterien-liste li span {
      font-size: var(--text-base);
      color: var(--color-text-muted);
      line-height: 1.6;
      max-width: 68ch;
    }

    .kriterien-liste li strong {
      color: var(--color-text);
      font-weight: 600;
    }

    /* ── BEWERTUNGS-ORGANISATIONEN ── */
    .orgs-grid {
      display: grid;
      grid-template-columns: repeat(3, 1fr);
      gap: var(--space-1);
      margin-top: var(--space-10);
    }

    .org-card {
      padding: var(--space-8);
      border: 1px solid var(--color-divider);
      background: var(--color-bg);
      position: relative;
      transition: background var(--transition-interactive);
    }

    .org-card::before {
      content: '';
      position: absolute;
      top: 0;
      left: 0;
      width: 100%;
      height: 3px;
      background: var(--color-primary);
      transform: scaleX(0);
      transform-origin: left;
      transition: transform var(--transition-slow);
    }

    .org-card:hover::before { transform: scaleX(1); }
    .org-card:hover { background: var(--color-surface); }

    .org-card__name {
      font-family: var(--font-display);
      font-size: var(--text-lg);
      font-weight: 700;
      color: var(--color-text);
      letter-spacing: -0.02em;
      margin-bottom: var(--space-3);
    }

    .org-card__label {
      font-size: var(--text-xs);
      font-weight: 700;
      letter-spacing: 0.1em;
      text-transform: uppercase;
      color: var(--color-text-faint);
      margin-bottom: var(--space-4);
    }

    .org-card__text {
      font-size: var(--text-sm);
      color: var(--color-text-muted);
      line-height: 1.65;
      margin-bottom: var(--space-5);
    }

    .org-card__link {
      font-size: var(--text-xs);
      font-weight: 700;
      letter-spacing: 0.06em;
      text-transform: uppercase;
      color: var(--color-text-faint);
      display: inline-flex;
      align-items: center;
      gap: var(--space-2);
      transition: color var(--transition-interactive);
    }

    .org-card__link:hover { color: var(--color-primary); }

    .org-card__link .arrow {
      transition: transform var(--transition-interactive);
    }

    .org-card__link:hover .arrow { transform: translateX(3px); }

    /* ── QUELLEN-TABELLE ── */
    .quellen-table-wrap {
      margin-top: var(--space-10);
      overflow-x: auto;
      -webkit-overflow-scrolling: touch;
    }

    .quellen-table {
      width: 100%;
      border-collapse: collapse;
      font-size: var(--text-sm);
    }

    .quellen-table thead {
      border-bottom: 2px solid var(--color-primary);
    }

    .quellen-table th {
      font-family: var(--font-body);
      font-size: var(--text-xs);
      font-weight: 700;
      letter-spacing: 0.12em;
      text-transform: uppercase;
      color: var(--color-text-faint);
      text-align: left;
      padding: var(--space-3) var(--space-4);
      white-space: nowrap;
    }

    .quellen-table td {
      padding: var(--space-5) var(--space-4);
      color: var(--color-text-muted);
      border-bottom: 1px solid var(--color-divider);
      vertical-align: top;
      line-height: 1.5;
    }

    .quellen-table tr:last-child td {
      border-bottom: none;
    }

    .quellen-table tr:hover td {
      background: var(--color-surface);
    }

    .quellen-table__name {
      font-family: var(--font-display);
      font-size: var(--text-base);
      font-weight: 600;
      color: var(--color-text);
      letter-spacing: -0.01em;
      display: block;
      margin-bottom: var(--space-1);
    }

    .quellen-table__url {
      font-size: var(--text-xs);
      color: var(--color-text-faint);
      letter-spacing: 0.02em;
    }

    .bias-badge {
      display: inline-block;
      font-size: var(--text-xs);
      font-weight: 700;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      padding: 3px var(--space-3);
      border-radius: var(--radius-sm);
      white-space: nowrap;
    }

    .bias-badge--center {
      background: color-mix(in oklab, #4a9a6a 15%, transparent);
      color: #4a9a6a;
      border: 1px solid color-mix(in oklab, #4a9a6a 30%, transparent);
    }

    .bias-badge--center-left {
      background: color-mix(in oklab, #5a8ab0 15%, transparent);
      color: #5a8ab0;
      border: 1px solid color-mix(in oklab, #5a8ab0 30%, transparent);
    }

    .quellen-table__note {
      font-size: var(--text-xs);
      color: var(--color-text-faint);
      line-height: 1.5;
      max-width: 36ch;
    }

    /* ── DISCLAIMER ── */
    .quellen-disclaimer {
      margin-top: var(--space-10);
      padding: var(--space-6) var(--space-8);
      border-left: 3px solid var(--color-divider);
    }

    .quellen-disclaimer p {
      font-size: var(--text-sm);
      color: var(--color-text-faint);
      line-height: 1.7;
      max-width: 72ch;
    }

    /* ── BRIDGE ── */
    .quellen-bridge {
      background: var(--color-surface);
      border-top: 1px solid var(--color-divider);
      padding-block: clamp(var(--space-16), 8vw, var(--space-32));
    }

    .quellen-bridge__inner {
      max-width: var(--content-default);
      margin-inline: auto;
      padding-inline: var(--space-6);
    }

    .quellen-bridge__text {
      font-family: var(--font-display);
      font-size: var(--text-2xl);
      font-weight: 600;
      color: var(--color-text);
      line-height: 1.25;
      letter-spacing: -0.02em;
      max-width: 24ch;
      margin-bottom: var(--space-10);
    }

    .quellen-bridge__text em {
      font-style: normal;
      color: var(--color-text-muted);
    }

    /* ── RESPONSIVE ── */
    @media (max-width: 800px) {
      .orgs-grid {
        grid-template-columns: 1fr;
      }

      .quellen-hero__headline {
        font-size: clamp(2rem, 9vw, 3.5rem);
      }

      .kriterien-liste {
        padding-inline: var(--space-5);
      }

      .kriterien-gruppe__btn {
        padding-inline: var(--space-5);
      }
    }

    @media (max-width: 600px) {
      .quellen-table th:nth-child(3),
      .quellen-table td:nth-child(3) {
        display: none;
      }
    }

    /* ── IN-PAGE-NAV ── */
    .inpage-nav {
      position: sticky;
      top: 57px;
      z-index: 60;
      background: color-mix(in oklab, var(--color-bg) 92%, transparent);
      backdrop-filter: blur(10px);
      -webkit-backdrop-filter: blur(10px);
      border-bottom: 1px solid var(--color-divider);
      opacity: 0;
      pointer-events: none;
      transform: translateY(-6px);
      transition:
        opacity 0.25s cubic-bezier(0.16, 1, 0.3, 1),
        transform 0.25s cubic-bezier(0.16, 1, 0.3, 1);
    }

    .inpage-nav.is-visible {
      opacity: 1;
      pointer-events: auto;
      transform: translateY(0);
    }

    .inpage-nav__inner {
      max-width: var(--content-default);
      margin-inline: auto;
      padding-inline: var(--space-6);
      display: flex;
      align-items: center;
      overflow-x: auto;
      scrollbar-width: none;
      -ms-overflow-style: none;
    }

    .inpage-nav__inner::-webkit-scrollbar { display: none; }

    .inpage-nav__link {
      display: inline-flex;
      align-items: center;
      font-size: var(--text-xs);
      font-weight: 600;
      letter-spacing: 0.08em;
      text-transform: uppercase;
      color: var(--color-text-faint);
      padding: var(--space-4) var(--space-5);
      white-space: nowrap;
      border-bottom: 2px solid transparent;
      transition:
        color var(--transition-interactive),
        border-color var(--transition-interactive);
      text-decoration: none;
      min-height: 44px;
    }

    .inpage-nav__link:hover { color: var(--color-text); }

    .inpage-nav__link.is-active {
      color: var(--color-primary);
      border-bottom-color: var(--color-primary);
    }

    @media (max-width: 600px) {
      .inpage-nav { top: 53px; }
      .inpage-nav__link { padding-inline: var(--space-3); }
    }