/* Faithful replica of the onegroup-design tokens + patterns for prototype review. */
:root{
  --bg:#FAFAFA;--surface:#FFFFFF;--ink:#111111;--ink-soft:#3F3F3F;--ash:#737373;--ash-soft:#A3A3A3;
  --hairline:#E5E5E5;--whisper:#F4F4F4;--spark:#E8A93A;--spark-soft:rgba(232,169,58,.10);--spark-border:rgba(232,169,58,.22);
  --live:#15803D;--live-tint:rgba(21,128,61,.08);--claret:#B91C1C;--claret-tint:rgba(185,28,28,.06);
  --font-body:'Switzer',-apple-system,system-ui,sans-serif;
  --font-wordmark:'Manrope',sans-serif;--font-mono:'JetBrains Mono',ui-monospace,Menlo,monospace;
  --r-sm:6px;--r-md:10px;--r-lg:14px;--r-pill:999px;--ease:cubic-bezier(.2,.7,.2,1);
}
*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);font-family:var(--font-body);font-size:13px;line-height:1.5;letter-spacing:-.005em;-webkit-font-smoothing:antialiased;font-feature-settings:'ss01'}
.mono{font-family:var(--font-mono)}
.lbl{font-family:var(--font-mono);font-size:9px;text-transform:uppercase;letter-spacing:.10em;color:var(--ash);font-weight:600}

/* shell */
.shell{min-height:100vh}
.topbar{height:52px;display:flex;align-items:center;gap:22px;padding:0 24px;border-bottom:1px solid var(--hairline);background:var(--surface);position:sticky;top:0;z-index:5}
.wordmark{font-family:var(--font-wordmark);font-weight:700;font-size:14px;letter-spacing:-.01em;display:flex;align-items:center;gap:7px}
.wordmark .dot{width:6px;height:6px;border-radius:var(--r-pill);background:var(--spark)}
.nav{display:flex;gap:2px;margin-left:8px}
.nav a{font-size:12.5px;color:var(--ash);text-decoration:none;padding:6px 11px;border-radius:var(--r-sm);font-weight:500}
.nav a:hover{background:var(--whisper);color:var(--ink-soft)}
.nav a.on{background:var(--ink);color:#fff}
.topbar .spacer{flex:1}
.avatar{width:26px;height:26px;border-radius:var(--r-pill);background:var(--whisper);border:1px solid var(--hairline);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:10px;color:var(--ash)}

.wrap{max-width:1120px;margin:0 auto;padding:22px 24px 60px}

/* page header */
.phead{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:18px}
.phead h1{font-size:19px;font-weight:600;margin:0;letter-spacing:-.02em}
.phead .sub{color:var(--ash);font-size:12.5px;margin-top:3px}
.live{display:inline-flex;align-items:center;gap:7px;font-family:var(--font-mono);font-size:10px;color:var(--live);background:var(--live-tint);border:1px solid rgba(21,128,61,.18);padding:5px 10px;border-radius:var(--r-pill);font-weight:600}
.live .pulse{width:7px;height:7px;border-radius:var(--r-pill);background:var(--live);box-shadow:0 0 0 0 rgba(21,128,61,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(21,128,61,.45)}70%{box-shadow:0 0 0 6px rgba(21,128,61,0)}100%{box-shadow:0 0 0 0 rgba(21,128,61,0)}}

/* kpi strip */
.kpis{display:grid;grid-template-columns:repeat(6,1fr);gap:10px;margin-bottom:26px}
.kpi{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:14px 14px 13px}
.kpi .v{font-size:27px;font-weight:550;letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums}
.kpi .l{margin-top:9px}
.kpi.alert{background:var(--claret-tint);border-color:rgba(185,28,28,.18)}
.kpi.alert .v{color:var(--claret)}
.kpi.good .v{color:var(--live)}
.kpi.rate .v{color:var(--ink)}

/* section header */
.sec{display:flex;align-items:center;gap:9px;margin:24px 0 11px}
.sec .ct{font-family:var(--font-mono);font-size:9px;color:var(--ash-soft);font-weight:600;background:var(--whisper);border-radius:var(--r-pill);padding:2px 7px}
.sec .line{flex:1;height:1px;background:var(--hairline)}

/* cards / rows */
.card{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);overflow:hidden}
.row{display:grid;align-items:center;gap:14px;padding:13px 16px;border-bottom:1px solid var(--hairline);cursor:pointer;transition:background .12s var(--ease)}
.row:last-child{border-bottom:none}
.row:hover{background:var(--whisper)}
.att{grid-template-columns:108px 1.4fr 1.6fr 70px 18px}
.att.esc{box-shadow:inset 3px 0 0 var(--claret)}
.att.fail{box-shadow:inset 3px 0 0 var(--claret)}
.att.over{box-shadow:inset 3px 0 0 var(--spark)}
.nm{font-weight:550;font-size:13px}
.sub2{color:var(--ash);font-size:12px}
.miss{color:var(--ink-soft);font-size:12.5px}
.miss b{color:var(--claret);font-weight:550}
.tm{font-family:var(--font-mono);font-size:11px;color:var(--ash);text-align:right;font-variant-numeric:tabular-nums}
.chev{color:var(--ash-soft);font-size:16px;text-align:center}

/* status tag */
.tag{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-mono);font-size:9px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;padding:4px 9px;border-radius:var(--r-pill);white-space:nowrap}
.tag.neg{color:var(--claret);background:var(--claret-tint);border:1px solid rgba(185,28,28,.18)}
.tag.warn{color:#92600c;background:var(--spark-soft);border:1px solid var(--spark-border)}
.tag.pos{color:var(--live);background:var(--live-tint);border:1px solid rgba(21,128,61,.18)}
.tag.neu{color:var(--ash);background:var(--whisper);border:1px solid var(--hairline)}
.tag .d{width:5px;height:5px;border-radius:var(--r-pill);background:currentColor}
.tag.prog .d{background:var(--spark);animation:pulse2 1.6s infinite}
@keyframes pulse2{0%,100%{opacity:1}50%{opacity:.35}}

/* progress (in-progress) row */
.prog-row{grid-template-columns:108px 1.4fr 1.6fr 70px 18px}

/* by-project */
.proj{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.pcard{background:var(--surface);border:1px solid var(--hairline);border-radius:var(--r-md);padding:13px 15px}
.pcard .top{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:9px}
.pcard .pn{font-weight:550;font-size:13px}
.pcard .pct{font-family:var(--font-mono);font-size:12px;font-weight:600}
.bar{height:6px;background:var(--whisper);border-radius:var(--r-pill);overflow:hidden}
.bar > i{display:block;height:100%;border-radius:var(--r-pill)}
.pcard .meta{margin-top:8px;color:var(--ash);font-size:11.5px;display:flex;gap:14px}
.pcard .meta .mono{color:var(--ash)}

/* guards */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:14px}
.search{flex:1;max-width:380px;position:relative}
.search input{width:100%;height:36px;border:1px solid var(--hairline);border-radius:var(--r-sm);background:var(--surface);padding:0 12px 0 34px;font-family:var(--font-body);font-size:13px;color:var(--ink);outline:none}
.search input:focus{border-color:var(--ink)}
.search .ic{position:absolute;left:11px;top:9px;color:var(--ash-soft)}
.btn{height:36px;border-radius:var(--r-sm);padding:0 15px;font-size:12.5px;font-weight:600;border:1px solid var(--hairline);background:var(--surface);color:var(--ink);cursor:pointer;display:inline-flex;align-items:center;gap:7px}
.btn:hover{background:var(--whisper)}
.btn.primary{background:var(--ink);color:#fff;border-color:var(--ink)}
.btn.primary:hover{opacity:.9}

.gtable{grid-template-columns:1.5fr 1.4fr 90px 200px}
.ghead{display:grid;gap:14px;padding:9px 16px;border-bottom:1px solid var(--hairline);background:var(--whisper)}
.grow{display:grid;gap:14px;align-items:center;padding:12px 16px;border-bottom:1px solid var(--hairline)}
.grow:last-child{border-bottom:none}
.grow:hover{background:var(--whisper)}
.editable{display:inline-flex;align-items:center;gap:8px;cursor:text;border-radius:var(--r-sm);padding:3px 7px;margin:-3px -7px;border:1px solid transparent}
.editable:hover{background:#fff;border-color:var(--hairline)}
.editable .pen{opacity:0;color:var(--ash-soft);font-size:11px}
.editable:hover .pen{opacity:1}
.editing{border:1px solid var(--ink)!important;background:#fff;border-radius:var(--r-sm);padding:5px 9px;display:flex;align-items:center;gap:8px}
.editing input{border:none;outline:none;font-family:var(--font-body);font-size:13px;font-weight:550;width:150px;color:var(--ink)}
.editing .save{font-family:var(--font-mono);font-size:9px;font-weight:700;color:var(--live);text-transform:uppercase;letter-spacing:.08em}
.ph{font-family:var(--font-mono);font-size:11.5px;color:var(--ink-soft)}
.post{font-size:12.5px}
.post .none{color:var(--ash-soft)}
.gact{display:flex;gap:7px;justify-content:flex-end}
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%);background:var(--ink);color:#fff;font-size:12.5px;font-weight:500;padding:10px 16px;border-radius:var(--r-md);display:inline-flex;align-items:center;gap:9px}
.toast .ok{color:#4ade80;font-family:var(--font-mono);font-size:11px}
.hint{color:var(--ash);font-size:12px;margin:2px 0 16px}

/* ---- mobile (≤640px) ---- */
@media (max-width:640px){
  .topbar{gap:10px;padding:0 14px;overflow-x:auto}
  .nav{margin-left:0}
  .nav a{padding:6px 9px;font-size:12px}
  .wrap{padding:16px 14px 60px}
  .phead{flex-direction:column;align-items:flex-start;gap:10px}
  .kpis{grid-template-columns:repeat(2,1fr);gap:8px}
  .kpi .v{font-size:23px}
  .att,.prog-row{grid-template-columns:1fr auto;grid-template-areas:"tag time" "name name" "miss miss";gap:6px 10px;row-gap:7px}
  .att > .tag,.prog-row > .tag{grid-area:tag;justify-self:start}
  .att > .tm,.prog-row > .tm{grid-area:time}
  .att > div:nth-child(2),.prog-row > div:nth-child(2){grid-area:name}
  .att > .miss,.prog-row > .miss{grid-area:miss}
  .att > .chev,.prog-row > .chev{display:none}
  .proj{grid-template-columns:1fr}
  .gtable{grid-template-columns:1fr}
  .ghead{display:none}
  .grow{grid-template-columns:1fr;gap:8px}
  .gact{just-content:flex-start;justify-self:start}
  .toolbar{flex-wrap:wrap}.search{max-width:none;flex:1 1 100%}
}
