:root{
  --bg:#eef1f5; --panel:#ffffff; --ink:#16202e; --muted:#64748b; --line:#e2e8f0;
  --navy:#1f3864; --blue:#2e5496; --accent:#0e7490;
  --planned:#a9b6c7; --elaborated:#2e5496; --validated:#0891b2; --executed:#15803d;
  --passed:#15803d; --failed:#dc2626; --blocked:#d97706; --pending:#a9b6c7;
  --manual:#d97706; --semi:#2563eb; --automated:#15803d;
  --shadow:0 1px 2px rgba(15,23,42,.06),0 8px 24px -12px rgba(15,23,42,.18);
  --mono:ui-monospace,"Cascadia Code","SFMono-Regular",Consolas,"Liberation Mono",Menlo,monospace;
  --sans:"Segoe UI",system-ui,-apple-system,"Helvetica Neue",sans-serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{background:radial-gradient(1200px 400px at 85% -10%,rgba(46,84,150,.10),transparent 60%),var(--bg);
  color:var(--ink);font-family:var(--sans);font-size:14px;line-height:1.45;-webkit-font-smoothing:antialiased}
.wrap{max-width:1180px;margin:0 auto;padding:22px 20px 60px}
.micro{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600}
header.top{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:space-between;gap:14px;
  padding-bottom:14px;border-bottom:2px solid var(--navy);margin-bottom:18px}
.brand{display:flex;flex-direction:column;gap:3px}
.brand .k{color:var(--blue)}
.brand h1{margin:0;font-size:20px;font-weight:700;color:var(--navy);letter-spacing:-.01em}
.brand .sub{color:var(--muted);font-size:12.5px}
.toolbar{display:flex;gap:8px;flex-wrap:wrap}
.btn{appearance:none;border:1px solid var(--line);background:var(--panel);color:var(--ink);
  padding:8px 13px;border-radius:9px;font-size:12.5px;font-weight:600;cursor:pointer;
  display:inline-flex;align-items:center;gap:7px;box-shadow:var(--shadow);transition:.15s}
.btn:hover{border-color:var(--blue);color:var(--blue);transform:translateY(-1px)}
.btn.primary{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn.primary:hover{background:var(--blue);color:#fff}
.btn.ghost{box-shadow:none;background:transparent}
.dot{width:8px;height:8px;border-radius:50%;display:inline-block}
.tabs{display:flex;gap:4px;margin-bottom:18px;border-bottom:1px solid var(--line);flex-wrap:wrap}
.tab{appearance:none;border:0;background:transparent;padding:11px 16px;font-size:13.5px;font-weight:600;
  color:var(--muted);cursor:pointer;border-bottom:2.5px solid transparent;margin-bottom:-1px}
.tab:hover{color:var(--ink)}
.tab.active{color:var(--navy);border-bottom-color:var(--navy)}
.view{display:none}
.view.active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}
.kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:18px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:14px 15px;box-shadow:var(--shadow);position:relative;overflow:hidden}
.kpi::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--blue)}
.kpi .v{font-family:var(--mono);font-size:25px;font-weight:700;color:var(--navy);line-height:1}
.kpi .v small{font-size:14px;color:var(--muted);font-weight:600}
.kpi .l{margin-top:6px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px;box-shadow:var(--shadow);margin-bottom:16px}
.panel h2{margin:0 0 3px;font-size:15px;color:var(--navy)}
.panel .hint{color:var(--muted);font-size:12px;margin-bottom:14px}
.legend{display:flex;flex-wrap:wrap;gap:14px;margin:2px 0 14px}
.legend span{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted);font-weight:600}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:820px){.grid2{grid-template-columns:1fr}}
svg{display:block;width:100%;height:auto;overflow:visible}
.barlabel{font-family:var(--mono);font-size:11px;fill:var(--muted)}
.barval{font-family:var(--mono);font-size:10.5px;fill:#fff;font-weight:600}
.axis{font-family:var(--mono);font-size:10px;fill:var(--muted)}
.filters{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-bottom:14px}
.filters select,.filters input{border:1px solid var(--line);border-radius:8px;padding:7px 10px;font-size:12.5px;font-family:var(--sans);background:#fff;color:var(--ink)}
.filters input{min-width:200px}
.tablewrap{overflow:auto;border:1px solid var(--line);border-radius:12px}
table{border-collapse:collapse;width:100%;font-size:12.5px;min-width:960px}
thead th{position:sticky;top:0;background:var(--navy);color:#fff;text-align:left;padding:9px 11px;font-size:11px;letter-spacing:.05em;text-transform:uppercase;font-weight:600;z-index:1}
tbody td{padding:8px 11px;border-bottom:1px solid var(--line);vertical-align:top}
tbody tr:hover{background:#f6f9fc}
td.id{font-family:var(--mono);font-size:11.5px;white-space:nowrap;color:var(--navy);font-weight:600}
td.lt{font-family:var(--mono);text-align:center}
.tag{display:inline-block;padding:2px 8px;border-radius:999px;font-size:10.5px;font-weight:700;letter-spacing:.02em;white-space:nowrap}
.sel{border:1px solid var(--line);border-radius:7px;padding:5px 7px;font-size:12px;background:#fff;font-family:var(--sans);width:100%}
.sel.state{border-left:4px solid var(--planned)}
.note-in{border:1px solid var(--line);border-radius:7px;padding:5px 7px;font-size:12px;width:100%;font-family:var(--sans)}
.count-pill{font-family:var(--mono);font-size:12px;color:var(--muted)}
.footnote{color:var(--muted);font-size:11.5px;margin-top:10px}
.savehint{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:10px;padding:9px 12px;font-size:12px;margin-bottom:16px;display:flex;gap:9px;align-items:center}
.errbox{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:10px;padding:14px 16px;font-size:13px}
