/* Fideograph Historical Simulation Engine v4.5 — Stylesheet
 * Edit this file to customise appearance.
 * Loaded by the WordPress plugin template.
 */


*{box-sizing:border-box;margin:0;padding:0}
:root{
  --p:#f6f0e0;--p2:#ede4cc;--p3:#e2d5b0;--p4:#d4c38a;
  --ink:#1a1510;--ink2:#352c1e;--ink3:#5c4f35;--ink4:#8c7a58;
  --gold:#b8860b;--gold2:#d4a017;--gold3:#f0d060;--goldpale:#faf3d8;
  --crim:#7a1515;--crim2:#a02020;--crimlt:#fff0ee;
  --forest:#245020;--forest2:#357030;--forestlt:#eef6ec;
  --amber:#8a5a00;--amberlt:#fff8e8;
  --slate:#2a3a4a;--slatelt:#eef2f6;
  --bd:#c8b888;--bd2:#ddd0aa;--bd3:#ede4cc;
  --shadow:rgba(26,21,16,0.08);
}
html{scroll-behavior:smooth}
body{font-family:'Source Serif 4',Georgia,serif;background:var(--p);color:var(--ink);min-height:100vh;font-size:15px;line-height:1.6}

/* SCROLLBAR */
::-webkit-scrollbar{width:6px;height:6px}
::-webkit-scrollbar-track{background:var(--p2)}
::-webkit-scrollbar-thumb{background:var(--bd);border-radius:3px}

/* ─── HEADER ─── */
.hdr{display:flex;align-items:center;gap:12px;padding:14px 24px;border-bottom:1px solid var(--bd);background:rgba(246,240,224,0.97);position:sticky;top:var(--fg-nav-h,82px);z-index:100;backdrop-filter:blur(4px)}
.logo{display:flex;align-items:center;gap:10px;text-decoration:none}
.logo-svg{width:32px;height:32px}
.logo-name{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;color:var(--ink);letter-spacing:0.01em}
.logo-name em{color:var(--gold);font-style:normal}
.hdr-center{flex:1;text-align:center}
.engine-title{font-family:'Playfair Display',serif;font-size:0.9rem;font-weight:400;color:var(--ink3);letter-spacing:0.06em;font-style:italic}
.hdr-right{display:flex;align-items:center;gap:10px}
.session-score{display:flex;align-items:center;gap:6px;font-size:0.75rem;color:var(--ink3);padding:4px 10px;border:0.5px solid var(--bd);border-radius:20px}
.score-dot{width:8px;height:8px;border-radius:50%;background:var(--bd)}
.score-dot.good{background:var(--forest2)}
.score-dot.mid{background:var(--gold)}
.score-dot.poor{background:var(--crim2)}

/* ─── LAYOUT ─── */
.layout{display:grid;grid-template-columns:260px 1fr 240px;min-height:calc(100vh - 57px)}

/* ─── LEFT SIDEBAR ─── */
.sidebar-l{border-right:1px solid var(--bd);padding:0;background:rgba(237,228,204,0.35);overflow-y:auto;max-height:calc(100vh - var(--fg-nav-h,82px) - 57px);position:sticky;top:calc(var(--fg-nav-h,82px) + 57px)}
.sb-section{padding:16px;border-bottom:1px solid var(--bd3)}
.sb-label{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.15em;color:var(--ink4);margin-bottom:10px;font-family:'Source Serif 4',serif;font-weight:400}

/* Model selector */
.model-opt{display:flex;align-items:flex-start;gap:8px;padding:8px 10px;border:0.5px solid transparent;border-radius:4px;cursor:pointer;margin-bottom:4px;transition:all 0.15s;background:transparent}
.model-opt:hover{background:var(--p2);border-color:var(--bd2)}
.model-opt.active{background:var(--goldpale);border-color:var(--gold)}
.model-radio{width:14px;height:14px;border-radius:50%;border:1.5px solid var(--bd);flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;transition:all 0.15s}
.model-opt.active .model-radio{border-color:var(--gold);background:var(--gold)}
.model-opt.active .model-radio::after{content:'';width:5px;height:5px;border-radius:50%;background:white}
.model-name{font-size:0.82rem;font-weight:600;color:var(--ink2);line-height:1.2}
.model-desc{font-size:0.72rem;color:var(--ink4);line-height:1.35;margin-top:2px}

/* Commitments */
.commit-item{display:flex;align-items:flex-start;gap:7px;padding:5px 0;border-bottom:0.5px solid var(--bd3);animation:fadeIn 0.3s ease}
.commit-item:last-child{border-bottom:none}
@keyframes fadeIn{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}
@keyframes dcmNodePop{from{opacity:0;transform:scale(0.3)}to{opacity:1;transform:scale(1)}}
.commit-icon{width:14px;height:14px;border-radius:50%;flex-shrink:0;margin-top:2px;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700}
.commit-icon.agree{background:var(--forest2);color:white}
.commit-icon.tension{background:var(--gold2);color:white}
.commit-icon.contra{background:var(--crim2);color:white}
.commit-text{font-size:0.76rem;color:var(--ink2);line-height:1.4}
.commit-empty{font-size:0.78rem;color:var(--ink4);font-style:italic;text-align:center;padding:8px 0}

/* Meter bars */
.meter-wrap{margin-bottom:10px}
.meter-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:3px}
.meter-lbl{font-size:0.7rem;color:var(--ink3)}
.meter-val{font-size:0.7rem;font-weight:600;color:var(--ink2)}
.meter-bg{height:4px;background:var(--p3);border-radius:2px;overflow:hidden}
.meter-fill{height:100%;border-radius:2px;transition:width 0.7s cubic-bezier(0.4,0,0.2,1),background 0.5s}

/* Scenario progress */
.sc-progress{display:flex;flex-direction:column;gap:4px}
.sc-prog-item{display:flex;align-items:center;gap:8px;padding:5px 8px;border-radius:3px;cursor:pointer;transition:background 0.15s;border:0.5px solid transparent}
.sc-prog-item:hover{background:var(--p2)}
.sc-prog-item.current{background:var(--goldpale);border-color:var(--gold)}
.sc-prog-dot{width:10px;height:10px;border-radius:50%;border:1.5px solid var(--bd);flex-shrink:0;transition:all 0.2s}
.sc-prog-dot.done{background:var(--forest2);border-color:var(--forest2)}
.sc-prog-dot.current{background:var(--gold);border-color:var(--gold)}
.sc-prog-dot.locked{background:var(--crim2);border-color:var(--crim2)}
.sc-prog-name{font-size:0.76rem;color:var(--ink3);line-height:1.3}
.sc-prog-item.current .sc-prog-name{color:var(--ink);font-weight:600}
.sc-prog-era{font-size:0.62rem;color:var(--ink4)}

/* ─── MAIN ─── */
.main{padding:28px 32px;overflow-y:auto;max-height:calc(100vh - var(--fg-nav-h,82px) - 57px)}
.section-hd{display:flex;align-items:center;gap:12px;margin-bottom:20px}
.section-hd h2{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:600;color:var(--ink);white-space:nowrap}
.section-hd-line{flex:1;height:0.5px;background:var(--bd)}

/* Scenario card grid */
.sc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:28px}
.sc-card{border:0.5px solid var(--bd2);border-radius:5px;padding:11px;cursor:pointer;background:white;transition:all 0.2s;position:relative}
.sc-card::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--gold);border-radius:0 0 5px 5px;transform:scaleX(0);transition:transform 0.2s;transform-origin:left}
.sc-card:hover::after,.sc-card.active::after{transform:scaleX(1)}
.sc-card:hover{border-color:var(--gold);box-shadow:0 2px 8px var(--shadow)}
.sc-card.active{border-color:var(--gold);background:var(--goldpale)}
.sc-card.completed{border-color:var(--bd);background:var(--p)}
.sc-card.completed::after{background:var(--forest2)}
.sc-card.collapsed{border-color:var(--crim2);background:var(--crimlt)}
.sc-card.collapsed::after{background:var(--crim2)}
.sc-year{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--gold);font-weight:700;margin-bottom:3px}
.sc-card.completed .sc-year{color:var(--forest2)}
.sc-card.collapsed .sc-year{color:var(--crim2)}
.sc-nm{font-family:'Playfair Display',serif;font-size:0.82rem;font-weight:600;color:var(--ink);line-height:1.3;margin-bottom:3px}
.sc-blurb{font-size:0.7rem;color:var(--ink4);line-height:1.35}
.sc-badge{position:absolute;top:7px;right:7px;font-size:0.58rem;padding:2px 6px;border-radius:10px;font-weight:700;letter-spacing:0.05em}
.sc-badge.done{background:var(--forestlt);color:var(--forest2)}
.sc-badge.fail{background:var(--crimlt);color:var(--crim2)}

/* Sim panel */
.sim-box{background:white;border:0.5px solid var(--bd);border-radius:8px;overflow:hidden;box-shadow:0 2px 12px var(--shadow)}
.sim-hdr{padding:14px 20px;border-bottom:1px solid var(--bd2);background:var(--p2);display:flex;align-items:center;justify-content:space-between}
.sim-hdr-left{display:flex;flex-direction:column;gap:2px}
.sim-hdr-era{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--gold);font-weight:700}
.sim-hdr-title{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:600;color:var(--ink)}
.sim-hdr-right{display:flex;align-items:center;gap:8px}
.difficulty-badge{font-size:0.62rem;padding:3px 9px;border-radius:12px;font-weight:600;letter-spacing:0.05em}
.diff-1{background:#eef6ec;color:var(--forest2);border:0.5px solid #b8ddb4}
.diff-2{background:var(--amberlt);color:var(--amber);border:0.5px solid #e8c880}
.diff-3{background:var(--crimlt);color:var(--crim2);border:0.5px solid #e8b8b8}

.sim-body{padding:20px}

/* Dispute block */
.dispute-blk{background:var(--p);border-left:3px solid var(--gold);padding:14px 16px;border-radius:0 5px 5px 0;margin-bottom:18px}
.dispute-eyebrow{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--gold);font-weight:700;margin-bottom:6px}
.dispute-txt{font-family:'EB Garamond',Georgia,serif;font-size:0.95rem;line-height:1.75;color:var(--ink2);font-style:italic}
.dispute-src{font-family:'Source Serif 4',serif;font-size:0.7rem;color:var(--ink4);margin-top:8px;font-style:normal}

/* Tabs */
.tabs{display:flex;gap:0;border-bottom:1px solid var(--bd2);margin-bottom:18px;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.tabs::-webkit-scrollbar{display:none}
.tab-btn{padding:8px 14px;font-family:'Source Serif 4',serif;font-size:0.78rem;color:var(--ink4);background:transparent;border:none;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all 0.15s;letter-spacing:0.02em;white-space:nowrap;flex-shrink:0}
.tab-btn:hover{color:var(--ink2)}
.tab-btn.active{color:var(--gold);border-bottom-color:var(--gold);font-weight:600}
.tab-pane{display:none}
.tab-pane.active{display:block;animation:fadeIn 0.2s ease}

/* Factions */
.factions-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:4px}
.faction-card{border:0.5px solid var(--bd2);border-radius:5px;padding:11px;background:var(--p)}
.faction-label{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.1em;font-weight:700;margin-bottom:5px}
.faction-label.pro{color:var(--forest2)}
.faction-label.con{color:var(--crim2)}
.faction-txt{font-size:0.78rem;color:var(--ink2);line-height:1.5}

/* Key figures */
.figure-list{display:flex;flex-direction:column;gap:8px}
.figure-item{display:flex;gap:10px;align-items:flex-start}
.figure-avatar{width:32px;height:32px;border-radius:50%;background:var(--p3);border:1px solid var(--bd);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:0.7rem;font-weight:700;color:var(--ink3)}
.figure-name{font-size:0.8rem;font-weight:600;color:var(--ink2);margin-bottom:2px}
.figure-role{font-size:0.7rem;color:var(--ink4);line-height:1.4}

/* Timeline */
.timeline{position:relative;padding-left:16px}
.timeline::before{content:'';position:absolute;left:4px;top:6px;bottom:6px;width:1px;background:var(--bd2)}
.tl-item{position:relative;padding-left:16px;margin-bottom:12px}
.tl-item::before{content:'';position:absolute;left:-8px;top:6px;width:8px;height:8px;border-radius:50%;background:var(--gold);border:1.5px solid white}
.tl-year{font-size:0.65rem;font-weight:700;color:var(--gold);letter-spacing:0.06em;margin-bottom:2px;text-transform:uppercase}
.tl-txt{font-size:0.78rem;color:var(--ink2);line-height:1.45}

/* Question block */
.q-block{margin-bottom:18px}
.q-eyebrow{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.14em;color:var(--ink4);margin-bottom:6px}
.q-txt{font-family:'Playfair Display',serif;font-size:1.02rem;color:var(--ink);font-weight:400;line-height:1.55}

/* Answer options */
.answers{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.ans-btn{display:flex;align-items:flex-start;gap:10px;width:100%;text-align:left;padding:11px 13px;border:0.5px solid var(--bd2);background:var(--p);font-family:'Source Serif 4',serif;font-size:0.83rem;color:var(--ink2);cursor:pointer;border-radius:5px;line-height:1.45;transition:all 0.15s;position:relative;overflow:hidden}
.ans-btn::before{content:'';position:absolute;left:0;top:0;bottom:0;width:0;background:var(--gold);opacity:0.07;transition:width 0.3s}
.ans-btn:hover::before{width:100%}
.ans-btn:hover{border-color:var(--gold)}
.ans-letter{width:20px;height:20px;border-radius:50%;border:1px solid var(--bd);font-size:0.65rem;font-weight:700;color:var(--ink4);flex-shrink:0;display:flex;align-items:center;justify-content:center;margin-top:1px;transition:all 0.15s;font-family:'Source Serif 4',serif}
.ans-btn:hover .ans-letter{border-color:var(--gold);color:var(--gold)}
.ans-btn:disabled{cursor:default}
.ans-btn:disabled::before{display:none}
.ans-btn.sel-correct{border-color:var(--forest2);background:var(--forestlt)}
.ans-btn.sel-correct .ans-letter{background:var(--forest2);border-color:var(--forest2);color:white}
.ans-btn.sel-wrong{border-color:var(--crim2);background:var(--crimlt)}
.ans-btn.sel-wrong .ans-letter{background:var(--crim2);border-color:var(--crim2);color:white}
.ans-btn.revealed{border-color:var(--forest2);background:var(--forestlt);opacity:0.7}

/* Confidence selector */
.confidence-row{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.conf-label{font-size:0.72rem;color:var(--ink4);white-space:nowrap}
.conf-btn{padding:4px 12px;border:0.5px solid var(--bd2);background:var(--p);font-family:'Source Serif 4',serif;font-size:0.72rem;color:var(--ink4);cursor:pointer;border-radius:20px;transition:all 0.15s}
.conf-btn:hover,.conf-btn.active{background:var(--goldpale);border-color:var(--gold);color:var(--ink2)}

/* Result panel */
.result-panel{display:none;margin-top:16px;border:0.5px solid var(--bd);border-radius:7px;overflow:hidden;animation:slideUp 0.3s ease}
.result-panel.show{display:block}
@keyframes slideUp{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

.result-comparison{display:grid;grid-template-columns:1fr 1fr;border-bottom:1px solid var(--bd2)}
.rc-col{padding:14px 16px}
.rc-col:first-child{border-right:0.5px solid var(--bd2)}
.rc-eyebrow{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;font-weight:700;margin-bottom:6px}
.rc-eyebrow.predict{color:var(--slate)}
.rc-eyebrow.actual{color:var(--gold)}
.rc-txt{font-size:0.8rem;color:var(--ink2);line-height:1.6}

.verdict-row{display:flex;align-items:center;gap:10px;padding:10px 16px;border-bottom:0.5px solid var(--bd2)}
.verdict-row.match{background:var(--forestlt)}
.verdict-row.partial{background:var(--amberlt)}
.verdict-row.mismatch{background:var(--crimlt)}
.verdict-icon{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0}
.verdict-icon.match{background:var(--forest2);color:white}
.verdict-icon.partial{background:var(--gold2);color:white}
.verdict-icon.mismatch{background:var(--crim2);color:white}
.verdict-lbl{font-size:0.8rem;font-weight:600}
.verdict-row.match .verdict-lbl{color:var(--forest)}
.verdict-row.partial .verdict-lbl{color:var(--amber)}
.verdict-row.mismatch .verdict-lbl{color:var(--crim2)}

.implication-blk{padding:13px 16px;background:var(--p2);border-bottom:0.5px solid var(--bd2)}
.impl-eyebrow{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--gold);font-weight:700;margin-bottom:5px}
.impl-txt{font-family:'EB Garamond',Georgia,serif;font-size:0.92rem;color:var(--ink);line-height:1.7;font-style:italic}

.patristic-blk{padding:13px 16px;border-bottom:0.5px solid var(--bd2)}
.patristic-eyebrow{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--crim2);font-weight:700;margin-bottom:8px}
.quote-item{margin-bottom:10px;padding:10px 13px;background:var(--p);border-left:2px solid var(--bd);border-radius:0 4px 4px 0}
.quote-txt{font-family:'EB Garamond',Georgia,serif;font-size:0.88rem;color:var(--ink2);line-height:1.65;font-style:italic;margin-bottom:4px}
.quote-attr{font-size:0.68rem;color:var(--ink4);font-style:normal}

.logical-chain{padding:13px 16px}
.lc-eyebrow{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--slate);font-weight:700;margin-bottom:10px}
.chain-steps{display:flex;flex-direction:column;gap:0}
.chain-step{display:flex;align-items:flex-start;gap:10px;padding:7px 0;border-bottom:0.5px solid var(--bd3)}
.chain-step:last-child{border-bottom:none}
.chain-num{width:20px;height:20px;border-radius:50%;background:var(--p3);border:1px solid var(--bd);font-size:0.65rem;font-weight:700;color:var(--ink3);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.chain-step.collapse .chain-num{background:var(--crim2);border-color:var(--crim2);color:white}
.chain-txt{font-size:0.78rem;color:var(--ink2);line-height:1.45}
.chain-step.collapse .chain-txt{color:var(--crim2);font-weight:600}

/* Tension alert */
.tension-box{display:none;margin-top:14px;padding:11px 14px;background:var(--amberlt);border:0.5px solid #d4a017;border-left:3px solid var(--gold2);border-radius:0 5px 5px 0}
.tension-box.show{display:block;animation:fadeIn 0.25s ease}
.tension-hd{font-size:0.7rem;font-weight:700;color:var(--amber);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:4px}
.tension-txt{font-size:0.8rem;color:var(--ink2);line-height:1.55}

/* Collapse alert */
.collapse-box{display:none;margin-top:14px;padding:13px 16px;background:var(--crimlt);border:0.5px solid #c08080;border-left:3px solid var(--crim2);border-radius:0 5px 5px 0}
.collapse-box.show{display:block;animation:fadeIn 0.25s ease}
.collapse-hd{font-size:0.7rem;font-weight:700;color:var(--crim2);text-transform:uppercase;letter-spacing:0.08em;margin-bottom:4px}
.collapse-txt{font-size:0.8rem;color:var(--ink2);line-height:1.55}

/* Nav row */
.nav-row{display:flex;gap:8px;margin-top:16px;align-items:center}
.nav-btn{padding:8px 18px;border:0.5px solid var(--bd);background:transparent;font-family:'Source Serif 4',serif;font-size:0.8rem;color:var(--ink3);cursor:pointer;border-radius:4px;transition:all 0.15s}
.nav-btn:hover{background:var(--p2);border-color:var(--bd);color:var(--ink)}
.nav-btn.primary{background:var(--gold);border-color:var(--gold);color:white;font-weight:600}
.nav-btn.primary:hover{background:var(--gold2)}
.nav-btn:disabled{opacity:0.4;cursor:default}
.nav-spacer{flex:1}

/* ─── RIGHT SIDEBAR ─── */
.sidebar-r{border-left:1px solid var(--bd);padding:0;background:rgba(246,240,224,0.6);overflow-y:auto;max-height:calc(100vh - var(--fg-nav-h,82px) - 57px);position:sticky;top:calc(var(--fg-nav-h,82px) + 57px)}

/* Journal */
.journal-entry{padding:10px 12px;border-bottom:0.5px solid var(--bd3);animation:fadeIn 0.3s ease}
.je-sc{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.08em;color:var(--gold);font-weight:700;margin-bottom:2px}
.je-model{font-size:0.7rem;font-weight:600;color:var(--ink2);margin-bottom:2px}
.je-verdict{display:inline-flex;align-items:center;gap:4px;font-size:0.65rem;padding:2px 7px;border-radius:10px;font-weight:600;margin-bottom:4px}
.je-verdict.match{background:var(--forestlt);color:var(--forest2)}
.je-verdict.partial{background:var(--amberlt);color:var(--amber)}
.je-verdict.mismatch{background:var(--crimlt);color:var(--crim2)}
.je-note{font-size:0.72rem;color:var(--ink4);line-height:1.4;font-style:italic}
.journal-empty{padding:16px;font-size:0.78rem;color:var(--ink4);font-style:italic;text-align:center}

/* Summary panel */
.summary-panel{display:none;padding:20px 16px}
.summary-panel.show{display:block}
.summary-hd{font-family:'Playfair Display',serif;font-size:1rem;font-weight:600;color:var(--ink);margin-bottom:14px;text-align:center}
.score-ring-wrap{text-align:center;margin-bottom:16px}
.score-ring-wrap svg{width:100px;height:100px}
.score-big{font-family:'Playfair Display',serif;font-size:2rem;font-weight:700;color:var(--ink)}
.score-sub{font-size:0.72rem;color:var(--ink4);margin-top:2px}
.final-verdict-box{border:0.5px solid var(--bd);border-radius:5px;padding:12px;background:var(--p2);margin-bottom:12px}
.fv-label{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--ink4);margin-bottom:5px}
.fv-model{font-family:'Playfair Display',serif;font-size:0.95rem;font-weight:600;color:var(--ink);margin-bottom:4px}
.fv-analysis{font-size:0.76rem;color:var(--ink3);line-height:1.5}

.export-btn{display:flex;align-items:center;justify-content:center;gap:7px;width:100%;margin-top:8px;padding:10px 14px;background:var(--ink);border:none;border-radius:4px;font-family:'Source Serif 4',serif;font-size:0.82rem;font-weight:600;color:var(--p);cursor:pointer;transition:background 0.15s;letter-spacing:0.02em}
.export-btn:hover{background:var(--ink2)}
.restart-btn{display:block;width:100%;padding:9px;border:0.5px solid var(--bd);background:transparent;font-family:'Source Serif 4',serif;font-size:0.8rem;color:var(--ink3);cursor:pointer;border-radius:4px;transition:all 0.15s;text-align:center;margin-top:10px}
.restart-btn:hover{background:var(--p2)}

/* Intro overlay */
.intro-overlay{position:fixed;inset:0;background:rgba(26,21,16,0.82);z-index:200;display:flex;align-items:flex-start;justify-content:center;padding-top:var(--fg-nav-h,82px);overflow-y:auto}
.intro-card{background:var(--p);border:1px solid var(--bd);border-radius:10px;max-width:600px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,0.3);display:flex;flex-direction:column;max-height:calc(100vh - var(--fg-nav-h,82px) - 10px);margin:5px 0 10px;overflow:hidden}
.intro-logo{text-align:center;margin-bottom:20px}
.intro-logo svg{width:48px;height:48px}
.intro-title{font-family:'Playfair Display',serif;font-size:1.35rem;font-weight:700;color:var(--ink);text-align:center;margin-bottom:4px}
.intro-subtitle{font-size:0.82rem;color:var(--ink3);text-align:center;margin-bottom:14px;font-style:italic}
.intro-body{font-size:0.83rem;color:var(--ink2);line-height:1.65;margin-bottom:14px}
.intro-body p{margin-bottom:10px}
.intro-body strong{color:var(--ink);font-weight:600}
.intro-model-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:16px}
.intro-model-opt{border:0.5px solid var(--bd2);border-radius:5px;padding:10px 12px;cursor:pointer;transition:all 0.15s;background:white}
.intro-model-opt:hover{border-color:var(--gold);background:var(--goldpale)}
.intro-model-opt.active{border-color:var(--gold);background:var(--goldpale)}
.intro-model-nm{font-size:0.82rem;font-weight:600;color:var(--ink);margin-bottom:2px}
.intro-model-ds{font-size:0.72rem;color:var(--ink4);line-height:1.3}
.intro-start{display:block;width:100%;padding:12px;background:var(--gold);border:none;font-family:'Playfair Display',serif;font-size:1rem;font-weight:600;color:white;cursor:pointer;border-radius:5px;letter-spacing:0.02em;transition:background 0.15s}
.intro-start:hover{background:var(--gold2)}
.intro-start:disabled{background:var(--bd);cursor:default}

/* ─── CROSS-SCENARIO CONTRADICTION PANEL ─── */
.contradiction-panel{display:none;margin-top:14px;border:1px solid var(--crim2);border-radius:6px;overflow:hidden;animation:slideUp 0.35s ease}
.contradiction-panel.show{display:block}
.contra-hdr{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--crim2)}
.contra-hdr-icon{width:20px;height:20px;border-radius:50%;background:white;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:var(--crim2);flex-shrink:0}
.contra-hdr-title{font-size:0.72rem;font-weight:700;color:white;text-transform:uppercase;letter-spacing:0.1em}
.contra-body{padding:12px 14px;background:var(--crimlt)}
.contra-body p{font-size:0.82rem;color:var(--ink2);line-height:1.6;margin-bottom:8px}
.contra-body p:last-child{margin-bottom:0}
.contra-commits{display:flex;flex-direction:column;gap:5px;margin:10px 0}
.contra-commit{display:flex;align-items:flex-start;gap:8px;padding:7px 10px;background:white;border:0.5px solid #e0b0b0;border-radius:4px}
.contra-commit-label{font-size:0.62rem;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;color:var(--crim2);white-space:nowrap;margin-top:1px}
.contra-commit-text{font-size:0.78rem;color:var(--ink2);line-height:1.4}
.contra-question{font-family:'Playfair Display',serif;font-size:0.9rem;color:var(--ink);margin:10px 0 6px;font-weight:600}
.contra-resolve-row{display:flex;gap:8px;margin-top:10px}
.contra-btn{padding:6px 14px;border-radius:3px;font-family:'Source Serif 4',serif;font-size:0.78rem;cursor:pointer;border:0.5px solid;transition:all 0.15s}
.contra-btn.accept{background:var(--crim2);border-color:var(--crim2);color:white}
.contra-btn.accept:hover{background:#c02828}
.contra-btn.dismiss{background:transparent;border-color:var(--bd);color:var(--ink3)}
.contra-btn.dismiss:hover{background:var(--p2)}

/* ─── MODEL DRIFT PANEL ─── */
.drift-overlay{display:none;position:fixed;inset:0;background:rgba(26,21,16,0.7);z-index:300;align-items:center;justify-content:center;padding:20px}
.drift-overlay.show{display:flex;animation:fadeIn 0.25s ease}
.drift-card{background:var(--p);border:1px solid var(--bd);border-radius:10px;padding:28px 32px;max-width:520px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,0.35);position:relative}
.drift-eyebrow{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.15em;color:var(--gold);font-weight:700;margin-bottom:8px}
.drift-title{font-family:'Playfair Display',serif;font-size:1.3rem;font-weight:700;color:var(--ink);margin-bottom:12px;line-height:1.3}
.drift-body{font-size:0.84rem;color:var(--ink2);line-height:1.7;margin-bottom:18px}
.drift-comparison{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:18px}
.drift-col{border:0.5px solid var(--bd2);border-radius:5px;padding:12px}
.drift-col.declared{background:var(--p2)}
.drift-col.actual{background:var(--goldpale);border-color:var(--gold)}
.drift-col-label{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.12em;font-weight:700;margin-bottom:5px}
.drift-col.declared .drift-col-label{color:var(--ink4)}
.drift-col.actual .drift-col-label{color:var(--gold)}
.drift-col-model{font-family:'Playfair Display',serif;font-size:0.9rem;font-weight:600;color:var(--ink);margin-bottom:4px}
.drift-col-note{font-size:0.72rem;color:var(--ink4);line-height:1.4}
.drift-evidence{margin-bottom:18px}
.drift-evidence-label{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--ink4);font-weight:700;margin-bottom:8px}
.drift-ev-item{display:flex;align-items:flex-start;gap:8px;padding:6px 0;border-bottom:0.5px solid var(--bd3)}
.drift-ev-item:last-child{border-bottom:none}
.drift-ev-sc{font-size:0.72rem;font-weight:600;color:var(--ink3);min-width:110px;flex-shrink:0}
.drift-ev-verdict{font-size:0.68rem;padding:2px 7px;border-radius:10px;font-weight:600;flex-shrink:0}
.drift-ev-verdict.match{background:var(--forestlt);color:var(--forest2)}
.drift-ev-verdict.partial{background:var(--amberlt);color:var(--amber)}
.drift-ev-verdict.mismatch{background:var(--crimlt);color:var(--crim2)}
.drift-ev-note{font-size:0.72rem;color:var(--ink4);line-height:1.4}
.drift-actions{display:flex;gap:10px}
.drift-action-btn{flex:1;padding:10px;border-radius:4px;font-family:'Source Serif 4',serif;font-size:0.82rem;font-weight:600;cursor:pointer;border:0.5px solid;transition:all 0.15s;text-align:center}
.drift-action-btn.revise{background:var(--gold);border-color:var(--gold);color:white}
.drift-action-btn.revise:hover{background:var(--gold2)}
.drift-action-btn.hold{background:transparent;border-color:var(--bd);color:var(--ink3)}
.drift-action-btn.hold:hover{background:var(--p2)}
.drift-model-opts{display:flex;flex-direction:column;gap:6px;margin-bottom:16px;display:none}
.drift-model-opts.show{display:flex}
.drift-model-pick{padding:8px 12px;border:0.5px solid var(--bd2);border-radius:4px;background:white;font-family:'Source Serif 4',serif;font-size:0.8rem;color:var(--ink2);cursor:pointer;transition:all 0.15s;text-align:left}
.drift-model-pick:hover{border-color:var(--gold);background:var(--goldpale)}
.drift-model-pick.active{border-color:var(--gold);background:var(--goldpale);font-weight:600}

/* ─── SIDEBAR DRIFT INDICATOR ─── */
.drift-indicator{display:none;margin-top:8px;padding:8px 10px;background:var(--goldpale);border:0.5px solid var(--gold);border-radius:4px;cursor:pointer;transition:all 0.15s}
.drift-indicator:hover{background:#f5ead0}
.drift-indicator.show{display:block;animation:fadeIn 0.3s ease}
.drift-ind-label{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--gold);font-weight:700;margin-bottom:3px}
.drift-ind-txt{font-size:0.75rem;color:var(--ink2);line-height:1.4}

/* ─── DIFFICULTY GATING ─── */
.sc-card.gated{background:var(--p2);border-color:var(--bd2);cursor:not-allowed;opacity:0.55}
.sc-card.gated::after{display:none}
.sc-card.gated:hover{border-color:var(--bd2);box-shadow:none}
.gate-lock{position:absolute;top:7px;right:7px;font-size:11px;color:var(--ink4)}
.gate-notice{display:none;margin-top:12px;padding:10px 14px;background:var(--goldpale);border:0.5px solid var(--gold);border-left:3px solid var(--gold);border-radius:0 5px 5px 0;animation:slideUp 0.3s ease}
.gate-notice.show{display:block}
.gate-notice-title{font-size:0.7rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:3px}
.gate-notice-txt{font-size:0.8rem;color:var(--ink2);line-height:1.5}

/* ─── FORCED REVISION MODAL ─── */
.rev-overlay{display:none;position:fixed;inset:0;background:rgba(26,21,16,0.78);z-index:350;align-items:center;justify-content:center;padding:20px}
.rev-overlay.show{display:flex;animation:fadeIn 0.25s ease}
.rev-card{background:var(--p);border:1px solid var(--crim2);border-radius:10px;padding:28px 32px;max-width:500px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,0.35)}
.rev-ey{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.15em;color:var(--crim2);font-weight:700;margin-bottom:8px}
.rev-ttl{font-family:'Playfair Display',serif;font-size:1.2rem;font-weight:700;color:var(--ink);margin-bottom:10px;line-height:1.3}
.rev-txt{font-size:0.83rem;color:var(--ink2);line-height:1.7;margin-bottom:12px}
.rev-fails{display:flex;gap:6px;margin-bottom:12px;flex-wrap:wrap}
.rev-fail-item{padding:3px 10px;border-radius:10px;font-size:0.7rem;font-weight:600;background:var(--crimlt);color:var(--crim2);border:0.5px solid #e0b0b0}
.rev-q{font-size:0.72rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--ink4);margin-bottom:8px}
.rev-opts{display:flex;flex-direction:column;gap:5px;margin-bottom:14px}
.rev-opt{padding:8px 12px;border:0.5px solid var(--bd2);border-radius:4px;background:white;font-family:'Source Serif 4',serif;font-size:0.81rem;color:var(--ink2);cursor:pointer;text-align:left;transition:all 0.15s}
.rev-opt:hover{border-color:var(--gold);background:var(--goldpale)}
.rev-opt.active{border-color:var(--gold);background:var(--goldpale);font-weight:600}
.rev-row{display:flex;gap:8px}
.rev-apply{flex:1;padding:9px;background:var(--gold);border:none;border-radius:4px;font-family:'Source Serif 4',serif;font-size:0.82rem;font-weight:600;color:white;cursor:pointer;transition:background 0.15s}
.rev-apply:hover{background:var(--gold2)}
.rev-apply:disabled{background:var(--bd);cursor:default}
.rev-skip{padding:9px 14px;border:0.5px solid var(--bd);border-radius:4px;background:transparent;font-family:'Source Serif 4',serif;font-size:0.82rem;color:var(--ink3);cursor:pointer;transition:all 0.15s}
.rev-skip:hover{background:var(--p2)}

/* ─── SHAREABLE RESULT CARD ─── */
.share-row{display:flex;align-items:center;gap:8px;padding:9px 16px;background:var(--p);border-top:0.5px solid var(--bd2)}
.share-btn{display:flex;align-items:center;gap:5px;padding:5px 11px;border:0.5px solid var(--bd);border-radius:3px;background:transparent;font-family:'Source Serif 4',serif;font-size:0.74rem;color:var(--ink3);cursor:pointer;transition:all 0.15s}
.share-btn:hover{background:var(--p2);color:var(--ink)}
.share-copied{font-size:0.72rem;color:var(--forest2);font-weight:600;opacity:0;transition:opacity 0.3s}
.share-copied.show{opacity:1}
.share-preview{display:none;margin:0 16px 12px;padding:11px 13px;background:var(--p2);border:0.5px solid var(--bd);border-radius:4px;font-size:0.74rem;color:var(--ink2);line-height:1.6;white-space:pre-wrap;font-family:'Source Serif 4',serif}
.share-preview.show{display:block;animation:fadeIn 0.2s ease}

/* ─── COUNTERFACTUAL PANEL ─── */
.cf-panel{display:none;border-top:0.5px solid var(--bd2);padding:13px 16px;background:var(--slatelt)}
.cf-panel.show{display:block;animation:fadeIn 0.25s ease}
.cf-eyebrow{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.13em;color:var(--slate);font-weight:700;margin-bottom:5px}
.cf-title{font-family:'Playfair Display',serif;font-size:0.9rem;font-weight:600;color:var(--ink);margin-bottom:6px}
.cf-body{font-family:'EB Garamond',Georgia,serif;font-size:0.9rem;color:var(--ink2);line-height:1.72;font-style:italic}
.cf-toggle{margin-top:8px;padding:0;font-family:'Source Serif 4',serif;font-size:0.72rem;color:var(--slate);cursor:pointer;background:none;border:none;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;opacity:0.8}

/* ─── EPISTEMOLOGY PRE-TEST ─── */
.ep-screen{display:none;flex-direction:column;flex:1;min-height:0;overflow:hidden}
.ep-screen.active{display:flex;flex-direction:column;animation:fadeIn 0.25s ease}
.ep-screen#ep-step-2{overflow-y:auto;padding:16px 24px 0;flex:1;min-height:0;flex-direction:column}
.ep-scroll-body{overflow-y:auto;flex:1;min-height:0;padding:20px 24px 0}
.ep-scroll-body::-webkit-scrollbar{width:4px}
.ep-scroll-body::-webkit-scrollbar-track{background:transparent}
.ep-scroll-body::-webkit-scrollbar-thumb{background:var(--bd);border-radius:2px}
.ep-footer{flex-shrink:0;padding:10px 24px 16px;border-top:0.5px solid var(--bd2);background:var(--p)}

.ep-step-indicator{display:flex;align-items:center;gap:6px;margin-bottom:20px;justify-content:center}
.ep-step-dot{width:8px;height:8px;border-radius:50%;background:var(--bd);transition:background 0.2s}
.ep-step-dot.done{background:var(--gold)}
.ep-step-dot.active{background:var(--ink)}
.ep-step-label{font-size:0.68rem;color:var(--ink4);letter-spacing:0.08em}
.ep-question{margin-bottom:12px;padding-bottom:12px;border-bottom:0.5px solid var(--bd3)}
.ep-question:last-of-type{border-bottom:none;margin-bottom:4px}
.ep-q-number{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.14em;color:var(--gold);font-weight:700;margin-bottom:5px}
.ep-q-text{font-family:'Playfair Display',serif;font-size:0.92rem;font-weight:600;color:var(--ink);line-height:1.4;margin-bottom:9px}
.ep-q-sub{font-size:0.8rem;color:var(--ink3);line-height:1.6;margin-bottom:10px;font-style:italic}
.ep-opts{display:flex;flex-direction:column;gap:5px;margin-bottom:4px}
.ep-opt{display:flex;align-items:flex-start;gap:9px;padding:8px 10px;border:0.5px solid var(--bd2);border-radius:4px;cursor:pointer;background:white;transition:all 0.15s;text-align:left;width:100%}
.ep-opt:hover{border-color:var(--gold);background:var(--goldpale)}
.ep-opt.selected{border-color:var(--gold);background:var(--goldpale)}
.ep-opt-radio{width:13px;height:13px;border-radius:50%;border:1.5px solid var(--bd);flex-shrink:0;margin-top:2px;transition:all 0.15s}
.ep-opt.selected .ep-opt-radio{background:var(--gold);border-color:var(--gold)}
.ep-opt-text{font-size:0.79rem;color:var(--ink2);line-height:1.4}
.ep-opt-tag{font-size:0.65rem;color:var(--ink4);margin-top:1px}
.ep-nav{display:flex;gap:8px}
.ep-back-btn{padding:9px 16px;border:0.5px solid var(--bd);border-radius:4px;background:transparent;font-family:'Source Serif 4',serif;font-size:0.82rem;color:var(--ink3);cursor:pointer;transition:all 0.15s}
.ep-back-btn:hover{background:var(--p2)}
.ep-next-btn{flex:1;padding:9px;background:var(--gold);border:none;border-radius:4px;font-family:'Playfair Display',serif;font-size:0.85rem;font-weight:600;color:white;cursor:pointer;transition:background 0.15s;letter-spacing:0.02em}
.ep-next-btn:hover{background:var(--gold2)}
.ep-next-btn:disabled{background:var(--bd);cursor:default}
.ep-progress-bar{height:3px;background:var(--p3);border-radius:2px;margin-bottom:16px;overflow:hidden}
.ep-progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width 0.4s ease}

/* ─── PRIMARY SOURCE DOCUMENTS ─── */
.src-list{display:flex;flex-direction:column;gap:12px;padding:2px 0}
.src-card{border:0.5px solid var(--bd2);border-radius:5px;overflow:hidden;background:white}
.src-card-hdr{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;padding:9px 12px;background:var(--p2);border-bottom:0.5px solid var(--bd2)}
.src-doc-title{font-size:0.78rem;font-weight:600;color:var(--ink);line-height:1.3}
.src-doc-meta{font-size:0.67rem;color:var(--ink4);margin-top:2px;line-height:1.3}
.src-doc-badge{font-size:0.6rem;padding:2px 7px;border-radius:10px;font-weight:700;white-space:nowrap;flex-shrink:0;margin-top:1px}
.src-doc-badge.hostile{background:var(--crimlt);color:var(--crim2);border:0.5px solid #e0b0b0}
.src-doc-badge.primary{background:var(--goldpale);color:var(--amber);border:0.5px solid #e8c880}
.src-doc-badge.council{background:var(--forestlt);color:var(--forest2);border:0.5px solid #b8ddb4}
.src-doc-badge.patristic{background:var(--slatelt);color:var(--slate);border:0.5px solid #b8ccd8}
.src-body{padding:11px 13px}
.src-excerpt{font-family:'EB Garamond',Georgia,serif;font-size:0.92rem;color:var(--ink2);line-height:1.75;font-style:italic;margin-bottom:7px}
.src-why{font-size:0.75rem;color:var(--ink3);line-height:1.5;padding:7px 10px;background:var(--p);border-radius:3px;border-left:2px solid var(--gold)}
.src-why-label{font-size:0.6rem;font-weight:700;color:var(--gold);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:3px}
.dcm-overlay{display:none;position:fixed;inset:0;background:rgba(26,21,16,0.88);z-index:400;align-items:center;justify-content:center;padding:20px}
.dcm-overlay.show{display:flex;animation:fadeIn 0.3s ease}
.dcm-card{background:var(--p);border:1px solid var(--bd);border-radius:10px;max-width:800px;width:100%;max-height:calc(100vh - var(--fg-nav-h,82px) - 20px);display:flex;flex-direction:column;box-shadow:0 24px 80px rgba(0,0,0,0.5);overflow:hidden}
.dcm-hdr{display:flex;align-items:center;justify-content:space-between;padding:14px 20px;border-bottom:1px solid var(--bd2);background:var(--p2);flex-shrink:0}
.dcm-eyebrow{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.14em;color:var(--crim2);font-weight:700;margin-bottom:2px}
.dcm-title{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--ink)}
.dcm-close{width:28px;height:28px;border-radius:50%;border:0.5px solid var(--bd);background:transparent;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--ink3);transition:all 0.15s}
.dcm-close:hover{background:var(--p3)}
.dcm-body{flex:1;overflow-y:auto}
.dcm-svg-wrap{padding:16px 20px 8px;overflow-x:auto}
.dcm-svg-wrap svg{display:block;min-width:680px}
.dcm-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;padding:12px 20px;border-top:0.5px solid var(--bd2);border-bottom:0.5px solid var(--bd2)}
.dcm-stat{text-align:center}
.dcm-stat-num{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--crim2)}
.dcm-stat-label{font-size:0.62rem;color:var(--ink4);text-transform:uppercase;letter-spacing:0.08em;margin-top:2px}
.dcm-exp{padding:14px 20px}
.dcm-exp-title{font-family:'Playfair Display',serif;font-size:0.88rem;font-weight:600;color:var(--ink);margin-bottom:6px}
.dcm-exp-txt{font-size:0.79rem;color:var(--ink3);line-height:1.65}
.dcm-exp-txt strong{color:var(--ink2);font-weight:600}
.dcm-footer{padding:11px 20px;border-top:0.5px solid var(--bd2);display:flex;align-items:center;gap:10px;flex-shrink:0;background:var(--p2)}
.dcm-model-note{font-size:0.72rem;color:var(--ink4);font-style:italic;flex:1}
.dcm-dismiss{padding:7px 16px;border:0.5px solid var(--bd);border-radius:4px;background:transparent;font-family:'Source Serif 4',serif;font-size:0.79rem;color:var(--ink3);cursor:pointer;transition:all 0.15s}
.dcm-dismiss:hover{background:var(--p3)}
.dcm-open-btn{display:inline-flex;align-items:center;gap:5px;margin-top:8px;padding:6px 12px;border:0.5px solid var(--bd);border-radius:3px;background:transparent;font-family:'Source Serif 4',serif;font-size:0.75rem;color:var(--ink3);cursor:pointer;transition:all 0.15s}
.dcm-open-btn:hover{background:var(--p2);color:var(--ink)}

.hw-panel{padding:4px 0}
.hw-intro{font-size:0.8rem;color:var(--ink3);line-height:1.6;margin-bottom:14px;font-style:italic;border-left:2px solid var(--bd);padding-left:10px}
.hw-grid{display:flex;flex-direction:column;gap:10px}
.hw-card{border:0.5px solid var(--bd2);border-radius:5px;overflow:hidden;background:white}
.hw-card-hdr{display:flex;align-items:center;gap:10px;padding:9px 12px;background:var(--p2);border-bottom:0.5px solid var(--bd2)}
.hw-avatar{width:30px;height:30px;border-radius:50%;background:var(--p3);border:1px solid var(--bd);flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:'Playfair Display',serif;font-size:0.65rem;font-weight:700;color:var(--ink3)}
.hw-name{font-size:0.8rem;font-weight:600;color:var(--ink);line-height:1.2}
.hw-stance{font-size:0.68rem;color:var(--crim2);font-weight:600;letter-spacing:0.04em;text-transform:uppercase;margin-top:1px}
.hw-body{padding:10px 12px}
.hw-quote{font-family:'EB Garamond',Georgia,serif;font-size:0.92rem;color:var(--ink2);line-height:1.72;font-style:italic;margin-bottom:6px}
.hw-attr{font-size:0.68rem;color:var(--ink4);font-family:'Source Serif 4',serif;font-style:normal}
.hw-concedes{margin-top:8px;padding:7px 10px;background:var(--goldpale);border:0.5px solid var(--gold);border-radius:3px}
.hw-concedes-label{font-size:0.6rem;text-transform:uppercase;letter-spacing:0.1em;color:var(--gold);font-weight:700;margin-bottom:3px}
.hw-concedes-txt{font-size:0.76rem;color:var(--ink2);line-height:1.45}
.hw-empty{font-size:0.82rem;color:var(--ink4);font-style:italic;text-align:center;padding:16px 0}
.hw-tab-badge{display:inline-block;margin-left:5px;padding:1px 6px;background:var(--crimlt);color:var(--crim2);border-radius:8px;font-size:0.6rem;font-weight:700;letter-spacing:0.05em;vertical-align:middle}
.tpi-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.tpi-title{font-family:'Playfair Display',serif;font-size:0.88rem;font-weight:600;color:var(--ink)}
.tpi-overall{display:flex;align-items:center;gap:8px}
.tpi-overall-label{font-size:0.65rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--ink4);font-weight:700}
.tpi-overall-badge{padding:3px 12px;border-radius:12px;font-size:0.72rem;font-weight:700;letter-spacing:0.05em}
.tpi-overall-badge.high{background:var(--forestlt);color:var(--forest2);border:0.5px solid #b8ddb4}
.tpi-overall-badge.medium{background:var(--amberlt);color:var(--amber);border:0.5px solid #e8c880}
.tpi-overall-badge.low{background:var(--crimlt);color:var(--crim2);border:0.5px solid #e8b8b8}
.tpi-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tpi-dimension{background:var(--p);border:0.5px solid var(--bd2);border-radius:5px;padding:10px 12px}
.tpi-dim-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px}
.tpi-dim-name{font-size:0.7rem;font-weight:700;color:var(--ink2);text-transform:uppercase;letter-spacing:0.08em}
.tpi-dim-score{font-size:0.7rem;font-weight:700}
.tpi-dim-score.high{color:var(--forest2)}
.tpi-dim-score.medium{color:var(--amber)}
.tpi-dim-score.low{color:var(--crim2)}
.tpi-bar-bg{height:5px;background:var(--p3);border-radius:3px;overflow:hidden;margin-bottom:6px}
.tpi-bar-fill{height:100%;border-radius:3px;transition:width 0.9s cubic-bezier(0.4,0,0.2,1)}
.tpi-bar-fill.high{background:var(--forest2)}
.tpi-bar-fill.medium{background:var(--gold2)}
.tpi-bar-fill.low{background:var(--crim2)}
.tpi-dim-note{font-size:0.72rem;color:var(--ink4);line-height:1.4}
.tpi-verdict{margin-top:12px;padding:9px 12px;border-radius:4px;font-size:0.8rem;line-height:1.6;font-family:'EB Garamond',Georgia,serif;font-style:italic}
.tpi-verdict.high{background:var(--forestlt);color:var(--forest);border-left:2px solid var(--forest2)}
.tpi-verdict.medium{background:var(--amberlt);color:var(--amber);border-left:2px solid var(--gold2)}
.tpi-verdict.low{background:var(--crimlt);color:var(--crim2);border-left:2px solid var(--crim2)}
.tpi-toggle{margin-top:10px;display:flex;align-items:center;gap:4px;font-size:0.72rem;color:var(--ink4);cursor:pointer;background:none;border:none;font-family:'Source Serif 4',serif;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px}

/* ─── TRUTH PRESSURE INDEX ─── */
.ph-wrap{margin-top:10px;padding:11px 12px;background:var(--goldpale);border:0.5px solid var(--gold);border-radius:4px}
.ph-label{font-size:0.62rem;text-transform:uppercase;letter-spacing:0.12em;color:var(--gold);font-weight:700;margin-bottom:4px}
.ph-txt{font-size:0.77rem;color:var(--ink2);line-height:1.5;margin-bottom:9px}
.ph-btn{display:block;width:100%;padding:8px;background:var(--gold);border:none;border-radius:4px;font-family:'Playfair Display',serif;font-size:0.82rem;font-weight:600;color:white;cursor:pointer;text-align:center;transition:background 0.15s}
.ph-btn:hover{background:var(--gold2)}
.ph-tag{display:block;margin-top:5px;font-size:0.67rem;color:var(--ink4);font-style:italic;text-align:center}

/* Responsive */
@media(max-width:1100px){.layout{grid-template-columns:220px 1fr 200px}.sc-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:800px){.layout{grid-template-columns:1fr}.sidebar-l,.sidebar-r{display:none}.sc-grid{grid-template-columns:repeat(2,1fr)}.main{padding:16px}}

@media(max-width:600px){
  .intro-overlay{padding-top:var(--fg-nav-h,50px)}
  .intro-card{border-radius:8px;max-height:calc(100vh - var(--fg-nav-h,50px) - 8px);margin:4px 0 6px}
  .intro-title{font-size:1.1rem;margin-bottom:3px}
  .intro-subtitle{font-size:0.76rem;margin-bottom:8px}
  .intro-body{font-size:0.79rem;line-height:1.5;margin-bottom:8px}
  .intro-body p{margin-bottom:5px}
  .ep-scroll-body{padding:14px 16px 0}
  .ep-footer{padding:8px 16px 12px}
  .intro-model-nm{font-size:0.78rem}
  .intro-model-ds{font-size:0.67rem}
  .intro-model-opt{padding:8px 9px}
  .intro-model-grid{gap:6px;margin-bottom:12px}
  .ep-q-number{font-size:0.58rem}
  .ep-q-text{font-size:0.84rem;margin-bottom:7px}
  .ep-opt-text{font-size:0.75rem}
  .ep-opt-tag{font-size:0.62rem}
  .ep-opt{padding:6px 8px;gap:7px}
  .ep-next-btn{font-size:0.82rem;padding:9px}
  .ep-back-btn{padding:8px 12px;font-size:0.78rem}
  .ep-progress-bar{margin-bottom:10px}
  .ep-question{margin-bottom:10px;padding-bottom:10px}
}
