/* =================== TalentLens — corporate clean UI ===================== */
:root{
  /* editorial paper palette (Daniel Siew design) */
  --bg:#e6ddca; --surface:#faf7ef; --surface-2:#f3ecda; --line:#e4dcca;
  --ink:#2c2823; --muted:#857c69; --brand:#2c2823;
  --brand-2:#9a7c43; --gold:#9a7c43; --gold-deep:#6c5326; --accent:#5c6e54;
  --strong:#5c6e54; --workable:#4f6a74; --stretch:#8c8473;
  --wood:#5f7d52; --fire:#b0694a; --earth:#9a7b3f; --metal:#8a8576; --water:#4f6a74;
  --radius:9px; --shadow:0 1px 2px rgba(44,40,35,.04),0 22px 46px -34px rgba(44,40,35,.32);
  --maxw:1080px;
}
*{box-sizing:border-box}
button,input,select,textarea{font-family:inherit}
html,body{margin:0;padding:0}
body{font-family:"Hanken Grotesk",ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Helvetica,Arial,sans-serif;
  color:var(--ink);line-height:1.6;font-size:15px;
  background:#e6ddca;background-image:radial-gradient(125% 85% at 18% -5%, #f2ecdb 0%, #ece3d0 52%, #e4dac4 100%);
  background-attachment:fixed;min-height:100vh;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
h1,h2,h3,h4{line-height:1.2;margin:0 0 .4em;font-weight:700;letter-spacing:-.012em}
a{color:var(--brand-2);text-decoration:none;font-weight:600}
a:hover{color:var(--gold-deep)}
.muted{color:var(--muted)}
.loading{padding:80px;text-align:center;color:var(--muted)}

/* layout */
.topbar{position:sticky;top:0;z-index:20;background:var(--surface);border-bottom:1px solid var(--line);
  display:flex;align-items:center;gap:18px;padding:15px 28px}
.brand{font-weight:700;letter-spacing:-.01em;font-size:19px;color:var(--ink);display:inline-flex;align-items:baseline;gap:10px}
.brand small{font-weight:600;color:var(--gold);margin-left:0;font-size:10.5px;text-transform:uppercase;letter-spacing:.16em}
.topnav{display:flex;gap:6px;margin-left:8px;flex-wrap:wrap}
.topnav button{background:none;border:none;color:var(--muted);font-weight:600;padding:8px 14px;border-radius:9px;cursor:pointer;font-size:13.5px;letter-spacing:.01em}
.topnav button:hover{background:var(--surface-2);color:var(--ink)}
.topnav button.active{background:var(--brand);color:#fff}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.usage-pill{font-size:12px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:5px 13px;color:var(--muted)}
.usage-pill strong{color:var(--ink)}
.container{max-width:var(--maxw);margin:0 auto;padding:28px 24px 80px}

/* buttons & forms */
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--brand);color:#fff;border:none;
  padding:12px 20px;border-radius:10px;font-weight:600;cursor:pointer;font-size:14px;letter-spacing:.01em;
  transition:background .15s ease}
.btn:hover{background:#161d2e}
.btn.secondary{background:var(--surface);color:var(--ink);border:1px solid var(--line)}
.btn.secondary:hover{background:var(--bg)}
.btn.ghost{background:none;color:var(--brand-2);padding:8px 10px}
.btn:disabled{opacity:.5;cursor:not-allowed}
.btn-row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}
label{display:block;font-weight:600;font-size:12.5px;margin:14px 0 5px;color:var(--ink);text-transform:uppercase;letter-spacing:.04em}
input,select{width:100%;padding:11px 13px;border:1px solid var(--line);border-radius:10px;font:inherit;background:var(--surface);color:var(--ink)}
input:focus,select:focus{outline:2px solid var(--gold);outline-offset:0;border-color:var(--gold)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.hint{font-size:12px;color:var(--muted);margin-top:4px}
.checkbox{display:flex;align-items:center;gap:8px;margin-top:10px}
.checkbox input{width:auto}

/* cards */
.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:28px;box-shadow:var(--shadow)}
.card + .card{margin-top:20px}
.card-narrow{max-width:440px;margin:48px auto}
.grid{display:grid;gap:16px}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}
.section-title{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:10px}
.section-title h2{margin:0}
.error-box{background:#fdecec;border:1px solid #f3c0c0;color:#9b2226;padding:14px 16px;border-radius:10px;margin:12px 0}
.notice{background:#fff6e6;border:1px solid #f0d99a;color:#8a6320;padding:10px 14px;border-radius:10px;margin:12px 0;font-size:14px}
.ok-box{background:#e9f6f2;border:1px solid #aedccd;color:#0f7b6c;padding:10px 14px;border-radius:10px;margin:10px 0}

/* table */
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line)}
th{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.04em}
tr:hover td{background:var(--bg)}
.tag{display:inline-block;font-size:12px;font-weight:700;padding:3px 9px;border-radius:999px}
.tag.strong{background:#e3f3ee;color:var(--strong)}
.tag.workable{background:#fbf0db;color:var(--workable)}
.tag.stretch{background:#eef0f3;color:var(--stretch)}
.tag.ent{background:#ece9fb;color:#5b4bbd}

/* ---- expert toggle gating ----
   !important so component display rules (e.g. .pillar-animal{display:block})
   can never accidentally reveal expert-only content in the default HR view. */
.expert-only{display:none !important}
.expert .expert-only{display:revert !important}
.expert .default-only{display:none !important}
.toggle{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer}
.toggle input{width:auto}

/* =================== REPORT =================== */
.report{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);
  padding:40px 44px;box-shadow:var(--shadow);max-width:860px;margin:0 auto}
.report-head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;
  border-bottom:1.5px solid var(--ink);padding-bottom:18px;margin-bottom:8px}
.report-kicker{text-transform:uppercase;letter-spacing:.18em;font-size:10.5px;color:var(--gold);font-weight:700}
.report-name{font-size:32px;margin:.12em 0 .18em;letter-spacing:-.02em}
.report-meta{color:var(--muted);font-size:14px}
.report-fit-badge{text-align:center;border-radius:12px;padding:14px 20px;min-width:124px;color:#fff}
.report-fit-badge.fit-strong{background:var(--strong)}
.report-fit-badge.fit-workable{background:var(--workable)}
.report-fit-badge.fit-stretch{background:var(--stretch)}
.fit-band{font-size:18px;font-weight:800}
.fit-sub{font-size:11px;opacity:.9}

.report-visuals{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:22px 0;padding:18px 0;border-bottom:1px solid var(--line)}
.visual-block{min-width:0}
.visual-title{font-size:13px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin-bottom:12px}
.mini-title{font-size:12px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:14px 0 6px}
.chart-caption{font-size:11.5px;color:var(--muted);margin-top:8px}

/* pillars */
.pillars-chart{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}
.pillar{border:1px solid var(--line);border-radius:10px;overflow:hidden;text-align:center;background:#fcfdff}
.pillar-day{outline:2px solid var(--brand-2)}
.pillar-label{font-size:10.5px;color:var(--muted);padding:5px 2px;background:var(--bg);border-bottom:1px solid var(--line);font-weight:600}
.pillar-stem{font-size:20px;font-weight:800;padding:12px 4px 6px}
.pillar-branch{font-size:16px;font-weight:700;padding:4px 4px 12px;color:var(--ink)}
.pillar-animal{display:block;font-size:10px;color:var(--muted);font-weight:600;margin-top:3px}
.el-wood{color:var(--wood)} .el-fire{color:var(--fire)} .el-earth{color:var(--earth)}
.el-metal{color:var(--metal)} .el-water{color:var(--water)}

/* luck */
.luck-row{display:grid;grid-template-columns:repeat(9,1fr);gap:5px}
.luck-cell{border:1px solid var(--line);border-radius:8px;text-align:center;padding:7px 2px;background:#fcfdff;font-size:11px}
.luck-current{outline:2px solid var(--accent);background:#eef8f5}
.luck-age{color:var(--muted);font-size:10px}
.luck-gz{font-weight:700;margin:3px 0;font-size:11.5px}
.luck-year{color:var(--muted);font-size:9.5px}

/* bars */
.bar-row{display:grid;grid-template-columns:140px 1fr 42px;align-items:center;gap:8px;margin-bottom:7px;font-size:13px}
.bar-label{font-weight:600;font-size:12.5px}
.bar-label em{font-size:11px;color:var(--muted);font-style:normal}
.bar-track{background:var(--bg);border-radius:999px;height:13px;overflow:hidden;border:1px solid var(--line)}
.bar-fill{height:100%;background:var(--brand);border-radius:999px}
.bar-val{font-size:11.5px;color:var(--muted);text-align:right}
.bar-strong .bar-fill{background:var(--strong)}
.bar-strong .bar-label{color:var(--ink)}
.elbar-row{display:grid;grid-template-columns:70px 1fr 42px;align-items:center;gap:8px;margin-bottom:5px;font-size:12px}
.elbar-label{font-weight:700}
.el-bg-wood{background:var(--wood)!important}.el-bg-fire{background:var(--fire)!important}
.el-bg-earth{background:var(--earth)!important}.el-bg-metal{background:var(--metal)!important}.el-bg-water{background:var(--water)!important}

/* gauge */
.gauge{margin-top:6px}
.gauge-track{position:relative;height:14px;background:var(--bg);border:1px solid var(--line);border-radius:999px;overflow:visible}
.gauge-fill{height:100%;background:var(--brand);border-radius:999px}
.gauge-mark{position:absolute;top:-3px;width:2px;height:20px;background:var(--ink);opacity:.4}
.gauge-caption{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:12.5px;color:var(--muted)}
.badge{background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-weight:700;color:var(--ink);font-size:11.5px}

/* sections */
.report-body{margin-top:8px}
.report-section{padding:16px 0;border-bottom:1px solid var(--line)}
.report-section:last-child{border-bottom:none}
.report-section h3{font-size:16px;color:var(--ink)}
.report-section p{margin:.3em 0}
.report-section ul{margin:.3em 0;padding-left:20px}
.report-section li{margin:.2em 0}
.role-list{font-size:14px}
.derived-note{font-size:11.5px;color:var(--muted);font-style:italic;border-left:2px solid var(--line);padding-left:8px;margin-top:8px}
.fit-result{border-radius:10px;padding:14px 16px;border:1px solid var(--line)}
.fit-result.fit-strong{background:#eef8f5;border-color:#aedccd}
.fit-result.fit-workable{background:#fdf6e7;border-color:#f0d99a}
.fit-result.fit-stretch{background:#f4f5f7}
.fit-badge-lg{font-weight:800;margin-bottom:6px}
.fit-strong .fit-badge-lg{color:var(--strong)}.fit-workable .fit-badge-lg{color:var(--workable)}.fit-stretch .fit-badge-lg{color:var(--stretch)}
.timing-tag{font-size:12px;color:var(--muted);font-weight:600}
.timing-phase{font-size:17px;font-weight:800;color:var(--brand);margin:2px 0 4px}
.timing-year{margin-top:10px;background:var(--bg);border-radius:8px;padding:10px 12px;font-size:14px}
.report-foot{margin-top:20px;font-size:12px;color:var(--muted)}
.chip{display:inline-block;background:var(--bg);border:1px solid var(--line);border-radius:999px;padding:3px 10px;font-size:11.5px;margin:0 4px 4px 0;color:var(--muted)}

/* report toolbar */
.report-toolbar{max-width:860px;margin:0 auto 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}

/* dashboard */
.profile-card{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:10px;margin-bottom:8px;background:#fff;cursor:pointer}
.profile-card:hover{border-color:var(--brand-2)}
.pc-name{font-weight:700}
.pc-meta{font-size:12.5px;color:var(--muted)}
.empty{text-align:center;color:var(--muted);padding:40px}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.filters select,.filters input{width:auto;min-width:160px}

/* tiers */
.tier-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px}
.tier{border:1px solid var(--line);border-radius:12px;padding:18px;text-align:center}
.tier.current{border-color:var(--brand);outline:2px solid var(--brand)}
.tier h3{margin-bottom:2px}
.tier .price{font-size:22px;font-weight:800;color:var(--brand);margin:6px 0}
.tier .cap{color:var(--muted);font-size:13px;margin-bottom:12px}

/* ---------------- tablet / phone responsive ---------------- */
@media (max-width:768px){
  /* header reflows into rows: brand · nav · account — nothing cut off */
  .topbar{flex-wrap:wrap;gap:9px 12px;padding:12px 16px;align-items:center}
  .brand{order:1;flex:1 1 100%;font-size:18px}
  .topnav{order:2;width:100%;margin-left:0;gap:6px;flex-wrap:wrap}
  .topnav button{padding:9px 13px}
  .topbar-right{order:3;width:100%;margin-left:0;justify-content:flex-start;flex-wrap:wrap;gap:8px}
  .usage-pill{white-space:normal;line-height:1.35;max-width:100%}

  .container{padding:18px 14px 64px}
  /* page title + primary button stack, button full width */
  .section-title{align-items:stretch}
  .section-title>.btn{width:100%}

  /* filters / list-tools stack full width, comfortable tap targets */
  .filters{gap:10px}
  .filters>input,.filters>select{width:100%;min-width:0}
  .list-tools{width:100%;margin-left:0;justify-content:space-between;flex-wrap:wrap;gap:10px}
  input,select{min-height:44px}

  /* report + forms */
  .field-row{grid-template-columns:1fr}
  .report{padding:24px 18px}
  .report-visuals{grid-template-columns:1fr}
  .report-head{flex-wrap:wrap}
  .report-fit-badge{min-width:0}
  .report-toolbar{flex-wrap:wrap;gap:10px}
  .bar-row{grid-template-columns:120px 1fr 40px}
  .luck-row{grid-template-columns:repeat(5,1fr)}

  /* team + group controls */
  .group-bar{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px}
  .group-pill{white-space:nowrap}

  /* wide data tables (admin companies, active-now, history) scroll inside the
     card instead of overflowing the page; team-grid already has .grid-wrap */
  .card table:not(.team-grid){display:block;overflow-x:auto;white-space:nowrap;-webkit-overflow-scrolling:touch}
  .section-title>.btn-row{width:100%}
  /* admin company detail: name row + add-user fields stack */
  #ad-userform{grid-template-columns:1fr}
}

@media (max-width:480px){
  .topbar{padding:11px 13px}
  .container{padding:16px 12px 56px}
  .card{padding:20px 16px}
  .report{padding:20px 14px}
  .report-name{font-size:24px}
  .card-grid{grid-template-columns:1fr}
  /* profile rows: name block over the pill+✕ if tight, no overflow */
  .profile-card{flex-wrap:wrap;gap:8px 12px}
  .profile-card .btn-row{margin-left:auto}
  .bar-row{grid-template-columns:92px 1fr 34px}
  .seg i{width:28px}
}

/* compact 1–2 page report layout (fonts stay readable; we tighten spacing) */
.report{padding:26px 30px}
.report-head{padding-bottom:13px;margin-bottom:4px}
.report-name{font-size:25px}
.report-visuals{margin:13px 0;padding:11px 0;gap:20px}
.report-section{padding:9px 0}
.report-section h3{font-size:14.5px;margin-bottom:4px}
.report-section p{margin:.22em 0}
.report-section ul{margin:.25em 0}
.report-body{margin-top:4px}
.report-foot{margin-top:12px;font-size:11px}
.fit-result{padding:11px 14px}
.timing-year{margin-top:7px;padding:8px 11px}

/* =================== PRINT / PDF =================== */
@media print{
  .topbar,.report-toolbar,.no-print{display:none!important}
  body{background:#fff}
  .report{box-shadow:none;border:none;max-width:none;padding:0}
  .report-section{break-inside:avoid}
  .report-visuals{break-inside:avoid}
}

/* =================== branding / trial / admin (v2 additions, premium palette) =================== */
.app-foot{text-align:center;color:var(--muted);font-size:11px;padding:22px 12px 32px;letter-spacing:.12em;text-transform:uppercase}
.tagline{font-size:13px;color:var(--ink);background:var(--surface-2);border-left:3px solid var(--gold);
  padding:12px 14px;border-radius:0 10px 10px 0;margin:14px 0 4px;line-height:1.55}
.trial-banner{font-size:13px;color:var(--muted);background:var(--surface-2);border:1px solid var(--line);
  border-radius:10px;padding:10px 14px;margin-bottom:14px}
.trial-banner:empty{display:none}
.trial-block{text-align:center;max-width:520px;margin:10px auto;padding:40px}
.trial-block .trial-icon{color:var(--gold);font-size:26px;margin-bottom:6px}
.trial-block .trial-msg{font-size:16px;font-weight:600;margin:6px 0 20px}
.row-sel td{background:var(--surface-2)!important}
tr[data-co]{cursor:pointer}
/* modal */
.modal-overlay{position:fixed;inset:0;background:rgba(26,33,48,.45);display:flex;align-items:center;
  justify-content:center;z-index:100;padding:20px}
.modal{background:var(--surface);border-radius:var(--radius);box-shadow:0 20px 60px rgba(20,30,60,.3);
  padding:26px 28px;max-width:440px;width:100%}
.modal h3{margin-top:0}
.preview-tbl{width:100%;border-collapse:collapse;margin-top:6px}
.preview-tbl td{padding:9px 4px;border-bottom:1px solid var(--line);font-size:14px}
.preview-tbl td:first-child{color:var(--muted);width:40%;text-transform:uppercase;font-size:11.5px;letter-spacing:.04em}
.preview-tbl td:last-child{font-weight:600}

.online-dot{display:inline-block;width:8px;height:8px;border-radius:50%;background:#2e7d63;
  margin-right:6px;vertical-align:middle;box-shadow:0 0 0 3px rgba(46,125,99,.18)}

/* ---------- team fit ---------- */
.chip-select{display:flex;flex-wrap:wrap;gap:8px 16px;margin:6px 0 4px}
.pick{display:inline-flex;align-items:center;gap:6px;font-size:14px;font-weight:600;text-transform:none;letter-spacing:0;margin:0}
.pick input{width:auto}
.anchor-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}
.anchor-row select{max-width:220px}
.band-pill{display:inline-block;font-size:12px;font-weight:800;padding:4px 11px;border-radius:999px;color:#fff}
.band-strong{background:#2e7d63}.band-workable{background:#3e8fa6}
.band-needs-management{background:#b0883f}.band-high-friction{background:#c25b52}
.seg{display:flex;gap:4px;margin-top:4px}
.seg i{width:38px;height:8px;border-radius:3px;background:var(--line)}
.seg i.on{background:var(--c)}
.team-summary{background:var(--surface-2);border:1px solid var(--line);border-left:3px solid var(--brand);
  border-radius:0 8px 8px 0;padding:11px 14px;font-weight:600;margin-bottom:14px}
.grid-wrap{overflow-x:auto}
.team-grid{border-collapse:separate;border-spacing:4px}
.team-grid th.grid-h{font-size:12px;color:var(--ink);text-transform:none;letter-spacing:0;white-space:nowrap;padding:4px 8px;text-align:left}
.team-grid td{padding:0}
.grid-cell{color:#fff;font-weight:700;font-size:11.5px;text-align:center;padding:10px 10px;border-radius:7px;min-width:96px}
.grid-self{background:var(--bg);border-radius:7px;color:var(--muted);text-align:center;min-width:96px}
.grid-legend{display:flex;flex-wrap:wrap;gap:14px;margin-top:12px;font-size:12px;color:var(--muted)}
.grid-legend i{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:5px;vertical-align:middle}
/* accordion write-ups (native <details>) */
.flagged{border:1px solid var(--line);border-radius:10px;margin-bottom:10px;overflow:hidden}
.flagged.flag-amber{border-left:4px solid #b0883f}
.flagged.flag-red{border-left:4px solid #c25b52}
.flagged summary{display:flex;align-items:center;gap:10px;cursor:pointer;padding:12px 15px;font-weight:700;list-style:none}
.flagged summary::-webkit-details-marker{display:none}
.flagged .wu-names{flex:0 0 auto}
.flagged .chev{margin-left:auto;transition:transform .15s ease;color:var(--muted)}
.flagged[open] .chev{transform:rotate(180deg)}
.flagged .wu-body{padding:0 15px 14px}
.flagged.flag-amber[open]{background:#fdf8ef}
.flagged.flag-red[open]{background:#fdf0ee}
.flagged p{margin:.3em 0;font-size:14px}
.flagged.flash{box-shadow:0 0 0 3px rgba(58,143,166,.45)}
.pair-card{margin-top:6px}
.owner-fit{border-left:4px solid var(--gold)}
.group-bar{display:flex;flex-wrap:wrap;gap:8px;align-items:center}
.group-pill{background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:7px 14px;
  font-weight:600;font-size:13px;cursor:pointer;color:var(--ink)}
.group-pill:hover{background:var(--bg)}
.group-pill.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.group-pill.add{color:var(--brand-2);border-style:dashed}
.grid-cell.clickable{cursor:pointer}
.grid-cell.clickable:hover{filter:brightness(1.07);outline:2px solid rgba(0,0,0,.18);outline-offset:-2px}
.group-pill.icon-only{width:34px;height:34px;padding:0;font-size:18px;line-height:1;display:inline-flex;align-items:center;justify-content:center}
/* red ✕ delete icon (replaces the word "Delete") */
.del-x{background:none;border:none;cursor:pointer;color:#c25b52;font-size:15px;line-height:1;
  width:28px;height:28px;border-radius:7px;display:inline-flex;align-items:center;justify-content:center;padding:0;opacity:.7}
.del-x:hover{opacity:1;background:#fdf0ee}
.del-x-abs{position:absolute;top:10px;right:10px}
.pc-grid{position:relative;padding-right:40px}
.empty-prompt{text-align:center;padding:34px}
.explainer{font-size:12.5px;line-height:1.55;background:var(--surface-2);border-radius:8px;padding:10px 13px;margin:6px 0 12px}
.qp-note{font-size:14px;line-height:1.6;max-width:640px}

/* list tools: per-page + view toggle */
.list-tools{display:flex;align-items:center;gap:14px;margin-left:auto}
.perpage{font-size:12.5px;color:var(--muted);text-transform:none;letter-spacing:0;margin:0;font-weight:600;display:inline-flex;align-items:center;gap:6px}
.perpage select{width:auto;padding:6px 8px}
.view-toggle{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.view-toggle button{background:var(--surface);border:none;padding:7px 12px;cursor:pointer;font-size:14px;color:var(--muted)}
.view-toggle button.active{background:var(--brand);color:#fff}

/* pager */
.pager{display:flex;flex-wrap:wrap;gap:6px;align-items:center;justify-content:center;margin-top:16px}
.pager button{background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:7px 12px;cursor:pointer;font-size:13px;font-weight:600;color:var(--ink)}
.pager .pg-num.active{background:var(--brand);color:#fff;border-color:var(--brand)}
.pager button:disabled{opacity:.45;cursor:not-allowed}

/* grid (card) views */
.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:12px}
.pc-grid{display:block}
.pc-grid .pc-top{display:flex;justify-content:space-between;align-items:center;gap:8px;margin-bottom:4px}
.pc-grid .pc-foot{display:flex;justify-content:space-between;align-items:center;margin-top:10px}
.wu-cardgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:10px}
.wu-cardgrid .flagged{margin-bottom:0}

/* members multi-select */
.ms-chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;min-height:4px}
.ms-chip{display:inline-flex;align-items:center;gap:6px;background:var(--surface-2);border:1px solid var(--line);border-radius:999px;padding:4px 6px 4px 11px;font-size:13px;font-weight:600}
.ms-chip button{background:none;border:none;cursor:pointer;color:var(--muted);font-size:15px;line-height:1;padding:0 2px}
.ms-chip button:hover{color:var(--fire)}
.ms-field{position:relative}
.ms-field input{padding-right:38px}
.ms-chev{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--muted);font-size:14px}
.ms-drop{display:none;position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:5;background:var(--surface);
  border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);max-height:240px;overflow-y:auto;padding:4px}
.ms-drop.open{display:block}
.ms-row{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:7px;cursor:pointer;font-size:14px;font-weight:500;text-transform:none;letter-spacing:0;margin:0}
.ms-row:hover{background:var(--surface-2)}
.ms-row input{width:auto}
.ms-empty{padding:10px 12px;font-size:13px}
.strengths-line{background:var(--surface-2);border-radius:8px;padding:8px 11px;font-size:13.5px}
.timing-line{color:var(--brand);font-weight:600;font-size:13.5px;margin-top:8px}

.icon-btn{font-size:17px;line-height:1;padding:8px 10px;border-radius:9px}
.icon-btn:hover{background:var(--surface-2)}
.icon-btn.active{background:var(--brand);color:#fff}

/* password field with show/hide eye */
.pw-wrap{position:relative}
.pw-wrap .pw-input{padding-right:46px}
.pw-eye{position:absolute;right:6px;top:50%;transform:translateY(-50%);background:none;border:none;
  cursor:pointer;color:var(--muted);padding:6px;display:inline-flex;align-items:center;border-radius:8px}
.pw-eye:hover{color:var(--ink);background:var(--surface-2)}
.pw-eye .eye-hide{display:none}
.pw-eye.on .eye-show{display:none}
.pw-eye.on .eye-hide{display:inline-flex}


/* =================== NEW EDITORIAL SKIN (Daniel Siew design) =================== */
/* Spectral serif for display headings/names; Hanken stays for labels & body */
h1,h2,.brand,.report-name,.pc-name,.report-section h3,.fit-band,.fit-badge-lg,
.timing-phase,.modal h3,.tier h3,.report-kicker+.report-name{
  font-family:"Spectral",Georgia,"Times New Roman",serif;font-weight:500;letter-spacing:-.01em}
.report-kicker,.visual-title,.mini-title,label,th,.perpage,.usage-pill,.group-pill,.tag,.band-pill,
.report-fit-badge .fit-sub,.chart-caption,.grid-h{font-family:"Hanken Grotesk",sans-serif}
.brand{color:var(--ink);font-weight:500}
.brand small{color:var(--gold)}
.brand-by{font-family:"Hanken Grotesk",sans-serif;font-size:12px;font-weight:400;color:#7d7563;letter-spacing:0;text-transform:none}
a{color:var(--gold)} a:hover{color:var(--gold-deep)}

/* inputs / buttons on paper */
input,select,textarea{background:#fffdf7}
.btn{background:var(--ink);color:#f4efe4}
.btn:hover{background:#1f1b16}
.btn.secondary{background:var(--surface);color:var(--ink);border-color:#ddd4c2}
.btn.secondary:hover{background:#f3ecda}
.usage-pill{background:#f1ead9;border-color:var(--line)}
.topnav button.active{background:var(--ink);color:#f4efe4}

/* soft tag chips */
.tag.strong{background:#e6ebdd;color:#4f5f47}
.tag.workable{background:#e1e9ec;color:#42606b}
.tag.stretch{background:#ece4d2;color:#8c8473}
.tag.ent{background:#efe7d6;color:#6c5326}

/* solid band pills + grid colours */
.band-strong{background:#5c6e54}.band-workable{background:#4f6a74}
.band-needs-management{background:#997a3c}.band-high-friction{background:#9c5644}
.report-fit-badge.fit-strong{background:#5c6e54}.report-fit-badge.fit-workable{background:#4f6a74}.report-fit-badge.fit-stretch{background:#8c8473}
.fit-result.fit-strong{background:#eef3e6;border-color:#dde6d2}
.fit-result.fit-workable{background:#e9eff2;border-color:#d6e2e7}
.fit-result.fit-stretch{background:#f3ecda;border-color:#e6ddc6}
.fit-strong .fit-badge-lg{color:#4f5f47}.fit-workable .fit-badge-lg{color:#42606b}.fit-stretch .fit-badge-lg{color:#8c8473}

/* bars + gauge */
.bar-track,.gauge-track,.elbar-row .bar-track{background:#efe7d6;border-color:var(--line)}
.bar-fill{background:#b8a983}
.bar-strong .bar-fill{background:#6c5326}
.bar-strong .bar-label{color:var(--ink)}
.gauge-fill{background:#7a6a4a}
.gauge-mark{background:var(--ink)}
.badge{background:#f1ead9;border-color:var(--line);color:var(--ink)}

/* report chrome */
.report-head{border-bottom-color:var(--ink)}
.report-kicker{color:var(--gold)}
.pillar{background:#fffdf7;border-color:var(--line)}
.pillar-label{background:#f3ecda;border-color:#ece4d2;color:#9a917d}
.pillar-day{outline-color:var(--gold)}
.luck-cell{background:#fffdf7;border-color:var(--line)}
.luck-current{outline-color:var(--accent);background:#eef3e6}

/* delete ✕ in muted terracotta */
.del-x{color:#bf6a55}.del-x:hover{background:#f6e7df}

/* banners / notes on paper */
.trial-banner{background:#f3ecda;border-color:#e6ddc6;color:var(--muted)}
.explainer{background:#f3ecda}
.team-summary{background:#f3ecda;border-color:var(--line);border-left-color:var(--gold)}
.tagline{background:#f3ecda;border-left-color:var(--gold)}
.ok-box{background:#eef3e6;border-color:#dde6d2;color:#4f5f47}
.online-dot{background:#5c6e54;box-shadow:0 0 0 3px rgba(92,110,84,.18)}
.group-pill.active{background:var(--ink);color:#f4efe4;border-color:var(--ink)}
.view-toggle button.active{background:var(--ink)}
.pager .pg-num.active{background:var(--ink);border-color:var(--ink)}
.del-x-abs{color:#bf6a55}

/* paper-grain overlay */
.texture{position:fixed;inset:0;z-index:60;pointer-events:none;mix-blend-mode:multiply;opacity:.30;
  background-size:160px 160px;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='160' height='160' filter='url(%23n)'/%3E%3C/svg%3E")}
@media print{.texture{display:none}}

/* ---- friendly empty states ---- */
.empty-state{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center;padding:34px 18px;color:#7d7563}
.empty-ico{font-size:30px;line-height:1;opacity:.75}
.empty-state p{margin:0;max-width:400px;line-height:1.55}

/* ---- first-login onboarding tour ---- */
#tour-root{position:fixed;inset:0;z-index:4000}
#tour-root.no-target{background:rgba(44,40,35,.55)}
.tour-ring{position:fixed;display:none;border-radius:12px;border:2px solid var(--gold);box-shadow:0 0 0 9999px rgba(44,40,35,.55);transition:top .18s ease,left .18s ease,width .18s ease,height .18s ease;pointer-events:none}
.tour-bubble{position:fixed;width:320px;max-width:calc(100vw - 24px);background:var(--surface);color:var(--ink);border:1px solid rgba(44,40,35,.10);border-radius:14px;box-shadow:0 18px 50px rgba(0,0,0,.30);padding:18px;z-index:4001}
.tour-text{margin:0 0 14px;font-size:15px;line-height:1.5}
.tour-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.tour-dots{display:flex;gap:6px}
.tour-dots i{width:7px;height:7px;border-radius:50%;background:rgba(44,40,35,.18)}
.tour-dots i.on{background:var(--gold)}
.tour-actions{display:flex;align-items:center;gap:14px;margin-left:auto}
.tour-skip{background:none;border:none;color:#7d7563;font:inherit;font-size:13px;cursor:pointer;text-decoration:underline;padding:4px}
.tour-next{padding:8px 20px}
@media(max-width:480px){.tour-bubble{padding:15px}.tour-text{font-size:14px}}
