/* AI Bonus Assessor — styled to the JS Global Design System.
   Tokens imported from brand/colors_and_type.css (the company's authoritative
   colors_and_type.css). Brand Orange #E07828 is the single focal accent; 60%+
   of the layout stays neutral; borders/tints do more work than shadows. */
@import url("brand/colors_and_type.css");

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body { background: var(--bg-page); color: var(--fg-1); }
.hidden { display: none !important; }

/* ---------------- Topbar (white, sticky, hairline) ---------------- */
.topbar {
  position: sticky; top: 0; z-index: 40;
  background: rgba(255,255,255,.94);
  backdrop-filter: blur(8px);
  border-bottom: 1px solid var(--border-1);
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 32px;
}
.brand { display: flex; align-items: center; gap: 14px; }
.brand-logo { height: 34px; width: auto; display: block; }
.brand-divider { width: 1px; height: 30px; background: var(--border-1); }
.brand-title { font-family: var(--font-cjk-sans); font-weight: 700; font-size: 16px; line-height: 1.1; color: var(--fg-1); }
.brand-sub { font-size: 11px; letter-spacing: var(--ls-eyebrow); text-transform: uppercase; color: var(--jsg-orange); font-weight: 700; margin-top: 3px; }
.topbar-actions { display: flex; align-items: center; gap: 14px; }
.health { width: 9px; height: 9px; border-radius: 50%; background: var(--jsg-mid-gray); }
.health.ok { background: var(--jsg-success); }
.health.bad { background: var(--jsg-danger); }
.powered { font-size: 11px; letter-spacing: .03em; color: var(--fg-3); white-space: nowrap; }
.langtoggle {
  font-size: 12px; letter-spacing: .14em; font-weight: 700; text-transform: uppercase;
  color: var(--fg-2); background: #fff; padding: 5px 12px;
  border: 1px solid var(--border-1); border-radius: var(--radius-md); cursor: pointer;
}
.langtoggle:hover { border-color: var(--jsg-orange); color: var(--jsg-orange); }
.iconbtn { background: transparent; border: none; padding: 4px; cursor: pointer;
  color: var(--fg-2); display: inline-flex; align-items: center; }
.iconbtn svg { width: 23px; height: 23px; display: block; }
.iconbtn:hover { color: var(--jsg-orange); }

/* ---------------- Title strip (eyebrow + bilingual H1 + orange rule) ---------------- */
.titlestrip {
  position: relative; overflow: hidden;
  background: var(--bg-page);
  border-bottom: 1px solid var(--border-1);
  padding: 30px 32px 26px;
}
.titlestrip .hex {
  position: absolute; right: -60px; top: -40px; height: 200px; opacity: .5;
  pointer-events: none; user-select: none;
}
.titlestrip .inner { position: relative; max-width: 1320px; margin: 0 auto; }
.eyebrow { font-size: var(--fs-eyebrow); letter-spacing: var(--ls-eyebrow); text-transform: uppercase; font-weight: 700; color: var(--jsg-orange); }
.rule { width: 56px; height: 4px; background: var(--jsg-orange); margin: 14px 0; }
.h1zh { font-family: var(--font-cjk-sans); font-size: 30px; font-weight: 700; line-height: 1.15; color: var(--fg-1); }
.h1en { font-size: 16px; color: var(--fg-2); margin-top: 4px; }

main { max-width: 1320px; margin: 0 auto; padding: 22px 32px 64px; }

/* ---------------- Buttons ---------------- */
.btn {
  font-family: var(--font-mixed-sans);
  border: 1px solid var(--border-1); background: #fff; color: var(--fg-1);
  padding: 9px 16px; border-radius: var(--radius-md); cursor: pointer;
  font-size: 13px; font-weight: 600; letter-spacing: .02em; transition: border-color .15s, background .15s, color .15s;
}
.btn:hover { border-color: var(--fg-1); }
.btn.primary { background: var(--jsg-orange); border-color: var(--jsg-orange); color: #fff; }
.btn.primary:hover { background: var(--jsg-orange-light); border-color: var(--jsg-orange-light); }
.btn.primary:active { background: var(--jsg-orange-shade); border-color: var(--jsg-orange-shade); }
.btn.ghost { background: transparent; border-color: transparent; color: var(--fg-2); }
.btn.ghost:hover { color: var(--jsg-orange); }
.btn.small { padding: 5px 11px; font-size: 12px; }
.btn { white-space: nowrap; }
/* Export button in Excel green */
.btn.excel { background: #217346; border-color: #217346; color: #fff; }
.btn.excel:hover { background: #1a5c38; border-color: #1a5c38; }
.btn:disabled { opacity: .4; cursor: not-allowed; }
.btn:focus-visible { outline: 2px solid var(--jsg-orange); outline-offset: 2px; }

.toolbar { display: flex; gap: 10px; align-items: center; margin-bottom: 16px; flex-wrap: wrap; }
.progress { color: var(--fg-2); font-size: 13px; letter-spacing: .02em; }

/* ---------------- Weights panel ---------------- */
.panel { background: #fff; border: 1px solid var(--border-1); border-radius: var(--radius-lg);
  padding: 18px 20px; margin-bottom: 18px; }
.panel-head { display: flex; justify-content: space-between; align-items: center;
  color: var(--fg-2); font-size: 12px; margin-bottom: 14px; }
.sliders { display: grid; grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); gap: 16px 28px; }
.slider-row { display: flex; flex-direction: column; gap: 5px; }
.slider-row .lab { display: flex; justify-content: space-between; align-items: center; font-weight: 600; font-size: 13px; }
.slider-row input[type=range] { width: 100%; accent-color: var(--jsg-orange); }
.slider-row.pinned input[type=range] { accent-color: var(--jsg-orange-shade); }
.pctwrap { display: inline-flex; align-items: center; gap: 1px; }
.wpct { width: 44px; text-align: right; font-family: var(--font-display); font-weight: 700;
  font-size: 13px; color: var(--jsg-orange-shade); border: 1px solid transparent; border-radius: var(--radius-sm);
  background: transparent; -moz-appearance: textfield; padding: 1px 2px; }
.wpct::-webkit-outer-spin-button, .wpct::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.wpct:hover { border-color: var(--border-1); }
.wpct:focus { outline: none; border-color: var(--jsg-orange); background: #fff; }
.pctsign { color: var(--jsg-orange-shade); font-weight: 700; font-size: 12px; }
.pin { color: var(--jsg-orange); font-size: 8px; vertical-align: 2px; cursor: help; }

/* ---------------- Layout ---------------- */
.layout { display: grid; grid-template-columns: 1fr; gap: 18px; align-items: start; }
/* When a project is open the left list shrinks so the detail gets the room. */
.layout.with-detail { grid-template-columns: minmax(300px, 0.85fr) 1.7fr; }
/* Compact list when detail is open: hide radar/evidence/compliance/rec/human/award (5-10;
   col 1 = checkbox, 2 = composite, 3 = BU, 4 = project, 11 = action). */
.layout.with-detail table th:nth-child(n+5):nth-child(-n+10),
.layout.with-detail table td:nth-child(n+5):nth-child(-n+10) { display: none; }
.table-wrap { background: #fff; border: 1px solid var(--border-1); border-radius: var(--radius-lg); overflow: hidden; }
table { width: 100%; border-collapse: collapse; font-size: 13px; }
thead tr { background: var(--jsg-navy-core); color: #fff; }
th { text-align: left; padding: 11px 14px; font-size: 10px; letter-spacing: .16em;
  text-transform: uppercase; font-weight: 700; }
td { padding: 12px 14px; border-bottom: 1px solid var(--border-1); vertical-align: middle; }
tbody tr { cursor: pointer; transition: background .12s; }
tbody tr:nth-child(even) { background: var(--bg-page); }
tbody tr:hover { background: var(--bg-tint-orange); }
tbody tr.active { background: var(--bg-tint-orange); box-shadow: inset 3px 0 0 var(--jsg-orange); }

/* Composite = the headline number (Calibri), functional color for state */
.comp { font-family: var(--font-display); font-size: 26px; font-weight: 700; line-height: 1;
  letter-spacing: var(--ls-display); font-variant-numeric: tabular-nums; }
.comp-good { color: var(--jsg-success); }
.comp-warn { color: var(--jsg-orange-shade); }
.comp-bad  { color: var(--jsg-danger); }
.comp-none { color: var(--jsg-mid-gray); font-weight: 400; }

.minis { display: flex; gap: 3px; align-items: flex-end; height: 24px; }
.mini { width: 9px; border-radius: var(--radius-sm); background: var(--border-1); }

/* Status pills — dot + tinted bg, the slide-6 convention */
.pill { display: inline-flex; align-items: center; gap: 6px; padding: 3px 10px;
  border-radius: var(--radius-pill); font-size: 11px; font-weight: 700; letter-spacing: .04em; white-space: nowrap; }
.pill::before { content: ""; width: 5px; height: 5px; border-radius: 50%; background: currentColor; flex: none; }
.pill-green  { background: #E8F5EA; color: #1f6731; }
.pill-amber  { background: #FBF0D9; color: #7a5008; }
.pill-red    { background: #F9DEDB; color: #80211b; }
.pill-orange { background: var(--jsg-orange-warm-tint); color: var(--jsg-orange-shade); }
.pill-mut    { background: #EEEEEC; color: var(--fg-2); }

td.t-title { font-weight: 600; max-width: 260px; font-family: var(--font-cjk-sans); }
td .who { color: var(--fg-3); font-size: 11px; font-weight: 400; margin-top: 2px; letter-spacing: .02em; }

/* ---------------- Detail ---------------- */
.detail { background: #fff; border: 1px solid var(--border-1); border-radius: var(--radius-lg);
  padding: 22px; position: sticky; top: 78px; align-self: start;
  max-height: calc(100vh - 96px); overflow: auto; box-shadow: var(--shadow-2); }
.detail .close { float: right; }
.detail h2 { margin: 0 0 2px; font-size: 19px; font-family: var(--font-cjk-sans); font-weight: 700; }
.detail .who { color: var(--fg-3); font-size: 12px; margin-bottom: 12px; letter-spacing: .02em; }
.detail .kv { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; margin: 10px 0 4px; }
.detail .kv .comp { font-size: 34px; margin-right: 4px; }
.section-t { font-size: var(--fs-eyebrow); letter-spacing: var(--ls-eyebrow); text-transform: uppercase;
  font-weight: 700; color: var(--fg-2); margin: 18px 0 6px; }
.dimcard { border: 1px solid var(--border-1); border-left: 3px solid var(--jsg-orange);
  border-radius: var(--radius-md); padding: 11px 14px; margin: 9px 0; }
.dimcard .dh { display: flex; justify-content: space-between; align-items: baseline; gap: 8px; }
.dimcard .dname { font-weight: 700; font-family: var(--font-cjk-sans); }
.dimcard .dscore { font-family: var(--font-display); font-weight: 700; font-size: 18px; font-variant-numeric: tabular-nums; }
.bar { height: 6px; border-radius: var(--radius-sm); background: var(--jsg-light-gray); margin: 8px 0; overflow: hidden; }
.bar > span { display: block; height: 100%; background: var(--jsg-orange); }
.dimcard .rat { margin: 2px 0; color: var(--fg-1); }
.dimcard .ev { font-family: var(--font-serif); font-style: italic; color: var(--fg-2); font-size: 13px;
  border-left: 2px solid var(--border-2); padding-left: 9px; margin-top: 5px; }
.detail ul { margin: 4px 0; padding-left: 18px; }
.detail li { margin: 3px 0; }
.tok { color: var(--fg-3); font-size: 11px; margin-top: 16px; letter-spacing: .04em;
  border-top: 1px solid var(--border-1); padding-top: 10px; }

.empty { padding: 48px; text-align: center; color: var(--fg-2); }

/* ---------------- Modal ---------------- */
.modal { position: fixed; inset: 0; background: rgba(14,40,65,.45); display: grid; place-items: center; z-index: 60; }
.modal-card { background: #fff; border-radius: var(--radius-lg); padding: 24px; width: min(520px, 92vw); box-shadow: var(--shadow-3); }
.modal-card h3 { margin: 0 0 16px; font-family: var(--font-cjk-sans); }
.modal-card label { display: block; font-size: 12px; color: var(--fg-2); margin: 12px 0 4px; font-weight: 600; }
.modal-card input[type=text], .modal-card input[type=password], .modal-card select {
  width: 100%; padding: 9px 11px; border: 1px solid var(--border-1); border-radius: var(--radius-md);
  font-family: inherit; font-size: 14px; background: #fff; }
.modal-card input:focus, .modal-card select:focus { outline: 2px solid var(--jsg-orange); outline-offset: 0; border-color: var(--jsg-orange); }
.modal-card input:disabled, .modal-card select:disabled { background: var(--bg-page); color: var(--fg-2); }
.row2 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.modal-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 20px; }

/* ---------------- Radar (replaces the mini bars) ---------------- */
.radar-wrap { display: flex; justify-content: center; padding: 16px 64px 20px; }
.radar { overflow: visible; }
.radar text { font-family: var(--font-mixed-sans); }
.detail .close {
  /* Stick the Close button to the detail panel's top-right corner while the
     report scrolls — long reports otherwise force a scroll-back to dismiss. */
  position: sticky; top: 0; float: right; z-index: 5;
  background: #fff; border-color: var(--border-2); color: var(--fg-2);
  box-shadow: 0 1px 4px rgba(26,26,26,.08);
}
.detail .close:hover { border-color: var(--jsg-orange); color: var(--jsg-orange); }
/* Give the heading some breathing room from the floated close button */
.detail h2 { padding-right: 92px; }

/* ---------------- Completeness + uploader note ---------------- */
.needs-pill { margin-top: 5px; }
.completeness { border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: 12px 14px; margin-top: 6px; }
.completeness.ok { border-left: 3px solid var(--jsg-success); }
.completeness.warn { border-left: 3px solid var(--jsg-warning); }
.completeness ul { margin: 6px 0 0; padding-left: 18px; }
.note-box { width: 100%; min-height: 130px; font-family: var(--font-mixed-sans); font-size: 12.5px;
  line-height: 1.55; border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: 10px;
  margin-top: 10px; resize: vertical; color: var(--fg-1); background: var(--bg-page); }
.note-actions { display: flex; gap: 8px; margin-top: 8px; flex-wrap: wrap; }
.notassessed { color: var(--fg-2); font-size: 13px; margin: 10px 0; }

/* ---------------- Business unit + source materials ---------------- */
.bu-logo { height: 18px; width: auto; vertical-align: -4px; margin-right: 9px; }
.bu-logo.bu-SNAPAC { height: 13px; vertical-align: -2px; }
/* Dedicated BU column: larger logo so visual weight is closer to the composite score */
td.bu-col, th.sortable[data-sort="bu"] { width: 120px; text-align: center; }
.bu-cell { display: inline-flex; align-items: center; }
.bu-cell .bu-logo { margin-right: 0; vertical-align: middle; height: 30px; }
.bu-cell .bu-logo.bu-SNAPAC { height: 22px; }
.bu-tag { display: flex; align-items: center; gap: 8px; margin: -2px 0 10px; }
.bu-tag .bu-logo { margin-right: 0; }
.bu-name { font-size: 11px; letter-spacing: .06em; color: var(--fg-2); font-weight: 600; }

.srcfiles { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 2px; }
.srcfile { display: inline-block; font-size: 12px; padding: 5px 11px; border: 1px solid var(--border-1);
  border-radius: var(--radius-md); color: var(--fg-link); background: #fff; }
.srcfile:hover { border-color: var(--jsg-orange); text-decoration: none; }
.srcref { font-size: 11px; color: var(--fg-3); margin-top: 5px; letter-spacing: .02em; }
.srcref a { color: var(--fg-link); }

/* ---------------- Dark tooltip (body-level, never clipped, flips up) ---------------- */
.tip {
  position: fixed; display: none; z-index: 1000; pointer-events: none;
  background: var(--jsg-near-black); color: #fff;
  font-size: 12px; font-weight: 500; line-height: 1.5; letter-spacing: .01em;
  padding: 9px 12px; border-radius: var(--radius-md);
  max-width: 300px; white-space: pre-line; text-align: left; box-shadow: var(--shadow-3);
}

/* ---------------- Progress / spinner ---------------- */
.spinner { display: inline-block; width: 13px; height: 13px; border: 2px solid var(--border-2);
  border-top-color: var(--jsg-orange); border-radius: 50%; animation: spin .7s linear infinite;
  vertical-align: -2px; margin-right: 8px; }
@keyframes spin { to { transform: rotate(360deg); } }
.ptext { color: var(--fg-2); }
.pbar { display: inline-block; width: 130px; height: 6px; background: var(--border-1); border-radius: 999px;
  overflow: hidden; margin: 0 9px; vertical-align: middle; }
.pbar > span { display: block; height: 100%; background: var(--jsg-orange); transition: width .25s ease; }
.pcount { color: var(--fg-2); font-variant-numeric: tabular-nums; font-size: 12px; }

/* ---------------- Contributors (leader + participants) ---------------- */
.who .lead { font-weight: 700; color: var(--fg-1); }
.who .lead-tag { display: inline-block; background: var(--bg-tint-orange); color: var(--jsg-orange-shade);
  font-size: 9px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
  padding: 1px 5px; border-radius: 3px; margin-right: 5px; vertical-align: 1px; }
.who .sep { margin: 0 5px; color: var(--border-2); }
.who .team { color: var(--fg-3); }

/* ---------------- Per-dimension confidence meter ---------------- */
.dright { display: flex; align-items: center; gap: 10px; }
.confmeter { display: inline-flex; gap: 2px; align-items: flex-end; }
.cf-dot { width: 4px; height: 10px; border-radius: 1px; background: var(--border-1); }
.cf-dot.cf-high { background: var(--jsg-success); }
.cf-dot.cf-med { background: var(--jsg-warning); }
.cf-dot.cf-low { background: var(--jsg-danger); }

/* ---------------- Settings modal ---------------- */
.hint { font-size: 12px; color: var(--fg-3); margin-top: 4px; line-height: 1.5; }
.setrow { display: flex; gap: 12px; padding: 9px 0; border-bottom: 1px solid var(--border-1); font-size: 13px; align-items: baseline; }
.setrow .setk { width: 100px; color: var(--fg-2); font-weight: 600; flex: none; }
.verbtn { background: var(--bg-tint-orange); color: var(--jsg-orange-shade); border: none;
  border-radius: var(--radius-pill); padding: 2px 11px; font-weight: 700; cursor: pointer; font-size: 12px; }
.changelog { margin-top: 4px; }
.changelog ul { margin: 4px 0; padding-left: 18px; }
#settingsCard, #payoutsCard { max-height: 86vh; overflow: auto; }

/* ---------------- Selection, review, payouts ---------------- */
.chk-col { width: 34px; text-align: center; }
.chk-col input { cursor: pointer; }
thead .chk-col input { accent-color: var(--jsg-orange); }
.row-tags { display: flex; gap: 6px; margin-top: 5px; flex-wrap: wrap; }

.rvform label { display: block; font-size: 12px; color: var(--fg-2); margin: 10px 0 4px; font-weight: 600; }
.rvform input[type=text], .rvform input[type=number], .rvform select, .rvform textarea {
  width: 100%; padding: 8px 10px; border: 1px solid var(--border-1); border-radius: var(--radius-md);
  font-family: inherit; font-size: 13px; background: #fff; }
.rvform input:focus, .rvform select:focus, .rvform textarea:focus { outline: 2px solid var(--jsg-orange); outline-offset: 0; border-color: var(--jsg-orange); }
.rvform label.chk { display: flex; align-items: center; gap: 8px; font-weight: 500; color: var(--fg-1); }
.rvform label.chk input { width: auto; }

.payout-batch { border: 1px solid var(--border-1); border-radius: var(--radius-md); padding: 12px 14px; margin: 10px 0; }
.payout-head { display: flex; justify-content: space-between; font-size: 13px; color: var(--fg-2);
  border-bottom: 1px solid var(--border-1); padding-bottom: 8px; margin-bottom: 8px; }
.payout-list { list-style: none; margin: 0; padding: 0; }
.payout-list li { display: flex; justify-content: space-between; padding: 5px 0; font-size: 13px; }
.payout-list a { color: var(--fg-link); }
.payout-list a:hover { color: var(--jsg-orange); }

/* ---------------- Sortable headers ---------------- */
th.sortable { cursor: pointer; user-select: none; }
th.sortable:hover { background: rgba(255,255,255,.08); }
.sort-arr { display: inline-block; font-size: 9px; margin-left: 4px; opacity: .45; vertical-align: 1px; }
.sort-arr.active { opacity: 1; color: var(--jsg-orange); }

.assessed-at { color: var(--fg-3); font-size: 11.5px; margin: 6px 0 0; letter-spacing: .02em; }

/* ---------------- Usage panel (Settings → AI usage & cost) ---------------- */
.usage-panel { margin-top: 8px; }
.usage-total { display: flex; align-items: baseline; gap: 14px; padding: 14px 16px;
  background: var(--bg-page); border: 1px solid var(--border-1); border-radius: var(--radius-md);
  border-left: 3px solid var(--jsg-orange); }
.ut-amount { font-family: var(--font-display); font-size: 30px; font-weight: 700; letter-spacing: var(--ls-display); color: var(--fg-1); }
.ut-meta { color: var(--fg-3); font-size: 12px; }
.usage-subtitle { font-size: var(--fs-eyebrow); letter-spacing: var(--ls-eyebrow); text-transform: uppercase;
  font-weight: 700; color: var(--fg-2); margin: 14px 0 4px; }
table.usage-tbl { width: 100%; border-collapse: collapse; font-size: 12.5px;
  background: #fff; border: 1px solid var(--border-1); border-radius: var(--radius-md); overflow: hidden; }
table.usage-tbl th { background: var(--bg-page); color: var(--fg-2); font-size: 10px;
  letter-spacing: .14em; text-transform: uppercase; font-weight: 700; padding: 8px 10px; text-align: left; }
table.usage-tbl td { padding: 8px 10px; border-top: 1px solid var(--border-1); color: var(--fg-1); }
table.usage-tbl th.num, table.usage-tbl td.num { text-align: right; font-variant-numeric: tabular-nums; }

/* ---------------- Responsive (phone / tablet) ---------------- */
@media (max-width: 900px) {
  .layout.with-detail { grid-template-columns: 1fr; }
  /* stacked: show all columns again, let the table scroll horizontally */
  .layout.with-detail table th:nth-child(n+5):nth-child(-n+10),
  .layout.with-detail table td:nth-child(n+5):nth-child(-n+10) { display: table-cell; }
  .detail { position: static; max-height: none; }
  .table-wrap { overflow-x: auto; }
  table { min-width: 720px; }
  .h1zh { font-size: 24px; }
  .powered { display: none; }
}
@media (max-width: 560px) {
  .topbar { padding: 10px 14px; }
  main { padding: 16px 14px 48px; }
  .titlestrip { padding: 22px 14px 20px; }
  .brand-sub { display: none; }
  .brand-divider { display: none; }
  .radar-wrap { padding: 12px 40px 16px; }
  .toolbar .btn { flex: 1 1 auto; }
}
