/* ── Wrapper ─────────────────────────────────────────────────────── */
.dr-wrap { max-width:780px; margin:0 auto; padding:1.5rem 1rem 4rem; }
.dr-back { font-size:.82rem; color:#6b7280; padding:.6rem 1rem .1rem;
           display:block; text-decoration:none; text-align:right; }
.dr-back:hover { color:#374151; }


/* ── CTA cards ───────────────────────────────────────────────────── */
.cta-section { margin-bottom:1.2rem; }
.cta-card {
  border-radius: 0; padding:1rem 1.25rem; margin-bottom:.65rem;
  background:linear-gradient(135deg,#f5f3ff 0%,#ede9fe 100%); border:1.5px solid #c4b5fd;
}
.cta-inner { display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.cta-eyebrow { font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:#7c3aed; margin-bottom:.22rem; }
.cta-title   { font-size:.9rem; color:#3b0764; font-weight:600; }
.cta-desc    { font-size:.8rem; color:#6d28d9; margin-top:.15rem; }
.cta-btn     { display:inline-block; padding:.5rem 1.2rem; background:#7c3aed; color:#fff;
               border-radius: 0; text-decoration:none; font-size:.88rem; font-weight:700; white-space:nowrap; flex-shrink:0; }
.cta-btn:hover { background:#6d28d9; }
.cta-btn-yellow { background:#d97706; }
.cta-btn-yellow:hover { background:#b45309; }
.cta-btn-blue { background:#1d4ed8; }
.cta-btn-blue:hover { background:#1e3a8a; }
.cta-btn-grey { background:#94a3b8; cursor:default; }

/* ── Chapter cards ───────────────────────────────────────────────── */
.result-chapter { margin-bottom:1.5rem; }
.dr-card {
  background:#fff; border-radius: 0;
  box-shadow:0 1px 4px rgba(0,0,0,.07),0 0 0 1px rgba(0,0,0,.05);
  padding:1.4rem 1.5rem 1.2rem; margin-bottom:1.25rem;
}
.dr-card-header { display:flex; align-items:baseline; gap:.55rem; margin-bottom:.9rem; cursor:pointer; user-select:none; }
.dr-card-header::after { content:'▾'; font-size:.78rem; color:#bbb; margin-left:auto; padding-left:.4rem; }
.dr-card--collapsed .dr-card-header::after { content:'▸'; }
.dr-card--collapsed > *:not(.dr-card-header) { display:none; }
.cta-card-locked { opacity:.65; }
.chapter-num { font-size:.72rem; font-weight:700; background:#f1f5f9; color:#6b7280; border-radius: 0; padding:.15rem .45rem; letter-spacing:.03em; }
.dr-card-title { font-size:1.05rem; font-weight:700; color:#111827; flex:1; }

/* ── Content elements ────────────────────────────────────────────── */
.dr-section-label { font-size:.68rem; font-weight:700; letter-spacing:.07em; text-transform:uppercase; color:#9ca3af; margin-bottom:.4rem; }
.hs-list { margin:1em; }
.dr-bullets { list-style:none; padding:0; margin:0 0 .95rem; }
.dr-bullets li { font-size:.88rem; color:#374151; padding:.18rem 0 .18rem 1.1rem; position:relative; }
.dr-bullets li::before { content:'•'; position:absolute; left:0; color:#6366f1; font-weight:700; }
.dr-questions { list-style:none; padding:0; margin:0 0 .95rem; border-left:3px solid #e0e7ff; padding-left:.85rem; }
.dr-questions li { font-size:.88rem; color:#374151; font-style:italic; padding:.2rem 0; }
.dr-chips { display:flex; flex-wrap:wrap; gap:.4rem; margin-bottom:.95rem; }
.dr-chip { display:inline-block; padding:.22rem .65rem; border-radius: 0; font-size:.84rem; font-weight:600; background:#f1f5f9; color:#374151; border:1px solid #e5e7eb; }
.dr-chip-self { background:#fef9c3; color:#854d0e; border-color:#fde68a; }
.dr-chip-pos  { background:#eff6ff; color:#1e40af; border-color:#bfdbfe; }
.dr-chip-neg  { background:#fdf4ff; color:#6b21a8; border-color:#e9d5ff; }
.dr-chip-arrow { font-size:.8rem; color:#9ca3af; align-self:center; }

/* ── Chapter footer ─────────────────────────────────────────────── */
.dr-card-footer {
  margin-top:.9rem; padding-top:.75rem;
  border-top:1px solid #f1f5f9;
  display:flex; align-items:center; gap:.5rem; flex-wrap:wrap;
}
.dr-footer-label { font-size:.7rem; color:#9ca3af; }
.dr-btn-map {
  font-size:.8rem; font-weight:600; color:#4338ca;
  text-decoration:none; padding:.28rem .65rem;
  border:1px solid #c7d2fe; border-radius: 0; background:#eef2ff;
  transition:background .12s;
}
.dr-btn-map:hover { background:#e0e7ff; }

/* ── Mini SVG map ────────────────────────────────────────────────── */
.chapter-minimap { float:right; margin:0 0 .75rem 1rem; }
@media (max-width:500px) { .chapter-minimap { float:none; margin:0 0 .75rem 0; } }

/* ── Interpretation elements ─────────────────────────────────────── */
.interp-ev-box { background:#f8f9fc; border:1px solid #e8eaf0; border-radius: 0; padding:.45rem .65rem; margin:.25rem 0 .4rem; font-size:.75rem; color:#555; display:none; }
.interp-ev-box.open { display:block; }
.interp-ev-box dl { margin:0; }
.interp-ev-box dt { display:inline; font-weight:600; color:#444; }
.interp-ev-box dt::after { content:': '; }
.interp-ev-box dd { display:inline; margin:0; color:#666; }
.interp-ev-box dd::after { content:'\A'; white-space:pre; }
.interp-info { display:inline-flex; align-items:center; justify-content:center;
  width:1.1rem; height:1.1rem; border-radius:50%; background:none;
  border:1px solid #bbb; color:#aaa; font-size:.65rem; cursor:pointer;
  margin-left:.25rem; vertical-align:middle; line-height:1; padding:0; font-family:inherit; }
.interp-info:hover { border-color:#4a90d9; color:#4a90d9; }

/* ── Score pills ─────────────────────────────────────────────────── */
.interp-scores { display:flex; flex-wrap:wrap; gap:.4rem .9rem; margin-top:.6rem; font-size:.82rem; }
.interp-score-pill { background:#f0f4fa; border-radius: 0; padding:.22rem .6rem; color:#444; white-space:nowrap; }
.interp-score-pill strong { color:#1a1a2e; }
.map-type-badge { display:inline-block; padding:.2rem .6rem; border-radius: 0; font-size:.8rem; font-weight:700; letter-spacing:.03em; }
.map-type-centered   { background:#d4edda; color:#155724; }
.map-type-polarized  { background:#fff3cd; color:#856404; }
.map-type-fragmented,.map-type-strongly_fragmented { background:#f8d7da; color:#721c24; }
.map-type-weakly_fragmented { background:#fce8d5; color:#7d3a00; }
.map-type-diffuse    { background:#e2e3e5; color:#383d41; }

/* ── Plan gate badges ────────────────────────────────────────────── */
.plan-badge { display:inline-block; font-size:.65rem; font-weight:700; padding:.1rem .4rem; border-radius: 0; background:#e0f2fe; color:#0369a1; margin-left:.4rem; vertical-align:middle; }
.plan-badge-lock { background:#f1f5f9; color:#94a3b8; }
.plan-pill { display:inline-block; font-size:.6rem; font-weight:700; letter-spacing:.05em; padding:.1rem .4rem; border-radius: 0; vertical-align:middle; margin-left:.4rem; }
.plan-pill-free   { background:#f1f5f9; color:#94a3b8; }
.plan-pill-basic  { background:#dbeafe; color:#1e40af; }
.plan-pill-full   { background:#ede9fe; color:#5b21b6; }
.plan-pill-admin  { background:#fef3c7; color:#92400e; }

/* ── Top pairs table ─────────────────────────────────────────────── */
.sim-table { width:100%; border-collapse:collapse; font-size:.84rem; }
.sim-table th { text-align:left; font-size:.75rem; color:#888; border-bottom:1px solid #eee; padding:.3rem .2rem; font-weight:600; }
.sim-table td { padding:.38rem .2rem; border-bottom:1px solid #f4f4f4; }
.sim-bar-wrap { display:flex; align-items:center; gap:.4rem; justify-content:flex-end; }
.sim-bar { height:6px; border-radius: 0; background:#4a90d9; }
.sim-pct { font-size:.78rem; color:#888; white-space:nowrap; }

/* ── Accordions ─────────────────────────────────────────────────── */
.acc { background:#fff; border-radius: 0; margin-bottom:.65rem;
       box-shadow:0 1px 4px rgba(0,0,0,.08); overflow:hidden; }
.acc > summary { padding:.85rem 1.25rem; font-size:.92rem; font-weight:600; color:#333;
  cursor:pointer; list-style:none; user-select:none;
  display:flex; justify-content:space-between; align-items:center; }
.acc > summary::-webkit-details-marker { display:none; }
.acc > summary::after { content:'▸'; font-size:.78rem; color:#bbb; }
.acc[open] > summary::after { content:'▾'; }
.acc > summary:hover { background:#fafafa; }
.acc-body { padding:.25rem 1.25rem 1.25rem; }

/* ── TIPI ────────────────────────────────────────────────────────── */
.tipi-badge-r { display:inline-block; background:#ede9fe; color:#5b21b6; border-radius: 0; font-size:.68rem; font-weight:700; padding:.05rem .35rem; margin-left:.3rem; vertical-align:middle; }
.tipi-section h2 { font-size:.82rem; font-weight:700; color:#888; text-transform:uppercase; letter-spacing:.04em; margin:0 0 .1rem; }
.tipi-section .tipi-date { font-size:.78rem; color:#bbb; margin:0 0 1rem; }
.tipi-rows { display:flex; flex-direction:column; gap:.55rem; }
.tipi-row { display:flex; align-items:center; gap:.7rem; }
.tipi-label { font-size:.83rem; color:#444; min-width:100px; flex-shrink:0; }
.tipi-bar-wrap { flex:1; position:relative; height:10px; background:#f0f0f0; border-radius: 0; overflow:visible; }
.tipi-bar { height:100%; background:#6c6ca8; border-radius: 0; min-width:4px; }
.tipi-norm { position:absolute; top:-3px; width:3px; height:16px; background:#1a1a2e; border-radius: 0; transform:translateX(-50%); }
.tipi-score { font-size:.82rem; color:#555; min-width:90px; text-align:right; flex-shrink:0; }
.tipi-dir { font-size:.72rem; color:#bbb; }
.tipi-note { font-size:.74rem; color:#bbb; margin-top:.8rem; }

/* ── Disclaimer ──────────────────────────────────────────────────── */
.dr-disclaimer { margin-top:2rem; font-size:.82rem; color:#6b7280; background:#f8f9ff; border-left:3px solid #c7d2fe; padding:.5rem .75rem; border-radius: 0; }

/* ── API tokens ─────────────────────────────────────────────────── */
.tok-create-form { display:flex; gap:.5rem; margin-bottom:1rem; flex-wrap:wrap; }
.tok-label-input { flex:1; min-width:180px; padding:.4rem .65rem; border:1px solid #ccc; border-radius: 0; font-size:.88rem; }
.tok-create-btn { padding:.4rem .85rem; background:#1a1a2e; color:#fff; border:none; border-radius: 0; font-size:.88rem; cursor:pointer; white-space:nowrap; }
.tok-create-btn:hover { background:#2d2d5e; }
.tok-new-box { background:#edfff3; border:1px solid #6fcf97; border-radius: 0; padding:.75rem 1rem; margin-bottom:1rem; font-size:.88rem; }
.tok-value { display:block; font-size:.78rem; word-break:break-all; background:#fff; border:1px solid #bef5d0; border-radius: 0; padding:.35rem .5rem; margin:.4rem 0; }
.tok-copy-btn { font-size:.78rem; padding:.2rem .55rem; cursor:pointer; background:#27ae60; color:#fff; border:none; border-radius: 0; }
.tok-table { width:100%; border-collapse:collapse; font-size:.83rem; margin-bottom:1rem; }
.tok-table th { text-align:left; color:#aaa; font-weight:600; padding:.3rem .4rem; border-bottom:1px solid #eee; }
.tok-table td { padding:.35rem .4rem; border-bottom:1px solid #f5f5f5; }
.tok-revoked td { color:#ccc; text-decoration:line-through; }
.tok-revoke-btn { font-size:.75rem; padding:.15rem .45rem; cursor:pointer; background:#fff; color:#c00; border:1px solid #fcc; border-radius: 0; }
.tok-revoke-btn:hover { background:#fde; }
.tok-revoked-label,.tok-expired-label { font-size:.78rem; }
.tok-revoked-label { color:#ccc; }
.tok-expired-label { color:#e67e22; }
.tok-expires-select { padding:.4rem .5rem; border:1px solid #ccc; border-radius: 0; font-size:.88rem; background:#fff; }
.tok-expired td { color:#bbb; }
.api-pre { background:#f5f5f5; border:1px solid #e0e0e0; border-radius: 0; padding:.6rem .8rem; font-size:.78rem; overflow-x:auto; margin:.25rem 0 .9rem; }
.tok-err { color:#b00; font-size:.88rem; margin-bottom:.75rem; }

/* ── Bottom nav ──────────────────────────────────────────────────── */
.dr-nav { display:flex; flex-wrap:wrap; gap:.5rem; padding-top:1.5rem; border-top:1px solid #e5e7eb; margin-top:2rem; }
.dr-nav a { font-size:.82rem; color:#6b7280; text-decoration:none; padding:.3rem .65rem; border:1px solid #e5e7eb; border-radius: 0; }
.dr-nav a:hover { background:#f8f9ff; color:#374151; }
.dr-meta { font-size:.72rem; color:#d1d5db; margin-left:auto; align-self:center; }
