:root{
  --bg:#0c0c0e;/* deep black */
  --panel:#121316;
  --text:#e6e6e6;
  --muted:#9aa0a6;
  --accent:#ff4f00; /* design.png */
  --neon:#c7ff01;   /* design.png */
  --card:#121317;
  --line:#23252b;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Ubuntu,Cantarell,Noto Sans,Arial,Helvetica,sans-serif;
}
.topbar{
  height:56px; display:flex; align-items:center; justify-content:space-between;
  padding:0 16px; border-bottom:1px solid var(--line); background:#0a0b0d;
}
.top-actions{display:flex; gap:8px}
.action-btn{background:#0f1013; color:var(--text); border:1px solid var(--line); border-radius:8px; padding:6px 10px; font-family:"JetBrains Mono",monospace; font-size:12px; cursor:pointer}
.action-btn:hover{filter:brightness(1.1)}
/* topbar nav removed */
.brand{display:flex; align-items:center; gap:10px}
.brand .logo{width:28px; height:28px; filter:invert(1)}
.brand .logo-full{height:26px; width:auto; display:block}
.brand-name{display:none}
.nav{display:flex; gap:16px}
.nav-link{color:var(--muted); text-decoration:none; font-family:"JetBrains Mono",monospace}
.nav-link:hover{color:var(--text)}
.app{padding:18px 18px 0 18px; height:calc(100vh - 56px)}

/* generic */
.grid{display:grid; gap:12px}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
.grid.cols-4{grid-template-columns:repeat(4,1fr)}
.panel{background:var(--panel); border:1px solid var(--line); border-radius:10px; padding:14px}
.panel-header{display:flex; align-items:center; justify-content:space-between; margin-bottom:8px}
.title{font-family:"JetBrains Mono", monospace; font-size:18px; letter-spacing:0.5px}
.subtitle{color:var(--muted); font-size:12px}
.tag{border:1px solid var(--line); color:var(--muted); border-radius:999px; padding:3px 8px; font-size:11px}
.tag.accent{border-color:var(--accent); color:#fff}

/* cards */
.mine-card{background:var(--card); border:1px solid var(--line); border-radius:12px; padding:12px; cursor:pointer; transition:transform .12s ease, border-color .12s ease}
.mine-card:hover{transform:translateY(-2px); border-color:#30323a}
.mine-name{font-weight:700}
.mine-meta{display:flex; gap:8px; margin:6px 0}
.kpis{display:flex; gap:12px; margin-top:8px}
.kpi{background:#0f1013; padding:8px; border-radius:8px; border:1px solid var(--line)}
.kpi .label{color:var(--muted); font-size:11px}
.kpi .value{font-family:"JetBrains Mono",monospace; color:var(--neon); font-weight:700}

/* map */
#map{height:360px; border-radius:12px; overflow:hidden; border:1px solid var(--line)}

/* layout for detail pages */
.columns{display:grid; grid-template-columns:320px 1fr; gap:14px}
.aside{display:flex; flex-direction:column; gap:12px}
.hero{font-size:22px; font-family:"JetBrains Mono", monospace}
.pill{border:1px solid var(--line); border-radius:999px; padding:4px 10px; font-size:12px; margin-right:6px}

/* chart container */
.chart{height:320px}

/* sql + llm */
.split{display:grid; grid-template-columns:1.3fr 1fr; gap:12px}
.split > * { min-width: 0; }
.triple{display:grid; grid-template-columns:1fr 1fr 1fr; gap:12px}
.triple > * { min-width: 0; }
.sql-box textarea{width:100%; height:160px; background:#0f1013; color:var(--text); border:1px solid var(--line); border-radius:8px; padding:10px; font-family:"JetBrains Mono",monospace; font-size:12px}
.sql-box{min-width:0}
#sql-result{overflow:auto}
.sql-actions{display:flex; justify-content:flex-end; margin-top:8px}
.prompt{flex:1 1 auto; height:36px; background:#0f1013; color:var(--text); border:1px solid var(--line); border-radius:8px; padding:8px 10px; font-family:"Inter",sans-serif;}

/* Mines layout + sidebar nav */
.layout-mines{display:grid; grid-template-columns:260px 1fr; gap:12px}
.sidebar{position:sticky; top:60px; height:calc(100vh - 80px); overflow:auto}
.tree{list-style:none; padding-left:0; margin:0}
.tree.coherent{display:flex; flex-direction:column; gap:6px}
.tree.coherent .node{margin:0; border-radius:10px}
.tree.coherent .node > .row{display:flex; align-items:center; gap:8px; cursor:pointer; padding:8px 10px; border-radius:8px; transition:background .12s ease, border-color .12s ease; border:1px solid transparent; font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.2px; color:#cfd3da}
.tree.coherent .node > .row:hover{background:#101216; border-color:#1f2229}
.tree.coherent .node.open > .row{background:#101216; border-color:#1f2229}
.tree.coherent .node.placeholder > .row{cursor:default; opacity:.45; border-style:dashed}
.tree.coherent .expander{width:14px; height:14px; border:1px solid #3a3d44; border-radius:3px; display:inline-flex; align-items:center; justify-content:center; font-size:10px; color:#848a96; background:#0c0d10}
.tree.coherent .node.open > .row .expander{color:#fff; border-color:#5a606d; background:#14161b}
.tree.coherent .node .label{font-family:"JetBrains Mono",monospace; font-size:12px}
.tree.coherent .children{display:none; margin:6px 0 0 14px; padding-left:10px; border-left:1px dashed #2a2c33}
.tree.coherent .node.open > .children{display:block}
.tree.coherent .child-item{padding:6px 12px; border-radius:6px; cursor:pointer; font-family:"JetBrains Mono",monospace; font-size:11px; color:#b9bec9; margin:2px 0; transition:background .12s ease, border-color .12s ease}
.tree.coherent .child-item:hover{background:#101216; color:#fff}
.tree.coherent .child-item.current{background:rgba(199,255,1,0.08); border:1px solid rgba(199,255,1,0.6); color:#fff}
.tree.coherent .child-item + .child-item{margin-top:2px}
.tree.coherent .child-item[data-key^="journey-"]{font-size:10px; letter-spacing:.4px; text-transform:uppercase; color:#7b7f86}
.tree.coherent .child-item[data-key^="journey-"]:hover{color:#cfd3da}
.draggable{cursor:grab}
.draggable:active{cursor:grabbing}
.btn{background:#101216; color:#fff; border:1px solid var(--line); border-radius:8px; padding:8px 10px; cursor:pointer}
.btn.primary{border-color:var(--accent); color:#fff}
.btn:hover{filter:brightness(1.1)}
.llm-answers{background:#0f1013; border:1px solid var(--line); border-radius:8px; padding:10px; min-height:160px}
.chat-box{display:flex; flex-direction:column; min-height:260px}
.chat-messages{flex:1 1 auto; overflow:auto; background:#0f1013; border:1px solid var(--line); border-radius:8px; padding:10px}
.chat-input{display:flex; gap:8px; margin-top:8px}
.msg{margin:6px 0; display:flex}
.msg .bubble{max-width:90%; padding:8px 10px; border-radius:10px; border:1px solid var(--line)}
.msg.user{justify-content:flex-end}
.msg.user .bubble{background:#14161b}
.msg.assistant .bubble{background:#0f1013}
/* Assistant typing indicator */
.msg.assistant.typing .bubble{display:flex; gap:6px; align-items:center}
.typing-dot{width:6px; height:6px; border-radius:50%; background:var(--muted); opacity:.5; animation:typingBlink 1s infinite ease-in-out}
.typing-dot:nth-child(2){animation-delay:.2s}
.typing-dot:nth-child(3){animation-delay:.4s}
@keyframes typingBlink{0%{opacity:.2; transform:translateY(0)}50%{opacity:1; transform:translateY(-2px)}100%{opacity:.2; transform:translateY(0)}}

/* Alerts list */
.alerts{display:flex; flex-direction:column; gap:6px; max-height:260px; overflow:auto}
.alert-item{display:flex; align-items:center; gap:8px; padding:6px 8px; border:1px solid var(--line); border-radius:8px; background:#0f1013; font-family:"JetBrains Mono",monospace; font-size:12px}
.alert-item .code{border:1px solid var(--line); border-radius:999px; padding:2px 6px}
.alert-item.clickable{cursor:pointer; transition:background .12s ease, border-color .12s ease;}
.alert-item.clickable:hover{border-color:#343741; background:#111317;}
.alert-item .inline-action{margin-left:auto; font-size:11px; color:var(--neon); letter-spacing:.3px; display:flex; align-items:center; gap:4px;}
.alert-item .inline-action::after{content:'▸'; font-size:11px;}

/* Modal for rule management */
.modal-backdrop{position:fixed; inset:0; background:rgba(0,0,0,0.5); display:flex; align-items:center; justify-content:center; z-index:1000}
.modal{background:#0f1013; border:1px solid var(--line); border-radius:12px; width:760px; max-width:98vw; padding:12px}
.modal .header{display:flex; justify-content:space-between; align-items:center; margin-bottom:8px}
.modal .title{font-family:"JetBrains Mono",monospace}
.rule-row{display:grid; grid-template-columns:70px 1fr 70px 100px 1fr 80px; gap:6px; align-items:center; padding:6px 0; border-bottom:1px solid #1b1d22}
.rule-row:last-child{border-bottom:none}
.rule-row input, .rule-row select{background:#0b0d10; color:var(--text); border:1px solid var(--line); border-radius:6px; padding:6px 8px; font-family:"JetBrains Mono",monospace; font-size:12px}
.modal .actions{display:flex; gap:8px; justify-content:flex-end; margin-top:10px}
.link{color:#9aa0a6; cursor:pointer}
.link:hover{color:#fff}

.automation-dialog{width:900px; max-width:98vw; padding:16px;}
.automation-dialog .header{display:flex; justify-content:space-between; align-items:flex-start; gap:12px; margin-bottom:14px;}
.automation-dialog .header .title{font-size:16px;}
.automation-metrics{display:grid; grid-template-columns:repeat(auto-fit,minmax(190px,1fr)); gap:10px; margin-bottom:16px;}
.automation-metric{background:#101216; border:1px solid #1f2229; border-radius:10px; padding:10px; display:flex; flex-direction:column; gap:4px;}
.automation-metric .label{font-family:"JetBrains Mono",monospace; font-size:11px; color:#9aa0a6;}
.automation-metric .value{font-family:"JetBrains Mono",monospace; font-size:16px; color:#fff;}
.automation-metric .hint{font-size:10px;}
.automation-steps{display:flex; flex-direction:column; gap:10px;}
.automation-steps .step{display:flex; gap:10px; align-items:flex-start; background:#0f1013; border:1px solid #1f2229; border-radius:10px; padding:10px;}
.automation-steps .step-tag{font-family:"JetBrains Mono",monospace; font-size:11px; color:var(--neon); border:1px solid rgba(199,255,1,0.5); border-radius:999px; padding:2px 8px;}
.automation-steps .step-title{font-family:"JetBrains Mono",monospace; font-size:12px; color:#e6e6e6;}
.automation-steps .step-copy{font-size:11px; line-height:1.4;}
.automation-chart{height:220px; margin-top:12px; border:1px solid #1f2229; border-radius:10px; padding:6px;}

.muted{color:var(--muted)}
.warning{color:var(--accent)}
.ok{color:var(--neon)}

/* helper */
.ghost{opacity:.4; pointer-events:none}
.layout{display:grid; grid-template-columns:260px 1fr; gap:12px; height:100%}
#content{min-height:0; height:100%; overflow:auto}
.shift-root{display:grid; grid-template-rows:auto auto minmax(0,1fr); gap:12px; height:100%; min-height:0}
.triple{height:100%; min-height:0}
.panel.fill{height:100%; display:flex; flex-direction:column; min-height:0}
.panel.fill .chat-box{flex:1; min-height:0}
.panel.fill #sql-result{flex:1; min-height:0}
.panel.fill .alerts{flex:1; max-height:none; min-height:0}
.sidenav{position:sticky; top:60px; height:calc(100vh - 80px); overflow:auto}
.current > .row .label{color:var(--neon)}

/* Copilot Dock (sticky footer) */
.copilot-dock{position:fixed; left:0; right:0; bottom:0; z-index:999; background:var(--panel); border-top:1px solid var(--line); box-shadow:0 -6px 20px rgba(0,0,0,0.35)}
.copilot-dock.with-sidenav{left:290px; border-left:1px solid var(--line)}
.copilot-dock .copilot-bar{display:flex; align-items:center; justify-content:space-between; padding:6px 10px; background:#0a0b0d; border-bottom:1px solid var(--line); cursor:pointer; user-select:none;}
.header-bar{display:flex; align-items:center; justify-content:space-between; padding:8px 12px; background:#0a0b0d; border:1px solid var(--line); border-radius:10px; margin-bottom:8px}
/* Edge variant: spans full panel width (flush left/right, top) */
.header-bar.edge{margin: -14px -14px 8px -14px; border-radius:10px 10px 0 0; border-left:none; border-right:none; border-top:none; border-bottom:1px solid var(--line)}
.header-bar .title{font-family:"JetBrains Mono",monospace; font-size:14px; letter-spacing:.4px; color:#cfd3da}
.copilot-dock .copilot-bar .title{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.4px; color:#cfd3da}
.copilot-dock .copilot-bar .right{display:flex; align-items:center; gap:8px; font-family:"JetBrains Mono",monospace; font-size:11px; color:#9aa0a6;}
.copilot-dock .copilot-bar .chevron{font-size:10px; color:#cfd3da;}
.copilot-dock .copilot-content{display:none; padding:10px; gap:12px; height:40vh; overflow:auto}
.copilot-dock.open .copilot-content{display:grid}
.copilot-dock.collapsed .copilot-bar{border-bottom:none}

/* Mine page chips/tabs/mini-bars/tables */
.chips{display:flex; flex-wrap:wrap; gap:8px}
.pill.link{cursor:pointer}
.tabs{display:flex; gap:14px}
.tab{font-family:"JetBrains Mono",monospace; font-size:12px; color:#9aa0a6; padding:6px 10px; border-radius:8px; cursor:pointer}
.tab.active{color:#fff; background:#101216; border:1px solid var(--line)}
.qgrid{display:block}
.qrow{display:grid; grid-template-columns:100px 120px 1fr; align-items:center; gap:8px; padding:2px 0}
.qval{font-family:"JetBrains Mono",monospace; color:#cfd3da; font-size:12px}
.qbar{height:6px; background:#111317; border:1px solid #1f2229; border-radius:999px; overflow:hidden}
.qbar .fill{display:block; height:100%}
.table{display:block}
.thead, .tr{display:grid; grid-template-columns:120px 1fr 120px 100px 110px 90px 90px 100px; gap:8px; padding:6px 8px}
.thead{border-bottom:1px solid var(--line); color:#cfd3da; font-family:"JetBrains Mono",monospace; font-size:12px}
.tbody .tr{border-bottom:1px solid #1b1d22}

/* Journey (Export Chain) */
.journey-root{display:flex; flex-direction:column; gap:12px; padding-bottom:160px;}
.journey-header .journey-kpis{display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:10px; margin-top:16px;}
.journey-kpi{background:#0f1013; border:1px solid var(--line); border-radius:10px; padding:12px;}
.journey-kpi .label{color:var(--muted); font-size:11px;}
.journey-kpi .value{font-family:"JetBrains Mono",monospace; font-size:20px; color:#fff; margin-top:4px;}
.journey-prompts{margin-top:12px; display:flex; flex-wrap:wrap; gap:8px;}
.journey-timeline{display:flex; align-items:center; gap:8px; font-family:"JetBrains Mono",monospace; font-size:12px;}
.journey-timeline label{color:#9aa0a6;}
.journey-timeline input[type=range]{width:180px; accent-color:var(--accent);}
.journey-slider-value{color:#cfd3da;}
.journey-map-panel .journey-map-wrap{display:flex; gap:14px; min-height:320px;}
.journey-map-canvas{flex:2; min-height:360px; border-radius:10px; border:1px solid var(--line); overflow:hidden;}
.journey-trackers{flex:1.2; display:flex; flex-direction:column; gap:10px;}
.tracker{background:#0f1013; border:1px solid var(--line); border-radius:10px; padding:12px;}
.tracker-title{font-family:"JetBrains Mono",monospace; font-size:12px; letter-spacing:.3px; margin-bottom:8px; color:#cfd3da;}
.tracker-body{display:flex; flex-direction:column; gap:10px;}
.journey-card{background:#101216; border:1px solid #1f2229; border-radius:10px; padding:10px; font-size:12px; transition:border-color .12s ease;}
.journey-card:hover{border-color:#30323a;}
.journey-card-title{font-family:"JetBrains Mono",monospace; font-size:12px; color:#cfd3da; margin-bottom:4px;}
.journey-card-line{color:#9aa0a6; font-size:11px; line-height:1.35;}
.journey-row{font-size:12px;}
.journey-row-top{display:flex; justify-content:space-between; gap:10px; align-items:center;}
.journey-row-top .label{font-family:"JetBrains Mono",monospace; color:#cfd3da;}
.journey-row-top .value{color:#9aa0a6; font-size:11px;}
.journey-row .progress{height:6px; background:#0a0b0d; border:1px solid #1f2229; border-radius:999px; overflow:hidden; margin-top:6px; position:relative;}
.journey-row .progress .fill{position:absolute; left:0; top:0; bottom:0; width:0%; background:linear-gradient(90deg,#4db6ff,#c7ff01);}
.journey-row-meta{display:flex; justify-content:space-between; font-size:10px; margin-top:6px; color:#6f747d; font-family:"JetBrains Mono",monospace;}
.journey-terminal{display:flex; flex-direction:column; gap:12px;}
.journey-termetrics{display:flex; gap:18px; font-family:"JetBrains Mono",monospace; font-size:12px; color:#cfd3da;}
.journey-termetrics .label{color:#9aa0a6; font-size:11px;}
.journey-terminal-grid{display:grid; grid-template-columns:1.3fr 1fr; gap:12px;}
.journey-terminal-cv{display:grid; gap:12px;}
.cv-frame{background:#0f1013; border:1px solid var(--line); border-radius:10px; padding:10px;}
.cv-title{font-family:"JetBrains Mono",monospace; font-size:12px; color:#cfd3da; margin-bottom:8px;}
.cv-image{position:relative; border-radius:8px; overflow:hidden; border:1px solid #1f2229;}
.cv-image img,.cv-image video{display:block; width:100%; height:auto;}
.cv-image video{object-fit:cover; background:#000;}
.cv-overlays{position:absolute; inset:0; pointer-events:none;}
.cv-overlay{position:absolute; border:2px solid var(--accent); border-radius:6px; padding:2px; color:#fff; font-size:10px; font-family:"JetBrains Mono",monospace; background:rgba(12,12,14,0.35);}
.cv-overlay span{position:absolute; left:0; bottom:-16px; padding:2px 4px; background:rgba(12,12,14,0.9); border-radius:4px; border:1px solid rgba(255,255,255,0.2); white-space:nowrap;}
.journey-terminal-meta{display:flex; flex-direction:column; gap:12px;}
.journey-vessel-card{background:#0f1013; border:1px solid var(--line); border-radius:10px; padding:12px; font-size:12px;}
.journey-vessel-header{display:flex; justify-content:space-between; color:#cfd3da; font-family:"JetBrains Mono",monospace; margin-bottom:6px;}
.journey-vessel-body{display:flex; flex-direction:column; gap:6px;}
.journey-vessel-body .progress{height:6px; background:#101216; border:1px solid #1f2229; border-radius:999px; overflow:hidden; position:relative;}
.journey-vessel-body .progress .fill{position:absolute; left:0; top:0; bottom:0; background:linear-gradient(90deg,#ff4f00,#ffd166); width:0%;}
.journey-vessel-values{display:flex; justify-content:space-between; font-family:"JetBrains Mono",monospace; color:#9aa0a6; font-size:11px;}
.journey-vessel-footer{font-size:10px; color:#6f747d; margin-top:4px;}
.journey-vessel-blurbs{display:flex; gap:12px; font-family:"JetBrains Mono",monospace; font-size:12px; color:#cfd3da;}
.journey-reconcile-top{display:grid; grid-template-columns:repeat(auto-fit,minmax(150px,1fr)); gap:10px; margin-bottom:12px; font-size:12px;}
.journey-reconcile-top .label{color:#9aa0a6; font-size:11px;}
.journey-event{display:grid; grid-template-columns:80px 1fr 70px; gap:8px; padding:6px 8px; border:1px solid #1f2229; border-radius:8px; font-size:11px; background:#101216;}
.journey-event + .journey-event{margin-top:6px;}
.journey-event .time{font-family:"JetBrains Mono",monospace; color:#cfd3da;}
.journey-event .severity{font-family:"JetBrains Mono",monospace; text-align:right;}
.journey-event.event-high{border-color:#ff4f00;}
.journey-event.event-medium{border-color:#ffd166;}
.journey-event.event-low{border-color:#4db6ff;}
.journey-dock-anchor .panel{background:rgba(15,16,19,0.75); border-style:dashed;}
.journey-dock-anchor .panel .title{font-size:14px;}
.child-item.small{font-size:11px; color:#7b7f86; padding-left:18px;}
.child-item.small:hover{background:#101216; color:#cfd3da;}
.cv-stats{margin-top:10px; border:1px solid #1f2229; border-radius:8px; padding:10px; background:rgba(16,17,21,0.75); display:flex; flex-direction:column; gap:8px;}
.cv-stats-meta{font-family:"JetBrains Mono",monospace; font-size:10px; color:#7b7f86;}
.cv-stats-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(140px,1fr)); gap:8px;}
.cv-stat{background:#101216; border:1px solid #1f2229; border-radius:6px; padding:8px; display:flex; flex-direction:column; gap:4px;}
.cv-stat .label{font-family:"JetBrains Mono",monospace; font-size:11px; color:#9aa0a6;}
.cv-stat .value{font-family:"JetBrains Mono",monospace; font-size:14px; color:#e6e6e6;}
.cv-stat .delta{font-family:"JetBrains Mono",monospace; font-size:10px; color:#7b7f86;}
.cv-stat[data-severity="high"]{border-color:#ff4f00;}
.cv-stat[data-severity="medium"]{border-color:#ffd166;}
.cv-stat[data-severity="low"]{border-color:#4db6ff;}
.cv-stats-note{font-size:10px; color:#7b7f86; font-family:"JetBrains Mono",monospace;}

@media (max-width:1200px){
  .journey-map-panel .journey-map-wrap{flex-direction:column;}
  .journey-trackers{flex-direction:row; flex-wrap:wrap;}
  .journey-trackers .tracker{flex:1 1 240px;}
  .journey-terminal-grid{grid-template-columns:1fr;}
  .journey-termetrics{flex-wrap:wrap;}
  .journey-header .journey-kpis{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));}
}
