/* Close Coach — "field coaching tool" design system
   Light workspace, dark anchor bar, cobalt accent, functional status colors.
   Mobile-first; desktop enhancements at >=860px. */

:root{
  --paper:#f5f5f1;
  --surface:#ffffff;
  --surface-2:#fafaf8;
  --ink:#15171c;
  --ink-2:#3a3f48;
  --muted:#697079;
  --line:#e6e7e2;
  --line-2:#d8dad3;
  --accent:#2347e6;
  --accent-deep:#16235c;
  --accent-tint:#eef1ff;
  --win:#16a34a;  --win-tint:#e8f6ec;
  --warn:#d97706; --warn-tint:#fbf1e3;
  --loss:#dc2626; --loss-tint:#fbeaea;
  --panel:#16181d;   /* dark anchor */
  --panel-2:#1e2128;
  --radius:14px;
  --shadow:0 1px 2px rgba(20,22,28,.04), 0 8px 24px rgba(20,22,28,.06);
  --display:'Archivo', system-ui, sans-serif;
  --body:'Inter', system-ui, -apple-system, sans-serif;
  --mono:'JetBrains Mono', ui-monospace, monospace;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  background:var(--paper);
  color:var(--ink);
  font-family:var(--body);
  font-size:15px;line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
h1,h2,h3,h4{font-family:var(--display);margin:0;letter-spacing:-.01em;font-weight:800}
a{color:var(--accent);text-decoration:none}
button{font-family:var(--body);cursor:pointer}

/* ---------------- top bar (dark anchor) ---------------- */
.topnav{
  background:var(--panel);color:#fff;
  display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:12px 16px;position:sticky;top:0;z-index:30;
}
.brand{display:flex;align-items:center;gap:11px;min-width:0}
.logo{
  width:38px;height:38px;border-radius:11px;flex:none;
  display:grid;place-items:center;background:var(--accent);color:#fff;
  font-family:var(--display);font-weight:800;font-size:16px;letter-spacing:.02em;
}
.brand h1{font-size:17px;color:#fff;line-height:1.1}
.brand .tag{font-size:11px;color:#9aa1ad;font-family:var(--mono);letter-spacing:.02em;margin-top:1px}
.nav{display:flex;align-items:center;gap:6px}
.nav a{
  color:#c7ccd4;font-size:13px;font-weight:600;padding:8px 11px;border-radius:9px;
}
.nav a:hover{color:#fff;background:rgba(255,255,255,.08)}
.nav a.active{color:#fff;background:rgba(255,255,255,.12)}

/* ---------------- funnel rail (signature) ---------------- */
.rail{
  background:var(--surface);border-bottom:1px solid var(--line);
  position:sticky;top:62px;z-index:20;
  display:flex;gap:0;align-items:stretch;overflow-x:auto;
  padding:10px 12px;scrollbar-width:none;
}
.rail::-webkit-scrollbar{display:none}
.stage{
  flex:1 0 auto;min-width:74px;display:flex;flex-direction:column;align-items:center;
  gap:6px;position:relative;padding:2px 4px;color:var(--muted);
}
.stage:not(:last-child)::after{
  content:"";position:absolute;top:15px;left:calc(50% + 18px);right:calc(-50% + 18px);
  height:2px;background:var(--line-2);
}
.stage.done:not(:last-child)::after{background:var(--accent)}
.dotMark{
  width:30px;height:30px;border-radius:50%;display:grid;place-items:center;
  background:var(--surface);border:2px solid var(--line-2);
  font-family:var(--mono);font-size:12px;font-weight:700;color:var(--muted);
  position:relative;z-index:1;transition:.18s;
}
.stage .lbl{font-size:11px;font-weight:700;letter-spacing:.02em;font-family:var(--display)}
.stage .gateTag{font-size:8px;font-family:var(--mono);color:var(--accent);letter-spacing:.08em;margin-top:-3px}
.stage.active .dotMark{border-color:var(--accent);color:var(--accent);box-shadow:0 0 0 4px var(--accent-tint)}
.stage.active{color:var(--ink)}
.stage.done .dotMark{background:var(--accent);border-color:var(--accent);color:#fff}
.stage.done{color:var(--ink-2)}
.stage.win .dotMark{background:var(--win);border-color:var(--win);color:#fff}
.stage.win{color:var(--win)}
.stage.loss .dotMark{background:var(--loss);border-color:var(--loss);color:#fff}
.stage.loss{color:var(--loss)}

/* ---------------- app layout ---------------- */
.app{max-width:1180px;margin:0 auto;padding:14px;display:flex;flex-direction:column;gap:14px}
.workspace{display:flex;flex-direction:column;gap:14px}

/* setup / controls card */
.controls{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
.controls > summary{
  list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;font-family:var(--display);font-weight:700;font-size:14px;
}
.controls > summary::-webkit-details-marker{display:none}
.controls > summary .chev{transition:.2s;color:var(--muted)}
.controls[open] > summary .chev{transform:rotate(180deg)}
.controls .body{padding:0 16px 16px;display:flex;flex-direction:column;gap:12px}
.field{display:flex;flex-direction:column;gap:6px}
.field label{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
select,input,textarea{
  width:100%;font-family:var(--body);font-size:15px;color:var(--ink);
  background:var(--surface);border:1.5px solid var(--line-2);border-radius:11px;
  padding:11px 12px;outline:none;transition:.15s;
}
select:focus,input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-tint)}
.fieldRow{display:grid;grid-template-columns:1fr 1fr;gap:10px}

/* buttons */
.btns{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.btn{
  border:1.5px solid var(--line-2);background:var(--surface);color:var(--ink);
  border-radius:11px;padding:11px 12px;font-weight:700;font-size:14px;
  display:flex;align-items:center;justify-content:center;gap:6px;transition:.15s;
}
.btn:hover{border-color:var(--ink-2)}
.btn:active{transform:translateY(1px)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;grid-column:1/-1}
.btn.primary:hover{background:#1a3ad1}
.btn.danger{color:var(--loss);border-color:var(--loss-tint);background:var(--loss-tint)}

.tip{font-size:13px;color:var(--ink-2);line-height:1.5;background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:12px}
.tip b{color:var(--ink)}
.tip .muted{color:var(--muted);font-size:12px;display:block;margin-top:6px}

/* chat panel */
.session{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden;min-height:60vh}
.sessionHead{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:12px 16px;border-bottom:1px solid var(--line)}
.sessionHead h2{font-size:14px}
.sessionHead #status{font-size:12px;color:var(--muted);margin-top:2px}
.pill{font-family:var(--mono);font-size:11px;font-weight:700;color:var(--muted);border:1px solid var(--line-2);border-radius:999px;padding:5px 10px;white-space:nowrap}
.pill[data-live="1"]{color:var(--accent);border-color:var(--accent);background:var(--accent-tint)}

.chat{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.chatEmpty{margin:auto;text-align:center;color:var(--muted);max-width:280px}
.chatEmpty h3{font-size:15px;color:var(--ink-2);margin-bottom:4px}
.msg{max-width:86%;padding:11px 13px;border-radius:14px;line-height:1.45;font-size:14px;border:1px solid transparent;white-space:pre-wrap}
.msg .name{font-family:var(--mono);font-size:9px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:5px;opacity:.7}
.msg.customer{align-self:flex-start;background:var(--surface-2);border-color:var(--line);border-left:3px solid var(--ink-2)}
.msg.trainee{align-self:flex-end;background:var(--accent);color:#fff}
.msg.trainee .name{color:#cdd6ff}
.msg.coach{align-self:flex-start;background:var(--warn-tint);border-color:#f0dcbb;color:#7a4d09}
.msg.coach .name{color:#b06a0a}
.msg.system{align-self:center;background:transparent;color:var(--muted);font-size:12.5px;text-align:center;max-width:100%;padding:4px}
.msg.system .name{display:none}

/* composer */
.composer{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line);background:var(--surface);position:sticky;bottom:0}
.composer input{flex:1}
.composer .send{flex:none;width:54px;background:var(--accent);border-color:var(--accent);color:#fff}

/* action strip (mobile-reachable) */
.actions{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:0 12px 12px}
.actions .btn{font-size:13px;padding:10px}

/* ---------------- scorecard ---------------- */
.scorecard{align-self:stretch;max-width:100%;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;display:flex;flex-direction:column;gap:14px;box-shadow:var(--shadow)}
.scoreHead{display:flex;align-items:center;justify-content:space-between}
.scoreHead .name{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.closeTag{font-family:var(--display);font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:.04em;padding:5px 11px;border-radius:999px}
.closeTag.closed{background:var(--win-tint);color:var(--win)}
.closeTag.almost{background:var(--warn-tint);color:var(--warn)}
.closeTag.lost{background:var(--loss-tint);color:var(--loss)}
.overall{display:flex;align-items:baseline;gap:8px}
.overall strong{font-family:var(--display);font-size:44px;font-weight:800;line-height:1;letter-spacing:-.02em}
.overall span{color:var(--muted);font-size:13px}
.funnel{display:flex;flex-wrap:wrap;gap:7px}
.badge{font-family:var(--mono);font-size:11px;font-weight:700;padding:5px 9px;border-radius:8px;border:1px solid var(--line)}
.badge.good{background:var(--win-tint);color:var(--win);border-color:#bfe6c9}
.badge.bad{background:var(--surface-2);color:var(--muted)}
.scoreGrid{display:grid;grid-template-columns:1fr 1fr;gap:10px 18px}
.scoreItem{display:flex;flex-direction:column;gap:5px}
.scoreItemTop{display:flex;justify-content:space-between;font-size:12.5px;color:var(--ink-2)}
.scoreItemTop strong{font-family:var(--mono);color:var(--ink)}
.bar{height:6px;border-radius:999px;background:var(--line);overflow:hidden}
.bar i{display:block;height:100%;background:var(--accent)}
.feedback,.better{font-size:13.5px;line-height:1.55;color:var(--ink-2);background:var(--surface-2);border:1px solid var(--line);border-radius:12px;padding:12px}
.feedback .name,.better .name{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:6px}
.betterList{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:6px}

/* ---------------- dashboard / admin ---------------- */
.page{max-width:1180px;margin:0 auto;padding:16px;display:flex;flex-direction:column;gap:16px}
.pageHead{display:flex;align-items:flex-end;justify-content:space-between;gap:12px;flex-wrap:wrap}
.pageHead h2{font-size:22px}
.pageHead p{color:var(--muted);font-size:13px;margin-top:3px}
.navlink{display:inline-block;color:var(--ink);font-size:13px;font-weight:600;border:1px solid var(--line-2);padding:8px 12px;border-radius:10px;background:var(--surface)}
.navlink:hover{border-color:var(--ink-2)}
.navlink.small{padding:4px 9px;font-size:13px}

.stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:12px}
.stats div{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.stats strong{display:block;font-family:var(--display);font-size:30px;font-weight:800;letter-spacing:-.02em}
.stats span{color:var(--muted);font-size:12px;font-weight:600}
.trend.up{color:var(--win)}.trend.down{color:var(--loss)}.trend.flat{color:var(--muted)}

.sparkWrap{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px;box-shadow:var(--shadow)}
.sparkLabel{font-family:var(--mono);font-size:10px;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.spark{display:flex;align-items:flex-end;gap:4px;height:64px}
.spark i{flex:1;min-width:6px;background:var(--accent);border-radius:3px 3px 0 0;opacity:.85}

.tableWrap{overflow-x:auto;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}
table{width:100%;border-collapse:collapse;min-width:760px}
th,td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--line);vertical-align:top;font-size:13px}
th{font-family:var(--mono);font-size:10px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);background:var(--surface-2)}
tbody tr:last-child td{border-bottom:0}
.subs{font-family:var(--mono);font-size:11px;color:var(--muted);min-width:300px}
.subs b{color:var(--ink)}
.scoreText td{background:var(--surface-2)}
.scoreText .betterInline ul{margin:6px 0 0;padding-left:18px}
.dot{font-family:var(--mono);font-size:11px;font-weight:700;padding:3px 8px;border-radius:7px;border:1px solid var(--line);white-space:nowrap}
.dot.on{background:var(--win-tint);color:var(--win);border-color:#bfe6c9}
.dot.asked{background:var(--warn-tint);color:var(--warn);border-color:#f0dcbb}
.dot.off{color:var(--muted)}

.adminGrid{display:grid;grid-template-columns:1fr;gap:14px}
.adminCard{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow)}
.adminCard h3{font-size:15px;margin-bottom:12px}
.adminCard form{display:flex;flex-direction:column;gap:10px}
.actionsCell{display:flex;flex-wrap:wrap;gap:6px}
.actionsCell form{display:flex;gap:6px;align-items:center}
.actionsCell input{max-width:150px;padding:7px 9px}
.miniBtn{border:1.5px solid var(--line-2);background:var(--surface);border-radius:9px;padding:7px 10px;font-weight:700;font-size:12px}
.dangerBtn{border:0;border-radius:9px;padding:7px 10px;font-weight:700;font-size:12px;background:var(--loss-tint);color:var(--loss)}
.secondaryBtn{border:0;border-radius:9px;padding:7px 10px;font-weight:700;font-size:12px;background:var(--surface-2);color:var(--ink-2)}

.successBox{background:var(--win-tint);border:1px solid #bfe6c9;color:#14692f;padding:12px;border-radius:11px}
.errorBox{background:var(--loss-tint);border:1px solid #f0c9c9;color:#9b1c1c;padding:12px;border-radius:11px}
.muted{color:var(--muted)}
code{font-family:var(--mono);font-size:12px;background:var(--surface-2);border:1px solid var(--line);padding:2px 5px;border-radius:5px}

/* ---------------- auth / install ---------------- */
.authWrap{min-height:100vh;display:grid;place-items:center;padding:18px;background:var(--panel)}
.authCard{width:min(440px,100%);background:var(--surface);border-radius:18px;padding:24px;box-shadow:0 24px 70px rgba(0,0,0,.4)}
.authCard.wide{max-width:720px}
.authCard .brand{margin-bottom:18px}
.authCard .brand h1{color:var(--ink)}
.authCard label{display:block;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);margin:12px 0 6px}
.authCard input,.authCard select{margin-bottom:2px}
.authCard .full{width:100%;margin-top:18px;background:var(--accent);border:0;color:#fff;padding:13px;border-radius:11px;font-weight:700;font-size:15px}
.buttonLink{display:inline-block;margin-top:12px;background:var(--ink);color:#fff;padding:12px 16px;border-radius:11px;font-weight:700}
.twoCols{display:grid;grid-template-columns:1fr 1fr;gap:12px}
details summary{cursor:pointer}

/* ---------------- desktop ---------------- */
@media(min-width:860px){
  body{font-size:15px}
  .topnav{padding:14px 24px}
  .rail{top:68px;padding:14px 24px;gap:0}
  .stage{min-width:0}
  .app{padding:20px;gap:18px}
  .workspace{display:grid;grid-template-columns:320px 1fr;gap:18px;align-items:start}
  .controls{position:sticky;top:150px}
  .controls > summary{cursor:default}
  .actions{grid-template-columns:repeat(3,1fr)}
  .session{min-height:72vh}
  .scoreGrid{grid-template-columns:1fr 1fr}
  .adminGrid{grid-template-columns:1fr 1fr}
}
@media(min-width:560px){ .scoreGrid{grid-template-columns:1fr 1fr} }
@media(max-width:559px){
  .scoreGrid{grid-template-columns:1fr}
  .stage .lbl{font-size:10px}
  .stage{min-width:64px}
}

@media(prefers-reduced-motion:reduce){*{transition:none!important}}

/* card form submit + auth primary */
.adminCard button[type=submit]{background:var(--accent);border:0;color:#fff;border-radius:11px;padding:11px;font-weight:700;font-size:14px}
.adminCard button[type=submit]:hover{background:#1a3ad1}
.adminCard label{font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--muted)}
.installCard{max-width:720px}

/* voice input + timer + time stat */
.mic{flex:none;width:44px;border:1.5px solid var(--line-2);background:var(--surface);color:var(--muted);border-radius:11px;display:grid;place-items:center;transition:.15s}
.mic:hover{color:var(--ink);border-color:var(--ink-2)}
.mic:disabled{opacity:.4;cursor:not-allowed}
.mic.listening{color:#fff;background:var(--loss);border-color:var(--loss);animation:micpulse 1.1s infinite}
@keyframes micpulse{0%,100%{box-shadow:0 0 0 0 rgba(220,38,38,.4)}50%{box-shadow:0 0 0 6px rgba(220,38,38,0)}}
.pillGroup{display:flex;align-items:center;gap:8px}
.timer{font-family:var(--mono);font-size:13px;font-weight:700;color:var(--accent);background:var(--accent-tint);border-radius:999px;padding:5px 10px;min-width:48px;text-align:center}
.timeStat{font-family:var(--mono);font-size:12px;color:var(--muted);margin-left:auto;white-space:nowrap}
.composer input:disabled{background:var(--surface-2);color:var(--muted)}
