/* Font fallback for embed contexts where Google Fonts may be blocked */
@font-face{font-family:'Poppins';font-style:normal;font-weight:400;font-display:swap;src:local('Poppins Regular'),local('Poppins-Regular')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:600;font-display:swap;src:local('Poppins SemiBold'),local('Poppins-SemiBold')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:700;font-display:swap;src:local('Poppins Bold'),local('Poppins-Bold')}
@font-face{font-family:'Poppins';font-style:normal;font-weight:800;font-display:swap;src:local('Poppins ExtraBold'),local('Poppins-ExtraBold')}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%;font-family:'Poppins',sans-serif}
:root,html,body{
  --bg:#07091c;--s1:#0e1328;--s2:#131829;--s3:#1a2035;--s4:#1f2640;
  --bdr:rgba(255,255,255,0.06);--bdr2:rgba(255,255,255,0.1);--bdr3:rgba(255,255,255,0.15);
  --gold:#c49a20;--gold-bg:rgba(196,154,32,0.1);--gold-bd:rgba(196,154,32,0.25);
  --txt:#dde3f0;--txt2:#94a3b8;--txt3:#64748b;
  --ok:#22c55e;--ok-bg:rgba(34,197,94,0.1);--ok-bd:rgba(34,197,94,0.25);
  --err:#ef4444;--err-bg:rgba(239,68,68,0.1);--err-bd:rgba(239,68,68,0.25);
  --warn:#f59e0b;--warn-bg:rgba(245,158,11,0.1);--warn-bd:rgba(245,158,11,0.25);
  --blue:#60a5fa;--blue-bg:rgba(96,165,250,0.1);--blue-bd:rgba(96,165,250,0.25);
  --blt-w:#cbd5e1;--blt-y:#eab308;--blt-g:#22c55e;--blt-b:#60a5fa;--blt-br:#c2772a;--blt-bk:#8b929e;
  --sw:245px;--r:10px;--rs:7px;--max-w:1400px;
  --topbar-h:58px;--mob-nav-h:60px;
}
body{background:var(--bg);color:var(--txt);-webkit-text-size-adjust:100%}


/* ── AUTH TABS ── */
.auth-tab{flex:1;padding:12px;font-size:13px;font-weight:600;cursor:pointer;text-align:center;color:var(--txt3);transition:.15s;border-bottom:2px solid transparent}
.auth-tab.active{color:var(--gold);border-bottom-color:var(--gold);background:var(--gold-bg)}
.auth-tab:hover:not(.active){color:var(--txt);background:var(--s2)}

/* ── ICONS ── */
.ico{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}
.ico svg{display:block}

/* ── LOGIN ── */
.boot-spinner{width:28px;height:28px;border:2px solid rgba(196,154,32,.25);border-top-color:var(--gold);border-radius:50%;animation:boot-spin .8s linear infinite}
@keyframes boot-spin{to{transform:rotate(360deg)}}
#login{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:20px}
#pending-screen{min-height:100vh;min-height:100dvh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;padding:20px}
.lg-bg{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.016) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.016) 1px,transparent 1px);background-size:40px 40px}
.lg-glow{position:absolute;width:600px;height:600px;background:radial-gradient(circle,rgba(196,154,32,0.07) 0%,transparent 70%);top:-100px;left:50%;transform:translateX(-50%)}
.lg-wrap{position:relative;z-index:1;width:100%;max-width:460px;text-align:center}
.lg-brand{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:6px}
.lg-mark{width:44px;height:44px;background:linear-gradient(135deg,var(--gold),#7a5c0d);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;letter-spacing:.05em;color:#000;flex-shrink:0}
.lg-name{font-size:18px;font-weight:700;letter-spacing:.05em}
.lg-sub{font-size:11px;color:var(--txt3);letter-spacing:.15em;text-transform:uppercase;margin-bottom:24px}

/* ── PORTAL SHELL ── */
.portal{display:flex;height:100vh;height:100dvh;overflow:hidden}

/* ── SIDEBAR ── */
.sidebar{width:var(--sw);background:var(--s1);border-right:1px solid var(--bdr);display:flex;flex-direction:column;flex-shrink:0;transition:transform .25s ease;z-index:200}
.sb-hd{padding:18px 14px 14px;border-bottom:1px solid var(--bdr)}
.sb-logo{display:flex;align-items:center;gap:9px;margin-bottom:6px}
.sb-mark{width:30px;height:30px;background:linear-gradient(135deg,var(--gold),#7a5c0d);border-radius:7px;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:10px;color:#000}
.sb-nm{font-size:13px;font-weight:700;letter-spacing:.04em}
.sb-ctx{font-size:10px;color:var(--txt3)}
.sb-org{margin-top:10px;padding:7px 10px;background:var(--s2);border-radius:var(--rs);font-size:11px;color:var(--txt2);border:1px solid var(--bdr);line-height:1.4;word-break:break-word}
.sb-nav{flex:1;overflow-y:auto;padding:10px 7px;-webkit-overflow-scrolling:touch}
.nav-lbl{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--txt3);padding:10px 8px 4px;font-weight:600}
.nav-item{display:flex;align-items:center;gap:9px;padding:10px 10px;border-radius:var(--rs);cursor:pointer;transition:all .12s;font-size:12.5px;color:var(--txt2);font-weight:500;margin-bottom:2px;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.nav-item:hover{background:var(--s2);color:var(--txt)}
.nav-item.active{background:var(--gold-bg);color:var(--gold)}
.nav-item .ico{width:18px;color:inherit;opacity:.75;flex-shrink:0}
.nav-item.active .ico{opacity:1}
.nb{margin-left:auto;background:var(--err);color:#fff;font-size:9px;font-weight:700;padding:1px 6px;border-radius:10px;min-width:18px;text-align:center}
.sb-ft{padding:10px 7px;border-top:1px solid var(--bdr)}
.user-row{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:var(--rs);cursor:pointer;transition:.12s}
.user-row:hover{background:var(--s2)}
.uav{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--gold),#5c3d0a);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#000;flex-shrink:0}
.uname{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.urole{font-size:10px;color:var(--txt3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.logout-ico{margin-left:auto;color:var(--txt3);cursor:pointer;transition:.12s;flex-shrink:0;padding:4px;-webkit-tap-highlight-color:transparent}
.logout-ico:hover{color:var(--txt)}

/* ── MOBILE SIDEBAR OVERLAY ── */
.sb-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.6);z-index:190;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}
.sb-overlay.open{display:block}

/* ── HAMBURGER ── */
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:6px;border-radius:var(--rs);transition:.15s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.hamburger:hover{background:var(--s2)}
.hamburger span{display:block;width:20px;height:2px;background:var(--txt2);border-radius:2px;transition:.25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MAIN ── */
.main{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.topbar{padding:0 18px;height:56px;border-bottom:1px solid var(--bdr);background:var(--s1);display:flex;align-items:center;justify-content:space-between;flex-shrink:0;gap:10px;overflow:hidden}
.tb-left{display:flex;align-items:center;gap:10px;min-width:0;flex:1}
.tb-title{font-size:15px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.view-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:22px 20px 40px;-webkit-overflow-scrolling:touch;min-width:0}
@media(max-width:768px){.view-body{overflow-x:visible}}

/* ── FACILITY SWITCHER ── */
.fac-switcher{display:flex;align-items:center;gap:6px;padding:5px 10px;background:var(--s2);border:1px solid var(--bdr2);border-radius:var(--rs);cursor:pointer;font-size:12px;font-weight:500;position:relative;max-width:200px}
.fac-switcher-text{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:140px}
.fac-switcher select{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;font-size:14px}

/* ── STATS GRID ── */
.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px}
.stat-card{background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);padding:18px 16px;position:relative;overflow:hidden}
.stat-accent{position:absolute;bottom:0;left:0;right:0;height:3px}
.stat-lbl{font-size:9.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--txt3);font-weight:600;margin-bottom:8px}
.stat-val{font-size:28px;font-weight:800;line-height:1;margin-bottom:5px}
.stat-sub{font-size:11px;color:var(--txt3);line-height:1.4;word-break:break-word;overflow-wrap:break-word}
.stat-ico-bg{position:absolute;top:14px;right:14px;opacity:.07;width:32px;height:32px}

/* ── CARDS ── */
.card{background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);overflow:hidden}
.card-hd{padding:13px 16px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap;min-width:0}
.card-ttl{font-size:13px;font-weight:700}
.card-body{padding:16px}
.g2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.g3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:16px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr)}
@media(max-width:768px){.grid-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:420px){.grid-4{grid-template-columns:repeat(2,1fr)}}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:6px;padding:7px 14px;border-radius:var(--rs);font-size:12.5px;font-weight:600;cursor:pointer;border:none;transition:all .15s;font-family:'Poppins',sans-serif;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.btn-gold{background:var(--gold);color:#000}
.btn-gold:hover{filter:brightness(1.1)}
.btn-ghost{background:var(--s2);color:var(--txt);border:1px solid var(--bdr2)}
.btn-ghost:hover{background:var(--s3);border-color:var(--bdr3)}
.btn-ok{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-bd)}
.btn-ok:hover{background:rgba(34,197,94,.18)}
.btn-err{background:var(--err-bg);color:var(--err);border:1px solid var(--err-bd)}
.btn-err:hover{background:rgba(239,68,68,.18)}
.btn-blue{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-bd)}
.btn-sm{padding:5px 11px;font-size:11.5px}
.btn-xs{padding:3px 8px;font-size:11px}
.btn .ico{width:14px}

/* ── TABLES ── */
.tbl{width:100%;border-collapse:collapse}
.tbl th{text-align:left;padding:9px 13px;font-size:10px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--txt3);border-bottom:1px solid var(--bdr);white-space:nowrap}
.tbl td{padding:10px 13px;font-size:12.5px;border-bottom:1px solid var(--bdr);vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tbody tr{cursor:pointer;transition:.1s}
.tbl tbody tr:hover td{background:var(--s2)}
.tbl-static tbody tr{cursor:default}
/* Scrollable table wrapper  --  tables scroll horizontally on overflow */
.card>.tbl,.tbl-wrap{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch;-ms-overflow-style:-ms-autohiding-scrollbar}
/* 520px floor only on desktop  --  mobile tables shrink/stack via .mob-stack */
@media(min-width:769px){
  .card>.tbl table,.tbl-wrap .tbl,.tbl-wrap table,table.tbl--scrollable{min-width:520px}
}
/* Ensure card overflow is visible so table scroll works */
.card{overflow:visible}
.card>.tbl{overflow-x:auto;border-radius:0 0 var(--r) var(--r)}

/* ── BELT BADGE ── */
.bb{display:inline-flex;align-items:center;gap:5px;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.bb-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}
.bb-White{background:rgba(203,213,225,.08);color:var(--blt-w);border:1px solid rgba(203,213,225,.2)}
.bb-Yellow{background:rgba(234,179,8,.09);color:var(--blt-y);border:1px solid rgba(234,179,8,.25)}
.bb-Green{background:rgba(34,197,94,.08);color:var(--blt-g);border:1px solid rgba(34,197,94,.25)}
.bb-Blue{background:rgba(96,165,250,.08);color:var(--blt-b);border:1px solid rgba(96,165,250,.25)}
.bb-Brown{background:rgba(194,119,42,.09);color:var(--blt-br);border:1px solid rgba(194,119,42,.25)}
.bb-Black{background:rgba(139,146,158,.08);color:var(--blt-bk);border:1px solid rgba(139,146,158,.22)}

/* ── PILL ── */
.pill{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:20px;font-size:10.5px;font-weight:600;white-space:nowrap}
.p-ok{background:var(--ok-bg);color:var(--ok);border:1px solid var(--ok-bd)}
.p-err{background:var(--err-bg);color:var(--err);border:1px solid var(--err-bd)}
.p-warn{background:var(--warn-bg);color:var(--warn);border:1px solid var(--warn-bd)}
.p-gold{background:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-bd)}
.p-blue{background:var(--blue-bg);color:var(--blue);border:1px solid var(--blue-bd)}
.p-muted{background:var(--s3);color:var(--txt3);border:1px solid var(--bdr)}

/* ── PROGRESS BAR ── */
.prog{height:7px;background:var(--s3);border-radius:4px;overflow:hidden}
.prog-fill{height:100%;border-radius:4px;transition:width .5s}

/* ── GATES ── */
.gates{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:14px}
.gate{padding:12px 10px;border-radius:var(--rs);border:1px solid var(--bdr);background:var(--s2);text-align:center}
.gate.g-pass{border-color:var(--ok-bd);background:rgba(34,197,94,.05)}
.gate.g-fail{border-color:var(--err-bd);background:rgba(239,68,68,.05)}
.gate.g-pend{border-color:var(--warn-bd);background:rgba(245,158,11,.04)}
.gate-lbl{font-size:9px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--txt3);margin-bottom:5px}
.gate-ico{width:26px;height:26px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 6px}
.gate-ico.pass-ico{background:rgba(34,197,94,.15);color:var(--ok)}
.gate-ico.fail-ico{background:rgba(239,68,68,.15);color:var(--err)}
.gate-ico.empty-ico{background:var(--s3);color:var(--txt3)}
.gate-status{font-size:11px;font-weight:600}
.gate-status.pass{color:var(--ok)}.gate-status.fail{color:var(--err)}.gate-status.empty{color:var(--txt3)}

/* ── FORMS ── */
.form-group{margin-bottom:14px}
.form-label{display:block;font-size:11.5px;font-weight:600;color:var(--txt2);margin-bottom:5px}
.form-input,.form-select,.form-textarea{width:100%;background:var(--s2);border:1px solid var(--bdr2);border-radius:var(--rs);padding:10px 12px;font-size:14px;color:var(--txt);font-family:'Poppins',sans-serif;outline:none;transition:border-color .15s;-webkit-appearance:none;appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--gold)}
.form-input::placeholder{color:var(--txt3)}
.form-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' stroke='%2364748b' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:30px}
.form-select option{background:var(--s2);color:var(--txt)}
.form-textarea{resize:vertical;min-height:70px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.form-hint{font-size:10.5px;color:var(--txt3);margin-top:3px}

/* ── MODAL ── */
#modal-overlay{position:fixed;inset:0;width:100%;height:100%;background:rgba(0,0,0,.65);display:none;align-items:flex-end;justify-content:center;z-index:1000;overflow:hidden}
#modal-overlay.open{display:flex}
.modal{background:var(--s1);border:1px solid var(--bdr2);border-radius:16px 16px 0 0;width:100%;max-height:92dvh;overflow-y:auto;box-shadow:0 -8px 40px rgba(0,0,0,.6);animation:slideUp .25s ease}
.modal-sm{max-width:480px}.modal-md{max-width:580px}.modal-lg{max-width:720px}
@keyframes slideUp{from{transform:translateY(30px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal-hd{padding:16px 20px 14px;border-bottom:1px solid var(--bdr);display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;background:var(--s1);z-index:1}
.modal-hd::before{content:'';position:absolute;top:8px;left:50%;transform:translateX(-50%);width:36px;height:4px;background:var(--bdr3);border-radius:2px}
.modal-title{font-size:15px;font-weight:700;margin-top:4px}
.modal-close{cursor:pointer;color:var(--txt3);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:5px;transition:.12s;-webkit-tap-highlight-color:transparent}
.modal-close:hover{background:var(--s2);color:var(--txt)}
.modal-body{padding:18px 20px}
.modal-ft{padding:14px 20px;border-top:1px solid var(--bdr);display:flex;align-items:center;justify-content:flex-end;gap:8px;flex-wrap:wrap;position:sticky;bottom:0;background:var(--s1)}

/* ── FILTERS ── */
.filter-bar{display:flex;gap:8px;margin-bottom:14px;align-items:center;flex-wrap:wrap;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:4px}
.search-wrap{position:relative;flex:1;min-width:160px}
.search-ico{position:absolute;left:9px;top:50%;transform:translateY(-50%);color:var(--txt3);width:14px;pointer-events:none}
.search-inp{width:100%;background:var(--s1);border:1px solid var(--bdr2);border-radius:var(--rs);padding:8px 11px 8px 30px;font-size:13px;color:var(--txt);font-family:'Poppins',sans-serif;outline:none;transition:.15s}
.search-inp::placeholder{color:var(--txt3)}
.search-inp:focus{border-color:var(--gold)}
.fchip{padding:5px 12px;border-radius:20px;font-size:11px;font-weight:600;cursor:pointer;border:1px solid var(--bdr2);background:var(--s1);color:var(--txt3);transition:.12s;user-select:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.fchip:hover{color:var(--txt)}.fchip.on{background:var(--gold-bg);border-color:var(--gold-bd);color:var(--gold)}

/* ── TABS ── */
.tab-bar{display:flex;gap:2px;background:var(--s2);padding:3px;border-radius:var(--rs);margin-bottom:16px;overflow-x:auto;-webkit-overflow-scrolling:touch}
.tab{padding:6px 14px;font-size:12px;font-weight:600;border-radius:5px;cursor:pointer;color:var(--txt3);transition:.12s;user-select:none;white-space:nowrap;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.tab.on{background:var(--s1);color:var(--txt);box-shadow:0 1px 3px rgba(0,0,0,.3)}

/* ── INFO ROW ── */
.irow{display:flex;align-items:flex-start;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--bdr);gap:8px}
.irow:last-child{border-bottom:none}
.ilbl{font-size:11.5px;color:var(--txt3);flex-shrink:0}
.ival{font-size:12.5px;font-weight:600;text-align:right;word-break:break-word}

/* ── RANK BADGES ── */
.rank{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:12px;flex-shrink:0}
.r1{background:linear-gradient(135deg,#c9a52c,#8b6914);color:#000}
.r2{background:linear-gradient(135deg,#9ca3af,#6b7280);color:#000}
.r3{background:linear-gradient(135deg,#b45309,#7c3706);color:#fff}
.rn{background:var(--s3);color:var(--txt3)}

/* ── UPLOAD ZONE ── */
.upload-zone{border:2px dashed var(--bdr2);border-radius:var(--r);padding:40px 24px;text-align:center;cursor:pointer;transition:.2s;-webkit-tap-highlight-color:transparent}
.upload-zone:hover,.upload-zone:active{border-color:var(--gold);background:var(--gold-bg)}
.upload-ttl{font-size:15px;font-weight:700;margin:12px 0 6px}
.upload-desc{font-size:12px;color:var(--txt3);margin-bottom:16px;line-height:1.5}

/* ── CHART ── */
.chart-wrap{position:relative;width:100%}
.chart-wrap canvas{display:block;max-width:100%}

/* ── PROFILE ── */
.prof-banner{background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);padding:18px;display:flex;align-items:flex-start;gap:14px;margin-bottom:16px}
.prof-av{width:52px;height:52px;border-radius:10px;background:var(--s3);border:1px solid var(--bdr2);display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700;flex-shrink:0;color:var(--txt2)}
.prof-name{font-size:19px;font-weight:800;margin-bottom:2px}
.prof-role{font-size:12.5px;color:var(--txt2);margin-bottom:8px}
.prof-meta{display:flex;gap:10px;flex-wrap:wrap;overflow:hidden}
.pmeta{font-size:11px;color:var(--txt3);display:flex;align-items:center;gap:4px}

/* ── BELT BARS ── */
.bbar-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}
.bbar-lbl{width:52px;font-size:11px;font-weight:700;flex-shrink:0}
.bbar-track{flex:1;height:20px;background:var(--s3);border-radius:4px;overflow:hidden}
.bbar-fill{height:100%;border-radius:4px;display:flex;align-items:center;justify-content:flex-end;padding-right:4px;font-size:9px;font-weight:700;color:#000;min-width:4px;transition:width .5s;overflow:hidden;white-space:nowrap}
.bbar-cnt{width:24px;text-align:right;font-size:11px;color:var(--txt3);flex-shrink:0}

/* ── TIMELINE ── */
.tl{padding-left:28px;position:relative}
.tl::before{content:'';position:absolute;left:8px;top:6px;bottom:6px;width:1px;background:var(--bdr)}
.tl-item{position:relative;padding:7px 0}
.tl-dot{position:absolute;left:-20px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700}
.tl-date{font-size:10.5px;color:var(--txt3);margin-bottom:2px}
.tl-txt{font-size:12.5px;font-weight:500}

/* ── FACILITY CARD ── */
.fac-card{background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);padding:18px;cursor:pointer;transition:.2s;-webkit-tap-highlight-color:transparent;touch-action:manipulation}
.fac-card:hover{border-color:var(--bdr3);transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.2)}
.fac-nm{font-size:13px;font-weight:700;margin-bottom:3px}
.fac-loc{font-size:11px;color:var(--txt3);margin-bottom:12px}

/* ── TOAST ── */
#toast{position:fixed;bottom:20px;left:50%;transform:translateX(-50%);z-index:3000;pointer-events:none;width:calc(100% - 32px);max-width:420px}
.toast-item{padding:12px 16px;border-radius:var(--rs);font-size:12.5px;font-weight:600;margin-bottom:8px;animation:slideUp .25s ease;border:1px solid;line-height:1.5;text-align:center;box-shadow:0 4px 20px rgba(0,0,0,.3)}
.toast-ok{background:rgba(7,9,28,.95);color:var(--ok);border-color:var(--ok-bd)}
.toast-err{background:rgba(7,9,28,.95);color:var(--err);border-color:var(--err-bd)}
.toast-info{background:rgba(7,9,28,.95);color:var(--gold);border-color:var(--gold-bd)}

/* ── MISC ── */
.hidden{display:none!important}
.fade-in{animation:fadeIn .22s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}
@keyframes pulse {
  0% { opacity: 0.4; transform: scale(0.85); }
  50% { opacity: 1; transform: scale(1.05); }
  100% { opacity: 0.4; transform: scale(0.85); }
}
.divider{height:1px;background:var(--bdr);margin:14px 0}
.section-lbl{font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--txt3);font-weight:600;margin-bottom:10px}
.empty-state{text-align:center;padding:44px 16px;color:var(--txt3)}
.empty-ico{width:40px;height:40px;margin:0 auto 10px;opacity:.25}
.empty-ttl{font-size:14px;font-weight:600;color:var(--txt2);margin-bottom:4px}
.empty-desc{font-size:12px;line-height:1.5}
.fw7{font-weight:700}.fw6{font-weight:600}
.hide-sm{display:table-cell}
.reg-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tc-ok{color:var(--ok)}.tc-err{color:var(--err)}.tc-warn{color:var(--warn)}.tc-gold{color:var(--gold)}.tc-blue{color:var(--blue)}.tc-muted{color:var(--txt3)}.tc-dim{color:var(--txt2)}
.mt4{margin-top:4px}.mt8{margin-top:8px}.mt12{margin-top:12px}.mt16{margin-top:16px}.mt20{margin-top:20px}
.mb8{margin-bottom:8px}.mb12{margin-bottom:12px}.mb16{margin-bottom:16px}.mb20{margin-bottom:20px}
::-webkit-scrollbar{width:4px;height:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--s3);border-radius:2px}

/* =============================================================
   RESPONSIVE BREAKPOINTS
============================================================= */

/* TABLET (≤ 1024px) */
@media(max-width:1024px){
  .stat-grid{grid-template-columns:repeat(2,1fr);gap:12px}
  .g3{grid-template-columns:1fr 1fr}
  .view-body{padding:18px 16px 32px}
  .topbar{padding:0 16px}
}

/* MOBILE (≤ 768px) */
@media(max-width:768px){
  :root{--sw:290px}

  /* Sidebar becomes fixed drawer */
  .sidebar{position:fixed;top:0;left:0;height:100%;height:100dvh;transform:translateX(-100%);box-shadow:8px 0 32px rgba(0,0,0,.5)}
  .sidebar.open{transform:translateX(0)}

  /* Show hamburger button */
  .hamburger{display:flex}

  /* Topbar compact */
  .topbar{padding:0 12px;height:52px}
  .tb-title{font-size:14px}
  /* Facility switcher: more room on mobile, allow full name to show */
  .fac-switcher{max-width:none;font-size:11px;padding:4px 8px;flex-shrink:1;min-width:0}
  .fac-switcher-text{max-width:160px;overflow:hidden;text-overflow:ellipsis}

  /* View body */
  .view-body{padding:14px 12px 80px}

  /* All grids to single column */
  .g2,.g3{grid-template-columns:1fr;gap:12px}
  .stat-grid{grid-template-columns:1fr 1fr;gap:10px}
  .stat-val{font-size:24px}
  .stat-card{padding:14px 12px}
  .stat-sub{font-size:10.5px}

  /* Forms */
  .form-row{grid-template-columns:1fr}
  .reg-grid{grid-template-columns:1fr!important}

  /* Modals full-height bottom sheets */
  .modal-sm,.modal-md,.modal-lg{max-width:100%}
  .modal-body{padding:14px 16px}
  .modal-ft{flex-direction:column-reverse;gap:8px}
  .modal-ft .btn{width:100%;justify-content:center;padding:12px}

  /* Cards compact */
  .card-hd{padding:11px 13px;gap:6px}
  .card-body{padding:13px}

  /* Profile */
  .prof-banner{flex-direction:column;gap:10px;padding:14px}
  .prof-av{width:44px;height:44px;font-size:16px}
  .prof-name{font-size:17px}

  /* Gates tighter on small screens */
  .gates{gap:6px}
  .gate{padding:10px 6px}
  .gate-lbl{font-size:8px}
  .gate-status{font-size:10px}
  .gate-ico{width:22px;height:22px}

  /* Tables  --  stacked card layout on mobile */
  .mob-stack thead{display:none}
  .mob-stack tbody tr{display:block;border:1px solid var(--bdr);border-radius:var(--rs);margin-bottom:8px;padding:2px 0;background:var(--s2)}
  .mob-stack td{display:flex;justify-content:space-between;align-items:center;padding:8px 14px;font-size:12px;border-bottom:1px solid var(--bdr);gap:8px;white-space:normal !important}
  .mob-stack td:last-child{border-bottom:none}
  .mob-stack td::before{content:attr(data-label);font-size:9.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase;color:var(--txt3);flex-shrink:0;margin-right:8px}
  /* Override inline min-width on tables and their wrappers so the .mob-stack
     pattern can actually shrink to viewport width. */
  table.tbl,table.tbl-static{min-width:0 !important}
  .card>.tbl > table,.tbl-wrap > table{min-width:0 !important}
  /* All tables scroll on mobile by default */
  .card>.tbl,.tbl-wrap{-webkit-overflow-scrolling:touch}
  
  /* Hide less critical table columns */
  .hide-sm{display:none!important}

  /* Filter */
  .filter-bar{gap:6px}
  .fchip{padding:4px 10px;font-size:10.5px}

  /* Charts: override fixed inline heights so labels don't overlap on narrow screens */
  .chart-wrap[style*="height:180px"],
  .chart-wrap[style*="height:160px"],
  .chart-wrap[style*="height:200px"]{height:clamp(140px,42vw,200px) !important}

  /* Position School / belt curriculum split view: collapse the fixed nav rail
     into a horizontally-scrolling strip above the content. */
  .cs-split{flex-direction:column !important;max-height:none !important}
  .cs-split-nav{width:100% !important;min-width:0 !important;max-height:none !important;max-height:38vh !important;border-right:none !important;border-bottom:1px solid var(--bdr) !important;display:flex !important;flex-direction:column;overflow-y:auto !important;padding:6px 8px !important}
  .cs-split-content{max-height:none !important;padding:14px 16px !important}
  /* Tighten nav items so the scroll list isn't visually heavy */
  .cs-split-nav .cs-ps-nav-item{font-size:11.5px !important;padding:7px 10px !important}

  /* Hide pill in topbar */
  .topbar-pill-hide{display:none}

  /* Login */
  .lg-name{font-size:14px}
  .lg-mark{width:36px;height:36px;font-size:11px}
  .lg-sub{margin-bottom:16px;font-size:10px}
}

/* SMALL MOBILE (≤ 420px) */
@media(max-width:420px){
  /* Collapse inline 2-up grids to single column on small phones. The
     attribute-selector + !important combination overrides inline styles. */
  div[style*="grid-template-columns:1fr 1fr"],
  div[style*="grid-template-columns: 1fr 1fr"],
  div[style*="grid-template-columns:repeat(2,1fr)"]{grid-template-columns:1fr !important}
  .stat-grid{grid-template-columns:1fr 1fr;gap:8px}
  .stat-val{font-size:22px}
  .stat-card{padding:12px 10px}
  .btn{padding:7px 12px;font-size:12px}
  .btn-sm{padding:5px 10px;font-size:11px}
  .view-body{padding:12px 10px 80px}
  .topbar{padding:0 10px}
  .gates{gap:4px}
  .gate{padding:9px 5px}
  .tb-title{font-size:13px}
  .card-hd{flex-direction:column;align-items:flex-start}
  .card-hd .btn-sm,.card-hd .btn-gold{width:100%;justify-content:center}
}

/* PRINT */
@media print{
  body{background:#fff;color:#000;font-size:11pt}
  .no-print,.hamburger,.sb-overlay,.sidebar{display:none!important}
  .portal{display:block}
  .main{width:100%}
  table{border-collapse:collapse;width:100%}
  th,td{border:1px solid #ddd;padding:6px 8px;font-size:9pt}
  th{background:#f5f5f5;font-weight:700}
  h1,h2,h3{color:#000}
}

/* =============================================================
   SIMVOLY / BAKND EMBED COLOR LOCK
   Prevents host platform stylesheets from overriding fonts,
   colors, or backgrounds inside the SIPS portal.
============================================================= */
@layer host-reset {
  #sbd-root, #sbd-root * { box-sizing:border-box !important; }
}

/* ── Font Family Lock ── */
#sbd-root,
#sbd-root div, #sbd-root span, #sbd-root p, #sbd-root a,
#sbd-root li, #sbd-root h1, #sbd-root h2, #sbd-root h3,
#sbd-root h4, #sbd-root h5, #sbd-root h6, #sbd-root label,
#sbd-root td, #sbd-root th, #sbd-root input, #sbd-root select,
#sbd-root textarea, #sbd-root button {
  font-family:'Poppins',sans-serif !important;
}

/* ── Root Container Backgrounds ── */
#sbd-root { background:#07091c !important; color:#dde3f0 !important; }
#sbd-root .portal { background:#07091c !important; }
#sbd-root .sidebar { background:#0e1328 !important; }
#sbd-root .topbar { background:#0e1328 !important; }
#sbd-root .card { background:#0e1328 !important; }
#sbd-root .stat-card { background:#0e1328 !important; }
#sbd-root .modal { background:#0e1328 !important; }
#sbd-root .modal-hd { background:#0e1328 !important; }
#sbd-root .modal-ft { background:#0e1328 !important; }
#sbd-root .sb-org { background:#131829 !important; }
#sbd-root .gate { background:#131829 !important; }
#sbd-root .fac-card { background:#0e1328 !important; }
#sbd-root .prof-banner { background:#0e1328 !important; }
#sbd-root .tab-bar { background:#131829 !important; }
#sbd-root .search-inp { background:#0e1328 !important; }
#sbd-root .fchip { background:#0e1328 !important; }
#sbd-root .form-input, #sbd-root .form-select, #sbd-root .form-textarea { background:#131829 !important; }

/* ── Navigation ── */
#sbd-root .nav-item { color:#94a3b8 !important; }
#sbd-root .nav-item:hover { color:#dde3f0 !important; background:#131829 !important; }
#sbd-root .nav-item.active { color:#c49a20 !important; background:rgba(196,154,32,0.1) !important; }
#sbd-root .nav-lbl { color:#64748b !important; }

/* ── Auth Tabs ── */
#sbd-root .auth-tab { color:#64748b !important; }
#sbd-root .auth-tab.active { color:#c49a20 !important; }
#sbd-root .auth-tab:hover:not(.active) { color:#dde3f0 !important; }

/* ── Topbar ── */
#sbd-root .tb-title { color:#dde3f0 !important; }

/* ── Buttons ── */
#sbd-root .btn-gold { background:#c49a20 !important; color:#000000 !important; }
#sbd-root .btn-ghost { background:#131829 !important; color:#dde3f0 !important; }
#sbd-root .btn-ok { color:#22c55e !important; }
#sbd-root .btn-err { color:#ef4444 !important; }
#sbd-root .btn-blue { color:#60a5fa !important; }

/* ── Stats ── */
#sbd-root .stat-lbl { color:#64748b !important; }
#sbd-root .stat-val { color:#dde3f0 !important; }
#sbd-root .stat-sub { color:#64748b !important; }

/* ── Cards ── */
#sbd-root .card-ttl { color:#dde3f0 !important; }

/* ── Tables ── */
#sbd-root .tbl th { color:#64748b !important; }
#sbd-root .tbl td { color:#dde3f0 !important; }

/* ── Belt Badges ── */
#sbd-root .bb-White { color:#cbd5e1 !important; }
#sbd-root .bb-Yellow { color:#eab308 !important; }
#sbd-root .bb-Green { color:#22c55e !important; }
#sbd-root .bb-Blue { color:#60a5fa !important; }
#sbd-root .bb-Brown { color:#c2772a !important; }
#sbd-root .bb-Black { color:#8b929e !important; }

/* ── Pills ── */
#sbd-root .pill { color:#dde3f0 !important; }
#sbd-root .p-ok { color:#22c55e !important; }
#sbd-root .p-err { color:#ef4444 !important; }
#sbd-root .p-warn { color:#f59e0b !important; }
#sbd-root .p-gold { color:#c49a20 !important; }
#sbd-root .p-blue { color:#60a5fa !important; }
#sbd-root .p-muted { color:#64748b !important; }

/* ── Gates ── */
#sbd-root .gate-lbl { color:#64748b !important; }
#sbd-root .gate-status.pass { color:#22c55e !important; }
#sbd-root .gate-status.fail { color:#ef4444 !important; }
#sbd-root .gate-status.empty { color:#64748b !important; }

/* ── Forms ── */
#sbd-root .form-label { color:#94a3b8 !important; }
#sbd-root .form-input { color:#dde3f0 !important; }
#sbd-root .form-input::placeholder { color:#64748b !important; }
#sbd-root .form-hint { color:#64748b !important; }
#sbd-root .form-select { color:#dde3f0 !important; }
#sbd-root .form-textarea { color:#dde3f0 !important; }

/* ── Search ── */
#sbd-root .search-inp { color:#dde3f0 !important; }
#sbd-root .search-inp::placeholder { color:#64748b !important; }

/* ── Filter Chips ── */
#sbd-root .fchip { color:#64748b !important; }
#sbd-root .fchip:hover { color:#dde3f0 !important; }
#sbd-root .fchip.on { color:#c49a20 !important; }

/* ── Tabs ── */
#sbd-root .tab { color:#64748b !important; }
#sbd-root .tab.on { color:#dde3f0 !important; background:#0e1328 !important; }

/* ── Info Rows ── */
#sbd-root .ilbl { color:#64748b !important; }
#sbd-root .ival { color:#dde3f0 !important; }

/* ── Modal ── */
#sbd-root .modal-title { color:#dde3f0 !important; }
#sbd-root .modal-close { color:#64748b !important; }
#sbd-root .modal-close:hover { color:#dde3f0 !important; }

/* ── Profile ── */
#sbd-root .prof-name { color:#dde3f0 !important; }
#sbd-root .prof-role { color:#94a3b8 !important; }
#sbd-root .pmeta { color:#64748b !important; }

/* ── Rank Badges ── */
#sbd-root .r1 { color:#000000 !important; }
#sbd-root .r2 { color:#000000 !important; }
#sbd-root .r3 { color:#ffffff !important; }
#sbd-root .rn { color:#64748b !important; }

/* ── Upload Zone ── */
#sbd-root .upload-ttl { color:#dde3f0 !important; }
#sbd-root .upload-desc { color:#64748b !important; }

/* ── Toasts ── */
#sbd-root .toast-ok { color:#22c55e !important; }
#sbd-root .toast-err { color:#ef4444 !important; }
#sbd-root .toast-info { color:#c49a20 !important; }

/* ── Belt Bars ── */
#sbd-root .bbar-fill { color:#dde3f0 !important; }
#sbd-root .bbar-cnt { color:#dde3f0 !important; }

/* ── Timeline ── */
#sbd-root .tl-date { color:#64748b !important; }
#sbd-root .tl-txt { color:#dde3f0 !important; }

/* ── Facility Cards ── */
#sbd-root .fac-nm { color:#dde3f0 !important; }
#sbd-root .fac-loc { color:#64748b !important; }

/* ── Text Color Utilities ── */
#sbd-root .tc-ok { color:#22c55e !important; }
#sbd-root .tc-err { color:#ef4444 !important; }
#sbd-root .tc-warn { color:#f59e0b !important; }
#sbd-root .tc-gold { color:#c49a20 !important; }
#sbd-root .tc-blue { color:#60a5fa !important; }
#sbd-root .tc-muted { color:#64748b !important; }
#sbd-root .tc-dim { color:#94a3b8 !important; }

/* ── Section & Empty States ── */
#sbd-root .section-lbl { color:#64748b !important; }
#sbd-root .empty-state { color:#64748b !important; }
#sbd-root .empty-ttl { color:#94a3b8 !important; }
#sbd-root .empty-desc { color:#64748b !important; }

/* ── Notification Badge ── */
#sbd-root .nb { color:#ffffff !important; background:#ef4444 !important; }

/* ── Login / Branding ── */
#sbd-root .lg-name { color:#dde3f0 !important; }
#sbd-root .lg-sub { color:#64748b !important; }
#sbd-root .lg-mark { color:#000000 !important; }
#sbd-root .sb-mark { color:#000000 !important; }
#sbd-root .sb-ctx { color:#64748b !important; }
#sbd-root .sb-org { color:#94a3b8 !important; }

/* ── User Avatar & Meta ── */
#sbd-root .uav { color:#000000 !important; }
#sbd-root .uname { color:#dde3f0 !important; }
#sbd-root .urole { color:#64748b !important; }
#sbd-root .logout-ico { color:#64748b !important; }
#sbd-root .logout-ico:hover { color:#dde3f0 !important; }

/* ── Hamburger ── */
#sbd-root .hamburger span { background:#94a3b8 !important; }

/* ── Icon SVGs ── */
#sbd-root .ico svg { color:inherit !important; }

/* ── Facility Switcher ── */
#sbd-root .fac-switcher { color:#dde3f0 !important; background:#131829 !important; }
#sbd-root .fac-switcher-text { color:#dde3f0 !important; }

/* ── User Management  --  Access Level Badges (lock) ── */
#sbd-root .pill { color:#dde3f0 !important; }
#sbd-root .p-ok  { color:#22c55e !important; background:rgba(34,197,94,0.1) !important; }
#sbd-root .p-err { color:#ef4444 !important; background:rgba(239,68,68,0.1) !important; }
#sbd-root .p-warn{ color:#f59e0b !important; background:rgba(245,158,11,0.1) !important; }
#sbd-root .p-gold{ color:#c49a20 !important; background:rgba(196,154,32,0.1) !important; }
#sbd-root .p-blue{ color:#60a5fa !important; background:rgba(96,165,250,0.1) !important; }
#sbd-root .p-muted{color:#64748b !important; background:rgba(30,38,60,0.9) !important; }
/* Tab bar */
#sbd-root .tab-bar { background:#131829 !important; }
#sbd-root .tab { color:#94a3b8 !important; }
#sbd-root .tab.on { color:#c49a20 !important; }
/* Facility Admin assessment queue specifics */
#sbd-root .form-hint { color:#64748b !important; }
#sbd-root select:disabled { color:#94a3b8 !important; }
/* OIP Quiz Overlay  --  outside normal modal, needs independent lock */
#oip-quiz-overlay { font-family:'Poppins',sans-serif !important; }
#oip-quiz-box { background:#0e1328 !important; border-color:rgba(255,255,255,.1) !important; font-family:'Poppins',sans-serif !important; }
#oip-quiz-hd, #oip-quiz-ft { background:#0e1328 !important; border-color:rgba(255,255,255,.06) !important; }
#oip-quiz-question { color:#dde3f0 !important; font-family:'Poppins',sans-serif !important; }
#oip-quiz-progress-label, #oip-quiz-remaining { color:#64748b !important; font-family:'Poppins',sans-serif !important; }
#oip-quiz-body { font-family:'Poppins',sans-serif !important; }

/* ── Study & Practice Module Lock ── */
#sbd-root .study-tab-active { color:#c49a20 !important; background:rgba(196,154,32,0.1) !important; }
#sbd-root .study-tab { color:#94a3b8 !important; }
#sbd-root .practice-card-title { color:#dde3f0 !important; font-weight:700 !important; }
#sbd-root .practice-card-desc { color:#64748b !important; }
#sbd-root .script-approved-label { color:#22c55e !important; }
#sbd-root .script-forbidden-label { color:#ef4444 !important; }
#sbd-root .script-safety-label { color:#c49a20 !important; }
#sbd-root .script-num-badge { font-weight:800 !important; }
#sbd-root .belt-identity-text { color:#dde3f0 !important; font-weight:700 !important; }
#sbd-root .belt-philosophy-text { color:#94a3b8 !important; }
#sbd-root .belt-principle-label { font-weight:700 !important; }
#sbd-root .assessment-level-label { font-weight:700 !important; }
#sbd-root .competency-item { color:#94a3b8 !important; }
#sbd-root .practice-result-score { font-weight:900 !important; }
#sbd-root .practice-result-grade { font-weight:800 !important; }
#sbd-root .practice-question-text { font-weight:600 !important; color:#dde3f0 !important; }
#sbd-root .practice-model-answer { color:#dde3f0 !important; }
#sbd-root .practice-diff-easy { color:#22c55e !important; }
#sbd-root .practice-diff-medium { color:#f59e0b !important; }
#sbd-root .practice-diff-hard { color:#ef4444 !important; }

/* ── Position School Curriculum Lock ── */
#sbd-root .ps-track-card { background:#131829 !important; border-color:rgba(255,255,255,0.06) !important; }
#sbd-root .ps-track-title { color:#dde3f0 !important; font-weight:800 !important; }
#sbd-root .ps-track-tagline { color:#64748b !important; }
#sbd-root .ps-track-desc { color:#94a3b8 !important; }
#sbd-root .ps-module-title { color:#dde3f0 !important; font-weight:700 !important; }
#sbd-root .ps-module-desc { color:#94a3b8 !important; }
#sbd-root .ps-identity-block { color:#94a3b8 !important; }
#sbd-root .ps-tier-green { color:#22c55e !important; }
#sbd-root .ps-tier-blue { color:#60a5fa !important; }
#sbd-root .ps-comp-item { color:#94a3b8 !important; }
#sbd-root .ps-outcome-pill { font-weight:600 !important; }
#sbd-root .ps-duration-val { color:#dde3f0 !important; font-weight:700 !important; }
#sbd-root .ps-audience-val { color:#dde3f0 !important; font-weight:600 !important; }
#sbd-root .ps-std-label { color:#64748b !important; font-weight:700 !important; }
#sbd-root .ps-std-items { color:#64748b !important; }


/* ── Curriculum Viewer ── */
#sbd-root .cs-body { font-family:'Poppins',sans-serif !important; color:#dde3f0 !important; }
#sbd-root .cs-body p.cs-para { font-size:13px !important; line-height:1.75 !important; color:#dde3f0 !important; margin:0 0 10px !important; }
#sbd-root .cs-body p.cs-script-desc { font-size:12.5px !important; color:#94a3b8 !important; font-style:italic !important; line-height:1.65 !important; margin:0 0 10px !important; }
#sbd-root .cs-body .cs-subhead { font-size:11px !important; font-weight:700 !important; letter-spacing:.07em !important; color:#c49a20 !important; margin:16px 0 8px !important; text-transform:uppercase !important; }
#sbd-root .cs-body .cs-table { width:100% !important; border-collapse:collapse !important; margin:12px 0 16px !important; font-size:12px !important; }
#sbd-root .cs-body .cs-table th { background:#1a2442 !important; color:#dde3f0 !important; font-weight:700 !important; padding:8px 10px !important; text-align:left !important; border:1px solid #2a3a5c !important; font-size:11.5px !important; }
#sbd-root .cs-body .cs-table td { padding:8px 10px !important; border:1px solid #2a3a5c !important; color:#94a3b8 !important; vertical-align:top !important; line-height:1.55 !important; }
#sbd-root .cs-body .cs-table tr:nth-child(even) td { background:rgba(255,255,255,.02) !important; }

/* ── Script blocks ── */
#sbd-root .cs-body .cs-script-header { font-size:12px !important; font-weight:700 !important; color:#dde3f0 !important; background:#1a2442 !important; border-left:3px solid #c49a20 !important; padding:8px 12px !important; margin:18px 0 0 0 !important; border-radius:4px 4px 0 0 !important; letter-spacing:.03em !important; }
#sbd-root .cs-body .cs-script-spacer { height:16px !important; display:block !important; }

/* ── Approved language  --  green ── */
#sbd-root .cs-body .cs-mode-label { font-size:10px !important; font-weight:700 !important; letter-spacing:.07em !important; padding:5px 12px !important; display:block !important; }
#sbd-root .cs-body .cs-approved-label { background:#052e16 !important; color:#22c55e !important; border-left:3px solid #22c55e !important; margin:0 !important; }
#sbd-root .cs-body .cs-forbidden-label { background:#2d0a0a !important; color:#ef4444 !important; border-left:3px solid #ef4444 !important; margin:0 !important; }
#sbd-root .cs-body .cs-approved-item { display:flex !important; align-items:flex-start !important; gap:8px !important; padding:8px 12px !important; background:#052e1666 !important; border-left:3px solid #22c55e !important; margin:1px 0 !important; }
#sbd-root .cs-body .cs-forbidden-item { display:flex !important; align-items:flex-start !important; gap:8px !important; padding:8px 12px !important; background:#2d0a0a66 !important; border-left:3px solid #ef4444 !important; margin:1px 0 !important; }
#sbd-root .cs-body .cs-approved-text { font-size:13px !important; color:#86efac !important; line-height:1.6 !important; font-weight:500 !important; }
#sbd-root .cs-body .cs-forbidden-text { font-size:13px !important; color:#fca5a5 !important; line-height:1.6 !important; }
#sbd-root .cs-body .cs-approved-tag { font-size:14px !important; color:#22c55e !important; flex-shrink:0 !important; margin-top:1px !important; }
#sbd-root .cs-body .cs-forbidden-tag { font-size:14px !important; color:#ef4444 !important; flex-shrink:0 !important; margin-top:1px !important; }

/* Color lock for script elements */
#sbd-root .cs-approved-label { background:#052e16 !important; color:#22c55e !important; }
#sbd-root .cs-forbidden-label { background:#2d0a0a !important; color:#ef4444 !important; }
#sbd-root .cs-approved-text { color:#86efac !important; }
#sbd-root .cs-forbidden-text { color:#fca5a5 !important; }
#sbd-root .cs-approved-tag { color:#22c55e !important; }
#sbd-root .cs-forbidden-tag { color:#ef4444 !important; }
#sbd-root .cs-script-header { color:#dde3f0 !important; background:#1a2442 !important; }

/* ── PS Curriculum Visual Design ── */
#sbd-root .cs-body .cs-course-header { background: rgba(30,42,70,0.5); padding: 20px; border-radius: 8px; border-bottom: 2px solid #c49a20; margin-bottom: 24px; }
#sbd-root .cs-body .cs-belt-title { font-size: 20px !important; font-weight: 800 !important; color: #fff; margin: 0 0 10px 0; letter-spacing: 0.05em; display: flex; align-items: center; gap: 12px; }
#sbd-root .cs-body .cs-belt-title.cs-yellow { border-bottom-color: #facc15; }
#sbd-root .cs-body .cs-belt-title.cs-green { border-bottom-color: #4ade80; }
#sbd-root .cs-body .cs-belt-subtitle { font-size: 14px; font-weight: 500; color: #94a3b8; }
#sbd-root .cs-body .cs-belt-tags { display: flex; flex-wrap: wrap; gap: 8px; margin-bottom: 12px; }
#sbd-root .cs-body .cs-tag { font-size: 11px; padding: 4px 10px; background: rgba(196,154,32,0.15); color: #c49a20; border-radius: 12px; font-weight: 600; letter-spacing: 0.05em; }
#sbd-root .cs-body .cs-belt-author { font-size: 11px; color: #64748b; margin: 0; font-style: italic; }
#sbd-root .cs-body .cs-strong-gold { color: #fcd34d !important; font-weight: 700 !important; font-size: 14px !important; display: inline-block; margin-top: 12px; margin-bottom: 4px; }
#sbd-root .cs-body .cs-alert-box { background: rgba(196,154,32,0.1); border-left: 4px solid #c49a20; padding: 16px; margin: 20px 0; border-radius: 0 8px 8px 0; }
#sbd-root .cs-body .cs-alert-danger { background: rgba(239,68,68,0.1); border-left-color: #ef4444; }
#sbd-root .cs-body .cs-alert-title { display: block; font-size: 13px !important; font-weight: 800 !important; color: #facc15 !important; margin-bottom: 8px; letter-spacing: 0.05em; }
#sbd-root .cs-body .cs-alert-danger .cs-alert-title { color: #ef4444 !important; }
#sbd-root .cs-body .cs-alert-text { font-size: 12.5px !important; line-height: 1.6 !important; color: #dde3f0 !important; margin: 0 !important; }

#sbd-root .cs-body .cs-para { font-size:13px !important; line-height:1.8 !important; color:#dde3f0 !important; margin:0 0 12px !important; }
#sbd-root .cs-body .cs-subhead { font-size:10.5px !important; font-weight:800 !important; letter-spacing:.09em !important; color:#c49a20 !important; margin:20px 0 8px !important; text-transform:uppercase !important; padding-bottom:5px !important; border-bottom:1px solid rgba(196,154,32,.2) !important; }
#sbd-root .cs-body .cs-table { width:100% !important; border-collapse:collapse !important; margin:14px 0 18px !important; font-size:12.5px !important; }
#sbd-root .cs-body .cs-table th { background:#1a2442 !important; color:#dde3f0 !important; font-weight:700 !important; padding:9px 12px !important; text-align:left !important; border:1px solid #2a3a5c !important; font-size:11.5px !important; letter-spacing:.04em !important; }
#sbd-root .cs-body .cs-table td { padding:9px 12px !important; border:1px solid #2a3a5c !important; color:#94a3b8 !important; vertical-align:top !important; line-height:1.6 !important; }
#sbd-root .cs-body .cs-table tr:nth-child(even) td { background:rgba(30,42,70,.4) !important; }
#sbd-root .cs-body .cs-table td:first-child { color:#dde3f0 !important; font-weight:600 !important; }
#sbd-root .cs-ps-nav-item { color:#94a3b8 !important; }

/* ══════════════════════════════════════════════════════════════════
   ONBOARDING / TOUR / GUIDE / ATTENTION SYSTEM
   ══════════════════════════════════════════════════════════════════ */

/* ── Welcome Overlay ── */
.welcome-overlay{position:fixed;inset:0;z-index:2000;background:rgba(7,9,28,.92);display:flex;align-items:center;justify-content:center;padding:20px;opacity:0;transition:opacity .35s ease;pointer-events:none}
.welcome-overlay.open{opacity:1;pointer-events:auto}
.welcome-box{background:var(--s1);border:1px solid var(--bdr2);border-radius:16px;max-width:520px;width:100%;padding:44px 36px 36px;text-align:center;transform:translateY(24px) scale(.96);transition:transform .35s ease;position:relative;overflow:hidden}
.welcome-overlay.open .welcome-box{transform:translateY(0) scale(1)}
.welcome-glow{position:absolute;top:-60px;left:50%;transform:translateX(-50%);width:320px;height:320px;background:radial-gradient(circle,rgba(196,154,32,.12) 0%,transparent 70%);pointer-events:none}
.welcome-icon{width:64px;height:64px;background:linear-gradient(135deg,var(--gold),#7a5c0d);border-radius:16px;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;position:relative}
.welcome-title{font-size:22px;font-weight:800;margin-bottom:8px;line-height:1.3}
.welcome-sub{font-size:13px;color:var(--txt2);line-height:1.65;margin-bottom:6px}
.welcome-role{font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:28px}
.welcome-actions{display:flex;flex-direction:column;gap:10px;align-items:center}
.welcome-btn-start{display:inline-flex;align-items:center;gap:8px;padding:12px 32px;background:var(--gold);color:#000;font-size:14px;font-weight:700;border:none;border-radius:var(--rs);cursor:pointer;font-family:'Poppins',sans-serif;transition:.15s}
.welcome-btn-start:hover{filter:brightness(1.1);transform:translateY(-1px)}
.welcome-btn-skip{padding:8px 16px;background:transparent;color:var(--txt3);font-size:12px;font-weight:500;border:none;cursor:pointer;font-family:'Poppins',sans-serif;transition:.15s}
.welcome-btn-skip:hover{color:var(--txt)}

/* ── Tour Spotlight Overlay ── */
.tour-overlay{position:fixed;inset:0;z-index:1800;pointer-events:none;opacity:0;transition:opacity .25s ease}
.tour-overlay.active{opacity:1;pointer-events:none}
.tour-backdrop{position:fixed;inset:0;background:transparent;pointer-events:none;transition:opacity .2s}
.tour-overlay.active .tour-backdrop{pointer-events:none}
.tour-spotlight{position:fixed;border-radius:10px;box-shadow:0 0 0 4px rgba(196,154,32,.7),0 0 30px 8px rgba(196,154,32,.35),0 0 60px 16px rgba(196,154,32,.15);z-index:1801;pointer-events:none;transition:all .35s cubic-bezier(.4,0,.2,1)}
.tour-tooltip{position:fixed;z-index:1802;background:var(--s1);border:1px solid var(--gold-bd);border-radius:12px;padding:20px 22px 18px;max-width:360px;width:calc(100vw - 40px);pointer-events:none;box-shadow:0 12px 40px rgba(0,0,0,.5);transform:translateY(8px);opacity:0;transition:all .3s cubic-bezier(.4,0,.2,1) .1s;cursor:grab}
.tour-tooltip:active{cursor:grabbing}
.tour-overlay.active .tour-tooltip{transform:translateY(0);opacity:1;pointer-events:auto}
.tour-step-badge{display:inline-block;font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.tour-title{font-size:15px;font-weight:700;margin-bottom:6px;line-height:1.35}
.tour-desc{font-size:12.5px;color:var(--txt2);line-height:1.65;margin-bottom:16px}
.tour-nav{display:flex;align-items:center;gap:8px;justify-content:space-between;flex-wrap:wrap}
.tour-dots{display:flex;gap:4px;align-items:center;flex-wrap:wrap;max-width:120px;overflow:hidden}
.tour-dot{width:6px;height:6px;border-radius:50%;background:var(--s3);flex-shrink:0}
.tour-dot.active{background:var(--gold);width:18px;border-radius:3px}
.tour-dot.done{background:var(--txt3)}
.tour-btns{display:flex;gap:6px;align-items:center}
.tour-btn-back{padding:6px 14px;background:var(--s2);color:var(--txt2);border:1px solid var(--bdr2);border-radius:var(--rs);font-size:12px;font-weight:600;cursor:pointer;font-family:'Poppins',sans-serif;transition:.12s}
.tour-btn-back:hover{background:var(--s3);color:var(--txt)}
.tour-btn-next{padding:6px 16px;background:var(--gold);color:#000;border:none;border-radius:var(--rs);font-size:12px;font-weight:700;cursor:pointer;font-family:'Poppins',sans-serif;transition:.12s}
.tour-btn-next:hover{filter:brightness(1.1)}
.tour-btn-skip{padding:6px 12px;background:transparent;color:var(--txt3);border:none;font-size:11px;font-weight:500;cursor:pointer;font-family:'Poppins',sans-serif;transition:.12s}
.tour-btn-skip:hover{color:var(--txt)}
.tour-progress-bar{height:3px;background:var(--s3);border-radius:2px;margin-bottom:14px;overflow:hidden}
.tour-progress-fill{height:100%;background:var(--gold);border-radius:2px;transition:width .35s ease}

/* ── Guide View ── */
.guide-header{margin-bottom:24px}
.guide-header-title{font-size:20px;font-weight:800;margin-bottom:4px}
.guide-header-sub{font-size:13px;color:var(--txt2)}
.guide-section-label{font-size:10px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--txt3);margin:24px 0 10px;padding-bottom:6px;border-bottom:1px solid var(--bdr)}
.guide-card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;margin-bottom:20px}
.guide-card{background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);padding:18px 16px;cursor:pointer;transition:all .15s;position:relative}
.guide-card:hover{border-color:var(--bdr3);background:var(--s2);transform:translateY(-1px)}
.guide-card-icon{width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:10px;flex-shrink:0}
.guide-card-title{font-size:13px;font-weight:700;margin-bottom:4px}
.guide-card-desc{font-size:11.5px;color:var(--txt3);line-height:1.55}
.guide-showme{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:600;color:var(--gold);margin-top:10px;cursor:pointer;transition:.12s}
.guide-showme:hover{color:var(--txt)}
.guide-checklist{background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);padding:18px;margin-bottom:20px}
.guide-checklist-title{font-size:13px;font-weight:700;margin-bottom:12px}
.checklist-item{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--bdr);font-size:12.5px}
.checklist-item:last-child{border-bottom:none}
.checklist-check{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:11px;font-weight:700}
.checklist-done{background:var(--ok-bg);border:1px solid var(--ok-bd);color:var(--ok)}
.checklist-pending{background:var(--s2);border:1px solid var(--bdr2);color:var(--txt3)}
.checklist-text{flex:1;min-width:0}
.checklist-text.done{color:var(--txt3);text-decoration:line-through}
.checklist-action{font-size:11px;font-weight:600;color:var(--gold);cursor:pointer;white-space:nowrap;transition:.12s}
.checklist-action:hover{color:var(--txt)}
.guide-relaunch{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;background:var(--gold-bg);color:var(--gold);border:1px solid var(--gold-bd);border-radius:var(--rs);font-size:13px;font-weight:600;cursor:pointer;font-family:'Poppins',sans-serif;transition:.15s;margin-bottom:20px}
.guide-relaunch:hover{background:var(--gold);color:#000}
.guide-search{width:100%;padding:10px 14px 10px 38px;background:var(--s2);border:1px solid var(--bdr);border-radius:var(--rs);font-size:12.5px;color:var(--txt);font-family:'Poppins',sans-serif;outline:none;transition:.15s;margin-bottom:16px}
.guide-search:focus{border-color:var(--gold-bd)}
.guide-search::placeholder{color:var(--txt3)}
.guide-search-wrap{position:relative}
.guide-search-ico{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--txt3);pointer-events:none}

/* ── Attention Notification Bar ── */
.attn-bar{display:none;align-items:center;gap:10px;padding:10px 16px;background:var(--gold-bg);border-bottom:1px solid var(--gold-bd);font-size:12px;animation:attnSlideIn .35s ease}
.attn-bar.show{display:flex}
@keyframes attnSlideIn{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.attn-bar-icon{flex-shrink:0;color:var(--gold)}
.attn-bar-text{flex:1;min-width:0;color:var(--txt);font-weight:500;line-height:1.4}
.attn-bar-action{flex-shrink:0;padding:4px 12px;background:var(--gold);color:#000;border:none;border-radius:var(--rs);font-size:11px;font-weight:700;cursor:pointer;font-family:'Poppins',sans-serif;transition:.12s;white-space:nowrap}
.attn-bar-action:hover{filter:brightness(1.1)}
.attn-bar-close{flex-shrink:0;color:var(--txt3);cursor:pointer;transition:.12s;padding:4px;border-radius:4px}
.attn-bar-close:hover{color:var(--txt);background:rgba(255,255,255,.06)}
.attn-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;border-radius:50%;background:var(--gold);animation:attnPulse 2s infinite}
@keyframes attnPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.3)}}

/* ── Post-Tour Modal ── */
.posttour-modal{text-align:center;padding:8px 0}
.posttour-icon{width:56px;height:56px;background:var(--ok-bg);border:1px solid var(--ok-bd);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;color:var(--ok)}
.posttour-title{font-size:18px;font-weight:700;margin-bottom:6px}
.posttour-desc{font-size:12.5px;color:var(--txt2);line-height:1.6;margin-bottom:20px;max-width:360px;margin-left:auto;margin-right:auto}
.posttour-actions{display:flex;flex-direction:column;gap:8px;align-items:center;max-width:300px;margin:0 auto}
.posttour-actions .btn{width:100%;justify-content:center}

/* ── Skip Reminder Banner ── */
.skip-reminder{position:fixed;bottom:calc(20px + env(safe-area-inset-bottom,0px));left:50%;transform:translateX(-50%) translateY(120px);z-index:1200;background:var(--s1);border:1px solid var(--gold-bd);border-radius:10px;padding:12px 20px;display:flex;align-items:center;gap:10px;font-size:12px;box-shadow:0 8px 30px rgba(0,0,0,.5);transition:transform .35s cubic-bezier(.4,0,.2,1);max-width:calc(100vw - 40px)}
.skip-reminder.show{transform:translateX(-50%) translateY(0)}
.skip-reminder-text{color:var(--txt2)}
.skip-reminder-link{color:var(--gold);font-weight:600;cursor:pointer;white-space:nowrap;transition:.12s}
.skip-reminder-link:hover{color:var(--txt)}
/* Suppress skip-reminder when a modal or placement assessment is active */
body.placement-active .skip-reminder,
body:has(#modal-overlay.open) .skip-reminder,
body:has(#oip-quiz-overlay[style*="display: flex"]) .skip-reminder,
body:has(#placement-overlay:not(.hidden)) .skip-reminder{display:none !important}

/* ── Responsive: Tour/Guide/Attention ── */
@media(max-width:768px){
  .welcome-box{padding:32px 22px 28px}
  .welcome-title{font-size:18px}
  .tour-tooltip{max-width:calc(100vw - 32px);padding:16px 18px 14px}
  .guide-card-grid{grid-template-columns:1fr}
  .attn-bar{flex-wrap:wrap}
  .attn-bar-action{width:100%;text-align:center;padding:8px}
  .tour-dots{max-width:80px}
}

/* ══════════════════════════════════════════════════════════════════
   ONBOARDING COLOR LOCK  --  SIMVOLY / BAKND EMBED PROTECTION
   ══════════════════════════════════════════════════════════════════ */

/* ── Welcome Overlay Lock ── */
#sbd-root .welcome-overlay { background:rgba(7,9,28,.92) !important; }
#sbd-root .welcome-box { background:#0e1328 !important; }
#sbd-root .welcome-title { color:#dde3f0 !important; }
#sbd-root .welcome-sub { color:#94a3b8 !important; }
#sbd-root .welcome-role { color:#c49a20 !important; }
#sbd-root .welcome-btn-start { background:#c49a20 !important; color:#000000 !important; }
#sbd-root .welcome-btn-skip { color:#64748b !important; }
#sbd-root .welcome-btn-skip:hover { color:#dde3f0 !important; }

/* ── Tour Lock ── */
#sbd-root .tour-tooltip { background:#0e1328 !important; }
#sbd-root .tour-step-badge { color:#c49a20 !important; }
#sbd-root .tour-title { color:#dde3f0 !important; }
#sbd-root .tour-desc { color:#94a3b8 !important; }
#sbd-root .tour-btn-back { background:#131829 !important; color:#94a3b8 !important; }
#sbd-root .tour-btn-back:hover { color:#dde3f0 !important; background:#1a2035 !important; }
#sbd-root .tour-btn-next { background:#c49a20 !important; color:#000000 !important; }
#sbd-root .tour-btn-skip { color:#64748b !important; }
#sbd-root .tour-btn-skip:hover { color:#dde3f0 !important; }
#sbd-root .tour-dot { background:#1a2035 !important; }
#sbd-root .tour-dot.active { background:#c49a20 !important; }
#sbd-root .tour-dot.done { background:#64748b !important; }
#sbd-root .tour-progress-fill { background:#c49a20 !important; }

/* ── Guide Lock ── */
#sbd-root .guide-header-title { color:#dde3f0 !important; }
#sbd-root .guide-header-sub { color:#94a3b8 !important; }
#sbd-root .guide-section-label { color:#64748b !important; }
#sbd-root .guide-card { background:#0e1328 !important; }
#sbd-root .guide-card:hover { background:#131829 !important; }
#sbd-root .guide-card-title { color:#dde3f0 !important; }
#sbd-root .guide-card-desc { color:#64748b !important; }
#sbd-root .guide-showme { color:#c49a20 !important; }
#sbd-root .guide-showme:hover { color:#dde3f0 !important; }
#sbd-root .guide-checklist { background:#0e1328 !important; }
#sbd-root .guide-checklist-title { color:#dde3f0 !important; }
#sbd-root .checklist-item { color:#dde3f0 !important; }
#sbd-root .checklist-done { color:#22c55e !important; }
#sbd-root .checklist-pending { color:#64748b !important; }
#sbd-root .checklist-text { color:#dde3f0 !important; }
#sbd-root .checklist-text.done { color:#64748b !important; }
#sbd-root .checklist-action { color:#c49a20 !important; }
#sbd-root .checklist-action:hover { color:#dde3f0 !important; }
#sbd-root .guide-relaunch { color:#c49a20 !important; }
#sbd-root .guide-relaunch:hover { color:#000000 !important; background:#c49a20 !important; }
#sbd-root .guide-search { color:#dde3f0 !important; background:#131829 !important; }
#sbd-root .guide-search::placeholder { color:#64748b !important; }
#sbd-root .guide-search-ico { color:#64748b !important; }

/* ── Attention Bar Lock ── */
#sbd-root .attn-bar { background:rgba(196,154,32,0.08) !important; }
#sbd-root .attn-bar-icon { color:#c49a20 !important; }
#sbd-root .attn-bar-text { color:#dde3f0 !important; }
#sbd-root .attn-bar-action { background:#c49a20 !important; color:#000000 !important; }
#sbd-root .attn-bar-close { color:#64748b !important; }
#sbd-root .attn-bar-close:hover { color:#dde3f0 !important; }
#sbd-root .attn-dot { background:#c49a20 !important; }

/* ── Post-Tour Modal Lock ── */
#sbd-root .posttour-title { color:#dde3f0 !important; }
#sbd-root .posttour-desc { color:#94a3b8 !important; }

/* ── Skip Reminder Lock ── */
#sbd-root .skip-reminder { background:#0e1328 !important; }
#sbd-root .skip-reminder-text { color:#94a3b8 !important; }
#sbd-root .skip-reminder-link { color:#c49a20 !important; }
#sbd-root .skip-reminder-link:hover { color:#dde3f0 !important; }

/* ══════════════════════════════════════════════════════════════════
   SECTION WALKTHROUGH CARDS
   ══════════════════════════════════════════════════════════════════ */

/* ── Walkthrough Card ── */
.swt-card{background:linear-gradient(135deg,rgba(196,154,32,.06),rgba(96,165,250,.04));border:1px solid var(--gold-bd);border-radius:var(--r);margin-bottom:18px;overflow:hidden;animation:swtSlideIn .35s ease}
@keyframes swtSlideIn{from{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}
.swt-header{display:flex;align-items:center;gap:10px;padding:14px 16px;cursor:pointer;user-select:none;-webkit-tap-highlight-color:transparent}
.swt-icon{width:32px;height:32px;border-radius:8px;background:var(--gold-bg);border:1px solid var(--gold-bd);display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--gold)}
.swt-header-text{flex:1;min-width:0}
.swt-label{font-size:9.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);line-height:1.3}
.swt-title{font-size:13px;font-weight:700;color:var(--txt);line-height:1.35}
.swt-toggle{color:var(--txt3);transition:transform .25s ease;flex-shrink:0}
.swt-card.collapsed .swt-toggle{transform:rotate(-90deg)}
.swt-body{padding:0 16px 14px;max-height:600px;overflow:hidden;transition:max-height .3s ease,padding .3s ease,opacity .25s ease;opacity:1}
.swt-card.collapsed .swt-body{max-height:0;padding:0 16px;opacity:0}
.swt-text{font-size:12.5px;color:var(--txt2);line-height:1.7;margin-bottom:10px}
.swt-text strong{color:var(--txt);font-weight:600}
.swt-tips{display:flex;flex-direction:column;gap:6px;margin-bottom:14px}
.swt-tip{display:flex;align-items:flex-start;gap:8px;font-size:12px;color:var(--txt2);line-height:1.55}
.swt-tip-icon{flex-shrink:0;margin-top:2px;color:var(--gold)}
.swt-tip strong{color:var(--txt);font-weight:600}
.swt-footer{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.swt-dismiss{padding:6px 14px;background:var(--gold);color:#000;border:none;border-radius:var(--rs);font-size:11.5px;font-weight:700;cursor:pointer;font-family:'Poppins',sans-serif;transition:.12s}
.swt-dismiss:hover{filter:brightness(1.1)}
.swt-later{font-size:11px;color:var(--txt3);cursor:pointer;font-family:'Poppins',sans-serif;transition:.12s;background:none;border:none;padding:4px}
.swt-later:hover{color:var(--txt)}

@media(max-width:768px){
  .swt-card{margin-bottom:14px}
  .swt-header{padding:12px 14px}
  .swt-body{padding:0 14px 12px}
}

/* ── Section Walkthrough Color Lock ── */
#sbd-root .swt-card { background:linear-gradient(135deg,rgba(196,154,32,.06),rgba(96,165,250,.04)) !important; }
#sbd-root .swt-icon { color:#c49a20 !important; }
#sbd-root .swt-label { color:#c49a20 !important; }
#sbd-root .swt-title { color:#dde3f0 !important; }
#sbd-root .swt-toggle { color:#64748b !important; }
#sbd-root .swt-text { color:#94a3b8 !important; }
#sbd-root .swt-text strong { color:#dde3f0 !important; }
#sbd-root .swt-tip { color:#94a3b8 !important; }
#sbd-root .swt-tip strong { color:#dde3f0 !important; }
#sbd-root .swt-tip-icon { color:#c49a20 !important; }
#sbd-root .swt-dismiss { background:#c49a20 !important; color:#000000 !important; }
#sbd-root .swt-later { color:#64748b !important; }
#sbd-root .swt-later:hover { color:#dde3f0 !important; }

/* ══════════════════════════════════════════════════════════════════
   LAYER 2: ONBOARDING SEQUENCE UI
   ══════════════════════════════════════════════════════════════════ */
.ob-seq{background:var(--s1);border:1px solid var(--bdr);border-radius:var(--r);margin-bottom:20px;overflow:hidden}
.ob-seq-hd{padding:16px 18px 12px;border-bottom:1px solid var(--bdr)}
.ob-seq-title{font-size:15px;font-weight:800;margin-bottom:2px}
.ob-seq-sub{font-size:11.5px;color:var(--txt3);line-height:1.45}
.ob-seq-progress{display:flex;align-items:center;gap:10px;padding:12px 18px;border-bottom:1px solid var(--bdr);background:var(--s2)}
.ob-seq-bar{flex:1;height:6px;background:var(--s3);border-radius:3px;overflow:hidden}
.ob-seq-bar-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .4s ease}
.ob-seq-pct{font-size:12px;font-weight:700;color:var(--gold);white-space:nowrap}
.ob-seq-list{padding:4px 0}
.ob-step{display:flex;align-items:flex-start;gap:12px;padding:14px 18px;border-bottom:1px solid var(--bdr);transition:background .12s}
.ob-step:last-child{border-bottom:none}
.ob-step:hover{background:var(--s2)}
.ob-step-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;flex-shrink:0;margin-top:1px}
.ob-step-num.done{background:var(--ok-bg);border:1px solid var(--ok-bd);color:var(--ok)}
.ob-step-num.active{background:var(--gold-bg);border:2px solid var(--gold);color:var(--gold);animation:obPulse 2s infinite}
.ob-step-num.locked{background:var(--s2);border:1px solid var(--bdr2);color:var(--txt3)}
@keyframes obPulse{0%,100%{box-shadow:0 0 0 0 rgba(196,154,32,.3)}50%{box-shadow:0 0 0 6px rgba(196,154,32,0)}}
.ob-step-body{flex:1;min-width:0}
.ob-step-title{font-size:13px;font-weight:600;margin-bottom:2px;line-height:1.35}
.ob-step-title.done{color:var(--txt3);text-decoration:line-through}
.ob-step-desc{font-size:11.5px;color:var(--txt3);line-height:1.5}
.ob-step-action{flex-shrink:0;align-self:center}
.ob-step-go{padding:5px 14px;background:var(--gold);color:#000;border:none;border-radius:var(--rs);font-size:11px;font-weight:700;cursor:pointer;font-family:'Poppins',sans-serif;transition:.12s;white-space:nowrap}
.ob-step-go:hover{filter:brightness(1.1)}
.ob-step-done-badge{font-size:10px;font-weight:600;color:var(--ok);white-space:nowrap}
.ob-seq-complete{text-align:center;padding:20px 18px;background:linear-gradient(135deg,rgba(34,197,94,.05),rgba(196,154,32,.05))}
.ob-seq-complete-ico{font-size:28px;margin-bottom:6px}
.ob-seq-complete-text{font-size:13px;font-weight:600;color:var(--ok)}
.ob-seq-complete-sub{font-size:11.5px;color:var(--txt3);margin-top:2px}

@media(max-width:768px){
  .ob-step{padding:12px 14px;gap:10px}
  .ob-step-num{width:24px;height:24px;font-size:10px}
  .ob-seq-hd{padding:14px 14px 10px}
  .ob-seq-progress{padding:10px 14px}
}

/* ── Layer 2 Color Lock ── */
#sbd-root .ob-seq { background:#0e1328 !important; }

/* ══════════════════════════════════════════════════════════════════
   LAYER 3: MODULE-LEVEL READING PROGRESS + COMPREHENSION CHECKS
   ══════════════════════════════════════════════════════════════════ */
.l3-progress-hd{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--s1);border-bottom:1px solid var(--bdr);border-radius:var(--r) var(--r) 0 0;flex-wrap:wrap}
.l3-progress-label{font-size:10px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--txt3);white-space:nowrap}
.l3-progress-bar{flex:1;height:5px;background:var(--s3);border-radius:3px;overflow:hidden;min-width:80px}
.l3-progress-fill{height:100%;background:var(--gold);border-radius:3px;transition:width .4s ease}
.l3-progress-pct{font-size:11px;font-weight:700;color:var(--gold);white-space:nowrap}
.l3-nav-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-left:auto}
.l3-nav-dot.read{background:var(--ok)}
.l3-nav-dot.unread{background:var(--s3);border:1px solid var(--bdr2)}
.l3-nav-dot.active-read{background:var(--gold)}
.l3-section-done{display:flex;align-items:center;justify-content:center;gap:8px;margin:24px 0 8px;padding:14px 20px;background:var(--gold-bg);border:1px solid var(--gold-bd);border-radius:var(--rs);cursor:pointer;font-size:13px;font-weight:600;color:var(--gold);font-family:'Poppins',sans-serif;transition:.15s}
.l3-section-done:hover{background:var(--gold);color:#000}
.l3-section-done.completed{background:var(--ok-bg);border-color:var(--ok-bd);color:var(--ok);cursor:default;pointer-events:none}
.l3-check-wrap{margin-top:16px;background:var(--s1);border:1px solid var(--bdr2);border-radius:var(--r);overflow:hidden;animation:swtSlideIn .3s ease}
.l3-check-hd{padding:12px 16px;background:var(--s2);border-bottom:1px solid var(--bdr);display:flex;align-items:center;gap:8px}
.l3-check-title{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;color:var(--gold)}
.l3-check-body{padding:16px}
.l3-check-q{font-size:13px;font-weight:600;line-height:1.55;margin-bottom:12px}
.l3-check-opts{display:flex;flex-direction:column;gap:6px}
.l3-check-opt{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background:var(--s2);border:1px solid var(--bdr);border-radius:var(--rs);cursor:pointer;font-size:12.5px;line-height:1.5;color:var(--txt2);transition:.12s}
.l3-check-opt:hover{border-color:var(--bdr3);background:var(--s3);color:var(--txt)}
.l3-check-opt.correct{background:var(--ok-bg);border-color:var(--ok-bd);color:var(--ok);cursor:default}
.l3-check-opt.wrong{background:var(--err-bg);border-color:var(--err-bd);color:var(--err);cursor:default}
.l3-check-opt-letter{font-weight:700;flex-shrink:0;width:18px}
.l3-check-result{margin-top:12px;padding:10px 14px;border-radius:var(--rs);font-size:12px;line-height:1.55}
.l3-check-result.pass{background:var(--ok-bg);border:1px solid var(--ok-bd);color:var(--ok)}
.l3-check-result.fail{background:var(--err-bg);border:1px solid var(--err-bd);color:var(--err)}
.l3-aid-row{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.l3-aid-btn{display:flex;align-items:center;gap:7px;padding:10px 16px;border-radius:var(--rs);font-size:12px;font-weight:600;cursor:pointer;border:1px solid var(--bdr2);background:var(--s2);color:var(--txt2);transition:.15s;font-family:'Poppins',sans-serif;flex:1;justify-content:center;min-width:140px}
.l3-aid-btn:hover{background:var(--s3);color:var(--txt);border-color:var(--bdr3)}
.l3-aid-btn.active{pointer-events:none;opacity:.6}
.l3-aid-btn svg{flex-shrink:0}
.l3-aid-container{margin-top:12px;background:var(--s1);border:1px solid var(--bdr2);border-radius:var(--r);overflow:hidden;animation:swtSlideIn .3s ease}
.l3-aid-hd{padding:10px 14px;background:var(--s2);border-bottom:1px solid var(--bdr);display:flex;align-items:center;gap:8px}
.l3-aid-label{font-size:10.5px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.l3-aid-body{padding:16px;font-size:13px;line-height:1.7;color:var(--txt2)}
.l3-aid-body p{margin:0 0 10px}
.l3-aid-body strong{color:var(--txt);font-weight:600}
.l3-skeleton{background:linear-gradient(90deg,var(--s2) 25%,var(--s3) 50%,var(--s2) 75%);background-size:200% 100%;animation:l3shimmer 1.5s infinite;border-radius:var(--rs);height:14px;margin:8px 0}
.l3-skeleton.wide{width:90%}
.l3-skeleton.med{width:65%}
.l3-skeleton.short{width:40%}
.l3-skeleton.block{height:48px;margin:6px 0}
@keyframes l3shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}
.l3-continue-btn{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;padding:11px 20px;background:var(--gold-bg);border:1px solid var(--gold-bd);border-radius:var(--rs);color:var(--gold);font-size:12.5px;font-weight:600;cursor:pointer;font-family:'Poppins',sans-serif;transition:.15s;width:100%}
.l3-continue-btn:hover{background:var(--gold);color:#000}
.l3-newq-btn{display:inline-flex;align-items:center;gap:6px;margin-top:10px;padding:7px 14px;border-radius:var(--rs);font-size:11px;font-weight:500;cursor:pointer;border:1px solid var(--bdr);background:transparent;color:var(--txt3);font-family:'Poppins',sans-serif;transition:.12s}
.l3-newq-btn:hover{color:var(--gold);border-color:var(--gold-bd)}

@media(max-width:768px){
  .l3-progress-hd{padding:8px 10px}
  .l3-check-body{padding:12px}
  .l3-check-opt{padding:8px 10px}
}

/* ── Layer 3 Color Lock ── */
#sbd-root .l3-progress-label { color:#64748b !important; }
#sbd-root .l3-progress-pct { color:#c49a20 !important; }
#sbd-root .l3-progress-fill { background:#c49a20 !important; }
#sbd-root .l3-nav-dot.read { background:#22c55e !important; }
#sbd-root .l3-nav-dot.active-read { background:#c49a20 !important; }
#sbd-root .l3-section-done { color:#c49a20 !important; }
#sbd-root .l3-section-done:hover { color:#000000 !important; background:#c49a20 !important; }
#sbd-root .l3-section-done.completed { color:#22c55e !important; }
#sbd-root .l3-check-title { color:#c49a20 !important; }
#sbd-root .l3-check-q { color:#dde3f0 !important; }
#sbd-root .l3-check-opt { color:#94a3b8 !important; }
#sbd-root .l3-check-opt:hover { color:#dde3f0 !important; }
#sbd-root .l3-check-opt.correct { color:#22c55e !important; }
#sbd-root .l3-check-opt.wrong { color:#ef4444 !important; }
#sbd-root .l3-check-opt-letter { color:inherit !important; }
#sbd-root .l3-check-result.pass { color:#22c55e !important; }
#sbd-root .l3-check-result.fail { color:#ef4444 !important; }
#sbd-root .l3-aid-btn { color:#94a3b8 !important; background:#131b35 !important; }
#sbd-root .l3-aid-btn:hover { color:#dde3f0 !important; }
#sbd-root .l3-aid-label { color:#60a5fa !important; }
#sbd-root .l3-aid-body { color:#94a3b8 !important; }
#sbd-root .l3-aid-body strong { color:#dde3f0 !important; }
#sbd-root .l3-continue-btn { color:#c49a20 !important; }
#sbd-root .l3-continue-btn:hover { color:#000000 !important; background:#c49a20 !important; }
#sbd-root .l3-newq-btn { color:#64748b !important; }
#sbd-root .l3-newq-btn:hover { color:#c49a20 !important; }
#sbd-root .ob-seq-hd { background:#0e1328 !important; }
#sbd-root .ob-seq-title { color:#dde3f0 !important; }
#sbd-root .ob-seq-sub { color:#64748b !important; }
#sbd-root .ob-seq-progress { background:#131829 !important; }
#sbd-root .ob-seq-pct { color:#c49a20 !important; }
#sbd-root .ob-seq-bar-fill { background:#c49a20 !important; }
#sbd-root .ob-step-title { color:#dde3f0 !important; }
#sbd-root .ob-step-title.done { color:#64748b !important; }
#sbd-root .ob-step-desc { color:#64748b !important; }
#sbd-root .ob-step-num.done { color:#22c55e !important; }
#sbd-root .ob-step-num.active { color:#c49a20 !important; }
#sbd-root .ob-step-num.locked { color:#64748b !important; }
#sbd-root .ob-step-go { background:#c49a20 !important; color:#000000 !important; }
#sbd-root .ob-step-done-badge { color:#22c55e !important; }
#sbd-root .ob-seq-complete-text { color:#22c55e !important; }
#sbd-root .ob-seq-complete-sub { color:#64748b !important; }

/* ── ASSESSOR PIN GATE ── */
.pin-gate-container{text-align:center;padding:24px 16px 32px;max-width:440px;margin:0 auto}
.pin-gate-icon{width:72px;height:72px;background:rgba(139,92,246,.15);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px;font-size:32px}
.pin-input-row{display:flex;gap:10px;justify-content:center;margin-bottom:12px}
.pin-digit{width:48px;height:56px;background:var(--s1);border:2px solid rgba(139,92,246,.3);border-radius:var(--r);text-align:center;font-size:22px;font-weight:700;color:#e2e8f0;font-family:'Poppins',sans-serif;caret-color:#8b5cf6;transition:.15s}
.pin-digit:focus{border-color:#8b5cf6;outline:none}
@media(max-width:480px){
  .pin-gate-container{padding:20px 12px 28px}
  .pin-input-row{gap:6px}
  .pin-digit{width:40px;height:50px;font-size:20px}
}
@media(max-width:360px){
  .pin-input-row{gap:4px}
  .pin-digit{width:36px;height:46px;font-size:18px}
}

/* ── PA Save Button + Mobile Responsive (Placement Assessment flow) ── */
#pa-save-btn:hover{background:rgba(139,92,246,.08);border-color:#a78bfa}
#pa-save-btn:disabled{opacity:.6;cursor:wait}

/* When placement assessment is active, hide all portal sidebars/drawers so
   the chevron pull-tab on mobile does not bleed into the overlay. */
body.placement-active .sidebar{display:none !important}

@media(max-width:480px){
  /* Timer banner — pull out of the fixed layer on narrow screens so it does
     not overlap the centered "Question X of Y" heading. Appears as a pill
     inline at the top of the overlay instead. */
  #pa-timer{position:static !important;display:block !important;margin:12px 16px 0 !important;font-size:12px !important;padding:6px 10px !important;max-width:none !important;text-align:center}
  /* PA controls row buttons — smaller padding/font, allow wrap */
  #pa-back-btn{padding:10px 16px !important;font-size:12px !important}
  #pa-save-btn{padding:10px 14px !important;font-size:12px !important}
  #pa-next-btn{padding:10px 18px !important;font-size:12px !important}
  /* Save status — hide the helper text on narrow screens; the button itself communicates intent */
  #pa-save-status{display:none !important}
  /* Placement content — guarantee horizontal breathing room so headings/questions don't clip */
  #placement-content{padding:0 16px !important;width:100% !important;max-width:100% !important;box-sizing:border-box !important}
  /* Placement overlay — make sure inner padding is consistent at narrow widths */
  #placement-overlay{padding-top:0 !important}
}

@media(max-width:360px){
  #pa-timer{font-size:11px !important;padding:5px 8px !important}
  #pa-back-btn,#pa-save-btn,#pa-next-btn{padding:9px 12px !important;font-size:11.5px !important}
  #placement-content{padding:0 12px !important}
}
