
  /* ============================================================================
     CORRELATED.CSS  (site-specific — "The Unprotected Majority")
     ----------------------------------------------------------------------------
     Everything that is NOT part of the shared shell (shell.css): the model
     view's data-viz controls (trait-distribution bars, collapsible Parameters,
     silence-count chips, chart sizing) and the entire Stimuli view layout
     (section tags, table-card pattern, design cards, stimulus grid).
     Loaded AFTER shell.css so these can lean on the shared tokens + components.
     ============================================================================ */

  /* first model panelcard hugs the topbar a little tighter */
  #view-model > .panelcard:first-of-type { margin-top:6px; }

  /* ===== trait-distribution block (presets left, coloured A/B bars right) ===== */
  .trait-grid { display:grid; grid-template-columns:auto 1fr; gap:14px 24px; align-items:center; }
  .trait-presets { display:flex; flex-direction:row; gap:8px; align-self:center; }
  .preset-btn {
    border:1px solid var(--line); background:#fff; color:var(--ink-soft);
    font-weight:700; font-size:.82rem; letter-spacing:.07em; padding:9px 16px;
    border-radius:10px; cursor:pointer; text-align:center; flex:0 1 auto;
    transition:border-color .15s, color .15s, background .15s, box-shadow .15s;
  }
  .preset-btn:hover { border-color:var(--accent); color:var(--accent); }
  .preset-btn.on { background:var(--accent); border-color:var(--accent); color:#fff; box-shadow:0 3px 10px rgba(79,70,229,0.28); }
  .trait-sliders { display:flex; flex-direction:column; gap:12px; min-width:0; }
  .traitbar { display:flex; align-items:center; gap:12px; }
  .tb-group { flex:none; width:18px; text-align:center; font-size:1.05rem; font-weight:800; }
  .trait-range-wrap { position:relative; flex:1 1 auto; min-width:0; }
  .trait-range {
    -webkit-appearance:none; appearance:none; width:100%; height:32px; display:block;
    border-radius:8px; background:transparent; cursor:ew-resize; padding:0; margin:0;
  }
  .trait-range::-webkit-slider-runnable-track { height:32px; border-radius:8px; background:var(--fill,#eee); border:1px solid rgba(0,0,0,0.10); }
  .trait-range::-moz-range-track { height:32px; border-radius:8px; background:var(--fill,#eee); border:1px solid rgba(0,0,0,0.10); }
  .trait-range::-webkit-slider-thumb {
    -webkit-appearance:none; width:10px; height:40px; margin-top:-5px; border-radius:4px;
    background:#fff; border:2px solid var(--ink); box-shadow:0 1px 4px rgba(0,0,0,0.40); cursor:ew-resize;
  }
  .trait-range::-moz-range-thumb { width:8px; height:38px; border-radius:4px; background:#fff; border:2px solid var(--ink); cursor:ew-resize; }
  /* share labels INSIDE the bar, centred over each coloured segment, position set dynamically by JS */
  .tb-in {
    position:absolute; top:50%; transform:translate(-50%,-50%); pointer-events:none;
    font-size:.74rem; font-weight:600; color:#fff; white-space:nowrap;
    text-shadow:0 1px 2px rgba(0,0,0,0.45); letter-spacing:.01em;
  }
  .tb-in b { font-weight:800; }
  .trait-foot { display:flex; flex-wrap:wrap; align-items:center; gap:10px 16px; margin-top:13px; }
  .ratio-chips { display:flex; gap:8px; flex-wrap:wrap; }
  .ratio-chips .chip {
    font-size:.8rem; font-weight:600; color:var(--ink-soft);
    background:#f1f0fb; border:1px solid #e2def7; border-radius:999px; padding:3px 11px; font-variant-numeric:tabular-nums;
  }
  .ratio-chips .chip b { color:var(--accent); font-weight:700; margin-left:3px; }
  .ratio-chips .chip.alt { background:#eef6f3; border-color:#d6efe5; }
  .ratio-chips .chip.alt b { color:#2e7d68; }
  .trait-foot .derived { margin:0; background:none; border:0; padding:0; font-size:.79rem; flex:1 1 auto; min-width:200px; }

  /* collapsible Parameters section */
  .params-collapse { border:1px solid var(--line); border-radius:12px; background:#fcfcff; margin:14px 0 0; overflow:hidden; }
  .params-summary { list-style:none; cursor:pointer; user-select:none; display:flex; align-items:center; gap:10px; padding:11px 16px; }
  .params-summary::-webkit-details-marker { display:none; }
  .params-summary .ps-chevron {
    width:0; height:0; flex:none;
    border-left:6px solid var(--accent); border-top:5px solid transparent; border-bottom:5px solid transparent;
    transition:transform .15s ease;
  }
  .params-collapse[open] .params-summary .ps-chevron { transform:rotate(90deg); }
  .params-summary .ps-title { font-family:'Source Serif 4', Georgia, serif; font-size:1.05rem; font-weight:700; letter-spacing:-0.01em; color:var(--ink); }
  .params-summary .ps-hint { font-size:.78rem; color:var(--muted); margin-left:auto; }
  .params-summary:hover .ps-title { color:var(--accent); }
  .params-body { padding:2px 16px 14px; }

  /* base controls + expressive utility, side by side */
  .param-cols { display:grid; grid-template-columns:1fr 1fr; gap:14px 26px; }
  .param-col .slider-field { margin-bottom:8px; }
  .param-col .slider-field:last-child { margin-bottom:0; }

  /* who-stays-silent count chips */
  .silcounts { display:flex; flex-wrap:wrap; justify-content:center; gap:14px 44px; margin-top:12px; }
  .silcount-group { min-width:200px; }
  .silcount-group .scg-head { font-size:.86rem; font-weight:700; margin-bottom:5px; }
  .silcount-group .scg-row { font-size:.82rem; color:var(--ink-soft); display:flex; align-items:center; gap:7px; padding:2px 0; font-variant-numeric:tabular-nums; }
  .silcount-group .scg-row b { color:var(--ink); }
  .silcount-group .scg-sw { width:10px; height:10px; border-radius:3px; flex:none; }

  /* charts at ~70% width on desktop */
  #chart-sil svg, #chart-cells svg { max-width:70%; }
  @media (max-width:760px) {
    .trait-grid { grid-template-columns:1fr; }
    .trait-presets { flex-wrap:wrap; }
    .preset-btn { flex:1 1 auto; }
    .param-cols { grid-template-columns:1fr; }
    #chart-sil svg, #chart-cells svg { max-width:100%; }
  }

  /* ===================== Stimuli view (scoped) ===================== */
  :root { --study1:#4f46e5; --study2:#0e9f6e; }
  .view { /* swappable content block */ }
  #view-stimuli .section { margin-top:28px; }
  #view-stimuli .section:first-child { margin-top:20px; }
  #view-stimuli .section-head { display:flex; align-items:baseline; gap:14px; margin-bottom:6px; }
  #view-stimuli .section-tag { font-size:0.72rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:#fff; padding:4px 11px; border-radius:999px; white-space:nowrap; }
  #view-stimuli .section-tag.s1 { background:var(--study1); }
  #view-stimuli .section-tag.s2 { background:var(--study2); }
  #view-stimuli .section-head h2 { font-family:'Source Serif 4',Georgia,serif; font-size:1.5rem; font-weight:700; letter-spacing:-0.01em; }
  #view-stimuli .section-note { font-size:0.9rem; color:var(--muted); margin-bottom:22px; }
  #view-stimuli .card { background:var(--card); border:1px solid var(--line); border-radius:var(--radius); box-shadow:var(--shadow); }
  #view-stimuli .card.pad { padding:22px 26px; }
  #view-stimuli .table-card { margin-bottom:26px; overflow:hidden; }
  #view-stimuli .table-card .table-head { padding:16px 26px; border-bottom:1px solid var(--line-soft); }
  #view-stimuli .table-card .table-head h3 { font-size:0.95rem; font-weight:700; color:var(--ink); }
  #view-stimuli .table-card .table-head p { font-size:0.82rem; color:var(--muted); margin-top:2px; }
  #view-stimuli table { width:100%; border-collapse:collapse; }
  #view-stimuli th, #view-stimuli td { padding:12px 26px; text-align:right; }
  #view-stimuli th:first-child, #view-stimuli td:first-child { text-align:left; }
  #view-stimuli thead th { font-size:0.7rem; font-weight:700; letter-spacing:0.06em; text-transform:uppercase; color:var(--muted); border-bottom:1px solid var(--line); }
  #view-stimuli tbody td { font-size:0.92rem; font-variant-numeric:tabular-nums; border-bottom:1px solid var(--line-soft); color:var(--ink-soft); }
  #view-stimuli tbody tr:last-child td { border-bottom:none; }
  #view-stimuli tbody tr:hover td { background:#fafbff; }
  #view-stimuli td.treat { font-weight:700; color:var(--ink); text-align:left; }
  #view-stimuli td.treat .dot { display:inline-block; width:8px; height:8px; border-radius:50%; margin-right:9px; vertical-align:middle; }
  #view-stimuli .dot.neutral { background:#94a3b8; }
  #view-stimuli .dot.majority { background:var(--accent); }
  #view-stimuli .dot.minority { background:var(--accent-2); }
  #view-stimuli .design { margin-bottom:22px; padding:22px 26px; }
  #view-stimuli .design:last-child { margin-bottom:0; }
  #view-stimuli .design-head { display:flex; align-items:center; gap:12px; margin-bottom:18px; padding-bottom:14px; border-bottom:1px solid var(--line-soft); }
  #view-stimuli .design-head .name { font-size:1.02rem; font-weight:700; color:var(--ink); }
  #view-stimuli .design-head .kind { font-size:0.74rem; font-weight:600; letter-spacing:0.04em; text-transform:uppercase; color:var(--muted); margin-left:auto; }
  #view-stimuli .swatch { width:26px; height:18px; border-radius:5px; flex:none; box-shadow:inset 0 0 0 1px rgba(0,0,0,0.05); }
  #view-stimuli .swatch.menwomen { background:linear-gradient(135deg,#7c5cff,#4f86ff); }
  #view-stimuli .swatch.trianglecircle { background:linear-gradient(135deg,#0e9f6e,#39b8ff); }
  #view-stimuli .swatch.solar { background:linear-gradient(135deg,#f7b733,#fc4a1a); }
  #view-stimuli .stim-row { display:grid; grid-template-columns:repeat(3,1fr); gap:18px; }
  #view-stimuli .stim { background:#fbfbfe; border:1px solid var(--line-soft); border-radius:10px; padding:12px 12px 14px; transition:box-shadow 0.18s, transform 0.18s; }
  #view-stimuli .stim:hover { box-shadow:var(--shadow); transform:translateY(-2px); }
  #view-stimuli .stim-label { display:flex; align-items:center; gap:7px; font-size:0.74rem; font-weight:700; letter-spacing:0.05em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:10px; }
  #view-stimuli .stim-label .dot { width:7px; height:7px; border-radius:50%; }
  #view-stimuli .stim img { display:block; width:100%; height:auto; border-radius:6px; }

  /* ---- interactive stimulus figures: each setting is its own coloured card ---- */
  #view-stimuli .stim-intro { margin-bottom:22px; }
  #view-stimuli .section-tag.s3 { background:#b4453f; }
  #view-stimuli .table-card { margin-bottom:24px; }

  /* each SETTING wrapped in a coloured card container */
  #view-stimuli .domain-section {
    background:var(--card); border:1px solid var(--line);
    border-left:5px solid var(--sec-accent, var(--accent));
    border-radius:var(--radius); box-shadow:var(--shadow);
    padding:18px 22px 22px; margin-top:22px;
  }
  #view-stimuli .domain-section.d-abstract  { --sec-accent:#4f46e5; }
  #view-stimuli .domain-section.d-political  { --sec-accent:#b4453f; }
  /* header row: title block left, groups switch hard right */
  #view-stimuli .domain-section .section-head {
    display:flex; align-items:center; flex-wrap:wrap; gap:8px 14px; margin-bottom:6px;
  }
  #view-stimuli .sh-titles { display:flex; align-items:baseline; gap:12px; min-width:0; }
  #view-stimuli .sec-toggle { margin-left:auto; flex:none; }
  #view-stimuli .domain-section .section-note { margin-bottom:14px; }
  #view-stimuli .muted-label { color:var(--muted); font-weight:600; }
  #view-stimuli .stim-cite { margin-top:12px; font-size:0.74rem; font-style:italic; color:var(--muted); }
  #view-stimuli .stim-fig { display:block; }
  #view-stimuli .gtoggle {
    display:inline-flex; gap:0; margin:0; border:1px solid var(--line);
    border-radius:8px; overflow:hidden; background:#fff; flex:none;
  }
  #view-stimuli .lg-svg { vertical-align:middle; margin-right:5px; }
  #view-stimuli .gt-btn {
    border:0; background:#fff; color:var(--ink-soft); cursor:pointer;
    font-size:0.7rem; font-weight:700; letter-spacing:0.04em; text-transform:uppercase;
    padding:5px 11px; transition:background .15s, color .15s;
  }
  #view-stimuli .gt-btn + .gt-btn { border-left:1px solid var(--line); }
  #view-stimuli .gt-btn:hover { color:var(--accent); }
  #view-stimuli .gt-btn.on { background:var(--accent); color:#fff; }
  #view-stimuli .stim-svg { background:#fff; border:1px solid var(--line-soft); border-radius:8px; padding:4px; }
  #view-stimuli .stim-svg svg { display:block; width:100%; height:auto; }
  #view-stimuli .stim-svg text { font-variant-numeric:tabular-nums; }
  #view-stimuli .stim-svg text.pri { fill:#3a3f45; font-size:9.5px; font-weight:600; }
  #view-stimuli .stim-svg text.pri .big { font-size:12px; font-weight:800; }
  #view-stimuli .stim-svg text.sec { fill:#a2a8b0; font-size:7.6px; font-weight:600; letter-spacing:0.02em; }
  #view-stimuli .stim-cap { font-size:0.74rem; color:var(--muted); margin-top:9px; line-height:1.45; }
  #view-stimuli .stim-cap b { color:var(--ink-soft); font-weight:700; }
  #view-stimuli .stim-leg { display:block; margin-top:6px; font-size:0.7rem; color:var(--ink-soft); font-weight:600; }
  #view-stimuli .stim-leg .ls { display:inline-block; width:9px; height:9px; border-radius:3px; vertical-align:middle; margin-right:4px; }

  @media (max-width:720px) {
    #view-stimuli .stim-row { grid-template-columns:1fr; }
    #view-stimuli .design, #view-stimuli .card.pad { padding:18px; }
    #view-stimuli th, #view-stimuli td { padding:11px 18px; }
    #view-stimuli .table-card .table-head { padding:14px 18px; }
  }
