:root{
  --navy:#061529;--navy2:#0b2f55;--blue:#1777ff;--blue2:#5fb0ff;--ink:#071426;--muted:#516174;--line:#d9e6f5;--panel:#ffffff;--soft:#f3f8ff;--danger:#dc2626;--ok:#16a34a;--amber:#d97706;
}*{box-sizing:border-box}html{scroll-behavior:smooth}body{margin:0;font-family:Inter,Segoe UI,Arial,sans-serif;background:#f4f9ff;color:var(--ink);font-weight:650}body:before{content:"";position:fixed;inset:0;z-index:-2;background:linear-gradient(105deg,#fff 0%,#f5fbff 43%,#e3f2ff 100%)}body:after{content:"";position:fixed;inset:0;z-index:-1;background-image:linear-gradient(rgba(23,119,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(23,119,255,.06) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(to bottom,#000,rgba(0,0,0,.75),transparent 92%)}button,a.ghost{border:0;border-radius:999px;background:linear-gradient(135deg,var(--blue),#0b66e8);color:#fff;font-weight:950;padding:12px 18px;cursor:pointer;text-decoration:none;display:inline-flex;gap:8px;align-items:center;justify-content:center;box-shadow:0 12px 26px rgba(23,119,255,.20);transition:.18s ease}button:hover,a.ghost:hover{transform:translateY(-1px);box-shadow:0 16px 32px rgba(23,119,255,.28)}.hidden{display:none!important}.login-screen{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(110deg,#fff,#f2f9ff 60%,#ddecff)}.login-card{width:min(480px,100%);background:rgba(255,255,255,.94);border:1px solid var(--line);box-shadow:0 30px 80px rgba(6,21,41,.14);border-radius:30px;padding:36px}.brand-mark{height:58px;width:82px;border-radius:14px;background:#fff;color:var(--blue);display:grid;place-items:center;font-weight:1000;letter-spacing:.02em;box-shadow:inset 0 0 0 3px #071426;font-size:20px}.login-card h1{font-size:34px;line-height:.95;margin:22px 0 10px;letter-spacing:-.04em}.login-card p{color:#35465a}.login-card label{display:block;margin:16px 0 8px;font-weight:950}.login-card input,.search,input,select,textarea{width:100%;border:1px solid var(--line);background:#fff;border-radius:14px;padding:13px 14px;font:inherit;box-shadow:0 6px 18px rgba(7,20,38,.04)}.login-card input:focus,.search:focus,input:focus,select:focus,textarea:focus{outline:3px solid rgba(23,119,255,.15);border-color:var(--blue)}textarea{min-height:96px}#appShell{display:grid;grid-template-columns:290px 1fr;min-height:100vh}aside{background:#fff;color:var(--ink);border-right:1px solid var(--line);padding:26px 22px;position:sticky;top:0;height:100vh;box-shadow:18px 0 55px rgba(7,20,38,.06)}.logo{font-size:36px;font-weight:1000;letter-spacing:-.06em;color:var(--ink);line-height:.82}.logo::first-letter{color:var(--blue)}.logo span{display:block;color:var(--blue);font-size:12px;letter-spacing:.32em;margin-top:8px;text-transform:uppercase}.side-sub{color:#5b6a7d;font-size:12px;text-transform:uppercase;letter-spacing:.16em;line-height:1.5;margin-top:16px}aside nav{display:grid;gap:9px;margin:30px 0}aside nav button{background:transparent;color:var(--ink);border:1px solid var(--line);text-align:left;justify-content:flex-start;box-shadow:none;border-radius:14px}aside nav button:hover{background:#eef6ff;border-color:#b9d8ff;box-shadow:none}.user-box{position:absolute;left:22px;right:22px;bottom:22px;background:#071426;color:#fff;border-radius:20px;padding:16px;box-shadow:0 18px 35px rgba(7,20,38,.18)}.user-box span{display:block;color:#9bc9ff;margin:4px 0 12px;text-transform:capitalize}.user-box button{width:100%;background:#fff;color:var(--ink);box-shadow:none}main{padding:32px;min-width:0}.topbar{display:flex;justify-content:space-between;gap:16px;align-items:flex-start;margin-bottom:24px;background:rgba(255,255,255,.72);border:1px solid var(--line);border-radius:26px;padding:24px;backdrop-filter:blur(12px);box-shadow:0 24px 70px rgba(7,20,38,.07)}.topbar h1{margin:5px 0 0;font-size:42px;letter-spacing:-.055em;line-height:.95}.topbar small{color:var(--blue);font-weight:1000;letter-spacing:.18em;text-transform:uppercase}.top-actions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.top-actions button{background:#071426}.page{display:none}.page.active{display:block}.panel,.card{background:rgba(255,255,255,.92);border:1px solid var(--line);border-radius:24px;padding:22px;box-shadow:0 22px 65px rgba(7,20,38,.08);margin:18px 0}.row{display:flex;justify-content:space-between;align-items:center;gap:14px;margin:12px 0;color:var(--ink)}.row h2{margin:0;font-size:28px;letter-spacing:-.04em}.hint{color:var(--muted);font-weight:600}.kpis{display:grid;grid-template-columns:repeat(4,minmax(150px,1fr));gap:16px;margin-bottom:20px}.kpi{background:linear-gradient(180deg,#fff,#eff7ff);border:1px solid #cfe4ff;border-radius:20px;padding:22px;box-shadow:0 20px 52px rgba(7,20,38,.08);position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;right:-20px;bottom:-30px;width:110px;height:110px;border-radius:30px;background:linear-gradient(135deg,rgba(23,119,255,.16),rgba(95,176,255,.08));transform:rotate(18deg)}.kpi span{display:block;color:var(--muted);text-transform:capitalize;font-size:13px;font-weight:950;position:relative;z-index:1}.kpi b{font-size:36px;color:var(--ink);letter-spacing:-.04em;position:relative;z-index:1}.table{width:100%;border-collapse:separate;border-spacing:0;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;margin:14px 0;box-shadow:0 12px 38px rgba(7,20,38,.05)}.table th{background:#071426;color:#fff;text-align:left;font-size:12px;text-transform:uppercase;letter-spacing:.09em;padding:13px}.table td{padding:13px;border-top:1px solid var(--line);vertical-align:top}.table tr:hover td{background:#f4f9ff}.table a{color:var(--blue);font-weight:950}.table button{padding:8px 12px;font-size:13px}.pill{display:inline-flex;border-radius:999px;padding:6px 10px;font-size:12px;font-weight:1000;background:#e8f1fb;color:#12304f}.PASS,.Compliant{background:#dcfce7;color:#166534}.FAIL,.FailedRemoveFromService{background:#fee2e2;color:#991b1b}.DueSoon{background:#fef3c7;color:#92400e}.PATOverdue,.InspectionOverdue{background:#fee2e2;color:#991b1b}.NoTestLogged{background:#dbeafe;color:#1e40af}.gridform{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:15px}.gridform label{font-weight:950;color:var(--ink);font-size:13px;text-transform:none}.gridform label.full,.gridform button.full{grid-column:1/-1}.gridform button.full{justify-self:start;margin-top:8px;min-width:180px}.modal{display:none;position:fixed;inset:0;background:rgba(7,20,38,.62);padding:30px;overflow:auto;z-index:20}.modalbox{background:#fff;border-radius:28px;padding:28px;max-width:980px;margin:30px auto;position:relative;box-shadow:0 40px 120px rgba(7,20,38,.26);border:1px solid var(--line)}.modalbox h2{font-size:32px;letter-spacing:-.04em;margin:0 0 18px}.x{position:absolute;right:18px;top:18px;border-radius:50%;width:38px;height:38px;padding:0;background:#071426;color:#fff}.search{margin:10px 0 18px}@media(max-width:1100px){.kpis{grid-template-columns:repeat(2,1fr)}#appShell{grid-template-columns:245px 1fr}aside{padding:22px 16px}main{padding:22px}.topbar h1{font-size:34px}}@media(max-width:820px){#appShell{grid-template-columns:1fr}aside{height:auto;position:relative}.user-box{position:static;margin-top:20px}.kpis{grid-template-columns:1fr}.topbar,.row{align-items:flex-start;flex-direction:column}.gridform{grid-template-columns:1fr}main{padding:16px}.table{font-size:13px;display:block;overflow:auto}.login-card{border-radius:24px;padding:28px}.topbar h1{font-size:32px}}
.system-logo{max-width:180px;max-height:78px;object-fit:contain;margin:0 0 18px;display:none;background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px;box-shadow:0 14px 34px rgba(7,20,38,.08)}
.logo-admin{display:flex;gap:20px;align-items:center;flex-wrap:wrap;margin:12px 0 24px}.logo-admin img{max-width:240px;max-height:120px;object-fit:contain;display:none;background:#fff;border:1px solid var(--line);border-radius:18px;padding:14px;box-shadow:0 12px 34px rgba(7,20,38,.08)}
.checkgrid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.checkgrid label{display:flex;gap:8px;align-items:center;background:#f4f9ff;border:1px solid var(--line);padding:10px;border-radius:12px}.checkgrid input{width:auto;box-shadow:none}.small{padding:7px 10px;font-size:12px}@media(max-width:820px){.checkgrid{grid-template-columns:1fr}}
.sig-preview{min-width:160px;min-height:56px;border:1px dashed #b8d7ff;border-radius:14px;display:flex;align-items:center;justify-content:center;background:#f8fbff;color:#60708a;font-size:12px;overflow:hidden}
.sig-preview img{max-width:150px;max-height:52px;object-fit:contain}

/* v10 white-label branding + small BSLF powered footer */
body{padding-bottom:46px}.login-bslf-logo{width:110px;height:auto;margin-bottom:12px}.brand-mark{display:none}.client-brand{margin:0 0 28px}.fallback-bslf-logo{width:130px;max-width:100%;height:auto;margin:4px 0 16px;display:block}.system-logo{max-width:190px;max-height:96px;width:auto;height:auto;object-fit:contain;margin:0 0 14px;display:none;background:#fff;border:1px solid var(--line);border-radius:16px;padding:10px;box-shadow:0 14px 34px rgba(7,20,38,.08)}.client-name{font-size:28px;font-weight:1000;line-height:1;letter-spacing:-.045em;color:#071426;text-transform:uppercase}.client-system-name{margin-top:10px;color:#52657b;font-size:13px;text-transform:uppercase;letter-spacing:.16em;font-weight:950;line-height:1.45}.powered-footer{position:fixed;left:0;right:0;bottom:0;z-index:30;height:42px;background:rgba(255,255,255,.96);border-top:1px solid #d9e8fb;box-shadow:0 -8px 26px rgba(7,20,38,.06);display:flex;align-items:center;justify-content:space-between;gap:16px;padding:6px 20px;font-size:12px;color:#334155;font-weight:750;backdrop-filter:blur(10px)}.powered-footer img{width:52px;height:auto;display:block}.pf-left,.pf-mid,.pf-right{display:flex;align-items:center;gap:10px}.powered-footer a{color:#1777ff;text-decoration:none;font-weight:950}.powered-footer.hidden{display:none!important}aside{height:calc(100vh - 42px)}#appShell{min-height:calc(100vh - 42px)}.logo,.side-sub{display:none!important}.white-label-panel{background:#f8fbff;border:1px solid var(--line);border-radius:18px;padding:16px;margin:14px 0}.checkgrid{display:grid;grid-template-columns:repeat(2,minmax(190px,1fr));gap:8px 16px}.checkgrid label{display:flex;gap:8px;align-items:center;font-weight:800;color:#334155}.sig-preview img{max-width:220px;max-height:80px;object-fit:contain}@media(max-width:820px){body{padding-bottom:78px}.powered-footer{height:auto;min-height:60px;flex-direction:column;align-items:flex-start;gap:3px;padding:8px 14px}.powered-footer img{width:46px}aside{height:auto}#appShell{min-height:calc(100vh - 78px)}}
/* v15 platform build */
.export-grid{display:flex;gap:12px;flex-wrap:wrap}.asset-profile{display:flex;gap:18px;align-items:flex-start;margin:14px 0 18px}.asset-photo{width:170px;height:130px;object-fit:cover;border-radius:18px;border:1px solid var(--line);box-shadow:0 14px 34px rgba(7,20,38,.10);background:#fff}.danger{background:#dc2626!important;color:#fff!important}.table td .danger{box-shadow:none}.page h2{letter-spacing:-.035em}@media(max-width:820px){.asset-profile{flex-direction:column}.asset-photo{width:100%;height:auto;max-height:260px}.export-grid a{width:100%}}


/* v16 responsive layout fix: small laptop/tablet menu + usable modals */
.mobile-menu-btn,.inline-menu-btn{display:none;background:#071426;color:#fff;box-shadow:0 12px 26px rgba(7,20,38,.16);padding:10px 14px;border-radius:14px}
.sidebar-backdrop{display:none}
@media(max-width:1180px){
  #appShell{grid-template-columns:1fr}
  .mobile-menu-btn{display:flex;position:fixed;left:16px;top:14px;z-index:80}
  .inline-menu-btn{display:inline-flex;margin:0 0 10px 0;box-shadow:none}
  main{padding:76px 18px 82px}
  aside#sidebar{position:fixed;left:0;top:0;bottom:0;height:auto;width:min(320px,86vw);z-index:90;transform:translateX(-105%);transition:transform .22s ease;overflow-y:auto;padding-bottom:90px}
  body.sidebar-open aside#sidebar{transform:translateX(0)}
  .sidebar-backdrop{position:fixed;inset:0;background:rgba(7,20,38,.48);z-index:85;display:none}
  body.sidebar-open .sidebar-backdrop{display:block}
  .user-box{position:static;margin-top:18px}
  .topbar{margin-top:0}
  .topbar h1{font-size:34px}
}
@media(max-width:980px){
  .modal{padding:12px;overflow:auto}
  .modalbox{max-width:calc(100vw - 24px);margin:10px auto;padding:20px;border-radius:22px;max-height:calc(100vh - 24px);overflow-y:auto}
  .modalbox h2{font-size:28px;padding-right:48px}
  .gridform{grid-template-columns:1fr 1fr;gap:12px}
  .gridform label{font-size:12px}
  .login-card input,.search,input,select,textarea{padding:11px 12px;border-radius:13px}
  .x{right:14px;top:14px;width:42px;height:42px}
}
@media(max-width:720px){
  main{padding:72px 12px 96px}
  .gridform{grid-template-columns:1fr}
  .modalbox{padding:18px 14px}
  .top-actions{width:100%}.top-actions button,.top-actions .ghost{flex:1}
  .kpis{grid-template-columns:1fr}
  .panel,.card,.topbar{border-radius:18px;padding:16px}
}
@media(min-width:1181px){.sidebar-backdrop{display:none!important}}

/* v17 responsive/accessibility fix: make sidebar/menu usable on laptops and stop footer hiding actions */
html,body{min-height:100%;overflow-x:hidden}
#appShell{padding-bottom:54px}
main{padding-bottom:96px}
.powered-footer{height:34px;min-height:34px;padding:4px 18px;font-size:11px;z-index:60}
.powered-footer img{width:46px;max-height:20px;object-fit:contain}
aside#sidebar{overflow-y:auto;overscroll-behavior:contain;padding-bottom:96px}
.user-box{position:static;margin-top:18px}

/* Make the off-canvas menu kick in earlier for smaller laptops / reduced height screens */
@media(max-width:1700px),(max-height:920px){
  #appShell{display:block;min-height:calc(100vh - 34px);padding-bottom:42px}
  main{padding:72px 22px 90px 22px;max-width:100%}
  .mobile-menu-btn{display:flex;position:fixed;left:16px;top:14px;z-index:100;background:#071426;color:#fff;border-radius:14px;padding:10px 14px}
  .inline-menu-btn{display:inline-flex;margin:0 0 10px 0;box-shadow:none;background:#071426;color:#fff}
  aside#sidebar{position:fixed;left:0;top:0;bottom:0;height:100dvh;width:min(330px,88vw);z-index:95;transform:translateX(-105%);transition:transform .22s ease;overflow-y:auto;padding:24px 20px 112px;background:#fff;box-shadow:22px 0 65px rgba(7,20,38,.22)}
  body.sidebar-open aside#sidebar{transform:translateX(0)}
  .sidebar-backdrop{position:fixed;inset:0;background:rgba(7,20,38,.48);z-index:90;display:none}
  body.sidebar-open .sidebar-backdrop{display:block}
  .user-box{position:static;margin-top:18px}
  .topbar{padding:22px 24px;margin-bottom:20px}
  .topbar h1{font-size:38px}
  .kpis{grid-template-columns:repeat(3,minmax(170px,1fr))}
}

@media(max-width:1180px){.kpis{grid-template-columns:repeat(2,minmax(150px,1fr))}}
@media(max-width:720px){.kpis{grid-template-columns:1fr}.topbar h1{font-size:32px}.top-actions{width:100%}.top-actions button,.top-actions a{width:100%}}

/* Modal fix for laptop screens: visible top, internal scroll and sticky save button */
.modal{padding:12px;z-index:120;align-items:flex-start;justify-content:center}
.modal[style*="block"]{display:flex!important}
.modalbox{width:min(1040px,calc(100vw - 24px));margin:10px auto;max-height:calc(100dvh - 24px);overflow-y:auto;border-radius:24px;padding:24px 24px 86px;scrollbar-gutter:stable;position:relative}
.modalbox h2{font-size:30px;line-height:1.05;padding-right:52px;position:sticky;top:0;background:#fff;z-index:2;padding-top:4px;padding-bottom:14px;margin:0 0 14px;border-bottom:1px solid #e6eef8}
.x{position:sticky;float:right;right:0;top:0;z-index:5;margin-left:auto}
.gridform button.full{position:sticky;bottom:10px;z-index:4;grid-column:1/-1;justify-self:start;box-shadow:0 16px 34px rgba(23,119,255,.28)}

@media(max-height:760px){
  .modalbox{max-height:calc(100dvh - 12px);margin:0 auto;padding:18px 18px 82px;border-radius:18px}
  .modalbox h2{font-size:26px}
  .gridform{gap:10px 14px}
  .gridform label{font-size:12px}
  input,select,textarea,.login-card input,.search{padding:10px 12px;border-radius:12px}
}

/* v18 clean responsive layout: keep desktop sidebar, only use drawer on true tablet/mobile */
html,body{min-height:100%;overflow-x:hidden}
body{padding-bottom:30px!important}
#appShell{display:grid!important;grid-template-columns:290px minmax(0,1fr)!important;min-height:calc(100vh - 30px)!important;padding-bottom:30px!important}
main{padding:28px 32px 64px!important;min-width:0!important}
aside#sidebar{position:sticky!important;top:0!important;left:auto!important;bottom:auto!important;transform:none!important;width:auto!important;height:calc(100vh - 30px)!important;z-index:20!important;padding:24px 20px 92px!important;box-shadow:18px 0 55px rgba(7,20,38,.06)!important;overflow-y:auto!important}
.mobile-menu-btn,.inline-menu-btn{display:none!important}
.sidebar-backdrop{display:none!important}
.powered-footer{height:28px!important;min-height:28px!important;padding:3px 18px!important;font-size:10px!important;z-index:35!important;pointer-events:none!important;justify-content:space-between!important;gap:10px!important;white-space:nowrap!important;overflow:hidden!important}
.powered-footer img{width:42px!important;max-height:18px!important;object-fit:contain!important}.powered-footer span{overflow:hidden;text-overflow:ellipsis}.topbar{margin-bottom:20px!important}.topbar h1{font-size:42px!important}.kpis{grid-template-columns:repeat(4,minmax(160px,1fr))!important}.user-box{position:static!important;margin-top:18px!important}.system-logo{min-height:54px}.system-logo[src=""],.system-logo:not([src]){display:none!important}.fallback-bslf-logo{width:150px;max-height:95px;object-fit:contain}

/* laptop: keep sidebar visible but tighten spacing */
@media(max-width:1450px){
  #appShell{grid-template-columns:255px minmax(0,1fr)!important}
  aside#sidebar{padding:18px 14px 80px!important}
  main{padding:22px 24px 62px!important}
  .system-logo{max-width:175px;max-height:82px}.client-name{font-size:23px}.client-system-name{font-size:11px;letter-spacing:.14em}
  aside nav{gap:8px;margin:20px 0} aside nav button{padding:10px 14px;border-radius:12px}
  .kpis{grid-template-columns:repeat(3,minmax(160px,1fr))!important}.topbar h1{font-size:36px!important}
}
@media(max-height:820px) and (min-width:981px){
  aside#sidebar{padding-top:14px!important;padding-bottom:72px!important}.client-brand{margin-bottom:16px!important}.system-logo{max-height:66px}.fallback-bslf-logo{max-height:58px;width:120px}.client-name{font-size:21px}.client-system-name{font-size:10px}aside nav{margin:14px 0;gap:6px}aside nav button{padding:8px 12px}.user-box{padding:12px;border-radius:16px}.user-box button{padding:9px 12px}
}

/* only switch to off-canvas when there genuinely isn't room */
@media(max-width:980px){
  body{padding-bottom:44px!important}
  #appShell{display:block!important;min-height:calc(100vh - 44px)!important;padding-bottom:44px!important}
  main{padding:70px 16px 76px!important}
  .mobile-menu-btn{display:flex!important;position:fixed!important;left:14px!important;top:12px!important;z-index:100!important;background:#071426!important;color:#fff!important;border-radius:14px!important;padding:10px 14px!important}
  .inline-menu-btn{display:none!important}
  aside#sidebar{position:fixed!important;left:0!important;top:0!important;bottom:0!important;height:100dvh!important;width:min(320px,88vw)!important;z-index:95!important;transform:translateX(-105%)!important;transition:transform .22s ease!important;background:#fff!important;box-shadow:22px 0 65px rgba(7,20,38,.22)!important;padding:22px 18px 84px!important;overflow-y:auto!important}
  body.sidebar-open aside#sidebar{transform:translateX(0)!important}.sidebar-backdrop{position:fixed!important;inset:0!important;background:rgba(7,20,38,.48)!important;z-index:90!important;display:none!important}body.sidebar-open .sidebar-backdrop{display:block!important}
  .topbar{padding:20px!important;border-radius:22px!important}.topbar h1{font-size:32px!important}.kpis{grid-template-columns:repeat(2,minmax(140px,1fr))!important}.powered-footer{height:34px!important;min-height:34px!important;font-size:9px!important;padding:4px 10px!important}.powered-footer img{width:34px!important}
}
@media(max-width:640px){.kpis{grid-template-columns:1fr!important}.top-actions{width:100%}.top-actions button,.top-actions a{width:100%}.powered-footer{justify-content:center!important}.powered-footer img{display:none!important}}

/* v18 modal: compact, clear, scrollable, save always accessible */
.modal{padding:10px!important;z-index:120!important;align-items:flex-start!important;justify-content:center!important;overflow:auto!important}.modal[style*="block"]{display:flex!important}.modalbox{width:min(1000px,calc(100vw - 20px))!important;margin:8px auto!important;max-height:calc(100dvh - 20px)!important;overflow-y:auto!important;border-radius:22px!important;padding:22px 22px 78px!important;position:relative!important}.modalbox h2{position:sticky!important;top:0!important;background:#fff!important;z-index:2!important;margin:0 0 14px!important;padding:4px 54px 12px 0!important;border-bottom:1px solid #e6eef8!important;font-size:28px!important}.x{position:sticky!important;float:right!important;top:0!important;right:0!important;z-index:5!important}.gridform{gap:12px 14px!important}.gridform label{font-size:12px!important}.gridform button.full{position:sticky!important;bottom:8px!important;z-index:6!important;margin-top:12px!important;min-width:200px!important}
@media(max-width:820px){.gridform{grid-template-columns:1fr!important}.modalbox{padding:18px 14px 78px!important;border-radius:18px!important}.modalbox h2{font-size:24px!important}input,select,textarea,.search{padding:10px 12px!important}}


/* v20 BSLF platform design system: premium layout, real breakpoints, FAB and dark mode */
:root{--radius-xl:22px;--radius-lg:16px;--shadow-soft:0 22px 70px rgba(7,20,38,.08);--shadow-card:0 12px 30px rgba(7,20,38,.06)}
body{font-weight:640;background:#f5faff!important;color:#071426!important;padding-bottom:0!important}
#appShell{grid-template-columns:264px minmax(0,1fr)!important;min-height:100vh!important;padding-bottom:0!important}
aside#sidebar{height:100vh!important;background:rgba(255,255,255,.92)!important;backdrop-filter:blur(16px);padding:22px 18px!important;border-right:1px solid #dbeafe!important;box-shadow:14px 0 44px rgba(7,20,38,.06)!important}
.client-brand{padding-bottom:18px;margin-bottom:12px;border-bottom:1px solid #e5eefb}.system-logo{display:block;max-width:170px!important;max-height:78px!important;object-fit:contain;margin-bottom:14px}.fallback-bslf-logo{max-width:160px!important;max-height:70px!important;object-fit:contain;margin-bottom:14px}.client-name{font-size:23px!important;line-height:1.02!important;letter-spacing:-.035em!important}.client-system-name{font-size:11px!important;letter-spacing:.18em!important;color:#53657a!important;margin-top:8px!important}
aside nav{gap:7px!important;margin:18px 0!important}aside nav button{min-height:42px;border-radius:13px!important;padding:9px 13px!important;font-size:14px!important;background:#fff!important;border:1px solid #d8e7f8!important}aside nav button:hover{background:#eef6ff!important;color:#0b66e8!important;transform:none!important}.user-box{border-radius:18px!important;padding:14px!important;background:#071426!important}.user-box button{min-height:38px;margin-top:8px!important;border-radius:999px!important}
main{padding:26px 30px 70px!important}.topbar{border-radius:26px!important;padding:22px 26px!important;margin-bottom:22px!important;box-shadow:var(--shadow-soft)!important;background:rgba(255,255,255,.82)!important}.topbar h1{font-size:42px!important;letter-spacing:-.055em!important}.topbar small{color:#1777ff!important;letter-spacing:.22em!important}.top-actions{display:flex;gap:10px;flex-wrap:wrap}.kpis{grid-template-columns:repeat(4,minmax(150px,1fr))!important;gap:16px!important}.kpi,.card,.panel{background:rgba(255,255,255,.86)!important;border:1px solid #dcebf9!important;box-shadow:var(--shadow-card)!important;border-radius:22px!important}.kpi{min-height:112px!important;padding:20px 22px!important;position:relative;overflow:hidden}.kpi:after{content:"";position:absolute;right:-24px;bottom:-24px;width:120px;height:100px;border-radius:36px;background:linear-gradient(135deg,rgba(23,119,255,.18),rgba(95,176,255,.06));transform:rotate(18deg)}.kpi span{text-transform:uppercase;font-size:12px!important;letter-spacing:.08em;color:#53657a!important}.kpi b{font-size:38px!important;letter-spacing:-.04em}.panel{padding:22px!important}.table{font-size:13px}.table th{background:#071426!important;color:#fff!important;font-size:11px!important;letter-spacing:.08em}.table td{border-bottom:1px solid #e8f1fb!important}.pill{border-radius:999px;padding:5px 9px;font-size:11px;font-weight:900}.pill.PASS,.pill.Compliant{background:#dcfce7;color:#166534}.pill.FAIL,.pill.FailedRemoveFromService{background:#fee2e2;color:#991b1b}.search{max-width:520px}.powered-footer{position:fixed!important;left:0!important;right:0!important;bottom:0!important;height:24px!important;min-height:24px!important;padding:2px 16px!important;font-size:9px!important;background:rgba(255,255,255,.92)!important;border-top:1px solid #dbeafe!important;z-index:30!important;pointer-events:none!important}.powered-footer img{width:38px!important;max-height:16px!important;object-fit:contain!important}.powered-footer span{opacity:.84;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mobile-menu-btn,.inline-menu-btn{display:none!important}
.quick-dock{position:fixed;right:24px;bottom:44px;z-index:75;display:flex;flex-direction:column-reverse;align-items:flex-end;gap:10px}.quick-main{width:58px;height:58px;border-radius:20px!important;font-size:30px;line-height:1;padding:0!important;box-shadow:0 18px 40px rgba(23,119,255,.30)!important}.quick-actions{display:none;flex-direction:column;gap:8px;background:#fff;border:1px solid #dbeafe;border-radius:18px;padding:10px;box-shadow:0 22px 60px rgba(7,20,38,.20)}.quick-dock.open .quick-actions{display:flex}.quick-actions button{justify-content:flex-start;min-width:145px;border-radius:12px!important;padding:10px 14px!important}.wizard-steps{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 16px}.wizard-steps span{padding:8px 12px;border-radius:999px;background:#eef6ff;color:#0b66e8;font-weight:900;font-size:12px}.wizard-box{background:#f8fbff;border:1px solid #dbeafe;border-radius:18px;padding:14px;margin:12px 0}.designer-preview{border:1px solid #dbeafe;background:#fff;border-radius:18px;padding:18px;margin-top:14px;box-shadow:var(--shadow-card)}.designer-preview .cert-line{height:9px;background:#eef6ff;border-radius:999px;margin:8px 0}.theme-toggle{font-size:12px!important}
body.dark{background:#061529!important;color:#edf6ff!important}body.dark:before{background:linear-gradient(120deg,#061529,#09213b 70%,#0b2f55)!important}body.dark:after{opacity:.25}body.dark aside#sidebar,body.dark .topbar,body.dark .panel,body.dark .card,body.dark .kpi,body.dark .quick-actions{background:rgba(7,20,38,.88)!important;border-color:#183553!important;color:#edf6ff!important}body.dark input,body.dark select,body.dark textarea,body.dark .search{background:#071426!important;color:#edf6ff!important;border-color:#244766!important}body.dark aside nav button{background:#071426!important;color:#edf6ff!important;border-color:#244766!important}body.dark .table td{border-bottom-color:#183553!important}body.dark .powered-footer{background:rgba(7,20,38,.94)!important;color:#dbeafe!important;border-color:#183553!important}
@media(max-width:1450px){#appShell{grid-template-columns:238px minmax(0,1fr)!important}main{padding:22px 24px 64px!important}.topbar h1{font-size:36px!important}.kpis{grid-template-columns:repeat(3,minmax(150px,1fr))!important}.client-name{font-size:20px!important}.system-logo{max-width:150px!important;max-height:68px!important}}
@media(max-width:1100px){#appShell{grid-template-columns:214px minmax(0,1fr)!important}aside#sidebar{padding:16px 12px!important}.topbar{flex-direction:column}.kpis{grid-template-columns:repeat(2,minmax(145px,1fr))!important}aside nav button{font-size:13px!important;padding:8px 10px!important}.client-system-name{letter-spacing:.1em!important}}
@media(max-width:900px){#appShell{display:block!important}.mobile-menu-btn{display:flex!important;position:fixed!important;left:14px!important;top:12px!important;z-index:100!important;background:#071426!important;color:#fff!important}aside#sidebar{position:fixed!important;inset:0 auto 0 0!important;width:min(310px,88vw)!important;height:100dvh!important;transform:translateX(-105%)!important;transition:transform .22s ease!important;z-index:95!important;box-shadow:22px 0 65px rgba(7,20,38,.25)!important}body.sidebar-open aside#sidebar{transform:translateX(0)!important}.sidebar-backdrop{display:none!important;position:fixed!important;inset:0!important;background:rgba(7,20,38,.48)!important;z-index:90!important}body.sidebar-open .sidebar-backdrop{display:block!important}main{padding:72px 14px 78px!important}.topbar h1{font-size:32px!important}.powered-footer img{display:none}.quick-dock{right:14px;bottom:46px}.quick-main{width:52px;height:52px}.modalbox{width:calc(100vw - 16px)!important}}
@media(max-width:640px){.kpis{grid-template-columns:1fr!important}.top-actions{width:100%}.top-actions button,.top-actions a{width:100%}.table{display:block;overflow-x:auto}.topbar,.panel,.kpi{border-radius:18px!important}.powered-footer{font-size:8px!important;justify-content:center!important}.quick-actions button{min-width:130px}}
