/*
Theme Name: Spooky Connections
Theme URI: https://spookyconnections.com/
Description: Dark editorial dossier theme for an open-source investigation. Subjects archive with search and type filters, per-subject connection maps, chronological timelines, sources, a sitewide connection graph, Donorbox support, newsletter, and full Open Graph sharing. Pairs with the Spooky Connections plugin.
Author: Spooky Connections
Version: 1.0.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: spooky
*/

:root{
  --bg:#0a0a0c; --panel:#101015; --panel-2:#15151b; --inset:#1b1b22;
  --bone:#e9e4d8; --dim:#8e8a80; --faint:#5a574f;
  --line:rgba(233,228,216,.10); --line-2:rgba(233,228,216,.20);
  --accent:#5154ab; --accent-2:#9498f0; --accent-dim:#3a3c80; --amber:#c79a3e;
  --grid:rgba(233,228,216,.05); --hatch:rgba(233,228,216,.03); --mg:rgba(233,228,216,.12);
  --header-bg:rgba(10,10,12,.80);
  --serif:'Spectral',Georgia,serif; --mono:'IBM Plex Mono',ui-monospace,monospace;
}
html[data-theme="light"]{
  --bg:#f4f1ea; --panel:#fffdf8; --panel-2:#f3efe6; --inset:#ece7db;
  --bone:#1b1812; --dim:#5f5b51; --faint:#94908a;
  --line:rgba(21,18,11,.12); --line-2:rgba(21,18,11,.22); --accent-2:#4649a3;
  --grid:rgba(21,18,11,.06); --hatch:rgba(21,18,11,.04); --mg:rgba(21,18,11,.14);
  --header-bg:rgba(244,241,234,.82);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--bone);font-family:var(--serif);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;transition:background .3s,color .3s}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto}
::selection{background:var(--accent);color:#fff}
.sc-grain{position:fixed;inset:0;z-index:9990;pointer-events:none;opacity:.03;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.wrap{max-width:1240px;margin:0 auto;padding:0 50px}
.skip-link{position:absolute;left:-9999px}
.skip-link:focus{left:8px;top:8px;background:var(--accent);color:#fff;padding:8px 12px;z-index:9999;border-radius:5px}

/* masthead */
.masthead{position:sticky;top:0;z-index:80;background:var(--header-bg);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.hd{max-width:1240px;margin:0 auto;padding:13px 50px;display:flex;align-items:center;gap:22px}
.brand{display:flex;align-items:center;gap:12px}
.brand .brand-logo{width:30px;height:30px;flex:none;object-fit:contain;display:block;filter:drop-shadow(0 0 6px rgba(81,84,171,.5))}
html[data-theme="light"] .brand .brand-logo,html[data-theme="light"] .ft-logo{filter:brightness(.25) drop-shadow(0 0 5px rgba(81,84,171,.35))}
.brand .nm{font-weight:600;font-size:16px;line-height:1}
.brand .nm small{display:block;font-family:var(--mono);font-size:8px;letter-spacing:.26em;text-transform:uppercase;color:var(--faint);margin-top:4px}
.mainnav{margin-left:10px;display:flex;gap:2px}
.mainnav a{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--dim);padding:8px 11px;border-radius:5px;transition:.2s}
.mainnav a:hover,.mainnav .current-menu-item>a{color:var(--bone);background:var(--panel-2)}
.mainnav ul{list-style:none;margin:0;padding:0;display:flex;gap:2px}
.tools{margin-left:auto;display:flex;gap:9px;align-items:center}
.icon-btn{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--line);border-radius:6px;color:var(--dim);cursor:pointer;background:transparent;transition:.2s}
.icon-btn:hover{color:var(--bone);border-color:var(--line-2)}
.icon-btn svg{width:15px;height:15px}
.icon-btn .moon{display:none}
html[data-theme="light"] .icon-btn .sun{display:none}
html[data-theme="light"] .icon-btn .moon{display:block}
.nav-btn{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;padding:9px 15px;border-radius:5px;transition:.2s;white-space:nowrap}
.nav-btn.donate{background:var(--accent);border:1px solid var(--accent);color:#fff}
.nav-btn.donate:hover{background:#454895}
.nav-btn.sub{border:1px solid var(--accent-dim);color:var(--accent-2)}
.nav-btn.sub:hover{background:rgba(81,84,171,.12)}
.burger{display:none;width:34px;height:34px;border:1px solid var(--line);border-radius:6px;background:transparent;color:var(--bone);cursor:pointer;align-items:center;justify-content:center}
.burger svg{width:18px;height:18px}

/* hero */
.hero{position:relative;padding:116px 0 92px;border-bottom:1px solid var(--line);background-image:radial-gradient(circle at 1px 1px,var(--grid) 1px,transparent 0);background-size:34px 34px}
.hero::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse at 72% 28%,rgba(81,84,171,.12),transparent 60%);pointer-events:none}
.hero .inner{position:relative;z-index:1}
.kicker{font-family:var(--mono);font-size:10px;letter-spacing:.3em;text-transform:uppercase;color:var(--accent-2);margin-bottom:28px}
.hero h1{font-weight:300;font-size:clamp(40px,6.6vw,86px);line-height:1.02;letter-spacing:-.02em;max-width:17ch;margin:0}
.hero h1 em{font-style:italic;font-weight:400;color:var(--accent-2)}
.hero .lede{margin-top:28px;max-width:54ch;font-size:clamp(17px,1.7vw,21px);font-weight:300;color:var(--dim)}
.hero .cta{margin-top:38px;display:flex;gap:14px;flex-wrap:wrap}
.btn{font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;padding:14px 22px;border-radius:5px;transition:.2s;border:1px solid var(--line-2);cursor:pointer;display:inline-block}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.btn.primary:hover{background:#454895}
.btn.ghost:hover{border-color:var(--bone)}
.stat{margin-top:44px;display:flex;gap:40px;flex-wrap:wrap;font-family:var(--mono);font-size:10px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.stat b{display:block;font-family:var(--serif);font-size:30px;font-weight:300;letter-spacing:normal;color:var(--bone);text-transform:none;margin-bottom:4px}

section{padding:74px 0}
.shead{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;flex-wrap:wrap;border-top:1px solid var(--line);padding-top:20px;margin-bottom:14px}
.shead h2{font-family:var(--mono);font-size:12px;font-weight:500;letter-spacing:.24em;text-transform:uppercase;margin:0}
.shead h2 b{color:var(--accent-2);font-weight:500}
.shead .note{font-family:var(--mono);font-size:10px;letter-spacing:.1em;color:var(--faint);text-transform:uppercase}
.shead .more{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--accent-2)}

.pillars{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);margin-top:28px}
.pillar{padding:26px 22px;border-right:1px solid var(--line);transition:.25s}
.pillar:last-child{border-right:0}
.pillar:hover{background:var(--panel)}
.pillar .pn{font-family:var(--mono);font-size:10px;color:var(--accent-2);letter-spacing:.16em;margin-bottom:16px}
.pillar h3{font-weight:500;font-size:19px;margin:0 0 9px;letter-spacing:-.01em}
.pillar p{font-size:13px;color:var(--dim);line-height:1.6;margin:0}

/* subjects controls */
.controls{display:flex;gap:16px;align-items:center;flex-wrap:wrap;margin-bottom:30px}
.search{position:relative;min-width:210px;max-width:340px;flex:1}
.search input{width:100%;background:var(--panel);border:1px solid var(--line);color:var(--bone);font-family:var(--mono);font-size:12px;padding:10px 12px 10px 32px;border-radius:6px;outline:none}
.search input:focus{border-color:var(--accent-dim)}
.search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);width:14px;height:14px;stroke:var(--dim);fill:none}
.filters{display:flex;gap:7px;flex-wrap:wrap}
.chip{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--dim);border:1px solid var(--line);padding:7px 12px;border-radius:20px;cursor:pointer;transition:.2s}
.chip:hover{color:var(--bone);border-color:var(--line-2)}
.chip.on{background:var(--accent);border-color:var(--accent);color:#fff}

.board{display:grid;grid-template-columns:repeat(auto-fill,minmax(248px,1fr));gap:20px}
.card{border:1px solid var(--line);background:var(--panel);overflow:hidden;display:block;transition:.25s}
.card:hover{border-color:var(--accent);transform:translateY(-3px)}
.plate{position:relative;aspect-ratio:1/1;border-bottom:1px solid var(--line);display:grid;place-items:center;overflow:hidden;background:repeating-linear-gradient(135deg,var(--hatch) 0 2px,transparent 2px 9px),var(--inset)}
.plate img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.plate .mgr{font-weight:600;font-size:74px;color:var(--mg);line-height:1}
.plate .fl{position:absolute;top:11px;left:13px;font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;color:var(--faint);background:var(--bg);padding:2px 5px;border-radius:2px}
.plate .ty{position:absolute;top:11px;right:13px;font-family:var(--mono);font-size:8px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);border:1px solid var(--line);padding:3px 7px;border-radius:2px;background:var(--bg)}
.cbody{padding:15px 16px 17px}
.cbody h3{font-weight:500;font-size:21px;letter-spacing:-.01em;line-height:1.1;margin:0}
.cbody .role{font-family:var(--mono);font-size:11px;color:var(--dim);margin-top:8px;line-height:1.5}
.cbody .foot{margin-top:14px;padding-top:12px;border-top:1px solid var(--line);display:flex;justify-content:space-between;font-family:var(--mono);font-size:9px;letter-spacing:.08em;color:var(--faint);text-transform:uppercase}
.card:hover .foot .open{color:var(--accent-2)}
.empty{padding:40px 8px;font-family:var(--mono);font-size:12px;color:var(--dim)}

.pager{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:30px;flex-wrap:wrap}
.count{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}
.sc-pagination{display:flex;gap:6px;flex-wrap:wrap}
.sc-pagination .page-numbers{font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--dim);border:1px solid var(--line);padding:8px 13px;border-radius:6px;transition:.2s}
.sc-pagination .page-numbers:hover{color:var(--bone);border-color:var(--line-2)}
.sc-pagination .page-numbers.current{background:var(--accent);border-color:var(--accent);color:#fff}

/* map */
.map-wrap{position:relative;border:1px solid var(--line);background:var(--panel);background-image:radial-gradient(circle at 1px 1px,var(--grid) 1px,transparent 0);background-size:30px 30px;border-radius:8px;overflow:hidden}
.map{width:100%;height:600px;display:block}
.map text{font-family:var(--mono);font-size:10.5px;fill:var(--dim);letter-spacing:.04em}
.map .edge{stroke:var(--line-2);stroke-width:1;fill:none;transition:.3s}
.map .edge.alleged{stroke-dasharray:3 4}
.map .edge.hot{stroke:var(--accent);stroke-width:1.5}
.map .node{cursor:pointer}
.map .node .sh{fill:var(--inset);stroke:var(--accent-2);stroke-width:1;transition:.3s}
.map .node.hot .sh{fill:var(--accent)}
.legend{position:absolute;bottom:14px;left:16px;display:flex;gap:18px;font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.legend i{display:inline-block;width:9px;height:9px;border:1px solid var(--accent-2);margin-right:6px;vertical-align:middle}
.legend .ci{border-radius:50%}.legend .di{transform:rotate(45deg)}
.map-loading{padding:80px;text-align:center;font-family:var(--mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint)}

/* reports */
.reports{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.rep{border:1px solid var(--line);background:var(--panel);padding:24px;display:flex;flex-direction:column;gap:14px;transition:.25s;min-height:220px}
.rep:hover{border-color:var(--accent);background:var(--panel-2)}
.rep .rdate{font-family:var(--mono);font-size:9.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--accent-2)}
.rep h3{font-weight:500;font-size:20px;line-height:1.25;letter-spacing:-.01em;flex:1;margin:0}
.rep .read{font-family:var(--mono);font-size:9.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim)}
.rep:hover .read{color:var(--accent-2)}

/* subscribe band */
.subscribe-band{border-top:1px solid var(--line);padding:64px 0}
.subscribe-band h2{font-weight:300;font-size:clamp(26px,3vw,38px);letter-spacing:-.02em;margin:0 0 10px}
.subscribe-band p{color:var(--dim);max-width:48ch;margin:0 0 22px}
.em{display:flex;border:1px solid var(--line);border-radius:6px;overflow:hidden;max-width:440px}
.em input{flex:1;background:var(--panel);border:0;color:var(--bone);font-family:var(--mono);font-size:13px;padding:13px 14px;outline:none}
.em button{background:var(--accent);color:#fff;border:0;font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:0 20px;cursor:pointer}

/* footer */
.site-footer{border-top:1px solid var(--line);padding:64px 48px;margin-top:50px;background:var(--panel)}
.ft{max-width:1240px;margin:0 auto;display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.ft .big{font-weight:300;font-size:28px;line-height:1.15;letter-spacing:-.01em;max-width:18ch}
.ft .big img{width:26px;vertical-align:-4px;margin-right:8px;filter:drop-shadow(0 0 6px rgba(81,84,171,.4))}
.ft h5{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--faint);margin:0 0 14px}
.ft a.fl,.ft .menu a{display:block;font-family:var(--mono);font-size:12px;color:var(--dim);padding:5px 0;transition:.2s}
.ft a.fl:hover,.ft .menu a:hover{color:var(--accent-2)}
.ft ul{list-style:none;margin:0;padding:0}
.ft .em{margin-top:8px}
.ft-social{display:flex;gap:9px;margin-top:22px}
.ft-social a{width:38px;height:38px;display:grid;place-items:center;border:1px solid var(--line);border-radius:7px;color:var(--dim);transition:.2s}
.ft-social a:hover{color:var(--accent-2);border-color:var(--accent)}
.ft-social svg{width:17px;height:17px}

/* table of contents */
.toc{margin:0 0 30px}
.toc-h{font-family:var(--mono);font-size:8.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint);margin-bottom:10px}
.toc ul{list-style:none;margin:0;padding:0;display:grid;gap:1px}
.toc a{display:block;font-family:var(--mono);font-size:11.5px;color:var(--dim);line-height:1.4;padding:6px 0 6px 11px;border-left:2px solid var(--line);transition:.2s}
.toc a:hover{color:var(--accent-2);border-left-color:var(--accent)}
.toc .sub{list-style:none;margin:1px 0 3px;padding:0;display:grid;gap:1px}
.toc .sub a{font-size:10.5px;padding-left:24px;color:var(--faint);border-left-color:transparent}
.toc .sub a:hover{color:var(--accent-2);border-left-color:var(--accent)}
.entry .toc,.paper .toc{border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:18px 20px}
.entry .toc a,.paper .toc a{font-size:12.5px}
.entry .toc .sub a,.paper .toc .sub a{font-size:11.5px}
.idcard .toc{margin:0;border-top:1px solid var(--line);padding:14px 16px 16px}
.idcard .toc a{font-size:11px}
.idcard .toc .sub a{font-size:10px}
.dossier-content h2,.dossier-content h3,.entry h2,.entry h3,.pbody h4{scroll-margin-top:88px}

/* generic single / page (non-dossier) */
.paper{max-width:760px;margin:64px auto;padding:0 50px}
.paper .ptitle{font-weight:300;font-size:clamp(32px,4.6vw,54px);line-height:1.05;letter-spacing:-.02em;margin:0 0 14px}
.paper .pmeta{font-family:var(--mono);font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--faint);margin-bottom:30px}
.entry{font-size:17px;line-height:1.8;color:var(--bone)}
.entry p{margin:0 0 18px;color:var(--dim)}
.entry h2{font-weight:500;font-size:26px;letter-spacing:-.01em;margin:38px 0 14px}
.entry h3{font-weight:500;font-size:21px;margin:30px 0 12px}
.entry a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px}
.entry img{border-radius:6px;margin:24px 0}
.entry blockquote{border-left:2px solid var(--accent);margin:24px 0;padding:4px 0 4px 20px;font-style:italic;color:var(--bone)}
.entry ul,.entry ol{color:var(--dim);padding-left:22px;margin:0 0 18px}
.entry code{font-family:var(--mono);font-size:.9em;background:var(--panel-2);padding:2px 5px;border-radius:3px}

/* dossier (single) */
.dossier-wrap{max-width:1100px;margin:0 auto;padding:42px 50px 90px}
.dossier-top{display:flex;align-items:center;gap:14px;margin-bottom:30px}
.dossier-top .ov-ref{font-family:var(--mono);font-size:10px;letter-spacing:.14em;color:var(--faint);text-transform:uppercase}
.share{margin-left:auto;display:flex;gap:8px}
.share a,.share button{width:34px;height:34px;display:grid;place-items:center;border:1px solid var(--line);border-radius:6px;color:var(--dim);cursor:pointer;background:transparent;transition:.2s}
.share a:hover,.share button:hover{color:var(--accent-2);border-color:var(--accent)}
.share .sc-copy.copied{color:var(--accent-2);border-color:var(--accent);background:rgba(81,84,171,.14)}
.share svg{width:15px;height:15px;fill:currentColor}
.dossier{display:grid;grid-template-columns:288px 1fr;gap:46px;align-items:start}
.idcard{border:1px solid var(--line);background:var(--panel);position:sticky;top:90px;max-height:calc(100vh - 110px);overflow-y:auto;overscroll-behavior:contain}
.idcard::-webkit-scrollbar{width:8px}
.idcard::-webkit-scrollbar-thumb{background:var(--line-2);border-radius:8px}
.idcard::-webkit-scrollbar-track{background:transparent}
.idcard{scrollbar-width:thin;scrollbar-color:var(--line-2) transparent}
.idphoto{position:relative;aspect-ratio:4/5;border-bottom:1px solid var(--line);display:grid;place-items:center;background:repeating-linear-gradient(135deg,var(--hatch) 0 2px,transparent 2px 9px),var(--inset);overflow:hidden}
.idphoto img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.idphoto .mgr{font-weight:600;font-size:100px;color:var(--mg)}
.idphoto .tag{position:absolute;top:12px;left:12px;font-family:var(--mono);font-size:8.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--accent-2);border:1px solid var(--accent-dim);padding:3px 8px;border-radius:2px;background:var(--bg)}
.idmeta{padding:4px 16px 16px;font-family:var(--mono)}
.idmeta .mrow{display:flex;justify-content:space-between;gap:12px;padding:11px 0;border-bottom:1px solid var(--line);font-size:11.5px}
.idmeta .mrow:last-child{border-bottom:0}
.idmeta .k{font-size:8.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--faint)}
.idmeta .stat-a{color:var(--amber)}
.pbody .dkick{font-family:var(--mono);font-size:10px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-2);margin-bottom:18px}
.pbody h1{font-weight:300;font-size:clamp(38px,5.4vw,64px);line-height:1;letter-spacing:-.02em;margin:0 0 22px}
.pbody .stand{font-size:20px;font-weight:300;line-height:1.5;max-width:42ch;color:var(--bone);margin:0 0 30px}
.dossier-content{font-size:16.5px;line-height:1.82;color:var(--dim)}
.dossier-content p{margin:0 0 18px}
.dossier-content a{color:var(--accent-2);text-decoration:underline;text-underline-offset:3px}
.dossier-content h2{font-family:var(--serif);font-weight:500;font-size:25px;color:var(--bone);margin:34px 0 12px;letter-spacing:-.01em}
.dossier-content h3{font-weight:500;font-size:20px;color:var(--bone);margin:26px 0 10px}
.dossier-content img{border-radius:6px;margin:24px 0}
.dossier-content blockquote{border-left:2px solid var(--accent);margin:24px 0;padding:4px 0 4px 20px;font-style:italic;color:var(--bone)}
.pbody h4{font-family:var(--mono);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--dim);margin:40px 0 16px;display:flex;align-items:center;gap:10px}
.pbody h4::before{content:"";width:18px;height:1px;background:var(--accent)}
.links{display:grid;gap:1px}
.lk{display:flex;align-items:center;gap:12px;padding:13px 14px;border:1px solid var(--line);background:var(--panel);font-family:var(--mono);font-size:13px;transition:.2s}
.lk:hover{border-color:var(--accent);background:var(--panel-2);padding-left:20px}
.lk .nd{width:8px;height:8px;border:1px solid var(--accent-2);flex:none}
.lk .nd.sq{border-radius:0}.lk .nd.ci{border-radius:50%}.lk .nd.di{transform:rotate(45deg)}
.lk .tier{margin-left:auto;font-size:8.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint)}
.sources{list-style:none;counter-reset:s;font-family:var(--mono);padding:0;margin:0}
.sources li{counter-increment:s;padding:10px 0 10px 30px;border-bottom:1px solid var(--line);font-size:12px;color:var(--dim);position:relative;line-height:1.5}
.sources li::before{content:counter(s,decimal-leading-zero);position:absolute;left:0;color:var(--accent-2);font-size:10px}

/* ego map */
.egomap{border:1px solid var(--line);background:var(--panel);background-image:radial-gradient(circle at 1px 1px,var(--grid) 1px,transparent 0);background-size:26px 26px;border-radius:8px;overflow:hidden}
.egomap svg{width:100%;height:auto;display:block}
.egomap text{font-family:var(--mono);font-size:11px;fill:var(--dim);letter-spacing:.03em}
.egomap .ectext{fill:var(--bone);font-size:12px}
.egomap .ee{stroke:var(--line-2);stroke-width:1.2}
.egomap .ee.alleged{stroke-dasharray:3 4;opacity:.75}
.egomap .sh{fill:var(--inset);stroke:var(--accent-2);stroke-width:1;transition:.2s}
.egomap .ecenter .sh{fill:var(--accent);stroke:var(--accent)}
.egomap .en{cursor:pointer}
.egomap .en:hover .sh{fill:var(--accent)}
.egomap .en:hover text{fill:var(--bone)}
.egomap .cap{padding:11px 14px;border-top:1px solid var(--line);font-family:var(--mono);font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);display:flex;gap:16px;flex-wrap:wrap}
.egomap .cap .dash{border-bottom:1px dashed var(--faint);width:18px;display:inline-block;vertical-align:middle;margin-right:5px}
.egomap .cap .solid{border-bottom:1px solid var(--accent-2);width:18px;display:inline-block;vertical-align:middle;margin-right:5px}

/* timeline */
.timeline{position:relative;margin-top:6px;padding-left:24px}
.timeline::before{content:"";position:absolute;left:4px;top:6px;bottom:8px;width:1px;background:var(--line-2)}
.tl-item{position:relative;padding-bottom:22px}
.tl-item:last-child{padding-bottom:0}
.tl-item::before{content:"";position:absolute;left:-24px;top:4px;width:9px;height:9px;border-radius:50%;background:var(--bg);border:1.5px solid var(--accent-2)}
.tl-date{font-family:var(--mono);font-size:11px;letter-spacing:.06em;color:var(--accent-2);margin-bottom:4px}
.tl-text{font-size:15.5px;color:var(--dim);line-height:1.55;max-width:60ch}

/* end-of-post CTA */
.post-cta{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:54px;padding-top:38px;border-top:1px solid var(--line-2)}
.cta-card{border:1px solid var(--line);background:var(--panel);border-radius:8px;padding:24px}
.cta-card .ck{font-family:var(--mono);font-size:9px;letter-spacing:.2em;text-transform:uppercase;color:var(--accent-2);margin-bottom:10px}
.cta-card h4{font-weight:500;font-size:22px;letter-spacing:-.01em;margin:0 0 8px}
.cta-card p{font-family:var(--mono);font-size:11.5px;color:var(--dim);line-height:1.6;margin:0 0 16px}

/* popup */
.pop{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:24px;background:rgba(4,4,6,.6);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:.3s}
.pop.open{opacity:1;visibility:visible}
.pop-card{position:relative;max-width:440px;width:100%;background:var(--panel);border:1px solid var(--line-2);border-radius:12px;padding:34px 32px 30px;transform:translateY(14px);transition:.3s}
.pop.open .pop-card{transform:none}
.pop-x{position:absolute;top:14px;right:16px;background:transparent;border:0;color:var(--faint);font-size:20px;cursor:pointer;line-height:1}
.pop-k{font-family:var(--mono);font-size:9px;letter-spacing:.22em;text-transform:uppercase;color:var(--accent-2);margin-bottom:14px}
.pop-card h3{font-weight:300;font-size:30px;letter-spacing:-.02em;margin:0 0 12px}
.pop-card p{font-size:15px;color:var(--dim);line-height:1.6;margin:0 0 22px}
.pop-act{display:flex;flex-direction:column;gap:10px}
.pop-tiny{font-family:var(--mono);font-size:9px;letter-spacing:.1em;text-transform:uppercase;color:var(--faint);text-align:center;margin-top:14px;cursor:pointer}

@media(max-width:900px){
  .wrap,.hd,.dossier-wrap,.paper{padding-left:30px;padding-right:30px}
  .mainnav{position:absolute;top:100%;left:0;right:0;background:var(--header-bg);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);flex-direction:column;padding:10px 30px 16px;display:none}
  .masthead.nav-open .mainnav{display:flex}
  .mainnav ul{flex-direction:column;gap:0;width:100%}
  .mainnav a{display:block;padding:11px 0;border-bottom:1px solid var(--line)}
  .burger{display:flex}
  .pillars{grid-template-columns:1fr 1fr}.pillar{border-bottom:1px solid var(--line)}.pillar:nth-child(2){border-right:0}
  .dossier{grid-template-columns:1fr;gap:28px}.idcard{position:static;max-height:none;overflow:visible}
  .reports{grid-template-columns:1fr}
  .ft{grid-template-columns:1fr;gap:28px}
  .site-footer{padding-left:0;padding-right:0}
  .post-cta{grid-template-columns:1fr}
  .map{height:460px}
  .controls{width:100%}.search{max-width:none}
  .board{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  .hd{gap:10px;padding:11px 18px}
  .brand .brand-logo{width:26px;height:26px}
  .brand .nm{font-size:14px;line-height:1.05}
  .brand .nm small{display:none}
  .tools{gap:7px}
  .icon-btn{width:32px;height:32px}
  .nav-btn{padding:9px 13px;font-size:9.5px;letter-spacing:.1em}
  .nav-btn.sub{display:none}
  .hero{padding:72px 0 60px}
  .stat{gap:26px}
  section{padding:56px 0}
  .board{grid-template-columns:1fr}
  .pop-card{padding:30px 22px 26px}.pop-card h3{font-size:26px}
}
