*{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;height:100vh;height:100dvh;overflow:hidden}
.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;height:100vh;height:100dvh;overflow-y:auto;overflow-x:hidden}
.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;height:auto;overflow:visible}.main{display:block;height:auto;overflow:visible}
  .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}


/* =========================================================================
   PropHog Agent System Tracker — additions
   Append this to css/styles.css. Uses the existing token system only
   (--gold is the navy #00205A, --disp is Bebas Neue, etc.) so it reads as
   part of the same app, not a bolt-on.
   ========================================================================= */

/* ===== System tab: the "Edit structure" entry button ===== */
.btn-edit-structure{
  border:1px solid var(--gold-deep);
  color:var(--gold-soft);
  font-size:12px;font-weight:700;
  padding:7px 13px;border-radius:var(--r3);
  display:inline-flex;align-items:center;gap:6px;
  transition:background .15s,filter .15s;
}
.btn-edit-structure:hover{background:var(--panel2);filter:brightness(1.04)}
.btn-edit-structure .es-ic{font-size:13px;line-height:1}

/* ===== Structure editor overlay ===== */
.se-overlay{
  position:fixed;inset:0;z-index:300;
  background:rgba(15,31,61,.48);backdrop-filter:blur(4px);
  display:flex;align-items:flex-start;justify-content:center;
  padding:38px 18px;overflow-y:auto;
}
body.se-open{overflow:hidden}
.se-modal{
  width:100%;max-width:760px;margin:auto;
  background:var(--panel);
  border:1px solid var(--line2);border-radius:var(--r);
  box-shadow:0 40px 90px -30px rgba(7,18,46,.6);
  display:flex;flex-direction:column;max-height:calc(100vh - 76px);
  animation:seIn .18s ease;
}
@keyframes seIn{from{opacity:0;transform:translateY(10px) scale(.99)}to{opacity:1;transform:none}}

.se-head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;padding:20px 22px 14px;border-bottom:1px solid var(--line)}
.se-title{font-family:var(--disp);font-size:25px;letter-spacing:1px;color:var(--text);line-height:1}
.se-sub{font-size:12px;color:var(--muted);margin-top:7px;max-width:560px;line-height:1.5;text-wrap:pretty}
.se-x{width:34px;height:34px;border-radius:var(--r3);color:var(--muted);border:1px solid var(--line);flex-shrink:0;font-size:15px;transition:all .14s}
.se-x:hover{color:var(--text);border-color:var(--line2);background:var(--panel2)}

.se-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:10px 22px;border-bottom:1px solid var(--line);background:var(--panel2)}
.se-archived-toggle{display:inline-flex;align-items:center;gap:8px;font-size:12px;color:var(--muted);cursor:pointer;font-weight:600}
.se-archived-toggle input{width:auto}
.se-saving{font-size:11px;color:var(--ok);font-weight:700;letter-spacing:.3px;min-height:14px}

.se-body{padding:16px 22px;overflow-y:auto;flex:1}
.se-loading,.se-empty,.se-empty-sub,.se-error{color:var(--muted);font-size:13px;text-align:center;padding:24px 8px;line-height:1.55}
.se-empty-sub{padding:10px 8px;color:var(--muted2);font-size:12px}
.se-error{color:var(--danger);text-align:left;background:rgba(217,59,54,.06);border:1px solid rgba(217,59,54,.25);border-radius:var(--r3);padding:14px 16px}

/* phase block */
.se-phase{border:1px solid var(--line);border-radius:var(--r);margin-bottom:14px;background:linear-gradient(180deg,var(--panel2),var(--panel));overflow:hidden}
.se-phase-h{display:flex;align-items:center;gap:10px;padding:12px 14px;border-bottom:1px solid var(--line);background:var(--panel)}
.se-areas{padding:8px 14px 12px}

/* area (group) block */
.se-area{border:1px solid var(--line);border-radius:var(--r2);margin:10px 0;background:var(--panel)}
.se-area-h{display:flex;align-items:center;gap:10px;padding:9px 11px;border-bottom:1px solid var(--line);background:var(--panel2)}
.se-items{padding:7px 11px 10px;display:flex;flex-direction:column;gap:6px}

/* item row */
.se-item{display:flex;align-items:center;gap:8px;padding:5px 7px;border:1px solid var(--line);border-radius:var(--r3);background:var(--panel2)}

/* the editable name inputs */
.se-name{flex:1;min-width:0;background:transparent;border:1px solid transparent;border-radius:6px;padding:7px 9px;font-weight:500;transition:border-color .14s,background .14s}
.se-name:hover{border-color:var(--line)}
.se-name:focus{background:var(--panel);border-color:var(--gold-deep);box-shadow:0 0 0 3px rgba(0,32,90,.12)}
.se-name-phase{font-family:var(--disp);font-size:19px;letter-spacing:.6px;color:var(--text);font-weight:400}
.se-name-area{font-size:12px;letter-spacing:.6px;text-transform:uppercase;color:var(--muted);font-weight:700}
.se-name-item{font-size:13.5px;color:var(--text)}

/* reorder arrows */
.se-reorder{display:flex;flex-direction:column;gap:2px;flex-shrink:0}
.se-reorder button{width:24px;height:17px;border:1px solid var(--line);border-radius:5px;color:var(--muted);font-size:9px;line-height:1;display:grid;place-items:center;transition:all .12s}
.se-reorder button:hover:not(:disabled){color:var(--gold-soft);border-color:var(--gold-deep);background:var(--panel2)}
.se-reorder button:disabled{opacity:.32;cursor:default}
.se-reorder-sm button{width:22px;height:15px}

/* row action buttons */
.se-row-actions{display:flex;gap:6px;flex-shrink:0;margin-left:auto}
.se-mini{font-size:11px;font-weight:700;color:var(--gold-soft);border:1px solid var(--line2);background:var(--panel);padding:6px 10px;border-radius:var(--r3);white-space:nowrap;transition:all .13s}
.se-mini:hover{border-color:var(--gold-deep);background:var(--panel2)}
.se-mini-danger{color:var(--muted)}
.se-mini-danger:hover{color:var(--danger);border-color:var(--danger);background:rgba(217,59,54,.06)}
.se-item-archive{margin-left:auto;flex-shrink:0}

.se-badge{font-size:9px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:var(--warn);background:rgba(222,122,34,.12);border:1px solid rgba(222,122,34,.32);padding:2px 7px;border-radius:20px;flex-shrink:0}
.se-phase.is-archived,.se-area.is-archived,.se-item.is-archived{opacity:.64}

/* footer */
.se-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;border-top:1px solid var(--line);background:var(--panel2)}
.se-add-phase{font-size:12px;font-weight:700;color:var(--gold-soft);border:1px dashed var(--line2);padding:9px 15px;border-radius:var(--r3);transition:all .14s}
.se-add-phase:hover{border-color:var(--gold-deep);border-style:solid;background:var(--panel)}
.se-done{background:var(--gold);color:#fff;font-weight:700;font-size:13px;padding:10px 22px;border-radius:var(--r3);transition:filter .15s}
.se-done:hover{filter:brightness(1.08)}

/* ===== Mobile drawer hamburger ===== */
.menu-btn{
  position:fixed;top:12px;left:12px;z-index:65;
  background:var(--panel);border:1px solid var(--line2);
  color:var(--text);font-weight:700;font-size:12px;
  padding:9px 13px;border-radius:30px;
  box-shadow:0 8px 22px -10px rgba(16,35,79,.45);
  align-items:center;gap:9px;
}
.menu-bars{display:inline-flex;flex-direction:column;gap:3px}
.menu-bars span{display:block;width:16px;height:2px;border-radius:2px;background:var(--gold-soft)}
.menu-btn-label{letter-spacing:.3px}
.menu-btn:active{transform:translateY(1px)}

/* ===== Mobile polish (<=980px) ===== */
@media(max-width:980px){
  /* push content clear of the fixed hamburger */
  .topbar{padding-top:58px}
  .empty-main{padding-top:80px}

  /* the off-canvas drawer gets a bit more presence + a shadow when open */
  .sidebar{box-shadow:0 0 60px -10px rgba(7,18,46,.55);max-width:86vw}

  /* bigger tap targets on the System checklist */
  .check{padding:13px 13px}
  .check .box{width:22px;height:22px}
  .check .lab{font-size:14px}
  .phase-h{padding:16px 16px}
  .phase-h .pname{font-size:18px}

  /* the structure editor goes (near) full screen and stacks cleanly */
  .se-overlay{padding:0}
  .se-modal{max-width:none;max-height:100vh;height:100vh;border-radius:0;border:none}
  .se-body{padding:14px 14px}
  .se-head,.se-toolbar,.se-foot{padding-left:16px;padding-right:16px}
  .se-phase-h,.se-area-h{flex-wrap:wrap}
  .se-row-actions{margin-left:0;width:100%;justify-content:flex-start;padding-top:2px}
  .se-name{font-size:16px} /* >=16px stops iOS zoom-on-focus */
  .se-name-area{font-size:13px}
  .se-mini{padding:9px 13px} /* fat-finger friendly */

  /* table tabs stay scrollable; give wide data tables a clearer scroll hint */
  .tablewrap{position:relative}
}

/* On small phones, drop the hamburger word to just the icon */
@media(max-width:420px){
  .menu-btn-label{display:none}
  .menu-btn{padding:11px}
}

/* Respect reduced motion in the editor too */
@media (prefers-reduced-motion:reduce){
  .se-modal{animation:none}
}

/* =========================================================================
   PropHog Agent System Tracker — pipeline cards + mobile polish
   Shared by BOTH the production app (append to css/styles.css) and the
   single-file build. Uses existing tokens and existing class names
   (.rec-card, .rec-stat, .modal, .switch …), so it layers on cleanly.
   ========================================================================= */

/* Card list reads as intentional on desktop too, not just a mobile fallback */
.rec-list{max-width:920px}
.rec-card{cursor:default}
.rec-main{border-radius:var(--r3);padding:2px 4px;margin:-2px -4px;transition:background .12s}
.rec-main:hover{background:rgba(0,32,90,.04)}
.rec-stat{position:relative}
.rec-stat::after{content:"";position:absolute;inset:-7px;border-radius:50%} /* bigger hit area */

/* ===== Phones: <=560px ===== */
@media(max-width:560px){

  /* Card becomes a comfortable two-row layout: toggle + name/meta on top,
     status + delete easy to reach. The separate "Edit" button is redundant
     because tapping the card opens the editor — so hide it on phones.        */
  .rec-card{gap:12px;padding:13px 13px;align-items:center}
  .rec-stat{width:40px;height:40px}
  .rec-stat span{width:13px;height:13px}
  .rec-name{font-size:15.5px}
  .rec-meta{font-size:12.5px;white-space:normal}      /* let meta wrap instead of truncating */
  .rec-edit{display:none}
  .rec-del{width:38px;height:38px;font-size:15px}
  .rec-tags{margin-left:auto}
  .rec-pill{font-size:11px;padding:5px 11px}

  .pc-add,.btn-row{width:100%;justify-content:center;padding:13px 16px;font-size:13.5px}

  /* ===== Record editor becomes a bottom sheet ===== */
  .modal-overlay{align-items:flex-end;padding:0}
  .modal{
    max-width:none;width:100%;
    border-radius:var(--r) var(--r) 0 0;
    max-height:92vh;display:flex;flex-direction:column;
    animation:pcSheetUp .24s cubic-bezier(.2,.7,.2,1);
  }
  .modal-h{position:sticky;top:0;z-index:3;background:var(--panel);border-radius:var(--r) var(--r) 0 0}
  .modal-h::before{ /* grab handle */
    content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);
    width:38px;height:4px;border-radius:4px;background:var(--line2);
  }
  .modal-h{padding-top:22px}
  .modal-b{overflow-y:auto;flex:1;-webkit-overflow-scrolling:touch}
  .modal-f{position:sticky;bottom:0;z-index:3;background:var(--panel);
           padding-bottom:max(16px,env(safe-area-inset-bottom))}
  .modal-grid{grid-template-columns:1fr}

  /* 16px inputs stop iOS from zooming the viewport on focus */
  .modal-b input,.modal-b select,.modal-b textarea{font-size:16px;padding:11px 12px}
  .modal-b textarea{min-height:84px}

  /* fat-finger toggles */
  .switch{padding:11px 16px 11px 11px;font-size:14px}
  .switch .kn{width:40px;height:23px}
  .switch .kn::after{width:19px;height:19px}
  .switch.on .kn::after{transform:translateX(17px)}

  .btn-add,.danger-ghost{padding:12px 20px;font-size:14px}
}

@keyframes pcSheetUp{from{transform:translateY(100%)}to{transform:none}}

@media (prefers-reduced-motion:reduce){
  .modal{animation:none}
}

/* On very small phones, stack the card so name never gets crushed */
@media(max-width:380px){
  .rec-card{flex-wrap:wrap}
  .rec-main{flex:1 1 100%;order:2}
  .rec-stat{order:1}
  .rec-tags{order:1;margin-left:auto}
  .rec-del{order:1}
}

/* =========================================================================
   PropHog Agent System Tracker — Reference Data editor extras
   Append to css/styles.css (after styles-additions.css, which provides the
   shared .se-* editor styles). Adds the product type + commission inputs.
   ========================================================================= */

.se-type{width:88px;flex-shrink:0;font-size:12px;text-align:center}
.se-comm{width:92px;flex-shrink:0;text-align:right;font-family:var(--mono);font-size:12px;padding:7px 9px}
.se-comm-head{display:flex;justify-content:space-between;font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--muted2);padding:0 8px 4px;font-weight:700}
.se-comm-head span:last-child{width:196px;text-align:right}

@media(max-width:560px){
  .se-item{flex-wrap:wrap}
  .se-name-item{flex:1 1 100%;order:1}
  .se-type{order:2;width:46%;text-align:left}
  .se-comm{order:2;width:46%}
  .se-item .se-mini,.se-item .se-badge{order:3}
  .se-comm-head{display:none}
}


/* ===== Invite dialog ===== */
.inv-link-row{display:flex;align-items:center;gap:8px;font-size:12.5px;color:var(--muted);font-weight:600;margin-top:4px;cursor:pointer}
.inv-link-row input{width:auto}
.inv-result{margin-top:14px;padding-top:14px;border-top:1px solid var(--line)}
.inv-result label{display:block;font-size:11px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin-bottom:6px}
.inv-link-box{display:flex;gap:8px}
.inv-link-box input{flex:1;min-width:0;font-family:var(--mono);font-size:12px}
.inv-note{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.5}


/* ===== Account & Access panel ===== */
.ac-status{display:flex;align-items:center;gap:9px;font-size:14px;font-weight:600;color:var(--text);padding:4px 0 14px;border-bottom:1px solid var(--line);margin-bottom:14px}
.ac-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}
.ac-dot.ac-active{background:var(--ok)}
.ac-dot.ac-revoked{background:var(--danger)}
.ac-dot.ac-none{background:var(--muted2)}
.ac-actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.ac-hint{flex:1 1 100%;font-size:12px;color:var(--muted);line-height:1.5;margin-top:2px}


/* ===== System % meter (crisp SVG donut) ===== */
.sys-meter{position:relative;width:64px;height:64px;flex-shrink:0}
.sys-meter-svg{width:64px;height:64px;display:block;transform:rotate(-90deg)}
.sm-track{fill:none;stroke:var(--panel3);stroke-width:4}
.sm-prog{fill:none;stroke:var(--gold);stroke-width:4;stroke-linecap:round;transition:stroke-dashoffset .6s cubic-bezier(.4,0,.2,1)}
.sys-meter-lbl{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;line-height:1;pointer-events:none}
.sys-meter-lbl .smv{font-weight:800;font-size:15px;color:var(--gold)}
.sys-meter-lbl .sml{font-size:8px;letter-spacing:1px;color:var(--muted);text-transform:uppercase;margin-top:2px}


/* ===== Team / All-Agents dashboard ===== */
.nav-dash{display:flex;align-items:center;gap:8px;margin:6px 10px 10px;padding:10px 12px;border:1px solid var(--line);border-radius:var(--r3);background:var(--panel2);color:var(--text);font-weight:700;font-size:13px;cursor:pointer;transition:all .15s}
.nav-dash .di{color:var(--gold-soft)}
.nav-dash:hover{border-color:var(--line2);background:var(--panel3)}
.nav-dash.active{background:linear-gradient(180deg,var(--panel2),var(--panel));border-color:var(--gold-deep);color:var(--gold)}
.nav-dash.active .di{color:var(--gold)}
.dash-back{font-size:11px;font-weight:700;color:var(--gold-soft);border:1px solid var(--line2);border-radius:20px;padding:4px 11px;margin-bottom:8px;align-self:flex-start;background:var(--panel);transition:all .15s}
.dash-back:hover{border-color:var(--gold-deep);color:var(--gold)}
.team-dash{padding:22px 26px 40px}
.team-head{display:flex;align-items:flex-end;justify-content:space-between;gap:16px;margin-bottom:18px}
.team-head h2{font-family:var(--disp);font-size:34px;letter-spacing:1.5px;color:var(--text);line-height:1}
.team-sub{font-size:12px;color:var(--muted);margin-top:4px}
.kpi .ksub{font-size:11px;color:var(--muted2);margin-top:3px}
.team-table-wrap{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)}
.team-table{width:100%;border-collapse:collapse;min-width:680px}
.team-table 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 12px;white-space:nowrap;border-bottom:1px solid var(--line2)}
.team-table tbody td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}
.dash-row{cursor:pointer;transition:background .12s}
.dash-row:hover{background:var(--panel2)}
.dash-row:hover .da-go{color:var(--gold)}
.da-name{font-weight:700;color:var(--text);font-size:13px}
.da-sub{font-size:11px;color:var(--muted);margin-top:1px}
.da-rank{font-family:var(--disp);font-size:18px;letter-spacing:1px;color:var(--gold)}
.da-bar{height:7px;border-radius:4px;background:var(--panel3);overflow:hidden;min-width:130px}
.da-bar span{display:block;height:100%;background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft));border-radius:4px;transition:width .4s}
.da-pct{font-size:11px;color:var(--muted);margin-top:4px;font-variant-numeric:tabular-nums}
.da-go{color:var(--gold-soft);font-weight:700;font-size:12px;white-space:nowrap}
.ta-c{text-align:center}.ta-r{text-align:right}
.dash-empty{text-align:center;color:var(--muted2);padding:34px 16px;font-size:13px}
@media(max-width:760px){.team-dash{padding:16px 14px 40px}.team-head h2{font-size:28px}}

/* ===== New-contact placeholder + EMD / Partners / Licensing tabs ===== */
.rec-name-empty{color:var(--muted2);font-style:italic;font-weight:500}
.et-table{width:100%;border-collapse:collapse}
.et-table 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:10px;white-space:nowrap;border-bottom:1px solid var(--line2)}
.et-table td{padding:6px 7px;border-bottom:1px solid var(--line);vertical-align:middle}
.et-table input{width:100%;min-width:92px}
.et-muted{color:var(--muted2)}
.et-table tfoot td{border-top:2px solid var(--line2);background:var(--panel2);font-variant-numeric:tabular-nums}
.emd-prog{margin-bottom:16px}
.emd-prog-top{display:flex;justify-content:space-between;align-items:baseline;font-size:12px;color:var(--muted);margin-bottom:7px}
.emd-prog-top b{color:var(--gold);font-size:13px;font-variant-numeric:tabular-nums}


/* ===== Dreams tab — "What Are You Building" ===== */
.dr-wrap{--c-time:#2E6FD6;--c-family:#C25E6A;--c-money:#2F8F6B;--c-home:#C2873C;--c-impact:#6E5AAE;--c-legacy:#1B6E8C;--c-fitness:#CB5A3C;--c-spiritual:#8C6FC0;--c-health:#5FA552;--c-relationships:#C85C8E;--c-travel:#2C9CBC;--c-business:#5E768F}
.dr-overlay{--c-time:#2E6FD6;--c-family:#C25E6A;--c-money:#2F8F6B;--c-home:#C2873C;--c-impact:#6E5AAE;--c-legacy:#1B6E8C;--c-fitness:#CB5A3C;--c-spiritual:#8C6FC0;--c-health:#5FA552;--c-relationships:#C85C8E;--c-travel:#2C9CBC;--c-business:#5E768F}
.dr-hero{margin:2px 0 22px}
.dr-eyebrow{font-family:var(--mono);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:var(--gold-soft);font-weight:600;display:flex;align-items:center;gap:10px}
.dr-eyebrow::before{content:"";width:26px;height:2px;background:var(--gold-soft);border-radius:2px}
.dr-hero h2{font-family:var(--disp);font-size:clamp(30px,3.6vw,44px);line-height:.92;letter-spacing:1.4px;color:var(--gold);margin-top:10px;text-wrap:balance}
.dr-sub{font-size:clamp(15px,1.6vw,17px);font-weight:600;color:var(--text);margin-top:10px}
.dr-bar{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-bottom:24px}
.dr-stats{display:flex;gap:13px;flex:1 1 440px;flex-wrap:wrap}
.dr-stat{flex:1 1 145px;background:var(--panel);border:1px solid var(--line);border-radius:var(--r);padding:15px 17px;box-shadow:0 1px 2px rgba(16,35,79,.05),0 14px 36px -24px rgba(16,35,79,.28);position:relative;overflow:hidden}
.dr-stat::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:linear-gradient(180deg,var(--gold),var(--gold-soft))}
.dr-k{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted)}
.dr-v{font-family:var(--disp);font-size:32px;line-height:.95;letter-spacing:1px;color:var(--gold);margin-top:6px}
.dr-v.sm{font-size:22px;letter-spacing:.4px;line-height:1.05;margin-top:8px}
.dr-vs{font-size:13px;color:var(--gold-soft);font-weight:600;margin-top:3px}
.dr-actions{display:flex;align-items:center;justify-content:flex-end}
.dr-primary{background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep));color:#fff;font-weight:800;font-size:15px;letter-spacing:.04em;padding:14px 22px;border-radius:999px;display:inline-flex;align-items:center;gap:9px;border:none;cursor:pointer;box-shadow:0 10px 22px -10px rgba(46,111,214,.7);transition:transform .12s,box-shadow .15s;white-space:nowrap}
.dr-primary:hover{transform:translateY(-1px);box-shadow:0 14px 28px -10px rgba(46,111,214,.8)}
.dr-primary svg{width:19px;height:19px}
.dr-grid{display:grid;gap:18px;grid-template-columns:repeat(auto-fill,minmax(330px,1fr))}
.dr-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 1px 2px rgba(16,35,79,.05),0 16px 40px -24px rgba(16,35,79,.28);overflow:hidden;display:flex;flex-direction:column;transition:transform .14s,box-shadow .15s;position:relative}
.dr-card:hover{transform:translateY(-3px);box-shadow:0 1px 2px rgba(16,35,79,.05),0 26px 50px -26px rgba(16,35,79,.4)}
.dr-accent{height:5px;background:var(--cc,var(--gold-soft))}
.dr-body{padding:20px 20px 16px;display:flex;flex-direction:column;gap:13px;flex:1;background:linear-gradient(180deg,color-mix(in srgb,var(--cc) 6%,#fff),#fff 52%)}
.dr-top{display:flex;align-items:center;justify-content:space-between;gap:10px}
.dr-cat{display:inline-flex;align-items:center;gap:9px}
.dr-cat .dr-chip{width:38px;height:38px;border-radius:11px;display:grid;place-items:center;background:color-mix(in srgb,var(--cc) 14%,#fff);color:var(--cc);flex-shrink:0}
.dr-cat .dr-chip svg{width:21px;height:21px}
.dr-lab{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--cc);font-weight:600}
.dr-pill{font-size:11px;font-weight:800;letter-spacing:.06em;text-transform:uppercase;padding:5px 11px;border-radius:999px;white-space:nowrap}
.dr-pill.s-not{background:var(--panel3);color:var(--muted)}
.dr-pill.s-prog{background:rgba(46,111,214,.12);color:var(--gold-soft)}
.dr-pill.s-done{background:rgba(47,143,107,.15);color:var(--c-money)}
.dr-title{font-family:var(--disp);font-size:25px;line-height:.98;letter-spacing:.6px;color:var(--gold)}
.dr-badge{align-self:flex-start;display:inline-flex;align-items:center;gap:7px;font-size:12px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--text);background:var(--panel2);border:1px solid var(--line);padding:6px 12px;border-radius:999px}
.dr-badge svg{width:14px;height:14px;color:var(--muted)}
.dr-block .dr-h{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:4px;display:flex;align-items:center;gap:7px}
.dr-block .dr-h::before{content:"";width:14px;height:2px;border-radius:2px;background:var(--cc,var(--line2));opacity:.7}
.dr-block p{font-size:15px;color:var(--text);line-height:1.5}
.dr-mut{color:var(--muted2)}
.dr-seg{display:flex;background:var(--panel2);border:1px solid var(--line);border-radius:10px;padding:4px;gap:4px;margin-top:2px}
.dr-seg button{flex:1;font-size:12px;font-weight:700;letter-spacing:.02em;color:var(--muted);padding:9px 5px;border-radius:7px;border:none;background:none;cursor:pointer;transition:all .14s;white-space:nowrap}
.dr-seg button.on{background:var(--panel);color:var(--gold);box-shadow:0 1px 3px rgba(16,35,79,.14)}
.dr-seg button[data-st="done"].on{color:var(--c-money)}
.dr-foot{display:flex;align-items:center;gap:4px;border-top:1px solid var(--line);padding:9px 12px}
.dr-foot button{font-size:13px;font-weight:600;color:var(--muted);padding:8px 12px;border-radius:8px;border:none;background:none;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:all .14s}
.dr-foot button:hover{background:var(--panel2);color:var(--gold)}
.dr-foot button.del:hover{color:#C2474A;background:rgba(194,71,74,.08)}
.dr-foot button svg{width:15px;height:15px}
.dr-spacer{flex:1}
.dr-card.done .dr-title{color:var(--c-money)}
.dr-card.done .dr-accent{background:var(--c-money)}
.dr-card.done::after{content:"ACHIEVED";position:absolute;top:18px;right:-34px;transform:rotate(45deg);background:var(--c-money);color:#fff;font-family:var(--mono);font-size:10px;letter-spacing:2px;font-weight:600;padding:5px 40px;box-shadow:0 6px 16px -6px rgba(47,143,107,.6)}
.dr-empty{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);box-shadow:0 1px 2px rgba(16,35,79,.05),0 16px 40px -24px rgba(16,35,79,.28);padding:60px 28px;text-align:center;position:relative;overflow:hidden}
.dr-empty::before{content:"";position:absolute;inset:0;background:radial-gradient(600px 240px at 50% 0%,rgba(46,111,214,.08),transparent 70%)}
.dr-empty-ic{width:70px;height:70px;margin:0 auto 6px;color:var(--gold-soft);position:relative}
.dr-empty h3{font-family:var(--disp);font-size:clamp(26px,3vw,36px);letter-spacing:1px;color:var(--gold);position:relative}
.dr-empty p{font-size:16px;color:var(--muted);max-width:46ch;margin:9px auto 24px;position:relative}
.dr-empty .dr-primary{position:relative}
.dr-motiv{margin-top:30px;border-radius:var(--r);padding:40px 38px;position:relative;overflow:hidden;background:linear-gradient(135deg,#0A1A3A 0%,#163B78 58%,#0B1E45 100%)}
.dr-motiv::before{content:"";position:absolute;right:-60px;top:-60px;width:300px;height:300px;border-radius:50%;background:radial-gradient(circle,rgba(46,111,214,.45),transparent 65%)}
.dr-e{font-family:var(--mono);font-size:12px;letter-spacing:3px;text-transform:uppercase;color:#7FA8EE;font-weight:600;position:relative}
.dr-motiv h3{font-family:var(--disp);font-size:clamp(24px,3vw,32px);line-height:1;letter-spacing:1px;color:#fff;margin:12px 0 20px;max-width:20ch;position:relative;text-wrap:balance}
.dr-quote{position:relative;padding-left:20px;border-left:3px solid var(--gold-soft);max-width:60ch}
.dr-dt{font-family:var(--disp);font-size:25px;letter-spacing:.5px;color:#fff;line-height:1.02}
.dr-wy{font-size:16px;color:#C5D6F5;margin-top:7px;line-height:1.5}
.dr-prompt{margin-top:24px;font-size:16px;color:#9FBCEF;font-style:italic;position:relative}
.dr-overlay{position:fixed;inset:0;background:rgba(8,18,40,.55);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:40px 18px;z-index:1200;overflow-y:auto;opacity:0;transition:opacity .15s}
.dr-overlay.show{opacity:1}
.dr-modal{background:var(--panel);border-radius:20px;width:100%;max-width:640px;box-shadow:0 40px 90px -30px rgba(8,18,40,.7);overflow:hidden}
.dr-mhead{padding:22px 26px 16px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;justify-content:space-between;gap:14px}
.dr-step{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold-soft);font-weight:600}
.dr-mhead h2{font-family:var(--disp);font-size:24px;letter-spacing:.6px;color:var(--gold);line-height:1;margin-top:7px}
.dr-x{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;color:var(--muted);background:var(--panel2);border:none;cursor:pointer;flex-shrink:0;transition:all .14s}
.dr-x:hover{color:var(--gold);background:var(--panel3)}
.dr-x svg{width:18px;height:18px}
.dr-mbody{padding:22px 26px}
.dr-cats{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.dr-tile{text-align:left;background:var(--panel2);border:1.5px solid var(--line);border-radius:14px;padding:16px;display:flex;gap:13px;align-items:flex-start;cursor:pointer;transition:all .15s}
.dr-tile:hover{border-color:var(--cc);background:#fff;transform:translateY(-2px);box-shadow:0 14px 30px -18px var(--cc)}
.dr-tile.on{border-color:var(--cc);background:color-mix(in srgb,var(--cc) 7%,#fff);box-shadow:0 0 0 3px color-mix(in srgb,var(--cc) 22%,transparent)}
.dr-tchip{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:color-mix(in srgb,var(--cc) 15%,#fff);color:var(--cc);flex-shrink:0}
.dr-tchip svg{width:23px;height:23px}
.dr-tx{display:flex;flex-direction:column;gap:4px;min-width:0}
.dr-nm{font-weight:800;font-size:16px;color:var(--gold);letter-spacing:.2px;line-height:1.15}
.dr-ds{font-size:13.5px;color:var(--muted);line-height:1.45}
.dr-field{margin-bottom:18px}
.dr-field label{display:block;font-weight:700;font-size:15px;color:var(--gold);margin-bottom:5px}
.dr-field .dr-help{font-size:13.5px;color:var(--muted);margin-bottom:9px}
.dr-field input,.dr-field textarea{font-size:16px;width:100%}
.dr-field textarea{min-height:104px;resize:vertical;line-height:1.5}
.dr-chips{display:flex;flex-wrap:wrap;gap:8px}
.dr-chips button{font-size:14px;font-weight:600;color:var(--text);background:var(--panel2);border:1.5px solid var(--line);border-radius:999px;padding:9px 15px;cursor:pointer;transition:all .14s}
.dr-chips button:hover{border-color:var(--line2)}
.dr-chips button.on{background:var(--gold);color:#fff;border-color:var(--gold)}
.dr-custom{display:none;margin-top:10px}
.dr-custom.show{display:block}
.dr-mfoot{padding:16px 26px 22px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.dr-chosen{display:flex;align-items:center;gap:9px;font-size:14px;color:var(--muted)}
.dr-chosen .dr-tchip{width:30px;height:30px;border-radius:9px}
.dr-chosen .dr-tchip svg{width:17px;height:17px}
.dr-ghost{font-size:14px;font-weight:700;color:var(--muted);padding:12px 16px;border-radius:10px;border:none;background:none;cursor:pointer;transition:all .14s}
.dr-ghost:hover{color:var(--gold);background:var(--panel2)}
.dr-go{background:linear-gradient(135deg,var(--gold-soft),var(--gold-deep));color:#fff;font-weight:800;font-size:15px;padding:13px 24px;border-radius:10px;letter-spacing:.03em;border:none;cursor:pointer;transition:all .14s;display:inline-flex;align-items:center;gap:8px}
.dr-go:hover{filter:brightness(1.06)}
.dr-go:disabled{opacity:.45;cursor:not-allowed;filter:none}
.dr-confetti{position:fixed;top:-12px;width:10px;height:14px;z-index:1300;border-radius:2px;pointer-events:none}
@media(max-width:680px){
  .dr-wrap{padding:0 14px}
  .dr-grid{grid-template-columns:1fr}
  .dr-cats{grid-template-columns:1fr}
  .dr-actions{width:100%}
  .dr-primary{width:100%;justify-content:center}
  .dr-motiv{padding:30px 22px}
}
@media(prefers-reduced-motion:reduce){.dr-card,.dr-tile,.dr-primary{transition:none}}


/* ===== Ledger stage actions (Clients / Delivery) ===== */
.ledger-acts{white-space:nowrap;text-align:right}
.btn-stage{font-size:11px;font-weight:700;color:var(--gold-soft);border:1px solid var(--line2);background:var(--panel);border-radius:7px;padding:6px 10px;margin-right:6px;cursor:pointer;transition:all .14s}
.btn-stage:hover{border-color:var(--gold-deep);color:var(--gold);background:var(--panel2)}

/* ===== EMD Plan — premium redesign ===== */
.emd-hero{display:flex;gap:24px;align-items:center;flex-wrap:wrap;border-radius:var(--r);padding:28px 30px;margin-bottom:18px;position:relative;overflow:hidden;background:linear-gradient(135deg,#0A1A3A 0%,#163B78 60%,#0B1E45 100%)}
.emd-hero::before{content:"";position:absolute;right:-50px;top:-50px;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(46,111,214,.4),transparent 65%)}
.emd-hero-l{flex:1 1 320px;position:relative;min-width:0}
.emd-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:#7FA8EE;font-weight:600}
.emd-big{font-family:var(--disp);font-size:clamp(44px,7vw,66px);line-height:.9;letter-spacing:1px;color:#fff;margin:6px 0 14px}
.emd-big span{font-family:var(--sans);font-size:18px;font-weight:600;color:#9FBCEF;letter-spacing:0;margin-left:10px}
.emd-bar{height:11px;border-radius:8px;background:rgba(255,255,255,.14);overflow:hidden}
.emd-bar span{display:block;height:100%;border-radius:8px;background:linear-gradient(90deg,#2E6FD6,#7FA8EE);transition:width .5s}
.emd-subline{font-size:14px;color:#C5D6F5;margin-top:10px;font-weight:500}
.emd-hero-r{display:flex;gap:12px;position:relative}
.emd-kpi{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.14);border-radius:12px;padding:13px 18px;text-align:center;min-width:84px}
.emd-kpi .k{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:#9FBCEF}
.emd-kpi .v{font-family:var(--disp);font-size:30px;letter-spacing:1px;color:#fff;line-height:1;margin-top:4px}
.emd-months{display:grid;gap:14px;grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}
.emd-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r2);padding:16px 17px;box-shadow:0 1px 2px rgba(16,35,79,.05),0 12px 30px -22px rgba(16,35,79,.3);transition:border-color .15s,box-shadow .15s}
.emd-card.hit{border-color:#2F8F6B;box-shadow:0 0 0 3px rgba(47,143,107,.12),0 12px 30px -22px rgba(16,35,79,.3)}
.emd-card-h{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:9px}
.emd-mn{font-family:var(--mono);font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--muted);font-weight:600}
.emd-pts{font-family:var(--disp);font-size:30px;letter-spacing:.5px;color:var(--gold);line-height:1}
.emd-pts i{font-family:var(--sans);font-size:11px;font-style:normal;color:var(--muted2);font-weight:600;margin-left:4px;letter-spacing:.5px}
.emd-card.hit .emd-pts{color:#2F8F6B}
.emd-mbar{height:7px;border-radius:5px;background:var(--panel3);overflow:hidden}
.emd-mbar span{display:block;height:100%;border-radius:5px;background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft));transition:width .4s}
.emd-card.hit .emd-mbar span{background:linear-gradient(90deg,#2F8F6B,#5cc497)}
.emd-mlabel{font-size:11px;color:var(--muted);margin:6px 0 13px;font-variant-numeric:tabular-nums}
.emd-ins{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px}
.emd-in{display:flex;flex-direction:column;gap:4px}
.emd-in span{font-family:var(--mono);font-size:9.5px;letter-spacing:.8px;text-transform:uppercase;color:var(--muted2);font-weight:600}
.emd-in input{padding:8px 9px;font-size:14px;font-variant-numeric:tabular-nums;text-align:center;background:var(--panel2);border:1px solid var(--line);border-radius:7px;width:100%}
.emd-in input:focus{border-color:var(--gold-soft);outline:none}
.emd-ro{font-size:15px;color:var(--text);text-align:center;padding:8px 0;font-weight:700}
@media(max-width:680px){.emd-hero{padding:22px 20px}.emd-hero-r{width:100%}.emd-kpi{flex:1;min-width:0}.emd-months{grid-template-columns:1fr}}


/* ===== Pipeline conversions (Top100/Recruit/Training -> another list) ===== */
.pc-convert{margin-top:16px;padding-top:15px;border-top:1px solid var(--line)}
.pc-convert-h{font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);margin-bottom:9px}
.pc-convert-row{display:flex;flex-wrap:wrap;gap:8px}
.pc-conv{font-size:13px;font-weight:700;color:var(--gold-soft);border:1px solid var(--line2);background:var(--panel);border-radius:8px;padding:9px 14px;cursor:pointer;transition:all .14s}
.pc-conv:hover{border-color:var(--gold-deep);color:var(--gold);background:var(--panel2)}


/* Agent login: roster is hidden for agents, so the sidebar doesn't need full width */
@media(min-width:981px){body.role-agent .app{grid-template-columns:240px 1fr}}


/* ===== Stat strips on list/table pages ===== */
.stat-strip{margin-bottom:16px}
.kpi-sub{font-size:11px;color:var(--muted);margin-top:5px;font-weight:500}
.kpi-bar{height:6px;border-radius:4px;background:var(--panel3);overflow:hidden;margin-top:10px}
.kpi-bar span{display:block;height:100%;border-radius:4px;background:linear-gradient(90deg,var(--gold-deep),var(--gold-soft));transition:width .4s}

/* ===== Rich empty state (pipeline tabs) ===== */
.list-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:56px 24px;border:1px dashed var(--line2);border-radius:var(--r);background:linear-gradient(180deg,var(--panel),var(--panel2))}
.list-empty-ic{width:56px;height:56px;border-radius:15px;display:flex;align-items:center;justify-content:center;background:var(--panel3);color:var(--gold-soft);margin-bottom:15px;box-shadow:inset 0 0 0 1px var(--line)}
.list-empty-ic svg{width:28px;height:28px}
.list-empty-t{font-family:var(--disp);font-size:24px;letter-spacing:.6px;color:var(--gold);line-height:1}
.list-empty-s{font-size:14px;color:var(--muted);margin-top:8px;max-width:46ch;text-wrap:pretty}


/* ===== Customize editor modal ===== */
.cz-ov{position:fixed;inset:0;background:rgba(10,20,45,.5);backdrop-filter:blur(3px);z-index:80;display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow:auto}
.cz-modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);width:100%;max-width:620px;box-shadow:0 30px 80px -30px rgba(16,35,79,.5);display:flex;flex-direction:column;max-height:calc(100vh - 80px)}
.cz-h{display:flex;align-items:center;justify-content:space-between;padding:18px 22px;border-bottom:1px solid var(--line)}
.cz-h-t{font-family:var(--disp);font-size:24px;letter-spacing:.5px;color:var(--gold)}
.cz-h-s{font-size:12px;color:var(--muted);margin-top:2px}
.cz-x{border:none;background:none;font-size:16px;color:var(--muted);cursor:pointer;padding:4px 8px;border-radius:8px}
.cz-x:hover{background:var(--panel3);color:var(--text)}
.cz-b{padding:18px 22px;overflow:auto}
.cz-sec{font-family:var(--mono);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-deep);font-weight:700;margin-bottom:12px}
.cz-sec span{font-family:var(--sans);text-transform:none;letter-spacing:0;color:var(--muted);font-weight:500}
.cz-sec-mt{margin-top:26px}
.cz-tabs{display:flex;flex-direction:column;gap:8px;margin-bottom:4px}
.cz-tab-row{display:flex;align-items:center;gap:12px}
.cz-in{flex:1;padding:9px 11px;border:1px solid var(--line2);border-radius:8px;background:var(--panel2);color:var(--text);font-size:14px;font-family:inherit}
.cz-in:focus{outline:none;border-color:var(--gold-soft)}
.cz-check{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);white-space:nowrap;cursor:pointer;min-width:64px}
.cz-locked{font-size:12px;color:var(--muted2);font-style:italic;min-width:90px;text-align:right}
.cz-field{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}
.cz-flabel{font-size:12px;font-weight:600;color:var(--muted)}
.cz-flabel i{font-weight:400;color:var(--muted2);font-style:normal}
.cz-field input{padding:9px 11px;border:1px solid var(--line2);border-radius:8px;background:var(--panel2);color:var(--text);font-size:14px;font-family:inherit}
.cz-field input:focus{outline:none;border-color:var(--gold-soft)}
.cz-grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.cz-grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:12px}
.cz-err{color:#C0392B;font-size:13px;font-weight:600;margin-top:8px}
.cz-f{display:flex;justify-content:flex-end;gap:10px;padding:16px 22px;border-top:1px solid var(--line)}
.cz-cancel{padding:10px 16px;border:1px solid var(--line2);background:var(--panel);color:var(--text);border-radius:9px;font-weight:600;font-size:14px;cursor:pointer}
.cz-save{padding:10px 18px;border:none;background:var(--gold);color:#fff;border-radius:9px;font-weight:700;font-size:14px;cursor:pointer}
.cz-save:hover{background:var(--gold-deep)}
.cz-save:disabled{opacity:.6;cursor:default}
@media(max-width:560px){.cz-grid2,.cz-grid3{grid-template-columns:1fr}.cz-tab-row{flex-wrap:wrap}}


/* ===== Dreams: achieved section ===== */
.dr-won-h{display:flex;align-items:center;gap:10px;margin:32px 0 14px;font-family:var(--disp);font-size:22px;letter-spacing:.6px;color:var(--c-money)}
.dr-trophy{width:26px;height:26px;display:inline-flex;color:var(--c-money)}
.dr-trophy svg{width:26px;height:26px}
.dr-won-c{font-family:var(--sans);font-size:12px;font-weight:700;background:rgba(47,143,107,.14);color:var(--c-money);border-radius:20px;padding:3px 10px;letter-spacing:0}
.dr-allwon{padding:18px;border:1px dashed var(--line2);border-radius:var(--r2);text-align:center;color:var(--muted);font-size:14px}


/* ===== Dreams: drag-to-reorder ===== */
.dr-sortable > *{cursor:grab}
.dr-sortable > *:active{cursor:grabbing}
.dr-sortable button,.dr-sortable input,.dr-sortable a,.dr-sortable select{cursor:pointer}
.dr-drag-ghost{opacity:.35}
.dr-drag-chosen{box-shadow:0 18px 42px -16px rgba(16,35,79,.55)}


/* ===== Quick Links (sidebar) ===== */
.ph-ql{margin-top:16px;padding:14px 12px 0;border-top:1px solid var(--line)}
.ph-ql:empty{display:none}
.ql-head{display:flex;align-items:center;justify-content:space-between;font-family:var(--mono);font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);font-weight:700;margin:0 2px 10px}
.ql-edit{border:none;background:none;color:var(--muted);cursor:pointer;font-size:13px;padding:2px 6px;border-radius:6px}
.ql-edit:hover{background:var(--panel3);color:var(--gold-soft)}
.ql-list{display:flex;flex-direction:column;gap:2px}
.ql-item{display:flex;align-items:center;gap:9px;padding:9px 10px;border-radius:9px;text-decoration:none;color:var(--text);font-size:13px;font-weight:600;transition:background .14s;min-width:0}
.ql-item:hover{background:var(--panel3)}
.ql-home{background:var(--panel2);border:1px solid var(--line);margin-bottom:9px;color:var(--gold)}
.ql-home:hover{border-color:var(--gold-soft);background:var(--panel3)}
.ql-home-ic{font-size:15px;line-height:1;flex:none}
.ql-dot{width:6px;height:6px;border-radius:50%;background:var(--gold-soft);flex:none}
.ql-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ql-ext{font-size:11px;color:var(--muted2);flex:none}
.ql-hint{font-size:10px;color:var(--muted2);font-style:italic;flex:none}
.ql-empty{color:var(--muted);cursor:default}
/* editor */
.ql-ov{position:fixed;inset:0;background:rgba(10,20,45,.5);backdrop-filter:blur(3px);z-index:85;display:flex;align-items:flex-start;justify-content:center;padding:48px 16px;overflow:auto}
.ql-modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--r);width:100%;max-width:520px;box-shadow:0 30px 80px -30px rgba(16,35,79,.5)}
.ql-mh{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--line)}
.ql-mt{font-family:var(--disp);font-size:22px;letter-spacing:.5px;color:var(--gold)}
.ql-x{border:none;background:none;font-size:15px;color:var(--muted);cursor:pointer}
.ql-mb{padding:16px 20px;display:flex;flex-direction:column;gap:10px;max-height:50vh;overflow:auto}
.ql-row{display:flex;gap:8px;align-items:center}
.ql-row input{padding:9px 10px;border:1px solid var(--line2);border-radius:8px;background:var(--panel2);color:var(--text);font-size:13px;font-family:inherit}
.ql-r-label{flex:0 0 34%;min-width:0}
.ql-r-url{flex:1;min-width:0}
.ql-row-del{flex:none;border:1px solid var(--line2);background:var(--panel);color:var(--muted);border-radius:8px;width:32px;height:32px;cursor:pointer}
.ql-row-del:hover{border-color:#C0392B;color:#C0392B}
.ql-add{margin:0 20px;padding:9px;border:1px dashed var(--line2);background:none;color:var(--gold-soft);border-radius:9px;font-weight:700;font-size:13px;cursor:pointer;width:calc(100% - 40px)}
.ql-add:hover{border-color:var(--gold-soft);background:var(--panel2)}
.ql-mf{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--line);margin-top:6px}
.ql-cancel{padding:9px 15px;border:1px solid var(--line2);background:var(--panel);color:var(--text);border-radius:9px;font-weight:600;cursor:pointer}
.ql-save{padding:9px 18px;border:none;background:var(--gold);color:#fff;border-radius:9px;font-weight:700;cursor:pointer}
.ql-save:disabled{opacity:.6}


/* ===== Customize: default agent links rows ===== */
.cz-links{display:flex;flex-direction:column;gap:8px;margin-bottom:10px}
.cz-link-row{display:flex;gap:8px;align-items:center}
.cz-link-row input{padding:9px 10px;border:1px solid var(--line2);border-radius:8px;background:var(--panel2);color:var(--text);font-size:13px;font-family:inherit}
.cz-l-label{flex:0 0 34%;min-width:0}
.cz-l-url{flex:1;min-width:0}
.cz-link-del{flex:none;border:1px solid var(--line2);background:var(--panel);color:var(--muted);border-radius:8px;width:32px;height:32px;cursor:pointer}
.cz-link-del:hover{border-color:#C0392B;color:#C0392B}
.cz-link-add{margin-top:2px;padding:9px;border:1px dashed var(--line2);background:none;color:var(--gold-soft);border-radius:9px;font-weight:700;font-size:13px;cursor:pointer;width:100%}
.cz-link-add:hover{border-color:var(--gold-soft);background:var(--panel2)}


/* ============================================================
   UX OVERHAUL: compact header · collapsible sidebar · mobile
   ============================================================ */

/* ---- Compact top bar (reclaim vertical space) ---- */
.topbar{padding:9px 22px 0}
.tb-row{align-items:center;gap:14px}
.tb-id{display:flex;align-items:center;gap:7px 12px;flex-wrap:wrap;min-width:0}
.tb-id h2{font-size:20px;line-height:1.15}
.tb-id .chips{margin-top:0}
.chip{font-size:10.5px;padding:3px 8px}
.tb-stats{gap:16px}
.sys-meter{width:46px;height:46px;flex:0 0 46px}
.sys-meter-svg{width:46px;height:46px}
.sys-meter-lbl .smv{font-size:11.5px;font-weight:800}
.sys-meter-lbl .sml{font-size:6px;letter-spacing:.4px;margin-top:0}
.tb-rank{padding-left:14px}
.tb-rank .lab{font-size:9px}
.tb-rank .val{font-size:18px}
.tabs{margin-top:7px}
.tab{padding:7px 12px;font-size:12.5px}

/* ---- Sidebar collapse button (lives in the brand) ---- */
.brand{position:relative}
.sidebar-collapse-btn{
  position:absolute;top:16px;right:14px;z-index:5;
  width:26px;height:26px;border-radius:8px;cursor:pointer;
  border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.12);
  color:#d6e4ff;font-size:15px;line-height:1;
  display:flex;align-items:center;justify-content:center}
.sidebar-collapse-btn:hover{background:rgba(255,255,255,.22)}
@media(max-width:980px){.sidebar-collapse-btn{display:none}}

/* ---- Desktop collapsed: slim rail with an expand button (never covers content) ---- */
@media(min-width:981px){
  body.sidebar-collapsed .app{grid-template-columns:56px 1fr}
  body.sidebar-collapsed .sidebar-main,
  body.sidebar-collapsed .sidebar-foot{display:none}
  body.sidebar-collapsed .sidebar-expand-btn{display:flex}
}
.sidebar-expand-btn{display:none;position:fixed;top:14px;left:10px;z-index:66;width:36px;height:36px;border-radius:10px;border:1px solid var(--line2);background:var(--panel);color:var(--text);font-size:16px;cursor:pointer;align-items:center;justify-content:center;box-shadow:0 6px 16px -8px rgba(16,35,79,.4)}
.sidebar-expand-btn:hover{border-color:var(--gold-deep);color:var(--gold-soft)}
@media(max-width:980px){.sidebar-expand-btn{display:none!important}}
@keyframes menuFade{from{opacity:0;transform:scale(.9)}to{opacity:1;transform:none}}

/* ---- Floating menu button: icon-only, never covers content ---- */
.menu-btn{padding:0;width:42px;height:42px;border-radius:12px;justify-content:center;gap:0}
.menu-btn .menu-btn-label{display:none!important}
.menu-bars{gap:3px}
.menu-bars span{width:18px}

/* ---- Admin sidebar tools: grouped + labelled ---- */
.side-foot-group{border-top:1px solid var(--line);padding:9px 12px 4px}
.side-foot-h{font-size:9.5px;font-weight:700;letter-spacing:1.1px;text-transform:uppercase;color:var(--muted2);margin:0 2px 7px}
.side-foot-h span{font-weight:600;letter-spacing:.4px;text-transform:none;color:var(--muted)}
.side-foot-group .side-foot{border-top:none;padding:0;gap:6px}
.side-foot-group .side-foot button{flex:1 1 calc(50% - 6px)}
.side-foot-danger{color:#C0392B!important;border-color:rgba(192,57,43,.3)!important}
.side-foot-danger:hover{border-color:#C0392B!important;background:rgba(192,57,43,.06)}

/* ---- Mobile: name clears the hamburger; tighter top ---- */
@media(max-width:980px){
  .topbar{padding:12px 16px 0 64px}
  .empty-main{padding-top:64px}
  .menu-btn{top:9px;left:10px}
}


/* ===== Ledger actions: Edit / Delete ===== */
.btn-edit{font-size:11px;font-weight:700;color:var(--gold-soft);border:1px solid var(--line2);background:var(--panel);border-radius:7px;padding:6px 12px;margin-right:6px;cursor:pointer;transition:all .14s}
.btn-edit:hover{border-color:var(--gold-deep);color:var(--gold);background:var(--panel2)}
.btn-del-soft{font-size:11px;font-weight:600;color:var(--muted);border:1px solid var(--line2);background:var(--panel);border-radius:7px;padding:6px 12px;cursor:pointer;transition:all .14s}
.btn-del-soft:hover{border-color:#C0392B;color:#C0392B;background:rgba(192,57,43,.05)}
.comm-pending{color:var(--muted);font-weight:600;cursor:help}

/* ===== Manager (team) roster ===== */
.mgr-you{font-size:9px;font-weight:800;letter-spacing:.6px;text-transform:uppercase;color:#fff;background:var(--gold-soft);border-radius:5px;padding:1px 5px;margin-left:6px;vertical-align:middle}

/* ===== Account panel: team access ===== */
.pp-team{margin-top:16px;padding-top:14px;border-top:1px solid var(--line)}
.pp-team-search{width:100%;padding:8px 10px;border:1px solid var(--line2);border-radius:8px;background:var(--panel2);color:var(--text);font-size:13px;font-family:inherit;margin:8px 0}
.pp-team-list{max-height:230px;overflow-y:auto;border:1px solid var(--line);border-radius:9px;padding:4px;margin-bottom:10px;background:var(--panel2)}
.pp-team-row{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:7px;cursor:pointer;font-size:13px;color:var(--text)}
.pp-team-row:hover{background:var(--panel)}
.pp-team-row input{width:16px;height:16px;accent-color:var(--gold-soft);cursor:pointer}
.pp-team-ok{display:block;font-size:12.5px;font-weight:600;margin-top:8px}

/* ===== Agent editor: field hint ===== */
.pp-field-hint{font-size:11px;color:var(--muted);margin-top:4px}


/* ============================================================
   Minimal admin chrome: user chip · Settings popover · Manage menu
   ============================================================ */

/* User chip */
.user-chip{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line)}
.uc-avatar{flex:0 0 34px;width:34px;height:34px;border-radius:50%;background:linear-gradient(140deg,#012A6B,#2E6FD6);color:#fff;font-size:12px;font-weight:800;letter-spacing:.5px;display:flex;align-items:center;justify-content:center}
.uc-info{flex:1;min-width:0}
.uc-name{font-size:13.5px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.uc-role{font-size:10px;letter-spacing:.5px;text-transform:uppercase;color:var(--muted);font-weight:600}
.uc-signout{flex:none;width:30px;height:30px;border-radius:8px;border:1px solid var(--line2);background:var(--panel);color:var(--muted);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .14s}
.uc-signout:hover{border-color:#C0392B;color:#C0392B}

/* Settings popover (sidebar foot) */
.side-foot-settings{position:relative;padding:10px 12px;border-top:1px solid var(--line)}
.settings-btn{width:100%;display:flex;align-items:center;gap:8px;padding:9px 12px;border:1px solid var(--line2);background:var(--panel);border-radius:10px;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:border-color .14s}
.settings-btn .settings-caret{margin-left:auto;color:var(--muted);font-size:11px}
.settings-btn:hover{border-color:var(--gold-deep)}
.settings-menu{display:none;position:absolute;left:12px;right:12px;bottom:56px;background:var(--panel);border:1px solid var(--line2);border-radius:12px;box-shadow:0 18px 44px -16px rgba(16,35,79,.5);padding:6px;z-index:40}
.settings-menu.open{display:block}
.settings-menu button{display:block;width:100%;text-align:left;padding:9px 11px;border:none;background:none;color:var(--text);font-size:13px;border-radius:8px;cursor:pointer}
.settings-menu button:hover{background:var(--panel2);color:var(--gold-soft)}

/* Topbar Manage menu (per-agent actions) */
.tb-manage{position:relative;display:flex;align-items:center}
.tb-manage-btn{padding:7px 12px;border:1px solid var(--line2);background:var(--panel);border-radius:9px;color:var(--text);font-size:12.5px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:6px;transition:border-color .14s}
.tb-manage-btn .caret{color:var(--muted);font-size:11px}
.tb-manage-btn:hover{border-color:var(--gold-deep)}
.tb-manage-menu{display:none;position:absolute;right:0;top:calc(100% + 8px);min-width:188px;background:var(--panel);border:1px solid var(--line2);border-radius:12px;box-shadow:0 18px 44px -16px rgba(16,35,79,.5);padding:6px;z-index:40}
.tb-manage-menu.open{display:block}
.tb-manage-menu button{display:block;width:100%;text-align:left;padding:9px 11px;border:none;background:none;color:var(--text);font-size:13px;border-radius:8px;cursor:pointer}
.tb-manage-menu button:hover{background:var(--panel2);color:var(--gold-soft)}
.tb-manage-menu button.danger{color:#C0392B}
.tb-manage-menu button.danger:hover{background:rgba(192,57,43,.06);color:#C0392B}

/* Manager (team-viewer) is role-agent but DOES get the roster rail */
body.is-manager .agent-roster-ui{display:flex!important}
body.is-manager .roster-head .btn-add{display:none!important}


/* ===== Top 100 actions + import wizard ===== */
.pc-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:4px}
.pc-actions .btn-row{flex:0 0 auto}
.pc-import{color:var(--gold-soft);border-style:dashed!important}
.pc-import:hover{border-color:var(--gold-deep)!important;color:var(--gold)}

.imp-ov{position:fixed;inset:0;background:rgba(8,18,40,.55);backdrop-filter:blur(3px);z-index:120;display:flex;align-items:center;justify-content:center;padding:18px}
.imp-modal{width:min(560px,96vw);max-height:92vh;overflow:auto;background:var(--panel);border:1px solid var(--line2);border-radius:18px;box-shadow:0 30px 80px -24px rgba(8,18,40,.6)}
.imp-h{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px 12px;border-bottom:1px solid var(--line)}
.imp-h-t{font-family:var(--disp);font-size:22px;letter-spacing:.5px;color:var(--text)}
.imp-h-s{font-size:12.5px;color:var(--muted);margin-top:2px}
.imp-x{border:1px solid var(--line2);background:var(--panel);color:var(--muted);width:30px;height:30px;border-radius:8px;cursor:pointer;flex:none}
.imp-x:hover{color:var(--text)}
.imp-b{padding:16px 20px}
.imp-drop{display:flex;flex-direction:column;align-items:center;text-align:center;gap:5px;padding:28px 16px;border:1.5px dashed var(--line2);border-radius:14px;background:var(--panel2);cursor:pointer;transition:border-color .15s,background .15s}
.imp-drop:hover{border-color:var(--gold-soft);background:var(--panel)}
.imp-drop-ic{width:42px;height:42px;border-radius:50%;background:var(--gold);color:#fff;font-size:20px;display:flex;align-items:center;justify-content:center;font-weight:800}
.imp-drop-t{font-weight:700;font-size:14px;color:var(--text)}
.imp-drop-s{font-size:12px;color:var(--muted)}
.imp-note{font-size:12px;color:var(--muted);margin-top:12px;line-height:1.5}
.imp-namemode{display:flex;gap:16px;flex-wrap:wrap;margin-bottom:12px;font-size:13px;color:var(--text)}
.imp-namemode label{display:flex;align-items:center;gap:6px;cursor:pointer}
.imp-field{margin-bottom:11px}
.imp-field label{display:block;font-size:11px;font-weight:700;letter-spacing:.4px;text-transform:uppercase;color:var(--muted);margin-bottom:5px}
.imp-field select{width:100%;padding:9px 10px;border:1px solid var(--line2);border-radius:9px;background:var(--panel2);color:var(--text);font-size:13px;font-family:inherit}
.imp-req{color:#C0392B}
.imp-grid2{display:grid;grid-template-columns:1fr 1fr;gap:0 12px}
.imp-sec{font-size:11px;font-weight:700;letter-spacing:.6px;text-transform:uppercase;color:var(--muted2);margin:14px 0 9px;padding-top:12px;border-top:1px solid var(--line)}
.imp-preview{margin-top:12px}
.imp-prev-h{font-size:13px;font-weight:700;color:var(--text);margin-bottom:6px}
.imp-prev-row{font-size:12.5px;color:var(--muted2);padding:3px 0}
.imp-err{color:#C0392B;font-size:13px;font-weight:600;margin-top:10px}
.imp-f{display:flex;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--line)}
.imp-btn{padding:10px 18px;border:none;background:var(--gold);color:#fff;border-radius:10px;font-weight:700;font-size:13px;cursor:pointer}
.imp-btn:disabled{opacity:.6;cursor:default}
.imp-btn-ghost{padding:10px 16px;border:1px solid var(--line2);background:var(--panel);color:var(--text);border-radius:10px;font-weight:600;font-size:13px;cursor:pointer}
@media(max-width:560px){.imp-grid2{grid-template-columns:1fr}}


/* ============================================================
   Mobile-first polish: scrollable tab strip + balanced header
   ============================================================ */
.tabs{-webkit-overflow-scrolling:touch;scrollbar-width:none;scroll-snap-type:x proximity;scroll-behavior:smooth}
.tabs::-webkit-scrollbar{display:none}
.tab{scroll-snap-align:start}

@media(max-width:980px){
  .topbar{position:sticky}
  .tb-row{gap:8px 12px}
  .tb-id h2{font-size:21px}
  .tb-stats{width:100%;justify-content:flex-start;gap:22px;margin-top:2px}
  .tabs{gap:0;padding-right:30px;margin-top:6px}
  .tab{padding:11px 15px;font-size:14px}
  /* fade hint so it's obvious the tabs scroll */
  .topbar::after{content:'';position:absolute;right:0;bottom:0;height:46px;width:34px;pointer-events:none;
    background:linear-gradient(90deg,rgba(255,255,255,0),rgba(255,255,255,.92))}
}

/* ===== New-contact dialog (name + phone first, no blank rows) ===== */
.modal.modal-sm{max-width:440px;width:min(440px,94vw)}
.pc-req{color:#C0392B}
.pc-new-err{color:#C0392B;font-size:13px;font-weight:600;margin-top:6px;min-height:16px}
.pc-convert-note{font-size:11.5px;color:var(--muted);margin-top:7px}
.pc-conv:disabled{opacity:.45;cursor:not-allowed}
.pc-conv:disabled:hover{border-color:var(--line2);color:var(--gold-soft);background:var(--panel)}


/* ===== System tab cleanup ===== */
.sys-overall .pbar-wide{margin-top:2px}
.sys-checklist-bar{display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;margin:22px 0 12px}
.scb-title{font-family:var(--disp);font-size:18px;letter-spacing:.4px;color:var(--text)}
.scb-title .ct{font-family:var(--sans);font-size:12px;letter-spacing:0;color:var(--muted);font-weight:400}
.scb-actions{display:flex;gap:8px;flex-wrap:wrap}
@media(max-width:560px){.sys-checklist-bar{flex-direction:column;align-items:flex-start;gap:8px}}
