*{box-sizing:border-box;margin:0;padding:0}
:root{
  --bg:#0f172a;--bg2:#1e293b;--bg3:#334155;
  --border:rgba(255,255,255,.08);--border2:rgba(255,255,255,.16);
  --text:#f1f5f9;--text2:#94a3b8;--text3:#64748b;
  --p:#0d9488;--pp:#0f766e;
}
html,body{height:100%;overflow:hidden}
body{font-family:'DM Sans',sans-serif;background:var(--bg);color:var(--text);display:flex;flex-direction:column}
.mi{font-family:'Material Symbols Outlined';font-style:normal;font-weight:300;font-size:20px;line-height:1;font-variation-settings:'FILL' 0,'wght' 300,'GRAD' 0,'opsz' 24;user-select:none;vertical-align:middle}
.mi.xs{font-size:15px}
input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}
input[type=number]{-moz-appearance:textfield}

/* Topbar */
.topbar{height:54px;background:#0a1120;border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 20px;flex-shrink:0;z-index:100}
.tb-icon{width:30px;height:30px;border-radius:7px;background:linear-gradient(135deg,#dc2626,#9f1239);display:flex;align-items:center;justify-content:center;text-decoration:none}
.tb-appname{font-size:15px;font-weight:700;color:#fff}
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:8px;font-size:12px;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:'DM Sans',sans-serif}
.bp{background:var(--p);color:#fff}.bp:hover{background:var(--pp)}
.bs{background:rgba(255,255,255,.08);color:var(--text2)}.bs:hover{background:rgba(255,255,255,.14)!important;color:#fff}

/* STICKY FAIRNESS BAR */
.fairness-bar{flex-shrink:0;z-index:90;padding:0;transition:all .3s;display:none}
.fairness-bar.visible{display:block}
.fairness-inner{padding:9px 20px;display:flex;align-items:center;gap:14px;box-shadow:0 4px 20px rgba(0,0,0,.4)}
.fairness-bar.green .fairness-inner{background:linear-gradient(90deg,rgba(5,150,105,.97),rgba(6,95,70,.97));border-bottom:1.5px solid rgba(52,211,153,.4)}
.fairness-bar.red .fairness-inner{background:linear-gradient(90deg,rgba(185,28,28,.97),rgba(127,29,29,.97));border-bottom:1.5px solid rgba(248,113,113,.4)}
.fairness-bar.amber .fairness-inner{background:linear-gradient(90deg,rgba(180,83,9,.97),rgba(120,53,15,.97));border-bottom:1.5px solid rgba(251,191,36,.4)}
.fairness-bar.neutral .fairness-inner{background:rgba(15,23,42,.97);border-bottom:1px solid var(--border)}
.fb-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.15);flex-shrink:0}
.fb-label{font-size:13px;font-weight:700;color:#fff;flex:1;min-width:0}
.fb-range{font-size:11px;color:rgba(255,255,255,.65);white-space:nowrap}
.fb-track-bg{width:120px;height:5px;background:rgba(255,255,255,.2);border-radius:3px;overflow:hidden;flex-shrink:0}
.fb-track-fill{height:100%;border-radius:3px;background:rgba(255,255,255,.8);transition:width .5s}
.fb-amount{font-size:15px;font-weight:800;color:#fff;font-family:var(--mono);flex-shrink:0}

/* Mode Toggle */
.mode-toggle-wrap{display:flex;justify-content:flex-start;padding:14px 20px 10px;flex-shrink:0}
.mode-toggle{display:flex;background:var(--bg2);border:1.5px solid var(--border2);border-radius:12px;padding:4px;gap:3px}
.mode-btn{display:flex;align-items:center;gap:7px;padding:7px 18px;border-radius:8px;border:none;font-size:13px;font-weight:600;cursor:pointer;font-family:'DM Sans',sans-serif;transition:all .2s;color:var(--text3);background:none}
.mode-btn.active.work{background:linear-gradient(135deg,#1e40af,#1d4ed8);color:#fff}
.mode-btn.active.home{background:linear-gradient(135deg,#065f46,#059669);color:#fff}
.mode-btn:hover:not(.active){background:rgba(255,255,255,.05);color:var(--text2)}

/* APP BODY — 70/30 split */
.app-body{display:flex;flex:1;overflow:hidden;gap:0}

/* LEFT: form panel */
.form-panel{flex:1;min-width:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden}
.form-scroll{padding:0 20px 20px;flex:1;overflow-y:auto}

/* RIGHT: staff panel */
.staff-panel{width:320px;flex-shrink:1;min-width:240px;background:var(--bg2);display:flex;flex-direction:column;overflow:hidden;margin:0 18px 12px 0}
.staff-panel-hdr{padding:14px 16px 10px;border-bottom:1px solid var(--border);flex-shrink:0}
.staff-panel-title{font-size:12px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.staff-list{flex:1;overflow-y:auto;padding:8px}
.staff-card{background:rgba(255,255,255,.04);border:1.5px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;cursor:pointer;transition:all .15s;position:relative}
.staff-card:hover{background:rgba(255,255,255,.07);border-color:var(--border2)}
.staff-card.selected{border-color:var(--p);background:rgba(13,148,136,.08)}
.staff-name{font-size:13px;font-weight:700;color:var(--text);margin-bottom:3px}
.staff-role{font-size:11px;color:var(--text3);margin-bottom:8px}
.staff-salary{font-size:16px;font-weight:800;font-family:var(--mono);color:#fff;margin-bottom:4px}
.staff-badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:700;margin-bottom:8px}
.staff-badge.under{background:rgba(220,38,38,.15);border:1px solid rgba(220,38,38,.3);color:#f87171}
.staff-badge.over{background:rgba(217,119,6,.12);border:1px solid rgba(217,119,6,.3);color:#fbbf24}
.staff-badge.fair{background:rgba(5,150,105,.12);border:1px solid rgba(5,150,105,.3);color:#34d399}
.staff-meta{display:flex;gap:10px;flex-wrap:wrap}
.staff-meta-item{font-size:10px;color:var(--text3);display:flex;align-items:center;gap:3px}
.add-staff-btn{width:100%;margin:4px 0 8px;background:rgba(13,148,136,.12);border:1.5px dashed rgba(13,148,136,.35);border-radius:10px;padding:10px;cursor:pointer;color:#2dd4bf;font-size:12px;font-weight:600;font-family:'DM Sans',sans-serif;display:flex;align-items:center;justify-content:center;gap:6px;transition:all .15s}
.add-staff-btn:hover{background:rgba(13,148,136,.2)}

/* Cards */
.card{background:rgba(255,255,255,.03);border:1.5px solid var(--border);border-radius:12px;padding:16px;margin-bottom:12px}
.card-title{font-size:11px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;margin-bottom:12px;display:flex;align-items:center;gap:6px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:10px}
.fg{margin-bottom:0}
.flbl{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.06em;display:block;margin-bottom:4px}
.fi,.fs{width:100%;padding:8px 11px;background:rgba(255,255,255,.05);border:1.5px solid var(--border);border-radius:8px;color:var(--text);font-size:13px;font-family:'DM Sans',sans-serif;transition:border-color .15s;outline:none}
.fi:focus,.fs:focus{border-color:rgba(255,255,255,.28)}
select.fi,select.fs{-webkit-appearance:none;appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 11px center;padding-right:32px}
select.fi option,select.fs option{background:#151929;color:#e2e8f0}
textarea.fi{resize:vertical}

/* ROLE SELECTOR — department grid */
.role-selector-wrap{margin-bottom:12px}
.dept-block{border:1.5px solid var(--border);border-radius:10px;margin-bottom:6px;overflow:hidden}
.dept-hdr{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;background:rgba(255,255,255,.03);transition:background .15s;user-select:none}
.dept-hdr:hover{background:rgba(255,255,255,.07)}
.dept-hdr.open{background:rgba(255,255,255,.05);border-bottom:1px solid var(--border)}
.dept-icon{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dept-name{font-size:12px;font-weight:700;color:var(--text2);flex:1}
.dept-count{font-size:10px;font-weight:600;color:var(--text3);margin-right:4px}
.dept-arr{font-size:14px;color:var(--text3);transition:transform .2s}
.dept-hdr.open .dept-arr{transform:rotate(90deg)}
.dept-body{display:none;padding:8px;display:none}
.dept-body.open{display:grid;grid-template-columns:1fr 1fr;gap:4px;padding:8px}
.role-chip{padding:8px 10px;border-radius:7px;border:1.5px solid var(--border);background:none;cursor:pointer;font-size:11px;font-weight:500;color:var(--text2);transition:all .15s;text-align:left;font-family:'DM Sans',sans-serif;line-height:1.3}
.role-chip:hover{border-color:var(--border2);color:var(--text);background:rgba(255,255,255,.04)}
.role-chip.selected{border-color:var(--p);background:rgba(13,148,136,.12);color:#2dd4bf;font-weight:700}
.selected-role-display{padding:10px 12px;background:rgba(13,148,136,.1);border:1.5px solid rgba(13,148,136,.3);border-radius:9px;display:flex;align-items:center;gap:8px;margin-bottom:10px}
.selected-role-display.empty{background:rgba(255,255,255,.04);border-color:var(--border)}

/* Skills — collapsible dept grid */
.skill-dept{border:1.5px solid var(--border);border-radius:9px;margin-bottom:6px;overflow:hidden}
.skill-dept-hdr{display:flex;align-items:center;gap:7px;padding:8px 12px;cursor:pointer;background:rgba(255,255,255,.02);transition:background .12s;user-select:none}
.skill-dept-hdr:hover{background:rgba(255,255,255,.06)}
.skill-dept-hdr.open{background:rgba(255,255,255,.04);border-bottom:1px solid var(--border)}
.skill-dept-name{font-size:11px;font-weight:700;color:var(--text2);flex:1}
.skill-dept-active{font-size:10px;font-weight:700;color:var(--p);margin-right:4px}
.skill-dept-arr{font-size:13px;color:var(--text3);transition:transform .15s}
.skill-dept-hdr.open .skill-dept-arr{transform:rotate(90deg)}
.skill-dept-body{display:none;flex-wrap:wrap;gap:5px;padding:8px 10px}
.skill-dept-body.open{display:flex}
.sk{padding:4px 9px;border-radius:6px;border:1.5px solid var(--border);background:rgba(255,255,255,.02);cursor:pointer;font-size:11px;font-weight:500;color:var(--text2);transition:all .12s;user-select:none}
.sk:hover{border-color:var(--border2);color:var(--text)}
.sk.active{border-color:var(--p);background:rgba(13,148,136,.11);color:#2dd4bf}

/* SARS toggle */
.sars-owner{display:flex;gap:6px;margin-bottom:10px}
.sars-btn{flex:1;padding:8px 6px;border-radius:8px;border:1.5px solid var(--border);background:none;cursor:pointer;font-size:11px;font-weight:600;color:var(--text3);font-family:'DM Sans',sans-serif;transition:all .15s;text-align:center}
.sars-btn.active{border-color:var(--p);background:rgba(13,148,136,.12);color:#2dd4bf}

/* Benefits */
.benefit-card{background:rgba(255,255,255,.03);border:1.5px solid var(--border);border-radius:9px;padding:11px;cursor:pointer;transition:all .15s;user-select:none}
.benefit-card:hover{border-color:var(--border2)}
.benefit-card.active{border-color:var(--p);background:rgba(13,148,136,.07)}
.benefit-card-hdr{display:flex;align-items:center;gap:7px}
.benefit-card.active .benefit-card-hdr{margin-bottom:10px}
.benefit-detail{display:none;padding-top:10px;border-top:1px solid var(--border)}
.benefit-card.active .benefit-detail{display:block}
.benefit-title{font-size:11px;font-weight:700;color:var(--text2)}
.benefit-card.active .benefit-title{color:#2dd4bf}

/* Tasks list */
.task-add-row{display:flex;gap:6px;margin-bottom:8px}
.task-item{display:flex;align-items:center;gap:6px;padding:6px 10px;background:rgba(255,255,255,.04);border:1px solid var(--border);border-radius:7px;margin-bottom:5px;font-size:12px;color:var(--text2)}
.task-item .task-del{background:none;border:none;cursor:pointer;color:var(--text3);padding:2px;border-radius:3px;display:flex;align-items:center;margin-left:auto;transition:color .12s;flex-shrink:0}
.task-item .task-del:hover{color:#f87171}

/* Result */
.result-section{background:linear-gradient(135deg,rgba(13,148,136,.07),rgba(29,78,216,.04));border:1.5px solid rgba(13,148,136,.18);border-radius:12px;padding:16px;margin-bottom:12px}
.tax-row{display:flex;align-items:center;justify-content:space-between;padding:7px 0;border-bottom:1px solid var(--border);font-size:12px}
.tax-row:last-child{border-bottom:none}
.tax-label{color:var(--text2);display:flex;align-items:center;gap:5px;flex:1;min-width:0}
.tax-amount{font-weight:600;font-family:var(--mono);flex-shrink:0;margin-left:8px}
.tax-row.total-row{padding-top:10px;margin-top:4px;border-top:2px solid var(--border2);border-bottom:none;font-size:14px;font-weight:800}
.tax-row.deduction .tax-amount{color:#f87171}
.tax-row.employer-row .tax-amount{color:#fbbf24}
.tax-row.employer-ee .tax-amount{color:#fb923c}
.badge-tag{font-size:9px;font-weight:700;padding:1px 5px;border-radius:3px;background:rgba(255,255,255,.07);color:var(--text3);letter-spacing:.03em;flex-shrink:0}
.badge-tag.employer{background:rgba(251,191,36,.14);color:#fbbf24}
.badge-tag.employee{background:rgba(248,113,113,.12);color:#f87171}
.badge-tag.note{background:rgba(13,148,136,.15);color:#2dd4bf}
.section-divider{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:.07em;padding:10px 0 5px;display:flex;align-items:center;gap:8px}
.section-divider::after{content:'';flex:1;height:1px;background:var(--border)}
.hourly-hero{background:rgba(13,148,136,.14);border:1.5px solid rgba(13,148,136,.28);border-radius:10px;padding:14px 16px;display:flex;align-items:center;justify-content:space-between;margin-top:12px}

/* App switcher */
/* ── APP SWITCHER ── */
.app-switcher{position:fixed;bottom:20px;left:16px;z-index:2000;display:flex;flex-direction:column;gap:8px;align-items:flex-start}
.app-switcher-toggle{width:42px;height:42px;border-radius:12px;background:#1f2937;border:1.5px solid rgba(255,255,255,.15);cursor:pointer;display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.6);transition:all .2s;box-shadow:0 4px 16px rgba(0,0,0,.35)}
.app-switcher-toggle:hover{background:#374151;color:#fff;border-color:rgba(255,255,255,.3)}
.app-switcher-menu{background:#0c1220;border:1.5px solid rgba(255,255,255,.12);border-radius:14px;padding:8px;display:none;flex-direction:column;gap:2px;box-shadow:0 8px 40px rgba(0,0,0,.55);min-width:188px}
.app-switcher-menu.open{display:flex}
.app-sw-icon{width:26px;height:26px;border-radius:7px;display:flex;align-items:center;justify-content:center;flex-shrink:0;overflow:hidden}
.app-sw-item{display:flex;align-items:center;gap:10px;padding:7px 9px;border-radius:9px;cursor:pointer;text-decoration:none;transition:background .15s;color:rgba(255,255,255,.6);font-size:12px;font-weight:500;border:none;background:none;font-family:inherit;width:100%;text-align:left}
.app-sw-item:hover{background:rgba(255,255,255,.07);color:#fff}
.app-sw-item.current{background:rgba(255,255,255,.08);color:#fff;font-weight:600}
.app-sw-sep{height:1px;background:rgba(255,255,255,.07);margin:2px 0}
html.light-mode .app-switcher-toggle{background:#fff;border-color:rgba(0,0,0,.15);color:#4b5563;box-shadow:0 2px 12px rgba(0,0,0,.1)}
html.light-mode .app-switcher-toggle:hover{background:#f3f4f6;color:#111}
html.light-mode .app-switcher-menu{background:#fff;border-color:rgba(0,0,0,.12);box-shadow:0 8px 32px rgba(0,0,0,.12)}
html.light-mode .app-sw-item{color:#4b5563}
html.light-mode .app-sw-item:hover{background:rgba(0,0,0,.05);color:#111}
html.light-mode .app-sw-item.current{background:rgba(0,0,0,.06);color:#111}
html.light-mode .app-sw-sep{background:rgba(0,0,0,.07)}
/* ── TEAM LIGHT MODE ── */
html.light-mode{--bg:#f5f5f7;--bg2:#ffffff;--bg3:#efefef;--bg4:#e5e5ea;--border:rgba(0,0,0,.09);--border2:rgba(0,0,0,.16);--text:#1a1a2e;--text2:#4b5563;--text3:#9ca3af;--p:#0d9488;}
html.light-mode body{background:var(--bg);color:var(--text);}
html.light-mode .topbar{background:#ffffff;border-bottom-color:rgba(0,0,0,.1);box-shadow:0 1px 4px rgba(0,0,0,.06);}
html.light-mode .form-panel{border-right-color:rgba(0,0,0,.08);}
html.light-mode .staff-panel{background:#f0f0f5;}
html.light-mode .staff-panel-hdr{border-bottom-color:rgba(0,0,0,.08);}
html.light-mode .staff-panel-title{color:var(--text3);}
html.light-mode .staff-card{background:#ffffff;border-color:rgba(0,0,0,.09);}
html.light-mode .staff-card:hover{background:#f9f9fb;border-color:rgba(0,0,0,.16);}
html.light-mode .staff-card.selected{border-color:#0d9488;background:rgba(13,148,136,.06);}
html.light-mode .staff-name{color:var(--text);}
html.light-mode .staff-role{color:var(--text3);}
html.light-mode .staff-salary{color:var(--text) !important;}
html.light-mode .staff-meta-item{color:var(--text3);}
html.light-mode .mode-toggle{background:#f0f0f5;border-color:rgba(0,0,0,.12);}
html.light-mode .fi{background:#f9f9fb;border-color:rgba(0,0,0,.14);color:var(--text);}
html.light-mode .fi:focus{border-color:#0d9488;background:#fff;}
html.light-mode .result-section{background:linear-gradient(135deg,rgba(13,148,136,.05),rgba(29,78,216,.03));border-color:rgba(13,148,136,.2);}
html.light-mode .flbl{color:var(--text2);}
html.light-mode .fg label{color:var(--text2);}
/* Fix hardcoded #fff in Team */
html.light-mode .staff-salary{color:var(--text) !important;}
html.light-mode [style*="color:#fff"]:not(.btn):not([class*="badge"]):not([class*="avatar"]):not([class*="staff-badge"]):not(button){color:var(--text) !important;}
html.light-mode [style*="color:rgba(255,255,255,.7"]{color:var(--text2) !important;}
html.light-mode [style*="color:rgba(255,255,255,.5"]{color:var(--text3) !important;}
html.light-mode [style*="color:rgba(255,255,255,.4"]{color:var(--text3) !important;}
html.light-mode [style*="color:rgba(255,255,255,.35"]{color:var(--text3) !important;}
html.light-mode [style*="background:#0a1120"],[style*="background:#1e293b"],[style*="background:#131e2e"]{background:var(--bg2) !important;}
html.light-mode [style*="background:rgba(255,255,255,.04)"]{background:rgba(0,0,0,.03) !important;}
html.light-mode [style*="background:rgba(255,255,255,.08)"]{background:rgba(0,0,0,.06) !important;}
html.light-mode [style*="border:1px solid var(--border)"]{border-color:rgba(0,0,0,.1) !important;}
html.light-mode [style*="border:1.5px solid var(--border)"]{border-color:rgba(0,0,0,.1) !important;}
/* Staff view modal */
html.light-mode #staff-view-modal > div{background:#ffffff !important;border-color:rgba(0,0,0,.1) !important;}
html.light-mode #vm-name{color:var(--text) !important;}
html.light-mode #vm-role{color:var(--text3) !important;}
html.light-mode #vm-body *[style*="color:#fff"]{color:var(--text) !important;}
html.light-mode #vm-body *[style*="color:rgba(255,255,255"]{color:var(--text2) !important;}

::-webkit-scrollbar{width:4px}.scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:2px}

/* Collapsible info box */
.payroll-info-detail.open{display:block !important}
.payroll-info-detail.open ~ span .mi{transform:rotate(180deg)}
/* Contextual help icon */
.ctx-help{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;border-radius:50%;background:rgba(99,102,241,.12);color:#818cf8;cursor:help;font-size:11px;margin-left:4px;flex-shrink:0;transition:all .12s;position:relative}
.ctx-help:hover{background:rgba(99,102,241,.25)}
.ctx-help .ctx-tip{display:none;position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:#1e293b;border:1px solid var(--border2);border-radius:8px;padding:8px 10px;font-size:10px;color:var(--text2);line-height:1.5;min-width:200px;max-width:280px;z-index:100;box-shadow:0 4px 16px rgba(0,0,0,.4);font-weight:400;text-transform:none;letter-spacing:0;white-space:normal;pointer-events:none}
.ctx-help:hover .ctx-tip{display:block}

/* Team extra light mode fixes */
html.light-mode .topbar .tb-appname,
html.light-mode [style*="font-weight:700;color:#fff"],
html.light-mode [style*="font-weight:800;color:#fff"],
html.light-mode [style*="font-weight:600;color:#fff"]{color:var(--text) !important;}
html.light-mode .mode-toggle-btn{color:var(--text2);}
html.light-mode .mode-toggle-btn.active{background:var(--p);color:#fff;}
html.light-mode .form-scroll{background:var(--bg);}
html.light-mode .form-section-title{color:var(--text2);}
html.light-mode select.fi option{background:#fff;color:var(--text);}
/* Staff view modal overrides */
html.light-mode #staff-view-modal [style*="color:#fff"]{color:var(--text) !important;}
html.light-mode #staff-view-modal [style*="color:rgba(255,255,255"]{color:var(--text2) !important;}
html.light-mode #staff-view-modal [style*="background:rgba(255,255,255,.04)"]{background:rgba(0,0,0,.03) !important;}
html.light-mode #staff-view-modal [style*="background:rgba(255,255,255,.08)"]{background:rgba(0,0,0,.06) !important;}
html.light-mode #staff-view-modal [style*="background:#0a1120"]{background:#fff !important;}
html.light-mode #staff-view-modal [style*="background:#1e293b"]{background:#f0f0f5 !important;}
/* Topbar app name */
html.light-mode .topbar span,html.light-mode .topbar div:not(button):not(.app-sw-icon){color:var(--text);}
html.light-mode .topbar .app-name-text{color:var(--text) !important;}

@media (max-width: 1280px) {
  .staff-panel { width: 280px; }
}
@media (max-width: 1024px) {
  .app-body { flex-direction:column; }
  .form-panel { border-right:none; border-bottom:1px solid var(--border); max-height:60vh; }
  .staff-panel { width:100%; min-width:0; flex:1; border-top:1px solid var(--border); }
  .staff-list { flex-direction:row; flex-wrap:wrap; gap:8px; padding:8px 12px; }
  .staff-card { width:calc(50% - 4px); margin-bottom:0; }
  .two-col { gap:8px; }
}
@media (max-width: 768px) {
  .topbar { padding:0 12px; gap:8px; }
  .topbar .mode-toggle-wrap { margin-left:8px; }
  .mode-btn { padding:6px 10px; font-size:11px; }
  .form-panel { max-height:none; }
  .form-scroll { padding:0 14px 14px; }
  .app-body { flex-direction:column; }
  .staff-panel { width:100%; }
  .staff-list { padding:6px 8px; }
  .staff-card { width:100%; }
  .two-col { grid-template-columns:1fr; }
  .three-col { grid-template-columns:1fr 1fr; }
  .fairness-inner { padding:8px 12px; gap:8px; }
  .fb-track-bg { display:none; }
}