:root{
  --navy:#0A2647;--navy2:#144272;--blue:#205295;--lightblue:#2C74B3;
  --accent:#00b8d9;--success:#00b894;--warn:#fdcb6e;--danger:#e17055;
  --bg:#f0f4f8;--white:#fff;--text:#1e2a3a;--muted:#6b7a8d;--border:#dce3ed;
  --sidebar-w:240px;
}
*{box-sizing:border-box;margin:0;padding:0;font-family:'Segoe UI',system-ui,sans-serif}
body{background:var(--bg);color:var(--text);min-height:100vh}
.screen{display:none;min-height:100vh}
.screen.active{display:flex}

/* ── CANDIDATE SCREENS ── */
.cand-wrap{min-height:100vh;background:linear-gradient(135deg,#0A2647 0%,#205295 60%,#2C74B3 100%);display:flex;align-items:center;justify-content:center;padding:24px}
.cand-card{background:var(--white);border-radius:20px;padding:40px 44px;width:100%;max-width:560px;box-shadow:0 24px 64px rgba(10,38,71,.3)}
.logo-bar{display:flex;align-items:center;gap:12px;margin-bottom:28px}
.logo-bar img{height:40px}
.logo-text{font-size:1.4rem;font-weight:700;color:var(--navy);letter-spacing:-0.5px}
.logo-text span{color:var(--lightblue)}
.step-bar{display:flex;gap:6px;margin-bottom:28px}
.step-dot{flex:1;height:5px;border-radius:3px;background:var(--border)}
.step-dot.done{background:var(--success)}
.step-dot.active{background:var(--lightblue)}
h2{font-size:1.45rem;font-weight:700;color:var(--navy);margin-bottom:6px}
.sub{font-size:.88rem;color:var(--muted);margin-bottom:24px}
label{display:block;font-size:.82rem;font-weight:600;color:var(--navy2);margin-bottom:5px;margin-top:14px}
input,select,textarea{width:100%;padding:11px 14px;border:1.5px solid var(--border);border-radius:9px;font-size:.93rem;color:var(--text);outline:none;transition:.2s}
input:focus,select:focus,textarea:focus{border-color:var(--lightblue);box-shadow:0 0 0 3px rgba(44,116,179,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 28px;border-radius:10px;border:none;cursor:pointer;font-size:.94rem;font-weight:600;transition:.2s}
.btn-primary{background:linear-gradient(135deg,var(--blue),var(--lightblue));color:#fff;width:100%;margin-top:22px}
.btn-primary:hover{opacity:.92;transform:translateY(-1px)}
.btn-outline{background:transparent;border:1.5px solid var(--border);color:var(--text)}
.btn-outline:hover{border-color:var(--lightblue);color:var(--lightblue)}
.jd-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:8px}
.jd-card{border:2px solid var(--border);border-radius:12px;padding:16px 14px;cursor:pointer;transition:.2s}
.jd-card:hover{border-color:var(--lightblue);background:#f0f7ff}
.jd-card.selected{border-color:var(--blue);background:#e8f1ff}
.jd-card .jd-icon{font-size:1.6rem;margin-bottom:6px}
.jd-card .jd-title{font-size:.85rem;font-weight:700;color:var(--navy);line-height:1.3}
.jd-card .jd-dept{font-size:.76rem;color:var(--muted);margin-top:3px}
.upload-zone{border:2px dashed var(--border);border-radius:12px;padding:28px 20px;text-align:center;cursor:pointer;transition:.2s;margin-top:10px}
.upload-zone:hover{border-color:var(--lightblue);background:#f5faff}
.upload-zone.has-file{border-color:var(--success);background:#f0fff8}
.upload-icon{font-size:2.2rem;margin-bottom:8px}
.upload-zone p{font-size:.87rem;color:var(--muted)}
.upload-zone .fname{font-weight:600;color:var(--success);margin-top:6px;font-size:.85rem}

/* Video Interview */
.video-header{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;padding:18px 24px;display:flex;align-items:center;justify-content:space-between}
.video-header .vlogo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:1.05rem}
.video-body{display:flex;min-height:calc(100vh - 68px);background:#f0f4f8}
.video-sidebar{width:280px;background:var(--white);border-right:1px solid var(--border);padding:20px 0}
.q-item{padding:12px 20px;display:flex;align-items:center;gap:10px;cursor:pointer;font-size:.85rem;border-left:3px solid transparent;transition:.15s}
.q-item:hover{background:#f5f8fc}
.q-item.active{background:#e8f1ff;border-left-color:var(--blue);color:var(--blue);font-weight:600}
.q-item.done{color:var(--success)}
.q-item .q-num{width:26px;height:26px;border-radius:50%;background:var(--bg);display:flex;align-items:center;justify-content:center;font-size:.78rem;font-weight:700;flex-shrink:0}
.q-item.active .q-num{background:var(--blue);color:#fff}
.q-item.done .q-num{background:var(--success);color:#fff}
.q-tag{font-size:.68rem;padding:2px 7px;border-radius:10px;margin-left:auto;font-weight:600}
.q-tag.tech{background:#e8f0ff;color:var(--blue)}
.q-tag.gen{background:#f0fff8;color:var(--success)}
.video-main{flex:1;padding:28px 32px;display:flex;flex-direction:column;gap:20px}
.q-display{background:var(--white);border-radius:14px;padding:24px;border:1px solid var(--border)}
.q-display .q-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin-bottom:8px}
.q-display .q-text{font-size:1.05rem;font-weight:600;color:var(--navy);line-height:1.5}
.video-container{background:var(--white);border-radius:14px;padding:20px;border:1px solid var(--border);display:flex;flex-direction:column;align-items:center;gap:14px}
video{width:100%;max-width:480px;border-radius:10px;background:#1a2332}
.rec-controls{display:flex;gap:10px;align-items:center}
.rec-btn{padding:10px 22px;border-radius:8px;border:none;cursor:pointer;font-weight:600;font-size:.88rem;transition:.2s}
.rec-start{background:var(--danger);color:#fff}
.rec-start:hover{opacity:.85}
.rec-stop{background:var(--warn);color:var(--text)}
.rec-stop:hover{opacity:.85}
.rec-next{background:var(--success);color:#fff}
.rec-next:hover{opacity:.85}
.rec-indicator{display:flex;align-items:center;gap:6px;font-size:.83rem;color:var(--muted)}
.rec-dot{width:10px;height:10px;border-radius:50%;background:var(--muted)}
.rec-dot.recording{background:var(--danger);animation:blink 1s infinite}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.3}}
.timer{font-size:1.1rem;font-weight:700;color:var(--navy);font-variant-numeric:tabular-nums}
.progress-outer{width:100%;background:var(--border);border-radius:6px;height:8px;overflow:hidden}
.progress-inner{height:100%;border-radius:6px;background:linear-gradient(90deg,var(--blue),var(--accent));transition:width .4s}

/* Thank You */
.ty-wrap{min-height:100vh;background:linear-gradient(135deg,#0A2647,#205295);display:flex;align-items:center;justify-content:center}
.ty-card{background:#fff;border-radius:20px;padding:48px;text-align:center;max-width:520px;box-shadow:0 24px 64px rgba(0,0,0,.25)}
.ty-icon{font-size:4rem;margin-bottom:16px}
.ty-card h2{font-size:1.7rem;color:var(--navy);margin-bottom:10px}
.ty-card p{color:var(--muted);line-height:1.6;margin-bottom:20px}
.score-preview{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:20px 0}
.sp-box{background:var(--bg);border-radius:10px;padding:14px 8px}
.sp-box .sp-val{font-size:1.4rem;font-weight:800;color:var(--blue)}
.sp-box .sp-lbl{font-size:.72rem;color:var(--muted);margin-top:3px}
.ref-code{background:var(--bg);border-radius:8px;padding:10px 16px;font-family:monospace;font-size:1rem;font-weight:700;color:var(--navy2);letter-spacing:2px;display:inline-block;margin-top:6px}

/* ── HR PORTAL ── */
.hr-login{min-height:100vh;background:linear-gradient(135deg,var(--navy) 0%,var(--blue) 100%);display:flex;align-items:center;justify-content:center}
.hr-login .cand-card{max-width:400px}
.layout{display:flex;min-height:100vh}
.sidebar{width:var(--sidebar-w);background:var(--navy);display:flex;flex-direction:column;flex-shrink:0}
.sb-logo{padding:22px 20px;border-bottom:1px solid rgba(255,255,255,.1);display:flex;align-items:center;gap:10px}
.sb-logo-text{color:#fff;font-weight:700;font-size:1rem;line-height:1.2}
.sb-logo-text span{color:var(--accent);font-size:.75rem;font-weight:500}
.sb-nav{flex:1;padding:14px 0}
.sb-section{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:1px;color:rgba(255,255,255,.3);padding:14px 20px 6px}
.sb-item{display:flex;align-items:center;gap:10px;padding:11px 20px;color:rgba(255,255,255,.7);cursor:pointer;font-size:.87rem;transition:.15s;border-left:3px solid transparent}
.sb-item:hover{color:#fff;background:rgba(255,255,255,.07)}
.sb-item.active{color:#fff;background:rgba(44,116,179,.35);border-left-color:var(--accent)}
.sb-item .sb-icon{font-size:1rem;width:20px;text-align:center}
.sb-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:.68rem;font-weight:700;padding:2px 7px;border-radius:10px}
.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden}
.topbar{background:var(--white);border-bottom:1px solid var(--border);padding:0 28px;height:60px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}
.topbar-title{font-size:1.1rem;font-weight:700;color:var(--navy)}
.topbar-right{display:flex;align-items:center;gap:14px}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem}
.content{flex:1;padding:24px 28px;overflow-y:auto}
.hr-page{display:none}
.hr-page.active{display:block}

/* KPI Cards */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
.kpi-card{background:var(--white);border-radius:14px;padding:20px;border:1px solid var(--border)}
.kpi-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.kpi-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:1.2rem}
.kpi-delta{font-size:.75rem;font-weight:600;padding:3px 8px;border-radius:6px}
.kpi-delta.up{background:#e6fff8;color:var(--success)}
.kpi-delta.down{background:#fff0ee;color:var(--danger)}
.kpi-val{font-size:2rem;font-weight:800;color:var(--navy)}
.kpi-lbl{font-size:.8rem;color:var(--muted);margin-top:2px}

/* Charts row */
.charts-row{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px;margin-bottom:24px}
.chart-card{background:var(--white);border-radius:14px;padding:20px;border:1px solid var(--border)}
.chart-card h3{font-size:.9rem;font-weight:700;color:var(--navy);margin-bottom:14px}

/* Candidate Table */
.table-card{background:var(--white);border-radius:14px;border:1px solid var(--border);overflow:hidden}
.table-header{padding:16px 20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border)}
.table-header h3{font-size:.95rem;font-weight:700;color:var(--navy)}
.filter-row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.filter-row input,.filter-row select{padding:7px 12px;border:1.5px solid var(--border);border-radius:8px;font-size:.82rem;width:auto}
.filter-row input{width:200px}
table{width:100%;border-collapse:collapse}
th{padding:11px 14px;text-align:left;font-size:.77rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);border-bottom:2px solid var(--border);background:#fafbfd;cursor:pointer;white-space:nowrap}
th:hover{color:var(--blue)}
th .sort-arrow{margin-left:4px;opacity:.4;font-size:.7rem}
td{padding:12px 14px;font-size:.86rem;border-bottom:1px solid var(--border);color:var(--text)}
tr:hover td{background:#f7f9fc}
.score-pill{display:inline-flex;align-items:center;gap:4px;font-weight:700;font-size:.82rem;padding:4px 10px;border-radius:20px}
.score-high{background:#e0fff4;color:#00875a}
.score-mid{background:#fff8e0;color:#a07000}
.score-low{background:#ffe8e8;color:#c0392b}
.rank-badge{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:.82rem}
.rank-1{background:#FFD700;color:#7a5800}
.rank-2{background:#C0C0C0;color:#444}
.rank-3{background:#CD7F32;color:#fff}
.rank-other{background:var(--bg);color:var(--muted)}
.status-badge{font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:10px}
.status-new{background:#e8f4fd;color:#1565c0}
.status-review{background:#fff8e0;color:#a07000}
.status-shortlisted{background:#e0fff4;color:#00875a}
.status-rejected{background:#ffe8e8;color:#c0392b}
.view-btn{padding:5px 12px;border:1.5px solid var(--border);border-radius:7px;background:transparent;cursor:pointer;font-size:.8rem;font-weight:600;color:var(--blue);transition:.15s}
.view-btn:hover{background:var(--blue);color:#fff;border-color:var(--blue)}
.paginator{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-top:1px solid var(--border);font-size:.83rem;color:var(--muted)}
.pag-btns{display:flex;gap:4px}
.pag-btn{width:30px;height:30px;border-radius:6px;border:1px solid var(--border);background:#fff;cursor:pointer;font-size:.8rem;display:flex;align-items:center;justify-content:center}
.pag-btn.active{background:var(--blue);color:#fff;border-color:var(--blue)}

/* Candidate Detail */
.cdet-header{background:var(--white);border-radius:14px;padding:24px;border:1px solid var(--border);display:flex;align-items:center;gap:20px;margin-bottom:20px}
.cdet-avatar{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--blue),var(--accent));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;flex-shrink:0}
.cdet-info h2{font-size:1.2rem;font-weight:700;color:var(--navy)}
.cdet-info p{font-size:.85rem;color:var(--muted);margin-top:2px}
.cdet-badges{display:flex;gap:8px;margin-top:8px;flex-wrap:wrap}
.cdet-badges span{font-size:.78rem;padding:4px 10px;border-radius:8px;font-weight:600}
.scores-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:20px}
.score-card{background:var(--white);border-radius:14px;padding:18px;border:1px solid var(--border);text-align:center}
.score-card .sc-val{font-size:2rem;font-weight:800}
.score-card .sc-lbl{font-size:.76rem;color:var(--muted);margin-top:4px}
.score-card .sc-bar{height:5px;border-radius:3px;margin-top:10px;overflow:hidden;background:var(--border)}
.score-card .sc-bar-fill{height:100%;border-radius:3px}
.detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:20px}
.detail-card{background:var(--white);border-radius:14px;padding:20px;border:1px solid var(--border)}
.detail-card h3{font-size:.88rem;font-weight:700;color:var(--navy);margin-bottom:14px;display:flex;align-items:center;gap:6px}
.skill-tag{display:inline-flex;font-size:.78rem;padding:4px 10px;border-radius:8px;margin:3px;font-weight:500}
.skill-match{background:#e0fff4;color:#00875a}
.skill-miss{background:#ffe8e8;color:#c0392b}
.skill-partial{background:#fff8e0;color:#a07000}
.video-q-item{padding:12px 0;border-bottom:1px solid var(--border)}
.video-q-item:last-child{border-bottom:none}
.video-q-item .vq-q{font-size:.83rem;color:var(--muted);margin-bottom:4px}
.video-q-item .vq-ans{font-size:.88rem;color:var(--text);font-style:italic}
.score-breakdown{display:flex;flex-direction:column;gap:8px}
.sb-row{display:flex;align-items:center;gap:10px}
.sb-row .sb-lbl{width:130px;font-size:.82rem;color:var(--muted)}
.sb-row .sb-bar{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}
.sb-row .sb-fill{height:100%;border-radius:4px}
.sb-row .sb-pct{width:36px;text-align:right;font-size:.82rem;font-weight:700;color:var(--navy)}

/* JD Editor */
.jd-editor-grid{display:grid;grid-template-columns:240px 1fr;gap:20px}
.jd-list-panel{background:var(--white);border-radius:14px;border:1px solid var(--border);overflow:hidden}
.jd-list-item{padding:13px 16px;border-bottom:1px solid var(--border);cursor:pointer;font-size:.86rem;transition:.15s}
.jd-list-item:hover{background:#f5f8fc}
.jd-list-item.active{background:#e8f1ff;color:var(--blue);font-weight:600}
.jd-edit-panel{background:var(--white);border-radius:14px;border:1px solid var(--border);padding:24px}
.jd-edit-panel h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:20px}
.q-edit-block{background:var(--bg);border-radius:10px;padding:16px;margin-bottom:12px}
.q-edit-block .q-type-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.7px;margin-bottom:8px}
.q-edit-block textarea{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;font-size:.87rem;resize:vertical;min-height:60px;background:var(--white)}
.save-flash{display:none;color:var(--success);font-size:.83rem;font-weight:600;margin-left:10px}
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(10,38,71,.5);z-index:999;align-items:center;justify-content:center}
.modal-overlay.open{display:flex}
.modal{background:#fff;border-radius:16px;padding:28px;max-width:500px;width:90%;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.modal h3{font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:14px}
.modal p{font-size:.88rem;color:var(--muted);margin-bottom:20px;line-height:1.6}
.modal-btns{display:flex;gap:10px;justify-content:flex-end}
.alert-bar{padding:10px 16px;border-radius:9px;font-size:.85rem;font-weight:600;margin-bottom:14px;display:none}
.alert-bar.err{background:#ffe8e8;color:#c0392b;display:block}
.alert-bar.ok{background:#e0fff4;color:#00875a;display:block}
@media(max-width:900px){.kpi-grid{grid-template-columns:repeat(2,1fr)}.charts-row{grid-template-columns:1fr}}

/* OTP SCREEN */
.otp-wrap{min-height:100vh;background:linear-gradient(135deg,#0A2647,#2C74B3);display:flex;align-items:center;justify-content:center;padding:24px}
.otp-code-inputs{display:flex;gap:10px;justify-content:center;margin:20px 0}
.otp-digit{width:48px;height:56px;border:2px solid var(--border);border-radius:10px;font-size:1.4rem;font-weight:700;text-align:center;outline:none;transition:.2s;-moz-appearance:textfield}
.otp-digit::-webkit-outer-spin-button,.otp-digit::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.otp-digit:focus{border-color:var(--lightblue);box-shadow:0 0 0 3px rgba(44,116,179,.15)}
.token-badge{background:#e8f1ff;border:1px solid #b3cfff;border-radius:10px;padding:10px 14px;font-family:monospace;font-size:.82rem;color:var(--blue);word-break:break-all;margin:8px 0;line-height:1.5}
/* ANTI-CHEAT */
.ac-bar{position:fixed;top:72px;right:16px;z-index:200;background:rgba(10,38,71,.92);color:#fff;border-radius:14px;padding:12px 16px;min-width:190px;backdrop-filter:blur(8px);box-shadow:0 6px 20px rgba(0,0,0,.35);display:none}
.ac-bar .ac-title{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.9px;opacity:.55;margin-bottom:9px}
.ac-row{display:flex;justify-content:space-between;align-items:center;padding:3px 0;gap:10px}
.ac-lbl{opacity:.7;font-size:.76rem}
.ac-val{font-weight:700;font-size:.8rem}
.ac-status{display:flex;align-items:center;gap:7px;margin-top:9px;padding-top:9px;border-top:1px solid rgba(255,255,255,.13);font-size:.8rem}
.ac-dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}
.ac-dot.green{background:#00b894;animation:pulse 2s infinite}
.ac-dot.red{background:#e17055;animation:blink .8s infinite}
.ac-dot.yellow{background:#fdcb6e}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}
/* HR VIDEO */
.hr-video-wrap{margin:8px 0;background:#0a1929;border-radius:8px;overflow:hidden}
.hr-video-wrap video{width:100%;max-width:480px;display:block;max-height:220px}
.hr-video-controls{display:flex;align-items:center;gap:8px;padding:7px 10px;background:#0d2137;flex-wrap:wrap}
.del-vid-btn{padding:5px 11px;border-radius:6px;border:none;background:#e17055;color:#fff;font-size:.75rem;font-weight:600;cursor:pointer}
.del-vid-btn:hover{background:#c0392b}
.no-video-badge{font-size:.78rem;color:var(--muted);font-style:italic;padding:5px 0;display:flex;align-items:center;gap:4px}
.storage-info{background:#e8f4fd;border:1px solid #b3cfff;border-radius:10px;padding:10px 16px;margin-bottom:14px;display:flex;align-items:center;justify-content:space-between;font-size:.82rem;flex-wrap:wrap;gap:8px}
.storage-info .si-lbl{color:var(--navy);font-weight:600}
.storage-info .si-val{color:var(--blue);font-weight:700}
/* LINKS PAGE */
.link-item{background:var(--bg);border-radius:10px;padding:14px 16px;margin-bottom:10px;display:flex;align-items:flex-start;gap:14px;flex-wrap:wrap;border:1px solid var(--border)}
.li-token{font-family:monospace;font-size:.75rem;color:var(--navy2);background:#fff;border:1px solid var(--border);padding:4px 8px;border-radius:6px;word-break:break-all;margin-top:4px;display:block;line-height:1.6}
.li-status{font-size:.74rem;font-weight:600;padding:3px 9px;border-radius:8px;white-space:nowrap}
.li-pending{background:#e8f4fd;color:#1565c0}
.li-used{background:#fff8e0;color:#a07000}
.li-expired{background:#f3f3f3;color:#999}
.li-completed{background:#e0fff4;color:#00875a}
/* AC STATS CARD */
.ac-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:10px}
.ac-stat-box{background:var(--bg);border-radius:9px;padding:12px 10px;text-align:center}
.ac-stat-box .asv{font-size:1.4rem;font-weight:800}
.ac-stat-box .asl{font-size:.72rem;color:var(--muted);margin-top:2px}
.risk-high{color:#e17055}
.risk-mid{color:#fdcb6e}
.risk-low{color:#00b894}

/* Server-rendered admin additions */
.inline-actions{display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.small-btn{padding:7px 12px;border-radius:8px;border:1.5px solid var(--border);background:#fff;color:var(--blue);font-size:.8rem;font-weight:700;cursor:pointer}
.small-btn.primary{background:var(--blue);color:#fff;border-color:var(--blue)}
.small-btn.danger{background:var(--danger);color:#fff;border-color:var(--danger)}
.small-btn.success{background:var(--success);color:#fff;border-color:var(--success)}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.form-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:20px;margin-bottom:18px}
.form-card h3{font-size:1rem;font-weight:700;color:var(--navy);margin-bottom:14px}
.switch-row{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:12px 0;border-bottom:1px solid var(--border)}
.switch-row:last-child{border-bottom:none}
.switch-row .meta{font-size:.78rem;color:var(--muted);margin-top:3px;line-height:1.4}
.config-input{max-width:240px}
.notice{padding:12px 14px;border-radius:10px;font-size:.84rem;line-height:1.5;margin-bottom:14px}
.notice.warn{background:#fff8e0;color:#795800;border:1px solid #f6dc84}
.notice.ok{background:#e0fff4;color:#00684a;border:1px solid #8be8c9}
.notice.err{background:#ffe8e8;color:#9b2b1d;border:1px solid #f0aca2}
.role-chip{display:inline-flex;padding:4px 10px;border-radius:999px;font-size:.74rem;font-weight:800;background:#e8f1ff;color:var(--blue)}
.permissions-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.perm-box{background:var(--bg);border:1px solid var(--border);border-radius:10px;padding:10px;font-size:.8rem}
.lock-screen{position:fixed;inset:0;background:rgba(10,38,71,.94);z-index:9999;display:none;align-items:center;justify-content:center;color:#fff;text-align:center;padding:24px}
.lock-screen.open{display:flex}
.lock-card{max-width:520px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:28px}
.recording-strip{background:#fff4f1;border:1px solid #f3b7aa;color:#9b2b1d;border-radius:10px;padding:10px 14px;font-size:.84rem;font-weight:700}
@media(max-width:900px){.form-grid,.permissions-grid{grid-template-columns:1fr}.video-body{flex-direction:column}.video-sidebar{width:100%}.scores-row{grid-template-columns:repeat(2,1fr)}.detail-grid{grid-template-columns:1fr}.jd-editor-grid{grid-template-columns:1fr}.cand-card{padding:28px 24px}.jd-grid{grid-template-columns:1fr}}
