/* ============================================================
   detail.css — shared by the in-page modal (index.html) and the
   standalone per-prediction page (detail.html).
   Holds the decision-trace text styles (.dt-*), the per-agent
   persona cards (.pa-*), and the two-column page layout (.dview-*).
   ============================================================ */

/* ---- detail panel (modal) ---- */
.dt-overlay{position:fixed;inset:0;z-index:100;background:rgba(15,17,21,.45);backdrop-filter:blur(3px);display:flex;align-items:flex-start;justify-content:center;padding:4vh 16px;overflow:auto}
.dt-overlay[hidden]{display:none}
.dt-panel{position:relative;background:var(--bg);border:1px solid var(--line-2);border-radius:12px;max-width:760px;width:100%;box-shadow:var(--shadow-lg);padding:26px 28px 28px}
.dt-close{position:absolute;top:13px;right:13px;appearance:none;border:1px solid var(--line-2);background:var(--surface);border-radius:6px;width:30px;height:30px;cursor:pointer;color:var(--ink-2);font-size:13px}
.dt-close:hover{border-color:var(--ink-3);color:var(--ink)}
.dt-q{font-family:var(--ff-display);font-weight:800;font-size:20px;letter-spacing:-.02em;line-height:1.22;margin:0 36px 4px 0}
.dt-stat{font-family:var(--ff-mono);font-size:13.5px;color:var(--ink-2);margin-bottom:6px}
.dt-stat .up{color:var(--up)}.dt-stat .down{color:var(--down)}
.dt-step{border-top:1px solid var(--line);padding-top:15px;margin-top:15px}
.dt-k{font-family:var(--ff-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--accent);margin-bottom:9px;display:flex;gap:8px}
.dt-k .n{color:var(--ink-3)}
.dt-actor{display:flex;flex-wrap:wrap;gap:6px 8px;margin:0}
.dt-pill{font-size:12.5px;border:1px solid var(--line-2);border-radius:999px;padding:3px 10px;background:var(--surface);color:var(--ink-2)}
.dt-pill b{color:var(--ink)}
.dt-rel{font-family:var(--ff-mono);font-size:12.5px;color:var(--ink-2);line-height:1.85}
.dt-rel .pos{color:var(--accent-ink)}.dt-rel .neg{color:var(--down)}
table.dt-trace{width:100%;border-collapse:collapse;font-family:var(--ff-mono);font-size:12px;margin-top:2px}
table.dt-trace th,table.dt-trace td{padding:5px 7px;text-align:right;border-bottom:1px solid var(--line)}
table.dt-trace th:first-child,table.dt-trace td:first-child{text-align:left;color:var(--ink-2)}
table.dt-trace th{color:var(--ink-3);font-weight:500}
table.dt-trace td.lead{color:var(--accent-ink);font-weight:700;background:var(--accent-soft)}
.dt-res{display:grid;grid-template-columns:1fr auto auto;gap:5px 16px;font-size:13.5px;align-items:baseline}
.dt-res .m{font-family:var(--ff-mono);text-align:right}
.dt-agents{display:flex;flex-direction:column;gap:9px;margin-top:2px}
.dt-ag{display:flex;gap:10px;align-items:baseline;font-size:13px;color:var(--ink-2);line-height:1.45}
.dt-role{flex:0 0 auto;font-family:var(--ff-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;padding:2px 7px;border-radius:999px;border:1px solid var(--line-2);background:var(--surface);min-width:60px;text-align:center;color:var(--ink-3)}
.dt-role.decider{color:#fff;background:var(--ink);border-color:var(--ink)}
.dt-role.candidate{color:var(--accent-ink);border-color:var(--accent-line);background:var(--accent-soft)}
.dt-ag b{color:var(--ink)}
.dt-id{color:var(--ink-3);font-size:12px}
.dt-pk{font-family:var(--ff-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}
.dt-ev{display:flex;flex-direction:column;gap:9px;margin-top:2px}
.dt-evi{font-size:12.5px;color:var(--ink-2);line-height:1.48}
.dt-evk{font-family:var(--ff-mono);font-size:10px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);margin-bottom:1px}
.dt-evi a{color:var(--accent-ink);border-bottom:1px solid var(--accent-line);white-space:nowrap}
.dt-round{font-family:var(--ff-mono);font-size:11px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);font-weight:700;margin:15px 0 7px;padding-top:9px;border-top:1px dashed var(--line-2)}
.dt-tr{display:flex;flex-direction:column;gap:12px;margin-top:2px}
.dt-tra{border-left:2px solid var(--line-2);padding-left:12px}
.dt-trh{font-size:13.5px;margin-bottom:3px}
.dt-trl{font-size:12.5px;color:var(--ink-2);line-height:1.5;margin-top:3px}
.dt-trl .dt-pk{margin-right:5px}
.dt-pk.pub{color:var(--up)}.dt-pk.dm{color:var(--down)}
.dt-adj{margin-top:13px;padding:12px 14px;background:var(--accent-soft);border:1px solid var(--accent-line);border-radius:8px;font-size:14px}
.dt-embed{margin-top:6px;border:1px solid var(--line);border-radius:6px;background:var(--bg-sunk);overflow:hidden}
.dt-embed code{display:block;padding:9px 11px;font-size:10.5px;color:var(--ink-2);white-space:pre-wrap;word-break:break-all}
.dt-note{font-size:12.5px;color:var(--ink-3);margin-top:13px;line-height:1.5}
.agent-anat{display:flex;flex-direction:column;gap:8px}
.agent-anat>div{display:grid;grid-template-columns:104px 1fr;gap:10px;align-items:baseline}
.agent-anat .ak{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.04em;text-transform:uppercase;color:var(--accent)}
.agent-anat .av{color:var(--ink-2);font-size:13px;line-height:1.45}
@media(max-width:560px){.agent-anat>div{grid-template-columns:1fr}}

/* ---- per-agent persona cards (the "人设卡"), collapsible ---- */
.pa-list{display:flex;flex-direction:column;gap:9px;margin-top:4px}
.pa-card{border:1px solid var(--line-2);border-radius:10px;background:var(--surface);overflow:hidden}
.pa-head{display:flex;align-items:center;gap:9px;flex-wrap:wrap;padding:10px 13px;background:var(--bg-sunk);cursor:pointer;list-style:none;user-select:none}
.pa-head::-webkit-details-marker{display:none}
.pa-head:hover{background:var(--bg-sunk);filter:brightness(.985)}
details[open]>.pa-head{border-bottom:1px solid var(--line)}
.pa-name{font-family:var(--ff-display);font-weight:700;font-size:15px;letter-spacing:-.01em;color:var(--ink)}
.pa-mini{font-family:var(--ff-mono);font-size:10px;color:var(--ink-3);border:1px solid var(--line-2);border-radius:999px;padding:1px 7px}
.pa-chev{margin-left:auto;font-size:18px;line-height:1;color:var(--ink-3);transition:transform .15s}
details[open]>.pa-head .pa-chev{transform:rotate(90deg)}
.pa-role{font-family:var(--ff-mono);font-size:9.5px;letter-spacing:.07em;text-transform:uppercase;padding:2px 8px;border-radius:999px;border:1px solid var(--line-2);background:var(--surface);color:var(--ink-3)}
.pa-role.decider,.pa-role.advisor{color:#fff;background:var(--ink);border-color:var(--ink)}
.pa-role.candidate{color:var(--accent-ink);border-color:var(--accent-line);background:var(--accent-soft)}
.pa-body{padding:12px 14px 14px}
.pa-who{font-size:13.5px;color:var(--ink-2);line-height:1.5;margin-bottom:11px}
.pa-grid{display:grid;grid-template-columns:1fr 1fr;gap:9px 16px;margin-bottom:4px}
.pa-f{font-size:12.5px;color:var(--ink-2);line-height:1.45}
.pa-f .pa-k{display:block;font-family:var(--ff-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:2px}
.pa-f.goal .pa-k{color:var(--accent)}
.pa-f.pub .pa-k{color:var(--up)}
.pa-f.priv .pa-k{color:var(--down)}
.pa-layer{display:flex;align-items:center;gap:6px;font-family:var(--ff-mono);font-size:9px;letter-spacing:.07em;text-transform:uppercase;color:var(--ink-4);margin:13px 0 7px}
.pa-layer::after{content:"";flex:1;height:1px;background:var(--line)}
.pa-turn{border-left:2px solid var(--accent-line);padding:2px 0 2px 12px;margin-top:9px}
.pa-rnd{font-family:var(--ff-mono);font-size:9.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);margin-bottom:3px}
.pa-l{font-size:12.5px;color:var(--ink-2);line-height:1.5;margin-top:4px}
.pa-l .dt-pk{margin-right:5px}
.pa-est{font-family:var(--ff-mono);font-size:11px;color:var(--ink-3);margin-top:7px}
@media(max-width:560px){.pa-grid{grid-template-columns:1fr}}

/* ---- election track: emergence trace + group table + viz panels ---- */
.elec-trace{display:flex;flex-direction:column;gap:5px;margin:2px 0 2px}
.et-row{display:flex;align-items:center;gap:9px}
.et-r{font-family:var(--ff-mono);font-size:10px;color:var(--ink-3);width:18px;flex:0 0 auto}
.et-track{position:relative;flex:1;height:12px;background:var(--bg-sunk);border:1px solid var(--line);border-radius:7px}
.et-mid{position:absolute;top:-2px;bottom:-2px;width:1px;background:var(--ink-3);opacity:.5}
.et-dot{position:absolute;top:50%;width:9px;height:9px;border-radius:50%;transform:translate(-50%,-50%);box-shadow:0 0 0 2px var(--bg)}
.et-v{font-family:var(--ff-mono);font-size:11px;width:46px;text-align:right;flex:0 0 auto;font-weight:600}
table.elec-grp td{text-align:right}
table.elec-grp td:first-child{text-align:left}
.elec-viz{display:flex;flex-direction:column;gap:6px}
.elec-viz svg{display:block;width:100%;height:auto}
.elec-viz .ev-cap{font-family:var(--ff-mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);padding:0 2px}
.elec-viz .ev-block{position:relative;border:1px solid var(--line);border-radius:9px;background:var(--surface);padding:8px 8px 4px}
.elec-viz .ev-block.bar{padding-bottom:8px}

/* ---- multi-source citations (bottom of every detail) ---- */
.dt-src{margin:2px 0 0;padding-left:20px;display:flex;flex-direction:column;gap:6px}
.dt-src li{font-size:12.5px;color:var(--ink-2);line-height:1.45}
.dt-src a{color:var(--accent-ink);border-bottom:1px solid var(--accent-line);font-weight:600}
.dt-src a:hover{border-bottom-color:var(--accent-ink)}
.dt-src .dt-srcd{font-family:var(--ff-mono);font-size:10.5px;color:var(--ink-3)}

/* ---- primary archetype tally bars ---- */
.pe-tally{display:flex;flex-direction:column;gap:6px;margin:4px 0 2px}
.pe-row{display:flex;align-items:center;gap:9px}
.pe-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.pe-nm{font-size:13px;color:var(--ink);width:96px;flex:0 0 auto}
.pe-bar{flex:1;height:10px;background:var(--bg-sunk);border-radius:6px;overflow:hidden}
.pe-bar>div{height:100%;border-radius:6px}
.pe-v{font-family:var(--ff-mono);font-size:12px;color:var(--ink-2);width:40px;text-align:right;flex:0 0 auto;font-weight:600}
.dview-legend .lg-cands{display:flex;flex-wrap:wrap;gap:6px 12px;margin-top:6px}
.dview-legend .lg-c{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--ink-2)}
.dview-legend .lg-c i{width:9px;height:9px;border-radius:50%;display:inline-block}

/* ---- standalone page layout (detail.html) ---- */
.dview-head{border-bottom:1px solid var(--line);background:var(--surface)}
.dview-head .row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:13px 0}
.dview-back{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;color:var(--ink-2);border:1px solid var(--line-2);border-radius:var(--r-sm);padding:7px 13px;transition:.15s}
.dview-back:hover{border-color:var(--ink-3);color:var(--ink)}
.dview-title{font-family:var(--ff-display);font-weight:800;font-size:clamp(20px,2.4vw,28px);letter-spacing:-.025em;line-height:1.15;margin:22px 0 0}
.dview-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.05fr);gap:30px;align-items:start;padding:22px 0 60px}
.dview-graph{position:sticky;top:74px;align-self:start;max-height:calc(100vh - 90px);overflow:auto;overscroll-behavior:contain}
.dview-graph-box{border:1px solid var(--line-2);border-radius:12px;background:var(--surface-2);box-shadow:var(--shadow-lg);overflow:hidden}
.dview-graph svg{display:block;width:100%;height:auto}
.dview-graph .wc-tip,.dview-graph-box{position:relative}
.dview-glabel{font-family:var(--ff-mono);font-size:10.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-3);padding:10px 14px;border-bottom:1px solid var(--line);display:flex;justify-content:space-between;gap:10px}
.dview-legend{font-size:12px;color:var(--ink-3);line-height:1.6;margin-top:11px}
.dview-legend b{color:var(--ink-2);font-weight:600}
.dview-text{min-width:0}
.wc-tip{position:absolute;pointer-events:none;opacity:0;transition:opacity .12s;background:var(--ink);color:#eceadf;font-size:12px;line-height:1.45;padding:8px 10px;border-radius:7px;max-width:230px;box-shadow:0 10px 26px rgba(0,0,0,.28);z-index:5}
@media(max-width:880px){
  .dview-grid{grid-template-columns:1fr;gap:18px}
  .dview-graph{position:static;max-height:none;overflow:visible}
}
