/* ==========================================================================
   Cadence components — extracted from the reference screens. All colors use
   theme.css variables so light/dark "just work".
   ========================================================================== */

/* layout shell */
.wrap{max-width:1080px;margin:0 auto;padding:20px 24px 48px}
.wrap-wide{max-width:1180px}

/* top bar */
.topbar{display:flex;align-items:center;justify-content:space-between;background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-lg);padding:12px 18px;margin-bottom:20px}
.brand{display:flex;align-items:center;gap:10px}
.logo{width:30px;height:30px;border-radius:8px;background:var(--brand-600);display:flex;align-items:center;justify-content:center;color:#fff;font-size:18px;flex:none}
.brand-name{font-size:15px;font-weight:600;letter-spacing:-.01em}
.brand-sub{font-size:11px;color:var(--ink-400)}
.top-right{display:flex;align-items:center;gap:10px}
.pill{font-size:12px;color:var(--brand-700);background:var(--brand-50);padding:5px 11px;border-radius:var(--r-md);display:inline-flex;align-items:center;gap:5px}
.avatar{width:30px;height:30px;border-radius:50%;background:var(--surface-2);border:.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:500;color:var(--ink-600)}
.icon-btn{width:32px;height:32px;border:.5px solid var(--border);background:var(--surface);border-radius:var(--r-md);color:var(--ink-600);cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center}
.icon-btn:hover{background:var(--surface-2)}

/* primary nav */
.nav{display:flex;gap:4px;flex-wrap:wrap;margin-bottom:18px}
.nav a{font-size:13px;color:var(--ink-600);padding:6px 12px;border-radius:var(--r-md)}
.nav a:hover{background:var(--surface)}
.nav a.active{background:var(--brand-600);color:#fff;font-weight:500}

/* page head */
.page-head{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:16px;gap:12px;flex-wrap:wrap}
.page-title{font-size:22px;font-weight:600;letter-spacing:-.01em}
.page-meta{font-size:13px;color:var(--ink-600);margin-top:2px}
.seg{display:flex;border:.5px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface)}
.seg a,.seg button{border:none;background:transparent;font:inherit;font-size:12px;color:var(--ink-600);padding:7px 13px;cursor:pointer}
.seg a.active,.seg button.active{background:var(--brand-600);color:#fff;font-weight:500}

/* metric cards */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px}
.metric{background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-lg);padding:16px}
.metric .label{font-size:12px;color:var(--ink-600)}
.metric .val{font-size:26px;font-weight:600;margin-top:6px}
.metric .val small{font-size:14px;color:var(--ink-400);font-weight:400}
.delta{font-size:11px;margin-top:4px;display:inline-flex;align-items:center;gap:3px}
.up{color:var(--positive)} .down{color:var(--risk)} .flat{color:var(--ink-400)}

/* grid + cards */
.cols{display:grid;grid-template-columns:1.4fr 1fr;gap:16px;margin-bottom:16px}
.cols-even{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.card{background:var(--surface);border:.5px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;margin-bottom:16px}
.card h2{font-size:15px;font-weight:500}
.card .csub{font-size:12px;color:var(--ink-400);margin-top:1px;margin-bottom:14px}
.legend{display:flex;gap:16px;font-size:12px;color:var(--ink-600);margin-bottom:10px}
.legend span{display:flex;align-items:center;gap:5px}
.sw{width:11px;height:11px;border-radius:3px;display:inline-block}
.swl{width:14px;height:3px;border-radius:2px;display:inline-block}
.chart-box{position:relative;height:200px}

/* scorecard */
.score-head{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.score-big{font-size:30px;font-weight:600;color:var(--brand-600);line-height:1}
.bar-row{margin-bottom:12px}
.bar-label{display:flex;justify-content:space-between;font-size:12px;margin-bottom:5px}
.bar-label span:last-child{color:var(--ink-600)}
.track{height:6px;background:var(--surface-2);border-radius:3px;overflow:hidden}
.fill{height:6px;border-radius:3px}

/* coaching */
.section-label{font-size:12px;color:var(--ink-400);margin:0 0 10px 2px}
.coach-card{display:flex;gap:12px;background:var(--surface);border:.5px solid var(--border);border-radius:0 var(--r-md) var(--r-md) 0;padding:13px 15px;margin-bottom:10px}
.coach-card i.lead{font-size:18px;margin-top:1px}
.coach-title{font-size:13px;font-weight:500;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.coach-body{font-size:12px;color:var(--ink-600);margin-top:4px;line-height:1.55}
.tag{font-size:10px;padding:1px 8px;border-radius:10px;font-weight:500}
.tag-risk{color:var(--risk);background:var(--risk-50)}
.tag-coach{color:var(--coach-text);background:var(--coach-50)}
.tag-pos{color:var(--positive);background:var(--positive-50)}
.tag-info{color:var(--info);background:var(--brand-50)}

/* tables */
table{width:100%;border-collapse:collapse;font-size:13px}
th{text-align:left;font-size:11px;font-weight:500;color:var(--ink-400);padding:6px 8px;border-bottom:.5px solid var(--border)}
td{padding:9px 8px;border-bottom:.5px solid var(--border)}
tr:last-child td{border-bottom:none}
.rep{display:flex;align-items:center;gap:9px}
.rep .av{width:26px;height:26px;border-radius:50%;background:var(--brand-50);color:var(--brand-800);font-size:10px;font-weight:600;display:flex;align-items:center;justify-content:center;flex:none}
.score-chip{font-weight:600;font-size:13px}
.right{text-align:right}
.muted{color:var(--ink-600)}
.flag{font-size:10px;color:var(--risk);background:var(--risk-50);padding:1px 7px;border-radius:9px;margin-left:4px}
.listen{font-size:12px;color:var(--brand-600);white-space:nowrap}

/* status pills */
.status{font-size:10px;padding:1px 8px;border-radius:10px;font-weight:500;display:inline-block}
.status-complete{color:var(--positive);background:var(--positive-50)}
.status-processing{color:var(--info);background:var(--brand-50)}
.status-failed{color:var(--risk);background:var(--risk-50)}
.status-queued{color:var(--coach-text);background:var(--coach-50)}
.status-received{color:var(--ink-600);background:var(--surface-2)}

/* forms */
.field{margin-bottom:14px}
.field label{display:block;font-size:12px;font-weight:500;color:var(--ink-600);margin-bottom:5px}
.input,.select,textarea.input{width:100%;font:inherit;font-size:14px;color:var(--ink-900);background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);padding:9px 11px}
.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--brand-600);box-shadow:0 0 0 3px var(--brand-50)}
.help{font-size:11px;color:var(--ink-400);margin-top:4px}
.err{font-size:11px;color:var(--risk);margin-top:4px}

/* buttons */
.btn{font:inherit;font-size:13px;font-weight:500;padding:9px 16px;border-radius:var(--r-md);cursor:pointer;border:1px solid transparent;display:inline-flex;align-items:center;gap:6px}
.btn-primary{background:var(--brand-600);color:#fff}
.btn-primary:hover{background:var(--brand-700)}
.btn-secondary{background:transparent;border-color:var(--border);color:var(--ink-600)}
.btn-secondary:hover{background:var(--surface)}
.btn-danger{background:var(--risk);color:#fff}
.btn-sm{padding:5px 10px;font-size:12px}

/* flash */
.flash{padding:11px 15px;border-radius:var(--r-md);font-size:13px;margin-bottom:16px;border:.5px solid}
.flash-success{background:var(--positive-50);border-color:var(--positive);color:var(--positive)}
.flash-error{background:var(--risk-50);border-color:var(--risk);color:var(--risk)}

/* misc */
.mono{font-family:var(--mono);font-size:13px}
.kv{display:grid;grid-template-columns:160px 1fr;gap:8px 16px;font-size:13px}
.kv dt{color:var(--ink-600)}
.empty{text-align:center;color:var(--ink-400);font-size:13px;padding:32px}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.spacer{height:8px}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}

@media(max-width:820px){
  .metrics{grid-template-columns:repeat(2,1fr)}
  .cols,.cols-even,.grid-2,.grid-3{grid-template-columns:1fr}
  .kv{grid-template-columns:1fr}
}
