*{box-sizing:border-box;margin:0;padding:0}
:root{
  --ink:#EEF1F6; --panel:#FFFFFF; --panel2:#F6F8FC; --panel3:#E9EEF6; --line:#DCE3EE; --line2:#C4CEDD;
  --gold:#00205A; --gold-soft:#2E6FD6; --gold-deep:#103B7E; --gold-dim:#9DB1D4;
  --text:#16233E; --muted:#586A86; --muted2:#8C99AE;
  --ok:#1FA85A; --ok-dim:#D7F1E2; --warn:#DE7A22; --danger:#D93B36;
  --cream:#FBFCFE;
  --r:14px; --r2:10px; --r3:7px;
  --shadow:0 18px 44px -22px rgba(15,35,79,.40);
  --sans:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,Helvetica,Arial,sans-serif;
  --disp:'Bebas Neue','Inter',sans-serif;
  --mono:'JetBrains Mono',ui-monospace,'SF Mono',Menlo,monospace;
}
html{background:var(--ink);-webkit-text-size-adjust:100%}
body{font-family:var(--sans);background:radial-gradient(1200px 700px at 80% -10%,rgba(0,32,90,.05),transparent 60%),var(--ink);color:var(--text);min-height:100vh;line-height:1.45;font-size:14px}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:13px;color:var(--text);background:var(--panel2);border:1px solid var(--line);border-radius:var(--r3);padding:7px 9px;width:100%;transition:border-color .15s,box-shadow .15s}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--gold-deep);box-shadow:0 0 0 3px rgba(0,32,90,.14)}
input::placeholder,textarea::placeholder{color:var(--muted2)}
select{appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 15px) 52%,calc(100% - 10px) 52%;background-size:5px 5px,5px 5px;background-repeat:no-repeat;padding-right:26px}
a{color:var(--gold-soft)}
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-thumb{background:var(--line2);border-radius:10px;border:2px solid var(--ink)}
::-webkit-scrollbar-track{background:transparent}

/* ===== Shell ===== */
.app{display:grid;grid-template-columns:300px 1fr;min-height:100vh}
.sidebar{background:linear-gradient(180deg,#FFFFFF,#F2F5FA);border-right:1px solid var(--line);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.brand{padding:22px 22px 18px;border-bottom:1px solid rgba(255,255,255,.08);background:linear-gradient(140deg,#012A6B,#001A4A)}
.brand h1{font-family:var(--disp);font-size:30px;letter-spacing:3px;line-height:.95;font-weight:400;color:#FFFFFF}
.brand h1 b{color:#4FB4DE;font-weight:400}
.brand .sub{font-size:10px;letter-spacing:2.5px;text-transform:uppercase;color:#AEBCD6;margin-top:3px}
.roster-head{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 8px}
.roster-head span{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.btn-add{background:var(--gold);color:#fff;font-weight:700;font-size:12px;padding:6px 11px;border-radius:var(--r3);display:inline-flex;align-items:center;gap:5px;transition:filter .15s,transform .1s}
.btn-add:hover{filter:brightness(1.08)}.btn-add:active{transform:translateY(1px)}
.search{padding:0 14px 8px}
.roster{flex:1;overflow-y:auto;padding:4px 10px 14px}
.agent-card{position:relative;padding:11px 12px 11px 14px;border-radius:var(--r2);border:1px solid transparent;cursor:pointer;margin-bottom:5px;transition:background .15s,border-color .15s}
.agent-card:hover{background:var(--panel)}
.agent-card.active{background:linear-gradient(180deg,var(--panel2),var(--panel));border-color:var(--line2)}
.agent-card.active::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:linear-gradient(180deg,var(--gold),var(--gold-deep))}
.agent-card .nm{font-weight:600;font-size:14px;display:flex;align-items:center;gap:7px}
.agent-card .meta{font-size:11px;color:var(--muted);margin-top:2px;display:flex;gap:8px;flex-wrap:wrap}
.rank-chip{font-size:9px;font-weight:800;letter-spacing:.5px;padding:2px 6px;border-radius:20px;background:rgba(0,32,90,.14);color:var(--gold-soft);border:1px solid rgba(0,32,90,.22)}
.mini-bar{height:4px;border-radius:4px;background:var(--panel3);margin-top:8px;overflow:hidden}
.mini-bar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold-deep),var(--gold));border-radius:4px;transition:width .4s}
.roster-empty{color:var(--muted2);font-size:12px;text-align:center;padding:30px 16px;line-height:1.6}
.side-foot{border-top:1px solid var(--line);padding:10px 14px;display:flex;gap:7px;flex-wrap:wrap}
.side-foot button{font-size:11px;color:var(--muted);padding:6px 9px;border-radius:var(--r3);border:1px solid var(--line);flex:1;transition:color .15s,border-color .15s}
.side-foot button:hover{color:var(--gold-soft);border-color:var(--gold-deep)}

/* ===== Main ===== */
.main{display:flex;flex-direction:column;min-width:0}
.empty-main{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;text-align:center;color:var(--muted);gap:14px;padding:40px}
.empty-main h2{font-family:var(--disp);font-size:34px;letter-spacing:2px;color:var(--text)}

.topbar{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);padding:16px 26px 0}
.tb-row{display:flex;align-items:flex-start;gap:20px;justify-content:space-between;flex-wrap:wrap}
.tb-id h2{font-family:var(--disp);font-size:32px;letter-spacing:1.5px;line-height:1;display:flex;align-items:center;gap:12px}
.tb-id .chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:9px}
.chip{font-size:11px;color:var(--muted);background:var(--panel2);border:1px solid var(--line);padding:4px 9px;border-radius:20px;display:inline-flex;align-items:center;gap:5px}
.chip b{color:var(--text);font-weight:600}
.tb-stats{display:flex;gap:24px;align-items:center}
.ring{--p:0;width:64px;height:64px;border-radius:50%;display:grid;place-items:center;background:conic-gradient(var(--gold) calc(var(--p)*1%),var(--panel3) 0);position:relative;flex-shrink:0}
.ring::before{content:"";position:absolute;inset:6px;border-radius:50%;background:var(--ink)}
.ring .pv{position:relative;font-weight:800;font-size:16px;color:var(--gold)}
.ring .pl{position:relative;font-size:8px;letter-spacing:1px;color:var(--muted);text-transform:uppercase;margin-top:-2px}
.tb-rank{text-align:right}
.tb-rank .lab{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.tb-rank .val{font-family:var(--disp);font-size:24px;letter-spacing:1px;color:var(--gold);line-height:1}
.tabs{display:flex;gap:2px;margin-top:14px;overflow-x:auto}
.tab{padding:10px 15px;font-size:13px;font-weight:500;color:var(--muted);border-bottom:2px solid transparent;white-space:nowrap;transition:color .15s,border-color .15s;display:flex;align-items:center;gap:7px}
.tab:hover{color:var(--text)}
.tab.active{color:var(--gold);border-bottom-color:var(--gold)}
.tab .badge{font-size:10px;background:var(--panel3);color:var(--muted);padding:1px 6px;border-radius:10px;font-weight:700}
.tab.active .badge{background:rgba(0,32,90,.12);color:var(--gold-soft)}

.content{padding:24px 26px 60px;max-width:1320px;width:100%}
.section-title{font-family:var(--disp);font-size:22px;letter-spacing:1.5px;color:var(--text);margin:4px 0 14px;display:flex;align-items:center;gap:10px}
.section-title .ct{font-size:12px;color:var(--muted);letter-spacing:0;font-family:var(--sans);font-weight:500}

/* cards / panels */
.panel{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:var(--r);padding:18px 20px;margin-bottom:18px;box-shadow:0 1px 2px rgba(16,35,79,.05),0 10px 26px -18px rgba(16,35,79,.18)}
.panel-h{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}
.panel-h h3{font-size:15px;font-weight:600;letter-spacing:.2px;display:flex;align-items:center;gap:9px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.field{display:flex;flex-direction:column;gap:5px;margin-bottom:11px}
.field label{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}

/* progress bar */
.pbar{height:7px;border-radius:6px;background:var(--panel3);overflow:hidden;flex:1}
.pbar i{display:block;height:100%;background:linear-gradient(90deg,var(--gold-deep),var(--gold));transition:width .4s}
.pbar.ok i{background:linear-gradient(90deg,var(--ok-dim),var(--ok))}

/* ===== System checklist ===== */
.phase{margin-bottom:16px;border:1px solid var(--line);border-radius:var(--r);overflow:hidden;background:var(--panel);box-shadow:0 1px 2px rgba(16,35,79,.05),0 10px 26px -18px rgba(16,35,79,.18)}
.phase-h{display:flex;align-items:center;gap:14px;padding:14px 18px;cursor:pointer;background:linear-gradient(180deg,var(--panel2),var(--panel));transition:background .15s}
.phase-h:hover{background:var(--panel3)}
.phase-h .pname{font-family:var(--disp);font-size:19px;letter-spacing:1px;color:var(--text);flex-shrink:0}
.phase-h .pcount{font-size:12px;color:var(--gold-soft);font-weight:700;font-variant-numeric:tabular-nums}
.phase-h .chev{color:var(--muted);transition:transform .2s;margin-left:auto}
.phase.collapsed .chev{transform:rotate(-90deg)}
.phase.collapsed .phase-body{display:none}
.phase.done .phase-h .pname{color:var(--gold)}
.phase-body{padding:6px 18px 16px}
.group{padding:12px 0;border-bottom:1px solid var(--line)}
.group:last-child{border-bottom:none}
.group-h{display:flex;align-items:center;gap:12px;margin-bottom:9px}
.group-h .gt{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:700;white-space:nowrap}
.group-h .gc{font-size:11px;color:var(--muted2);font-variant-numeric:tabular-nums}
.checks{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:6px}
.check{display:flex;align-items:center;gap:10px;padding:9px 11px;border-radius:var(--r3);background:var(--panel2);border:1px solid var(--line);cursor:pointer;transition:background .12s,border-color .12s;user-select:none}
.check:hover{background:var(--panel3);border-color:var(--line2)}
.check .box{width:18px;height:18px;border-radius:5px;border:1.5px solid var(--line2);flex-shrink:0;display:grid;place-items:center;transition:all .15s}
.check .box svg{width:11px;height:11px;stroke:#fff;stroke-width:3.5;opacity:0}
.check .lab{font-size:13px;color:var(--text)}
.check.on{background:rgba(31,168,90,.10);border-color:rgba(31,168,90,.45)}
.check.on .box{background:var(--ok);border-color:var(--ok)}
.check.on .box svg{opacity:1}
.check.on .lab{color:var(--muted)}

/* progressions badges */
.prog-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:8px}
.prog{display:flex;align-items:center;gap:10px;padding:11px 13px;border-radius:var(--r2);background:var(--panel2);border:1px solid var(--line);cursor:pointer;transition:all .15s}
.prog:hover{border-color:var(--line2)}
.prog .ic{width:26px;height:26px;border-radius:50%;border:1.5px solid var(--line2);display:grid;place-items:center;flex-shrink:0;color:var(--muted2);font-size:13px;transition:all .15s}
.prog .pl{font-size:12.5px;font-weight:500}
.prog.on{background:linear-gradient(180deg,rgba(0,32,90,.10),rgba(0,32,90,.03));border-color:rgba(0,32,90,.4)}
.prog.on .ic{background:var(--gold);border-color:var(--gold);color:#fff}
.prog.on .pl{color:var(--gold-soft)}

/* ===== Tables ===== */
.tablewrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r);background:var(--panel);box-shadow:0 1px 2px rgba(16,35,79,.05),0 10px 26px -18px rgba(16,35,79,.18)}
table{border-collapse:collapse;width:100%;font-size:13px}
thead th{position:sticky;top:0;background:var(--panel3);text-align:left;font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted);font-weight:700;padding:11px 10px;white-space:nowrap;border-bottom:1px solid var(--line2)}
tbody td{padding:5px 7px;border-bottom:1px solid var(--line);vertical-align:middle}
tbody tr:hover{background:rgba(0,32,90,.04)}
td input,td select,td textarea{background:transparent;border:1px solid transparent;border-radius:5px;padding:6px 7px}
td input:hover,td select:hover,td textarea:hover{border-color:var(--line)}
td input:focus,td select:focus,td textarea:focus{background:var(--panel2);border-color:var(--gold-deep)}
td.num{text-align:right;font-variant-numeric:tabular-nums;font-family:var(--mono);font-size:12px;color:var(--gold-soft);white-space:nowrap;padding-right:12px}
td.idx{color:var(--muted2);font-size:11px;text-align:center;width:34px;font-variant-numeric:tabular-nums}
.row-x{color:var(--muted2);width:30px;text-align:center}
.row-x button{width:22px;height:22px;border-radius:5px;color:var(--muted2);transition:all .12s}
.row-x button:hover{background:rgba(217,59,54,.12);color:var(--danger)}
.cell-toggle{width:42px;height:23px;border-radius:20px;background:var(--panel3);border:1px solid var(--line2);position:relative;cursor:pointer;transition:background .15s;margin:0 auto}
.cell-toggle::after{content:"";position:absolute;top:1.5px;left:1.5px;width:18px;height:18px;border-radius:50%;background:var(--muted);transition:transform .18s,background .15s}
.cell-toggle.on{background:var(--ok-dim);border-color:var(--ok)}
.cell-toggle.on::after{transform:translateX(19px);background:var(--ok)}
.tbl-foot{display:flex;align-items:center;gap:14px;padding:11px 14px;border-top:1px solid var(--line2);background:var(--panel2);flex-wrap:wrap}
.btn-row{background:var(--panel3);border:1px solid var(--line2);color:var(--gold-soft);font-weight:600;font-size:12px;padding:8px 14px;border-radius:var(--r3);display:inline-flex;align-items:center;gap:6px;transition:all .15s}
.btn-row:hover{background:var(--panel3);border-color:var(--gold-deep);filter:brightness(1.1)}
.totals{display:flex;gap:22px;margin-left:auto;flex-wrap:wrap}
.total{text-align:right}
.total .l{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.total .v{font-family:var(--mono);font-size:16px;font-weight:600;color:var(--gold)}

/* dreams */
.dream-row{display:grid;grid-template-columns:40px 130px 1fr 1fr 30px;gap:8px;align-items:center;padding:5px 0}
.dream-row .di{color:var(--gold-deep);font-family:var(--disp);font-size:18px;text-align:center}

/* EMD */
.emd-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.emd-month{background:var(--panel2);border:1px solid var(--line);border-radius:var(--r2);padding:14px;box-shadow:0 1px 2px rgba(16,35,79,.05),0 10px 26px -18px rgba(16,35,79,.18)}
.emd-month h4{font-family:var(--disp);font-size:17px;letter-spacing:1px;color:var(--gold-soft);margin-bottom:10px;display:flex;justify-content:space-between;align-items:baseline}
.emd-month h4 .mp{font-family:var(--mono);font-size:13px;color:var(--gold)}
.emd-total{display:flex;align-items:center;gap:16px;background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--gold-deep);border-radius:var(--r);padding:16px 20px;margin-bottom:16px}
.emd-total .big{font-family:var(--mono);font-size:26px;font-weight:700;color:var(--gold)}

/* partners */
.partner{background:var(--panel2);border:1px solid var(--line);border-radius:var(--r2);margin-bottom:10px;overflow:hidden;box-shadow:0 1px 2px rgba(16,35,79,.05),0 10px 26px -18px rgba(16,35,79,.18)}
.partner-h{display:grid;grid-template-columns:1fr auto auto;gap:12px;align-items:center;padding:12px 16px;cursor:pointer}
.partner-h:hover{background:var(--panel3)}
.partner-h .pn{font-weight:600}
.partner-body{padding:4px 16px 16px;border-top:1px solid var(--line);display:none}
.partner.open .partner-body{display:block}
.flagset{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:5px;margin-top:10px}

/* toast */
.toast{position:fixed;bottom:22px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--panel3);border:1px solid var(--line2);color:var(--text);padding:11px 20px;border-radius:30px;font-size:13px;font-weight:500;box-shadow:var(--shadow);opacity:0;pointer-events:none;transition:all .25s;z-index:100;display:flex;align-items:center;gap:9px}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast .dot{width:8px;height:8px;border-radius:50%;background:var(--ok)}
.save-pill{font-size:11px;color:var(--muted2);display:flex;align-items:center;gap:6px}
.save-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--ok);transition:opacity .2s}

/* misc */
.hint{font-size:12px;color:var(--muted);background:var(--panel2);border:1px solid var(--line);border-left:3px solid var(--gold-deep);border-radius:var(--r3);padding:11px 14px;margin-bottom:16px;line-height:1.55}
.muted{color:var(--muted)}
.btn-ghost{border:1px solid var(--line2);color:var(--muted);font-size:12px;padding:7px 12px;border-radius:var(--r3);transition:all .15s}
.btn-ghost:hover{color:var(--gold-soft);border-color:var(--gold-deep)}
.split{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.choose-one{font-size:11px;color:var(--gold-deep);font-weight:700;letter-spacing:1px;text-transform:uppercase}

@media(max-width:980px){
  .app{grid-template-columns:1fr}
  .sidebar{position:fixed;left:0;top:0;width:300px;z-index:60;transform:translateX(-100%);transition:transform .25s}
  .sidebar.open{transform:translateX(0)}
  .grid2,.grid3{grid-template-columns:1fr}
  .menu-btn{display:inline-flex!important}
  .scrim{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:55;display:none}
  .scrim.show{display:block}
}
.menu-btn{display:none;align-items:center;gap:7px}

/* ===== Team Dashboard ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(178px,1fr));gap:14px;margin-bottom:18px}
.kpi{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:var(--r2);padding:16px 16px 15px;box-shadow:0 1px 2px rgba(16,35,79,.05),0 10px 26px -18px rgba(16,35,79,.18)}
.kpi .l{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.kpi .v{font-family:var(--disp);font-size:30px;letter-spacing:1px;color:var(--gold);line-height:1.05;margin-top:6px}
.kpi .ksub{font-size:11px;color:var(--muted2);margin-top:3px}
.rank-tag{font-size:11px;color:var(--muted);white-space:nowrap}.rank-tag b{color:var(--text);font-weight:700}
.dash-row{cursor:pointer;transition:background .12s}
.dash-row:hover{background:rgba(0,32,90,.04)}
.da-name{font-weight:600;font-size:13.5px}.da-sub{font-size:11px;color:var(--muted);margin-top:1px}
.nav-dash{display:flex;align-items:center;gap:9px;padding:10px 12px;margin:0 0 6px;border-radius:var(--r2);cursor:pointer;font-weight:600;font-size:13px;color:var(--muted);border:1px solid transparent;transition:all .14s}
.nav-dash:hover{background:var(--panel);color:var(--text)}
.nav-dash.active{background:linear-gradient(180deg,var(--panel2),var(--panel));border-color:var(--line2);color:var(--text)}
.nav-dash .di{width:18px;height:18px;display:grid;place-items:center;color:var(--gold-soft);font-size:14px}
.roster-sub{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted2);padding:6px 4px 6px;margin-top:2px}
.dash-back{font-size:11px;font-weight:600;color:var(--gold-soft);border:1px solid var(--line2);padding:5px 11px;border-radius:20px;transition:all .14s;line-height:1}
.dash-back:hover{border-color:var(--gold-deep);background:var(--panel2)}

/* ===== Pipeline cards (Recruits / Field Trainings) ===== */
.rec-list{display:flex;flex-direction:column;gap:8px}
.rec-card{display:flex;align-items:center;gap:14px;background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:var(--r2);padding:11px 13px;box-shadow:0 1px 2px rgba(16,35,79,.05),0 8px 22px -18px rgba(16,35,79,.16);transition:border-color .14s,box-shadow .14s}
.rec-card:hover{border-color:var(--line2);box-shadow:0 1px 2px rgba(16,35,79,.06),0 14px 30px -18px rgba(16,35,79,.24)}
.rec-stat{width:32px;height:32px;border-radius:50%;border:2px solid var(--line2);flex-shrink:0;cursor:pointer;display:grid;place-items:center;transition:all .15s}
.rec-stat span{width:11px;height:11px;border-radius:50%;background:var(--line2);transition:all .15s}
.rec-stat:hover{border-color:var(--ok)}
.rec-stat.on{border-color:var(--ok);background:rgba(31,168,90,.12)}.rec-stat.on span{background:var(--ok)}
.rec-main{flex:1;min-width:0;cursor:pointer}
.rec-name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-meta{font-size:12px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.rec-appt{color:var(--gold-soft);font-weight:600;margin-left:4px}
.rec-tags{flex-shrink:0}
.rec-pill{font-size:10px;font-weight:700;letter-spacing:.5px;text-transform:uppercase;padding:4px 10px;border-radius:20px;background:var(--panel3);color:var(--muted2);border:1px solid var(--line);white-space:nowrap}
.rec-pill.on{background:rgba(31,168,90,.12);color:#127A40;border-color:rgba(31,168,90,.35)}
.rec-edit{flex-shrink:0;font-size:12px;font-weight:600;color:var(--gold-soft);border:1px solid var(--line2);padding:7px 13px;border-radius:var(--r3);transition:all .14s}
.rec-edit:hover{border-color:var(--gold-deep);background:var(--panel2)}
.rec-del{flex-shrink:0;width:30px;height:30px;border-radius:var(--r3);color:var(--muted2);transition:all .12s}
.rec-del:hover{background:rgba(217,59,54,.12);color:var(--danger)}
.rec-empty{color:var(--muted2);font-size:13px;text-align:center;padding:34px 16px;border:1px dashed var(--line2);border-radius:var(--r2)}

/* ===== Modal record editor ===== */
.modal-overlay{position:fixed;inset:0;z-index:200;display:none;align-items:flex-start;justify-content:center;padding:42px 18px;background:rgba(15,31,61,.45);backdrop-filter:blur(3px);overflow-y:auto}
.modal-overlay.show{display:flex}
.modal{width:100%;max-width:720px;background:var(--panel);border:1px solid var(--line2);border-radius:var(--r);box-shadow:0 40px 90px -30px rgba(7,18,46,.6);animation:modalIn .18s ease;margin:auto}
@keyframes modalIn{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}
.modal-h{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:18px 22px 14px;border-bottom:1px solid var(--line)}
.mh-t{font-family:var(--disp);font-size:24px;letter-spacing:1px;color:var(--text);line-height:1}
.mh-s{font-size:12px;color:var(--muted);margin-top:6px}
.modal-x{width:32px;height:32px;border-radius:var(--r3);color:var(--muted);border:1px solid var(--line);flex-shrink:0;transition:all .14s}
.modal-x:hover{color:var(--text);border-color:var(--line2);background:var(--panel2)}
.modal-b{padding:18px 22px}
.switch-row{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}
.switch{display:inline-flex;align-items:center;gap:9px;padding:8px 14px 8px 9px;border-radius:30px;border:1px solid var(--line);background:var(--panel2);font-size:13px;font-weight:600;color:var(--muted);transition:all .15s}
.switch .kn{width:34px;height:19px;border-radius:20px;background:var(--panel3);border:1px solid var(--line2);position:relative;transition:background .15s;flex-shrink:0}
.switch .kn::after{content:"";position:absolute;top:1px;left:1px;width:15px;height:15px;border-radius:50%;background:var(--muted);transition:transform .18s,background .15s}
.switch.on{color:var(--text);border-color:rgba(31,168,90,.4);background:rgba(31,168,90,.08)}
.switch.on .kn{background:var(--ok-dim);border-color:var(--ok)}
.switch.on .kn::after{transform:translateX(15px);background:var(--ok)}
.modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.modal-b textarea{resize:vertical;min-height:74px}
.modal-f{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px 18px;border-top:1px solid var(--line)}
.danger-ghost:hover{color:var(--danger);border-color:var(--danger)}
@media(max-width:620px){.modal-grid{grid-template-columns:1fr}}

/* ===== Agent topbar stats (world-class) ===== */
.tb-stats{display:flex;gap:20px;align-items:center}
.stat-ring{position:relative;width:76px;height:76px;flex-shrink:0}
.stat-ring svg{width:100%;height:100%;transform:rotate(-90deg);display:block}
.stat-ring .trk{fill:none;stroke:var(--panel3);stroke-width:7}
.stat-ring .prg{fill:none;stroke:var(--gold);stroke-width:7;stroke-linecap:round;transition:stroke-dashoffset .55s cubic-bezier(.4,0,.2,1)}
.stat-ring .sr-c{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center}
.sr-pct{font-family:var(--disp);font-size:24px;letter-spacing:.5px;color:var(--text);line-height:1}
.sr-pct span{font-size:12px;color:var(--muted);margin-left:1px}
.sr-lab{font-size:8px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted2);margin-top:3px;font-weight:700}
.tb-rank{text-align:right;padding-left:20px;border-left:1px solid var(--line)}
.tb-rank .lab{font-size:9.5px;letter-spacing:1.6px;text-transform:uppercase;color:var(--muted2);font-weight:700}
.rank-line{display:flex;align-items:center;gap:10px;justify-content:flex-end;margin-top:6px}
.rank-name{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap}
.rank-badge{font-family:var(--disp);font-size:21px;letter-spacing:1px;color:#fff;background:linear-gradient(135deg,#0B3070,#00205A);border-radius:9px;padding:2px 12px;line-height:1.25;box-shadow:0 8px 18px -10px rgba(0,32,90,.75),inset 0 1px 0 rgba(255,255,255,.12)}
.rank-sub{font-size:11px;color:var(--muted);margin-top:6px}
@media(max-width:560px){.tb-rank{padding-left:14px}.rank-name{display:none}}

/* ===== Clients / Delivery book ===== */
.book-bar{display:flex;align-items:center;gap:18px;flex-wrap:wrap;background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line);border-radius:var(--r2);padding:12px 16px;margin-bottom:14px;box-shadow:0 1px 2px rgba(16,35,79,.05),0 10px 26px -18px rgba(16,35,79,.16)}
.book-bar .totals{margin-left:auto}
.pol-figs{display:flex;gap:18px;flex-shrink:0}
.pol-figs .pf{text-align:right}
.pol-figs .pf span{display:block;font-size:9px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted2)}
.pol-figs .pf b{font-family:var(--mono);font-size:14px;color:var(--gold-soft);font-weight:600}
.calc-row{display:flex;gap:12px;margin-top:16px}
.calc-field{flex:1;background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line2);border-radius:var(--r2);padding:13px 15px}
.cf-l{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.cf-v{font-family:var(--mono);font-size:21px;font-weight:600;color:var(--gold);margin-top:5px;line-height:1}
@media(max-width:560px){.pol-figs{display:none}.calc-row{flex-direction:column}}

/* ===== Hover "lamp" animations — dashboard KPI tiles ===== */
.kpi{position:relative;transition:transform .3s cubic-bezier(.2,.7,.2,1),box-shadow .35s ease,border-color .25s ease}
.kpi:hover{transform:translateY(-5px);border-color:var(--line2);box-shadow:0 2px 5px rgba(16,35,79,.08),0 24px 52px -18px rgba(16,35,79,.34),0 0 30px -2px rgba(79,180,222,.55),0 12px 66px 6px rgba(46,111,214,.32)}
.kpi .v{transition:text-shadow .3s ease}
.kpi:hover .v{text-shadow:0 0 22px rgba(46,111,214,.42)}

/* ===== Hover animations — sidebar agent cards ===== */
.agent-card{position:relative;transition:background .2s ease,border-color .2s ease,transform .24s cubic-bezier(.2,.7,.2,1),box-shadow .24s ease}
.agent-card:hover{background:linear-gradient(180deg,#fff,var(--panel2));border-color:var(--line2);box-shadow:inset 3px 0 0 0 var(--gold-soft),0 12px 26px -16px rgba(16,35,79,.45)}
.agent-card:not(.active):hover{transform:translateX(4px)}
.agent-card .nm{transition:color .2s ease}
.agent-card:hover .nm{color:var(--gold-soft)}
.agent-card .mini-bar i{transition:box-shadow .25s ease,width .4s}
.agent-card:hover .mini-bar i{box-shadow:0 0 10px rgba(79,180,222,.65)}
/* same lamp cue on the Dashboard nav item */
.nav-dash{position:relative;transition:background .18s,color .18s,box-shadow .22s,transform .22s cubic-bezier(.2,.7,.2,1)}
.nav-dash:not(.active):hover{transform:translateX(3px);box-shadow:0 10px 22px -16px rgba(16,35,79,.4)}

@media (prefers-reduced-motion:reduce){
  .kpi,.agent-card,.nav-dash{transition:none!important}
  .kpi:hover,.agent-card:not(.active):hover,.nav-dash:not(.active):hover{transform:none}
}

/* ===== Modal flag/checklist sections (Business Partners) ===== */
.mf-sec{margin-top:18px}
.mf-sec .mf-h{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:9px;padding-top:14px;border-top:1px solid var(--line)}
.mf-sec .flagset{display:grid;grid-template-columns:repeat(auto-fill,minmax(190px,1fr));gap:6px}

/* print */
@media print{
  .sidebar,.tabs,.topbar .tb-stats,.tbl-foot .btn-row,.row-x,.side-foot,.menu-btn,.btn-add,.toast{display:none!important}
  body,html{background:#fff;color:#000}
  .app{display:block}.main{display:block}
  .panel,.phase,.tablewrap,.emd-month,.partner{border-color:#bbb;background:#fff!important;break-inside:avoid}
  .content{padding:0;max-width:none}
  .check,.prog,input,select,textarea{background:#fff!important;color:#000!important;border-color:#ccc!important}
  .check.on .box{background:#000;border-color:#000}.check.on .box svg{stroke:#fff}
  .section-title,.tb-id h2,.phase-h .pname{color:#000!important}
  *{-webkit-print-color-adjust:exact;print-color-adjust:exact}
}

/* ===== Live app extensions (agent-system-tracker.prophog2.com) ===== */
.sidebar{overflow:hidden}
.sidebar-main{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.sidebar-foot{flex-shrink:0;margin-top:auto}
.agent-roster-ui{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}
.side-foot.side-foot-status{border-top:none;padding-top:0}

.user-profile-summary{padding:12px 15px;border-bottom:1px solid var(--line);font-size:13px;background:var(--panel2)}
.user-profile-label{color:var(--muted);font-size:11px}
.user-profile-name{font-weight:700;color:var(--text);font-size:14px;margin-top:2px}
.user-profile-role{font-size:11px;color:var(--gold-soft);text-transform:uppercase;font-weight:600;margin-top:2px}
.btn-sign-out{color:var(--danger);font-size:11px;border:1px solid var(--danger);background:transparent;padding:4px 8px;border-radius:var(--r3);margin-top:8px;width:100%;cursor:pointer;font-weight:600;transition:background .15s,color .15s}
.btn-sign-out:hover{background:rgba(217,59,54,.1)}

.main-empty-hint{padding:40px;color:var(--muted);text-align:center}

.agent-item{position:relative;padding:11px 12px 11px 14px;border-radius:var(--r2);border:1px solid transparent;cursor:pointer;margin-bottom:5px;transition:background .2s ease,border-color .2s ease,transform .24s cubic-bezier(.2,.7,.2,1),box-shadow .24s ease;font-family:var(--sans)}
.agent-item:hover{background:linear-gradient(180deg,#fff,var(--panel2));border-color:var(--line2);box-shadow:inset 3px 0 0 0 var(--gold-soft),0 12px 26px -16px rgba(16,35,79,.45)}
.agent-item:not(.active):not(.active-selected-style):hover{transform:translateX(4px)}
.agent-item.active,.agent-item.active-selected-style{background:linear-gradient(180deg,var(--panel2),var(--panel));border-color:var(--line2)}
.agent-item.active::before,.agent-item.active-selected-style::before{content:"";position:absolute;left:0;top:8px;bottom:8px;width:3px;border-radius:3px;background:linear-gradient(180deg,var(--gold),var(--gold-deep))}
.agent-item-name{font-weight:600;font-size:14px;color:var(--text);line-height:1.35;transition:color .2s ease}
.agent-item:hover .agent-item-name{color:var(--gold-soft)}
.agent-item-meta{font-size:11px;color:var(--muted);margin-top:3px}
.status-active{color:var(--ok)}
.status-onboarding{color:var(--warn)}
.status-inactive{color:var(--muted2)}

button.is-busy,.btn-add.is-busy,.btn-row.is-busy,.btn-ghost.is-busy,.check.is-busy,.prog.is-busy,.cell-toggle.is-busy{opacity:.65;cursor:wait;pointer-events:none}
.prog.is-readonly{cursor:default;opacity:.85}

.field-spaced{margin-bottom:14px}
.phase-count{color:var(--gold-soft)}
.pbar-label{font-size:12px;color:var(--muted);width:38px;text-align:right;flex-shrink:0}
.pbar-narrow{max-width:200px}
.pbar-wide{max-width:480px}
.split-mb{margin-bottom:14px}
.total-left{text-align:left}
.rank-name-sub{margin-top:4px}

.state-loading,.state-error{padding:40px;text-align:center}
.state-loading{color:var(--muted)}
.state-error{color:var(--danger)}

td.mono{font-family:var(--mono)}
td.num-gold{color:var(--gold-soft)}
td.num-ok{color:var(--ok)}
.btn-wipe{background:none;border:none;color:var(--danger);cursor:pointer;padding:0;font-size:13px}
.btn-wipe:hover{text-decoration:underline}
.row-divider{border-bottom:1px solid var(--line)}

.policy-modal-overlay{position:fixed;inset:0;background:rgba(15,31,61,.45);z-index:70;display:flex;align-items:center;justify-content:center;padding:20px;backdrop-filter:blur(3px)}
.policy-modal-panel{background:linear-gradient(180deg,var(--panel2),var(--panel));border:1px solid var(--line2);border-radius:var(--r);padding:24px;max-width:460px;width:100%;box-shadow:var(--shadow)}
.policy-modal-panel h3{font-family:var(--disp);font-size:24px;letter-spacing:1px;margin-bottom:18px;color:var(--text)}
.policy-modal-actions{display:flex;gap:10px;margin-top:20px;justify-content:flex-end}
.policy-modal-hint{font-size:12px;color:var(--muted);margin-top:6px;line-height:1.5}
.policy-estimate{margin-top:14px;padding:12px 14px;border-radius:var(--r3);background:rgba(0,32,90,.08);border:1px solid rgba(0,32,90,.2);font-size:12px;color:var(--gold-soft);line-height:1.6}
.policy-estimate b{color:var(--gold);font-family:var(--mono)}

.col-idx{width:34px}
.col-called,.col-married{width:70px}
.col-num{min-width:120px}
.col-name{min-width:130px}
.col-loc{min-width:120px}
.col-tz{min-width:90px}
.col-age{min-width:55px}
.col-occ{min-width:130px}
.col-appt{min-width:130px}
.col-qual{min-width:170px}
.col-notes{min-width:200px}
.cell-center{text-align:center}
.row-empty td{padding:20px 24px;text-align:center;color:var(--muted2)}
.toggle-readonly{opacity:.6;pointer-events:none}

.tb-id h2{font-family:var(--sans);font-size:24px;font-weight:700;letter-spacing:-0.02em;line-height:1.2;color:var(--text)}

body.role-agent .staff-only-ui,
body.role-agent .admin-only-ui,
body.role-agent .super-admin-only-ui,
body.role-agent .agent-roster-ui{display:none!important}
body.role-admin .super-admin-only-ui{display:none!important}

.hint-mt{margin-top:14px}
.hint-narrow{max-width:420px}
.dream-empty{padding:20px 0;color:var(--muted2);text-align:center;font-size:13px}
.btn-add-dream{margin-top:10px}
.dream-header{font-size:10px;letter-spacing:1px;text-transform:uppercase;color:var(--muted)}
.empty-main-tall{min-height:320px}
.col-action{width:30px}
.col-children{width:80px}
.col-homeowner{width:90px}
.col-referred{min-width:120px}
.pbar-fill{display:block;height:100%}
.is-hidden{display:none!important}

/* ===== Login page ===== */
body.auth-page{display:flex;justify-content:center;align-items:center;min-height:100vh;margin:0;overflow:hidden;background:radial-gradient(1200px 700px at 80% -10%,rgba(0,32,90,.08),transparent 60%),var(--ink)}
.auth-container{background:var(--panel);border:1px solid var(--line);padding:0;border-radius:var(--r);width:100%;max-width:380px;box-shadow:var(--shadow);text-align:center;overflow:hidden}
.auth-brand-header{background:linear-gradient(140deg,#012A6B,#001A4A);padding:28px 32px 22px;text-align:center}
.auth-brand{margin-bottom:0}
.auth-brand .crown{font-size:32px;color:#4FB4DE;line-height:1;margin-bottom:5px}
.auth-brand h1{font-family:var(--disp);font-size:36px;letter-spacing:2px;margin:0;color:#fff}
.auth-brand h1 b{color:#4FB4DE;font-weight:400}
.auth-brand .sub{font-size:11px;color:#AEBCD6;text-transform:uppercase;letter-spacing:1px;margin-top:2px;font-weight:600}
.auth-form{padding:32px}
.auth-group{text-align:left;margin-bottom:20px}
.auth-group label{display:block;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px;font-weight:600}
.auth-group input{width:100%;padding:12px;background:var(--panel2);border:1px solid var(--line);border-radius:var(--r3);color:var(--text);font-size:14px;box-sizing:border-box}
.auth-group input:focus{border-color:var(--gold-deep);background:var(--panel)}
.btn-auth-submit{width:100%;padding:14px;background:var(--gold);color:#fff;border:none;border-radius:var(--r3);font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.5px;cursor:pointer;transition:filter .2s ease;margin-top:10px}
.btn-auth-submit:hover{filter:brightness(1.08)}
.auth-status-msg{font-size:12px;color:var(--danger);margin-top:15px;min-height:18px;font-weight:500;padding:0 32px 24px}
