:root{
  --paper:#F7F6F9; --card:#ffffff; --soft:#F5F3F8;
  --ink:#16151C; --ink2:#54515E; --ink3:#8B8696;
  --line:#ECEAF0; --line2:#DED9E6;
  --pink:#EA257D; --purple:#763397;
  --pink-soft:rgba(234,37,125,.12); --pink-faint:rgba(234,37,125,.06);
  --purple-soft:rgba(118,51,151,.07);
  --gradient:linear-gradient(135deg,#EA257D 0%,rgba(234,37,125,.92) 50%,#763397 100%);
  /* aliases the app already uses everywhere — repointed to the brand palette */
  --rust:#EA257D; --pine:#763397;
  --info-b:rgba(37,99,235,.10); --info-t:#2563EB;
  --ok-b:rgba(20,160,107,.12); --ok-t:#14A06B;
  --warn-b:rgba(213,138,14,.14); --warn-t:#B9760C;
  --bad-b:rgba(220,40,65,.10); --bad-t:#DC2841;
  --teal-b:rgba(14,148,136,.12); --teal-t:#0E9488;
  --r:14px;
  --sans:'DM Sans',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --head:'Plus Jakarta Sans',var(--sans);
  --mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --shadow:0 1px 2px rgba(15,14,20,.04),0 2px 7px rgba(15,14,20,.04);
  --shadow-lg:0 4px 22px rgba(15,14,20,.07);
}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:var(--sans);background:var(--paper);color:var(--ink2);line-height:1.55;-webkit-font-smoothing:antialiased;}
a{color:var(--pink);text-decoration:none;}
button{font-family:var(--sans);font-weight:600;cursor:pointer;border:1px solid var(--line2);background:var(--card);color:var(--ink);padding:8px 14px;border-radius:10px;font-size:13px;transition:all .14s;line-height:1.2;}
button:hover{background:var(--soft);border-color:var(--purple);}
button.primary{background:var(--gradient);color:#fff;border:none;box-shadow:0 2px 9px rgba(234,37,125,.28);}
button.primary:hover{filter:brightness(1.05);background:var(--gradient);box-shadow:0 4px 14px rgba(234,37,125,.34);}
button:disabled{opacity:.5;cursor:default;}
input,select{font-family:inherit;font-size:14px;padding:9px 11px;border:1px solid var(--line2);border-radius:10px;background:var(--card);color:var(--ink);width:100%;}
input[type=checkbox]{width:auto;}

/* header */
header{background:var(--card);color:var(--ink);padding:14px 26px;display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--line);}
header .mark{font-family:var(--head);font-weight:800;font-size:19px;display:flex;align-items:center;gap:9px;letter-spacing:-.3px;color:var(--ink);}
header .mark::before{content:"";width:14px;height:14px;border-radius:50%;background:var(--gradient);}
header .sub{font-size:12px;color:var(--ink3);}
header .banner{margin-left:auto;display:flex;gap:7px;flex-wrap:wrap;}
.chip{font-size:11.5px;font-family:var(--sans);font-weight:500;padding:5px 11px;border-radius:999px;background:var(--card);border:1px solid var(--line);color:var(--ink2);display:inline-flex;align-items:center;gap:6px;box-shadow:var(--shadow);}
.chip::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--ink3);}
.chip.live::before{background:var(--ok-t);}
.chip.mock::before{background:var(--warn-t);}

/* layout */
.wrap{max-width:980px;margin:0 auto;padding:30px 26px 90px;}
.crumb{font-size:13px;color:var(--ink3);margin-bottom:14px;}
.crumb a{color:var(--pink);}
h1{font-family:var(--head);font-size:26px;margin-bottom:4px;font-weight:800;color:var(--ink);letter-spacing:-.4px;}
h2{font-family:var(--head);font-size:18px;margin:26px 0 12px;font-weight:800;color:var(--ink);}
.muted{color:var(--ink3);font-size:14px;}

/* cards */
.grid{display:grid;gap:11px;}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
@media(max-width:760px){.grid2{grid-template-columns:1fr;}}
.xbtn{border:1px solid var(--line2);background:var(--card);color:var(--ink3);width:26px;height:26px;padding:0;border-radius:8px;font-size:13px;line-height:1;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;}
.xbtn:hover{background:var(--bad-b);border-color:var(--bad-t);color:var(--bad-t);}
button.danger{border-color:var(--bad-b);color:var(--bad-t);}
button.danger:hover{background:var(--bad-b);border-color:var(--bad-t);}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 18px;box-shadow:var(--shadow);}
.card.click{cursor:pointer;transition:box-shadow .14s,border-color .14s;}
.card.click:hover{border-color:var(--line2);box-shadow:var(--shadow-lg);}
.row{display:flex;align-items:center;gap:12px;}
.spread{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;}
.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(96px,1fr));gap:12px;margin:16px 0;}
.metric{background:var(--card);border:1px solid var(--line);border-radius:14px;padding:13px;box-shadow:var(--shadow);}
.metric .k{font-size:11.5px;color:var(--ink3);font-weight:500;margin-bottom:6px;}
.metric .v{font-family:var(--head);font-size:22px;font-weight:800;color:var(--ink);line-height:1;}

/* pills */
.pill{font-size:11.5px;font-weight:600;padding:3px 10px;border-radius:999px;white-space:nowrap;}
.pill.missing{background:var(--bad-b);color:var(--bad-t);}
.pill.partial{background:var(--warn-b);color:var(--warn-t);}
.pill.planned,.pill.in_progress{background:var(--info-b);color:var(--info-t);}
.pill.published{background:var(--ok-b);color:var(--ok-t);}
.pill.High{background:var(--pink-soft);color:var(--pink);}
.pill.Medium{background:var(--warn-b);color:var(--warn-t);}
.pill.Low{background:var(--soft);color:var(--ink3);}
.tag{font-size:11px;font-weight:600;background:var(--soft);color:var(--ink2);padding:3px 9px;border-radius:999px;border:1px solid var(--line);}
.tag.type{background:rgba(118,51,151,.08);color:var(--purple);border-color:rgba(118,51,151,.18);}

/* forms */
.field{margin-bottom:12px;}
.field label{display:block;font-size:12px;color:var(--ink2);margin-bottom:5px;font-weight:500;}
.formrow{display:flex;gap:10px;}
.formrow .field{flex:1;}

/* progress */
.bar{height:8px;background:var(--soft);border-radius:999px;overflow:hidden;}
.bar > div{height:100%;background:var(--gradient);transition:width .3s;}

/* cluster brief */
.brief h3{font-family:var(--head);font-size:12px;color:var(--ink3);text-transform:uppercase;letter-spacing:.05em;margin:16px 0 6px;font-weight:700;}
.brief .struct{background:var(--soft);border-radius:12px;padding:12px 14px;}
.struct .h1{font-size:13px;font-weight:700;margin-bottom:6px;color:var(--ink);}
.struct .h2line{font-size:13px;color:var(--ink2);padding:3px 0;}
.struct .h2line::before{content:"H2";font-family:var(--mono);font-size:9px;color:var(--purple);background:var(--card);border:1px solid var(--line);padding:2px 5px;border-radius:5px;margin-right:7px;}
.gain{background:var(--teal-b);color:var(--ink);border:1px solid rgba(14,148,136,.22);border-radius:12px;padding:11px 14px;font-size:13.5px;}
.note{background:var(--purple-soft);border:1px solid rgba(118,51,151,.14);border-radius:12px;padding:11px 14px;font-size:13.5px;color:var(--ink);}
.chiprow{display:flex;flex-wrap:wrap;gap:7px;}
.entity{background:var(--info-b);color:var(--info-t);font-size:12px;font-weight:500;padding:4px 10px;border-radius:8px;text-decoration:none;display:inline-block;border:1px solid rgba(37,99,235,.18);}
a.entity:hover{filter:brightness(.97);}
.entity em{font-style:normal;opacity:.7;font-family:var(--mono);font-size:11px;}

/* grouped entity-coverage panel */
.cgroup{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card);margin-top:8px;}
.cgrow{display:flex;gap:14px;padding:11px 14px;border-bottom:1px solid var(--line);align-items:flex-start;}
.cgrow:last-child{border-bottom:none;}
.cglbl{min-width:140px;flex-shrink:0;font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;color:var(--ink3);padding-top:4px;}
.cglbl.miss{color:var(--bad-t);}
.cglbl.cov{color:var(--info-t);}
.cgrow .chiprow{margin-top:0;flex:1;}
.ent{font-size:12px;font-weight:500;padding:4px 10px;border-radius:8px;display:inline-flex;align-items:center;gap:4px;border:1px solid;}
.ent.have{background:var(--ok-b);color:var(--ok-t);border-color:rgba(20,160,107,.25);}
.ent.miss{background:var(--bad-b);color:var(--bad-t);border-color:rgba(220,40,65,.22);}
.ent.cover{background:var(--info-b);color:var(--info-t);border-color:rgba(37,99,235,.22);}
@media(max-width:640px){.cgrow{flex-direction:column;gap:6px;}.cglbl{padding-top:0;}}
.phrase{background:var(--soft);color:var(--ink2);font-size:12px;padding:4px 10px;border-radius:8px;border:1px solid var(--line);}
ul.tasks{list-style:none;}
ul.tasks li{font-size:13.5px;padding:4px 0;color:var(--ink);}
ul.tasks li::before{content:"☐";margin-right:8px;color:var(--ink3);}

/* finding */
.finding{border-left:3px solid var(--line2);padding:11px 14px;background:var(--card);border-radius:0 12px 12px 0;border:1px solid var(--line);}
.finding.high{border-left-color:var(--bad-t);}
.finding.med,.finding.warn{border-left-color:var(--warn-t);}
.finding.low{border-left-color:var(--info-t);}

/* map */
.mapbox{background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:10px;box-shadow:var(--shadow);}
.mapnode{cursor:pointer;transition:stroke-width .1s;}
.mapnode:hover{stroke:#fff;stroke-width:3;filter:drop-shadow(0 1px 3px rgba(15,14,20,.3));}
.maptip{position:absolute;left:0;top:0;transform:translate(-50%,calc(-100% - 13px));background:var(--card);border:1px solid var(--line2);border-radius:11px;padding:9px 12px;box-shadow:var(--shadow-lg);font-size:13px;pointer-events:none;opacity:0;transition:opacity .12s;z-index:6;min-width:170px;max-width:250px;}
.maptip.show{opacity:1;}
.maptip::after{content:"";position:absolute;left:50%;bottom:-6px;width:11px;height:11px;background:var(--card);border-right:1px solid var(--line2);border-bottom:1px solid var(--line2);transform:translateX(-50%) rotate(45deg);}
.layerhdr{font-family:var(--head);font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--ink3);margin:22px 0 9px;font-weight:700;}
.cannib{background:var(--purple-soft);border:1px solid rgba(118,51,151,.16);color:var(--ink);font-size:13.5px;line-height:1.6;}
.pillarcard{background:var(--gradient);color:#fff;border-radius:var(--r);padding:15px 17px;margin-top:6px;box-shadow:0 4px 16px rgba(234,37,125,.22);}
.pillarcard.click{cursor:pointer;transition:box-shadow .14s,transform .14s;}
.pillarcard.click:hover{box-shadow:0 6px 22px rgba(234,37,125,.3);transform:translateY(-1px);}
/* brief highlight when deep-linked from the Topical map */
.card.flash{animation:flashpulse 1.6s ease-out;}
@keyframes flashpulse{0%{box-shadow:0 0 0 3px var(--pink),0 4px 22px rgba(234,37,125,.25);border-color:var(--pink);}100%{box-shadow:var(--shadow);}}
.pillarcard .muted{color:rgba(255,255,255,.85);}
.pillarcard code{background:rgba(255,255,255,.18);color:#fff;padding:1px 6px;border-radius:4px;font-family:var(--mono);font-size:12px;}
.ptag{font-size:10px;font-family:var(--mono);letter-spacing:.12em;color:rgba(255,255,255,.8);margin-bottom:3px;}
.maptable{width:100%;border-collapse:collapse;background:var(--card);border:1px solid var(--line);border-radius:12px;overflow:hidden;font-size:13px;box-shadow:var(--shadow);}
.maptable th{text-align:left;font-size:11px;text-transform:uppercase;color:var(--ink3);font-weight:600;padding:8px 10px;background:var(--soft);}
.maptable td{padding:8px 10px;border-top:1px solid var(--line);color:var(--ink2);}
.maptable tr.click:hover td{background:var(--pink-faint);}
.maptable code{font-family:var(--mono);font-size:11.5px;color:var(--pink);}
.sdot{display:inline-block;width:9px;height:9px;border-radius:50%;background:var(--line2);vertical-align:0;}
.sdot.published{background:var(--ok-t);}
.sdot.partial{background:var(--warn-t);}
.sdot.planned,.sdot.in_progress{background:var(--info-t);}
.sdot.missing{background:var(--bad-t);}
code{font-family:var(--mono);font-size:11.5px;}
.tdrop{opacity:.5;}
.existcard{background:var(--warn-b);border:1px solid rgba(185,118,12,.3);color:#7a4f08;border-radius:12px;padding:11px 14px;margin-bottom:12px;font-size:13px;line-height:1.5;}
.existcard code{background:rgba(185,118,12,.12);padding:1px 6px;border-radius:4px;}
.existcard a{color:#7a4f08;}

/* badges + priority */
.badge{font-size:11px;font-weight:600;padding:3px 10px;border-radius:999px;background:var(--soft);color:var(--ink3);border:1px solid var(--line);white-space:nowrap;}
.badge.warn{background:var(--warn-b);color:var(--warn-t);border-color:rgba(185,118,12,.32);}
.pscore{font-family:var(--head);font-size:12px;font-weight:800;color:#fff;background:var(--gradient);border-radius:999px;padding:4px 11px;min-width:30px;text-align:center;}

/* content-brief key/value rows */
.briefbox{border:1px solid var(--line);border-radius:12px;padding:4px 14px;}
.brow{display:flex;gap:12px;padding:9px 0;border-bottom:1px dashed var(--line);font-size:13px;align-items:baseline;}
.brow:last-child{border-bottom:none;}
.bk{color:var(--ink3);min-width:130px;font-size:11px;text-transform:uppercase;letter-spacing:.04em;font-weight:600;flex-shrink:0;}
.bv{color:var(--ink);}
.faqlist{list-style:none;margin:8px 0 0;padding:0;}
.faqlist li{padding:7px 0 7px 22px;position:relative;font-size:13px;color:var(--ink);border-bottom:1px dashed var(--line);}
.faqlist li:last-child{border-bottom:none;}
.faqlist li::before{content:"?";position:absolute;left:0;top:7px;width:16px;height:16px;border-radius:50%;background:var(--info-b);color:var(--info-t);font-size:10px;font-weight:700;display:grid;place-items:center;}
.anchor{display:inline-block;background:var(--pink-faint);color:var(--pink);border:1px solid var(--pink-soft);border-radius:6px;padding:2px 8px;font-weight:600;font-size:12px;}

/* link tasks */
.ltask{display:flex;gap:10px;align-items:flex-start;padding:10px 12px;border:1px solid var(--line);border-radius:11px;margin-top:8px;font-size:13px;cursor:pointer;}
.ltask input{margin-top:2px;width:15px;height:15px;flex-shrink:0;cursor:pointer;accent-color:var(--ok-t);}
.ltask.done>div{opacity:.5;text-decoration:line-through;}
.ltype{font-size:10px;font-weight:600;padding:2px 8px;border-radius:999px;background:var(--info-b);color:var(--info-t);white-space:nowrap;}
.lnk{font-size:11px;font-weight:600;color:var(--pink);cursor:pointer;text-decoration:underline;margin-right:8px;}
.lnk:hover{color:var(--purple);}

/* modal */
.overlay{position:fixed;inset:0;background:rgba(15,14,20,.5);display:none;align-items:center;justify-content:center;padding:24px;z-index:60;}
.overlay.show{display:flex;}
.modal{background:var(--card);border:1px solid var(--line);border-radius:18px;max-width:660px;width:100%;max-height:85vh;overflow:auto;box-shadow:var(--shadow-lg);}
.mh{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--card);}
.mh h3{font-family:var(--head);font-size:17px;font-weight:800;margin:0;color:var(--ink);}
.mh p{margin:4px 0 0;font-size:12px;}
.x{cursor:pointer;border:none;background:var(--soft);color:var(--ink3);width:30px;height:30px;border-radius:9px;font-size:14px;flex-shrink:0;}
.x:hover{background:var(--line2);color:var(--ink);}
.mb{padding:16px 20px;}

/* data table (modals + competitor matrix) */
.dt{width:100%;border-collapse:collapse;font-size:13px;}
.dt th{text-align:left;color:var(--ink3);font-size:10.5px;text-transform:uppercase;letter-spacing:.05em;font-weight:600;padding:8px 10px;border-bottom:1px solid var(--line);}
.dt th.c{text-align:center;}
.dt td{padding:9px 10px;border-bottom:1px solid var(--line);color:var(--ink);}
.dt td.n{font-family:var(--mono);text-align:right;}
.dt td.c{text-align:center;font-weight:700;}
.dt td.cy{color:var(--ok-t);}
.dt td.cn{color:var(--line2);}
.dt tr:last-child td{border-bottom:none;}

/* pipeline progress strip */
.pipe{display:flex;align-items:flex-start;background:var(--card);border:1px solid var(--line);border-radius:var(--r);padding:16px 12px;overflow-x:auto;margin-bottom:14px;box-shadow:var(--shadow);}
.pstep{flex:1;min-width:80px;display:flex;flex-direction:column;align-items:center;text-align:center;position:relative;padding:0 3px;}
.pstep .ln{position:absolute;top:14px;left:50%;width:100%;height:2px;background:var(--line);z-index:0;}
.pstep:last-child .ln{display:none;}
.pstep.done .ln{background:var(--purple);}
.pstep .node{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;z-index:1;background:var(--soft);color:var(--ink3);border:2px solid var(--line);font-weight:700;font-size:12px;}
.pstep.done .node{background:var(--gradient);color:#fff;border:none;}
.pstep.active .node{background:#fff;color:var(--pink);border:2px solid var(--pink);box-shadow:0 0 0 4px var(--pink-faint);}
.pstep .nm{font-size:11px;font-weight:600;color:var(--ink2);margin-top:8px;line-height:1.25;}

/* misc */
.empty{text-align:center;color:var(--ink3);padding:40px 0;font-size:14px;}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--line2);border-top-color:var(--pink);border-radius:50%;animation:sp .7s linear infinite;vertical-align:-2px;}
@keyframes sp{to{transform:rotate(360deg);}}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:10px;font-size:13px;opacity:0;transition:opacity .2s;pointer-events:none;box-shadow:var(--shadow-lg);z-index:80;}
.toast.show{opacity:1;}
.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:18px 0;flex-wrap:wrap;}
.tabs button{border:none;border-bottom:2px solid transparent;border-radius:0;background:none;color:var(--ink3);padding:9px 14px;font-weight:600;margin-bottom:-1px;}
.tabs button:hover{background:none;color:var(--ink2);}
.tabs button.active{color:var(--pink);border-bottom-color:var(--pink);}

/* how-to (link audit export instructions) */
.howlbl{font-size:11px;text-transform:uppercase;letter-spacing:.05em;color:var(--ink3);font-weight:700;margin-bottom:10px;}
.howto{list-style:none;margin:0;padding:0;counter-reset:h;}
.howto li{counter-increment:h;position:relative;padding:6px 0 6px 30px;font-size:13.5px;color:var(--ink);}
.howto li::before{content:counter(h);position:absolute;left:0;top:5px;width:21px;height:21px;border-radius:50%;background:var(--gradient);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;}

/* finding URL list (cannibalization / competing pages) */
.urllist{list-style:none;margin:8px 0 0;padding:0;}
.urllist li{position:relative;padding:5px 0 5px 18px;border-bottom:1px dashed var(--line);}
.urllist li:last-child{border-bottom:none;}
.urllist li::before{content:"";position:absolute;left:2px;top:11px;width:6px;height:6px;border-radius:50%;background:var(--purple);}
.urllist a{font-family:var(--mono);font-size:12px;word-break:break-all;}
.urllist code{color:var(--pink);background:none;}

/* internal-link graph rows */
.lgcard{margin-bottom:11px;}
.lglink{display:flex;gap:11px;align-items:flex-start;padding:10px 0;border-top:1px dashed var(--line);font-size:13px;}
.lglink:first-of-type{border-top:1px solid var(--line);margin-top:6px;}
.lgdir{flex-shrink:0;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;font-size:12px;font-weight:700;margin-top:1px;}
.lgdir.down{background:var(--pink-soft);color:var(--pink);}
.lgdir.up{background:var(--teal-b);color:var(--teal-t);}
.lgdir.peer{background:var(--purple-soft);color:var(--purple);}
/* internal-link silo list inside a brief */
.silo{border:1px solid var(--line);border-radius:12px;overflow:hidden;background:var(--card);}
.silorow{display:flex;gap:11px;align-items:center;padding:10px 13px;border-top:1px solid var(--line);transition:background .12s;}
.silorow:first-child{border-top:none;}
.silorow:hover{background:var(--soft);}
.siloname{font-weight:600;color:var(--ink);font-size:13.5px;}
.silowhy{color:var(--ink3);font-size:11.5px;margin-top:2px;}
.silotag{flex-shrink:0;font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.03em;padding:3px 9px;border-radius:999px;}
.silotag.down{background:var(--pink-faint);color:var(--pink);}
.silotag.up{background:var(--teal-b);color:var(--teal-t);}
.silotag.peer{background:var(--purple-soft);color:var(--purple);}

/* cluster-board filter pills */
.cfilters{display:flex;gap:8px;flex-wrap:wrap;margin:2px 0 16px;}
.cfpill{background:var(--card);border:1px solid var(--line);border-radius:999px;padding:7px 15px;font-size:12.5px;font-weight:600;color:var(--ink2);cursor:pointer;display:inline-flex;align-items:center;gap:7px;transition:all .14s;}
.cfpill:hover{border-color:var(--line2);color:var(--ink);}
.cfpill.active{background:var(--ink);color:#fff;border-color:transparent;}
.cfpill .c{font-family:var(--mono);font-size:11px;opacity:.55;}
.cfpill.active .c{opacity:.8;}

/* cluster card dropdown chevron */
.cfpill .chev, .card .chev{}
.card .chev{display:inline-flex;align-items:center;justify-content:center;color:var(--ink3);width:22px;height:22px;flex-shrink:0;transition:transform .2s,color .2s;}
.card .chev svg{width:16px;height:16px;}
.card.click:hover .chev{color:var(--ink2);}
.card.open .chev{transform:rotate(180deg);color:var(--pink);}

/* topical map — labeled ring nodes (mockup design) */
.map-svg{display:block;width:100%;height:auto;max-height:600px;}
.mspoke{stroke:var(--line2);stroke-width:1.4;}
.map-node{cursor:pointer;}
.map-node:hover > circle:first-of-type{filter:brightness(.95);stroke-width:3.4;}
.map-node:hover .node-label{font-weight:700;}
.node-label{font-size:13px;fill:var(--ink);font-weight:500;paint-order:stroke;stroke:var(--card);stroke-width:3.5px;stroke-linejoin:round;}
.node-rank{font-family:var(--mono);font-weight:600;font-size:12.5px;}
.map-legend{display:flex;align-items:center;gap:20px;margin-top:16px;padding:12px 16px;background:var(--soft);border-radius:12px;flex-wrap:wrap;font-size:13px;color:var(--ink2);}
.map-legend .lgdot{width:12px;height:12px;border-radius:50%;display:inline-block;vertical-align:middle;margin-right:7px;border:2px solid;}
.map-legend .lgdot.pub{background:rgba(20,160,107,.18);border-color:var(--ok-t);}
.map-legend .lgdot.pip{background:rgba(213,138,14,.18);border-color:var(--warn-t);}
.map-legend .lgdot.miss{background:rgba(220,40,65,.16);border-color:var(--bad-t);}
.map-legend .lgdot.plan{background:rgba(37,99,235,.16);border-color:var(--info-t);}

/* horizontal-scroll wrapper for wide tables (maptable etc.) so they never clip */
.tscroll{overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;}

/* ---------- responsive: working pages (cluster · map · audit · modals) ---------- */
@media(max-width:680px){
  .formrow{flex-direction:column;gap:0;}
  .overlay{padding:12px;}
  .modal{max-height:92vh;border-radius:14px;}
  .mh,.mb{padding-left:16px;padding-right:16px;}
  .brow{flex-direction:column;gap:3px;}
  .bk{min-width:0;}
  .spread{flex-wrap:wrap;}
  .metrics{grid-template-columns:repeat(auto-fit,minmax(84px,1fr));}
  .map-legend{gap:10px 16px;}
}
