/* Dashboard, page-specific (premium). Design system in system.css */

/* top bar */
.dtopbar { position:sticky; top:0; z-index:30; background:rgba(255,253,244,0.86); backdrop-filter:blur(8px); border-bottom:1.5px solid var(--ink); }
.dtopbar-inner { display:flex; align-items:center; gap:var(--s4); padding:14px var(--s6); }
.dtopbar .brand { flex:0 0 auto; display:flex; }
.dscan { flex:1 1 300px; min-width:0; max-width:380px; }
.dengine { display:flex; align-items:center; gap:9px; flex:0 1 auto; min-width:0; overflow:hidden; white-space:nowrap; }
.dengine .mono { font-size:13px; color:var(--text); } .dengine .sep { color:var(--text-faint); }
.dengine .scanning { color:var(--green-soft); display:inline-flex; align-items:center; gap:7px; }
.livedot { width:7px; height:7px; border-radius:7px; background:var(--green-soft); box-shadow:0 0 8px var(--green-soft); flex:0 0 auto; display:inline-block; }
.dspace { flex:1; }
.duser { display:flex; align-items:center; gap:10px; flex:0 0 auto; }
.davatar { width:38px; height:38px; border-radius:10px; flex:0 0 auto; background:linear-gradient(135deg,#3a5168,#2c3e50); display:inline-flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-size:13px; color:#fff; font-weight:600; }
.dmeta { line-height:1.3; white-space:nowrap; } .dmeta .nm { font-size:13.5px; color:var(--text-bright); } .dmeta .pl { font-size:11px; color:var(--text-dim); }

/* terminal */
.dterm { display:flex; gap:var(--s6); align-items:flex-start; padding:var(--s8) 0 var(--s6); }
.dterm-logo { flex:0 0 auto; padding:12px; border-radius:14px; background:var(--surface-1); border:1px solid var(--line-2); }
.term-lines { font-family:var(--font-mono); font-size:15px; line-height:2.1; padding-top:4px; margin:0; white-space:pre-wrap; }
.term-lines .k { color:var(--text-dim); } .term-lines .v { color:var(--text-bright); } .term-lines .g { color:var(--green-soft); }
.cursor { display:inline-block; width:9px; height:1.05em; background:var(--green-soft); vertical-align:-2px; animation:blink 1.1s steps(1) infinite; }

/* grid */
.dgrid { display:grid; grid-template-columns:232px minmax(0,1.6fr) 300px 340px; gap:var(--s6); align-items:start; border-top:1px solid var(--line-2); padding-top:var(--s8); padding-bottom:var(--s6); }

/* ── Full-width scorecard band (pulled out of the cramped Audit column) ── */
.scoreband { border-top:1px solid var(--line-2); margin-top:var(--s2); padding-top:var(--s8); padding-bottom:var(--s12); }
.scoreband-row { display:flex; gap:var(--s8); align-items:flex-start; flex-wrap:wrap; }
.scoreband-row > #verdict { flex:0 0 300px; }
.sb-scores { flex:1 1 460px; min-width:0; }
.sb-scores .rings { display:grid; grid-template-columns:repeat(5,minmax(0,1fr)); gap:var(--s5); }
@media (max-width:760px){ .sb-scores .rings { grid-template-columns:repeat(2,1fr); } .scoreband-row > #verdict { flex:1 1 100%; } }
.dcol { display:flex; flex-direction:column; gap:var(--s5); min-width:0; }
.panel-head { display:flex; align-items:center; justify-content:space-between; }
.panel-h { display:flex; align-items:center; gap:9px; margin:0; font-size:16px; color:var(--text-bright); font-family:var(--font-display); font-weight:600; white-space:nowrap; }
.panel-h .pi { font-family:var(--font-mono); color:#0891b2; font-size:14px; }
.dtabs { display:flex; gap:18px; }
.dtab { font-family:var(--font-mono); font-size:13px; cursor:pointer; padding-bottom:5px; color:var(--text-faint); border-bottom:2px solid transparent; }
.dtab.active { color:var(--text-bright); border-bottom-color:var(--green-soft); }

/* site */
.sitecard { display:flex; flex-direction:column; gap:14px; }
.site-card-head { display:flex; align-items:center; gap:9px; font-size:16px; color:var(--text-bright); font-weight:600; white-space:nowrap; }
.site-card-head .sdot { width:9px; height:9px; border-radius:9px; background:#0891b2; flex:0 0 auto; }
.site-card-head .edit { margin-left:auto; color:var(--text-faint); font-family:var(--font-mono); font-size:13px; cursor:pointer; }
.sitetags { display:flex; gap:8px; flex-wrap:wrap; } .sitetags .tag { cursor:pointer; }
.site-desc { font-size:14px; color:var(--text-dim); margin:0; line-height:1.65; }
.targets { display:flex; flex-direction:column; gap:2px; }
.trow { display:flex; align-items:center; justify-content:space-between; padding:11px 12px; cursor:pointer; }
.trow > span { display:flex; align-items:center; gap:11px; font-size:14.5px; color:var(--text); white-space:nowrap; }
.trow .ti { font-family:var(--font-mono); color:var(--text-faint); font-size:13px; }
.trow.add > span { color:var(--text-dim); }
.trow .st { width:8px; height:8px; border-radius:8px; }
.trow .st.green { background:var(--green-soft); box-shadow:0 0 7px var(--green-soft); }
.trow .st.amber { background:var(--amber-soft); box-shadow:0 0 7px var(--amber-soft); }
.trow .tnum { font-family:var(--font-mono); font-size:12px; color:var(--text-dim); white-space:nowrap; }
.trow .tnum.on { color:var(--green-soft); }
.trow .tnum.off { color:var(--text-faint); }

/* audit */
.lastscan { display:flex; flex-direction:column; gap:4px; }
.lastscan .ls-h { display:flex; align-items:center; gap:9px; font-size:15px; color:var(--text-bright); font-weight:600; white-space:nowrap; }
.lastscan .ls-sub { font-size:14px; color:var(--text-dim); }
.grid2 { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.grid2 > * { min-width:0; }
.ctr { justify-content:center; padding:13px; } .sm2 { font-size:12px; }
.connect-h { display:flex; justify-content:space-between; margin-top:8px; } .connect-h .x { cursor:pointer; color:var(--text-faint); }
.connect { padding:var(--s5); display:flex; flex-direction:column; gap:14px; min-width:0; }
.connect .ch { display:flex; align-items:center; gap:11px; min-width:0; }
.connect .ch > div { min-width:0; }
.connect .cic { width:34px; height:34px; border-radius:9px; flex:0 0 auto; }
.connect .cic.green { background:rgba(16,185,129,0.16); border:1px solid rgba(52,211,153,0.3); }
.connect .cic.violet { background:rgba(8,145,178,0.14); border:1px solid rgba(0,179,214,0.3); }
.icontile.cyan { background:rgba(8,145,178,0.16); color:#0e7490; }
.connect .cn { font-size:14px; color:var(--text-bright); font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.connect .cs { font-size:12.5px; color:var(--text-dim); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.connect .locked { height:38px; border-radius:8px; display:flex; align-items:center; justify-content:center; border:1px solid var(--line-2);
  background:repeating-linear-gradient(135deg,rgba(44,62,80,0.06) 0 6px,transparent 6px 12px); }
.connect .locked .mono { font-size:10px; letter-spacing:0.16em; color:var(--text-faint); }
.scores-head { display:flex; align-items:baseline; gap:10px; margin-top:8px; margin-bottom:16px; flex-wrap:wrap; }
.scores-head .sh-title { font-family:var(--font-display); font-size:15px; color:var(--text-bright); letter-spacing:0.06em; font-weight:700; }
.scores-head .dim { font-size:12px; color:var(--text-dim); }
.dim { color:var(--text-dim); }
/* verdict (Foundation vs Authority) */
#verdict { margin-bottom:18px; }
.vgrid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.vcell { text-align:center; padding:14px 8px; border:1px solid var(--line-2); border-radius:11px; background:var(--surface-2); }
.vn { font-family:var(--font-display); font-weight:700; font-size:34px; line-height:1; }
.vl { font-size:13px; color:var(--text-bright); font-weight:600; margin-top:6px; }
.vs { font-family:var(--font-mono); font-size:10.5px; color:var(--text-faint); margin-top:2px; }
.vline { font-size:13.5px; color:var(--text); line-height:1.6; margin:12px 0 0; }
.vfacts { font-size:11px; color:var(--text-faint); margin-top:8px; letter-spacing:0.03em; }

.rings { display:flex; justify-content:space-between; gap:8px; flex-wrap:wrap; }
.ring { display:inline-flex; flex-direction:column; align-items:center; gap:9px; }
.ring .glabel { font-family:var(--font-mono); font-size:11.5px; letter-spacing:0.04em; color:var(--text-dim); }
.citestrip { display:flex; flex-wrap:wrap; gap:9px; }

/* agents */
.agents { display:flex; flex-direction:column; gap:12px; }
.agent { border-radius:var(--radius); }
.agent-top { padding:16px var(--s5); display:flex; align-items:center; justify-content:space-between; cursor:pointer; gap:10px; }
.agent-top .lft { display:flex; align-items:center; gap:13px; min-width:0; }
.agent-ic { width:38px; height:38px; border-radius:10px; flex:0 0 auto; display:inline-flex; align-items:center; justify-content:center; font-family:var(--font-mono); font-size:14px; }
.agent-name { font-size:14.5px; color:var(--text-bright); font-weight:600; white-space:nowrap; }
.agent-status { font-family:var(--font-mono); font-size:12px; margin-top:2px; }
.agent-status .count { color:var(--amber-soft); }
.agent-chev { color:var(--text-faint); transition:transform .25s; }
.agent.open .agent-chev { transform:rotate(180deg); }
.agent-detail { max-height:0; overflow:hidden; opacity:0; transition:max-height .32s cubic-bezier(.2,.7,.2,1),opacity .25s,padding .25s; padding:0 var(--s5); }
.agent.open .agent-detail { max-height:320px; opacity:1; padding:0 var(--s5) 16px; }
.iss-line { display:block; color:var(--text-dim); font-size:12.5px; line-height:1.5; margin-bottom:9px; } .iss-line b { color:var(--text); }
.agent .run { background:var(--surface-3); border:1px solid var(--line-strong); color:var(--text-bright); font-family:var(--font-mono); font-size:12px; padding:9px 14px; border-radius:9px; cursor:pointer; }
.agent .run:hover { border-color:#0891b2; background:rgba(8,145,178,0.12); }

/* talk */
.upgrade { display:flex; align-items:center; gap:14px; }
.up-txt { flex:1; } .up-h { font-size:14.5px; color:var(--text-bright); font-weight:600; } .up-s { font-size:12.5px; color:var(--text-dim); }
.up-btn { background:var(--ink); color:var(--paper2); border-color:var(--ink); font-weight:700; }
.chatcard { padding:var(--s6); }
.chatbody { display:flex; flex-direction:column; gap:16px; }
.msg { line-height:1.65; font-size:14px; }
.msg.user { align-self:flex-end; background:#2c3e50; color:#fff; padding:10px 14px; border-radius:12px 12px 4px 12px; max-width:82%; }
.msg.agent { align-self:flex-start; max-width:92%; }
.msg.agent .offtag { color:var(--text-faint); font-size:10px; margin-left:7px; letter-spacing:0.06em; }
.cbgreet { margin:0 0 8px; font-size:14.5px; color:var(--text-bright); }
.qchips { display:flex; flex-wrap:wrap; gap:8px; margin-top:14px; }
.qchip { background:var(--surface-2); border:1px solid var(--line-2); color:var(--text); font-family:var(--font-mono); font-size:11.5px; padding:8px 12px; border-radius:99px; cursor:pointer; }
.qchip:hover { border-color:#0891b2; background:rgba(8,145,178,0.12); color:var(--text-bright); }
.msg.agent .who { display:flex; align-items:center; gap:9px; margin-bottom:6px; }
.msg.agent .who .pixel { font-size:11px; color:#0891b2; letter-spacing:0.06em; }
.msg h4 { color:var(--text-bright); font-size:14px; font-weight:600; margin:14px 0 12px; }
.checklist { list-style:none; padding:0; margin:0; display:flex; flex-direction:column; gap:11px; }
.checklist li { display:flex; align-items:center; gap:11px; font-size:14px; color:var(--text); }
.checklist .cb { width:17px; height:17px; border-radius:5px; border:1.5px solid var(--line-strong); flex:0 0 auto; }
.chatinput { padding:12px 14px; display:flex; align-items:center; gap:10px; }
.chatinput input { flex:1; background:transparent; border:none; outline:none; color:var(--text-bright); font-size:13.5px; }
.chatinput .chatsend { width:30px; height:30px; border-radius:8px; background:var(--green); border:none; color:#04130D; cursor:pointer; flex:0 0 auto; }

/* modal */
.modal-overlay { position:fixed; inset:0; background:rgba(44,62,80,0.45); backdrop-filter:blur(4px); display:grid; place-items:center; z-index:50; padding:20px; }
.modal { background:var(--surface-1); border:1px solid var(--line-strong); border-radius:16px; padding:28px; max-width:560px; width:100%; max-height:86vh; overflow-y:auto; }
.modal h3 { color:var(--text-bright); font-size:18px; margin:0 0 6px; display:flex; align-items:center; gap:10px; font-family:var(--font-display); }
.modal .sub { color:var(--text-dim); font-size:13px; margin-bottom:18px; }
.modal code, .modal .codebox { display:block; background:var(--bg); border:1px solid var(--line-2); border-radius:9px; padding:14px; font-family:var(--font-mono); font-size:12px; color:var(--green-soft); word-break:break-all; white-space:pre-wrap; max-height:280px; overflow-y:auto; }
.modal .row { display:flex; gap:10px; margin-top:14px; }
.modal .spin { width:16px; height:16px; }
.modal .copybtn { background:var(--green); color:#04130D; border:none; font-family:var(--font-mono); font-weight:700; font-size:13px; padding:10px 16px; border-radius:8px; cursor:pointer; }
.modal .closebtn { background:var(--surface-2); border:1px solid var(--line-2); color:var(--text-bright); font-family:var(--font-mono); font-size:13px; padding:10px 16px; border-radius:8px; cursor:pointer; margin-left:auto; }
.cite-result { display:flex; align-items:center; gap:12px; padding:12px 0; border-bottom:1px solid var(--line-2); }
.cite-result:last-child { border:none; } .cite-result .q { flex:1; font-size:13.5px; color:var(--text); } .cite-result .verdict { font-family:var(--font-mono); font-size:12px; font-weight:700; }

@media (max-width:1300px){ .dgrid { grid-template-columns:1fr 1fr; } }
@media (max-width:760px){ .dgrid { grid-template-columns:1fr; } .dengine,.duser .dmeta { display:none; } }
