:root{--blue:#0b56c5;--blue2:#08386f;--ink:#0f172a;--muted:#64748b;--line:#d8e0ec;--bg:#f6f8fb;--card:#fff}*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;color:var(--ink);background:var(--bg)}.login-page{min-height:100vh;display:grid;grid-template-columns:43% 57%;background:#fff}.hero{position:relative;overflow:hidden;background:radial-gradient(circle at 80% 45%,#165ec1,transparent 35%),linear-gradient(145deg,#071b3d,#0a4ca5 55%,#061a36);color:#fff;padding:58px 62px;display:flex;flex-direction:column}.hero:after{content:"";position:absolute;inset:auto -10% 12% -10%;height:360px;background:repeating-linear-gradient(165deg,rgba(78,153,255,.16),rgba(78,153,255,.16) 1px,transparent 3px,transparent 12px);border-radius:50%;transform:rotate(-8deg)}.hero-brand{display:flex;align-items:center;gap:18px;font-size:38px;font-weight:800}.book-icon{font-size:48px}.hero-copy{margin-top:115px;max-width:510px;z-index:1}.hero h1{font-size:41px;line-height:1.3;margin:0 0 18px}.hero p{font-size:20px;line-height:1.5;color:#dbeafe}.manual-visual{z-index:1;margin-top:72px;width:360px;height:170px;background:rgba(255,255,255,.95);border-radius:12px;box-shadow:0 18px 30px rgba(0,0,0,.28);transform:rotate(-2deg);display:flex;align-items:center;justify-content:center;color:#123}.manual-visual span{background:#1262c7;color:white;border-radius:8px;padding:8px 14px;font-weight:800;font-size:28px}.hero-features{margin-top:auto;display:grid;grid-template-columns:repeat(3,1fr);gap:20px;z-index:1}.feature{display:flex;gap:13px;align-items:flex-start;font-size:14px}.feature b{display:block;color:#fff;margin-bottom:8px}.feature small{color:#c9d8ef;line-height:1.45}.feature i{width:54px;height:54px;border-radius:50%;background:rgba(255,255,255,.12);display:grid;place-items:center;font-style:normal;font-size:22px}.login-wrap{display:flex;align-items:center;justify-content:center;padding:45px}.login-card{width:100%;max-width:690px;background:#fff;border:1px solid #dfe5ee;border-radius:16px;box-shadow:0 12px 34px rgba(15,23,42,.13);padding:62px}.login-card h2{text-align:center;font-size:32px;margin:0 0 10px}.login-card .sub{text-align:center;color:#64748b;font-size:20px;margin-bottom:40px}.field{margin-bottom:22px}.field label{display:block;margin-bottom:10px;font-weight:600}.input{width:100%;height:58px;border:1px solid #cbd5e1;border-radius:8px;padding:0 16px;font-size:17px}.btn{width:100%;height:58px;border:0;border-radius:8px;background:linear-gradient(90deg,#1464d2,#0953bd);color:white;font-size:18px;font-weight:700;cursor:pointer}.btn.secondary{background:#fff;color:#111;border:1px solid #d4dce8}.divider{display:flex;align-items:center;gap:24px;color:#475569;margin:34px 0}.divider:before,.divider:after{content:"";height:1px;background:#dce3ee;flex:1}.method-title{font-weight:600;margin:22px 0 10px}.login-links{text-align:center;margin:24px 0}.login-links a{color:#0757c2;text-decoration:none}.terms{border-top:1px solid #e2e8f0;padding-top:22px;text-align:center;color:#64748b}.error{background:#fee2e2;color:#991b1b;padding:12px;border-radius:8px;margin-bottom:18px}.app-body{display:flex;min-height:100vh}.sidebar{width:270px;background:#071b3d;color:#fff;padding:28px}.brand{display:flex;gap:12px;align-items:center;font-size:24px;margin-bottom:38px}.sidebar nav a{display:block;color:#dbeafe;text-decoration:none;padding:14px 12px;border-radius:10px;margin-bottom:7px}.sidebar nav a:hover{background:rgba(255,255,255,.1)}.main{flex:1}.topbar{background:#fff;border-bottom:1px solid #e2e8f0;padding:28px 36px;display:flex;justify-content:space-between;align-items:center}.topbar h1{margin:0;font-size:30px}.topbar p{margin:6px 0 0;color:var(--muted)}.user-chip{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:99px;padding:10px 15px}.user-chip a{margin-left:12px;color:#0757c2}.content{padding:34px}.grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:18px}.card{background:#fff;border:1px solid #e2e8f0;border-radius:14px;padding:22px;box-shadow:0 6px 18px rgba(15,23,42,.04)}.card h3{margin:0 0 10px}.stat{font-size:34px;font-weight:800;color:#0b56c5}.table{width:100%;border-collapse:collapse;background:#fff;border-radius:12px;overflow:hidden}.table th,.table td{text-align:left;border-bottom:1px solid #e2e8f0;padding:13px}.badge{padding:5px 9px;border-radius:99px;background:#dcfce7;color:#166534;font-weight:700;font-size:12px}.badge.expired{background:#fee2e2;color:#991b1b}@media(max-width:900px){.login-page{grid-template-columns:1fr}.hero{display:none}.login-card{padding:34px}.sidebar{display:none}.grid{grid-template-columns:1fr}.topbar{display:block}.content{padding:20px}}

/* Mobile-first home/dashboard upgrade */
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}body{padding-bottom:env(safe-area-inset-bottom)}a{-webkit-tap-highlight-color:transparent}.mobile-nav{display:none}.home-hero{display:grid;grid-template-columns:1.08fr .92fr;gap:26px;align-items:center;background:linear-gradient(135deg,#071b3d 0%,#0b56c5 62%,#0ea5e9 100%);color:#fff;border-radius:24px;padding:34px;box-shadow:0 18px 40px rgba(7,27,61,.2);overflow:hidden;position:relative}.home-hero:before{content:"";position:absolute;right:-120px;top:-120px;width:340px;height:340px;background:rgba(255,255,255,.14);border-radius:50%}.home-copy{position:relative;z-index:1}.eyebrow{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.24);font-weight:700;font-size:13px;letter-spacing:.02em}.home-copy h2{font-size:38px;line-height:1.12;margin:18px 0 14px;max-width:740px}.home-copy p{font-size:17px;line-height:1.6;color:#dbeafe;max-width:650px;margin:0}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}.action-btn{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:0 18px;border-radius:12px;background:#fff;color:#0757c2;text-decoration:none;font-weight:800}.action-btn.muted{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.28)}.screen-preview{position:relative;z-index:1;background:rgba(255,255,255,.94);border-radius:20px;padding:14px;box-shadow:0 24px 45px rgba(0,0,0,.22);color:#0f172a}.preview-top{height:32px;display:flex;gap:7px;align-items:center}.preview-top span{width:10px;height:10px;border-radius:50%;background:#cbd5e1}.preview-grid{display:grid;grid-template-columns:1.3fr 1fr;gap:10px}.preview-card{min-height:82px;border-radius:14px;background:#f1f5f9;border:1px solid #e2e8f0;padding:14px;display:flex;flex-direction:column;justify-content:center}.preview-card.large{grid-row:span 2;background:linear-gradient(135deg,#e0f2fe,#eff6ff)}.preview-card b{font-size:22px}.preview-card small{margin-top:5px;color:#64748b}.stats-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px;margin:22px 0}.stat-card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:20px;text-decoration:none;color:#0f172a;box-shadow:0 6px 18px rgba(15,23,42,.05);display:grid;gap:8px;min-height:135px}.stat-card span{font-size:28px}.stat-card small{color:#64748b;font-weight:700}.stat-card strong{font-size:36px;color:#0b56c5;line-height:1}.quick-panel{display:grid;grid-template-columns:1.3fr .7fr;gap:16px;margin-bottom:22px}.panel-card{background:#fff;border:1px solid #e2e8f0;border-radius:18px;padding:22px;box-shadow:0 6px 18px rgba(15,23,42,.05)}.panel-card h3{margin:0 0 14px}.quick-actions{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.quick-actions a{background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px;padding:14px;text-align:center;text-decoration:none;color:#0f172a;font-weight:800}.panel-text{color:#64748b;line-height:1.55;margin:0 0 12px}.text-link,.section-head a{color:#0757c2;text-decoration:none;font-weight:800}.section-head{display:flex;justify-content:space-between;gap:15px;align-items:flex-start;margin-bottom:14px}.section-head h3{margin:0}.section-head p{margin:6px 0 0;color:#64748b}.responsive-table{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.recent-card{margin-bottom:22px}

@media(max-width:1100px){.home-hero{grid-template-columns:1fr}.screen-preview{max-width:640px}.stats-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-panel{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:900px){.app-body{display:block}.main{min-height:100vh}.topbar{position:sticky;top:0;z-index:20;padding:calc(16px + env(safe-area-inset-top)) 18px 16px;background:rgba(255,255,255,.96);backdrop-filter:blur(12px)}.topbar h1{font-size:24px}.topbar p{font-size:14px}.user-chip{margin-top:12px;display:inline-flex}.content{padding:16px 16px calc(92px + env(safe-area-inset-bottom))}.mobile-nav{position:fixed;left:0;right:0;bottom:0;z-index:50;display:grid;grid-template-columns:repeat(6,1fr);gap:2px;background:rgba(255,255,255,.96);border-top:1px solid #e2e8f0;padding:8px 8px calc(8px + env(safe-area-inset-bottom));box-shadow:0 -8px 24px rgba(15,23,42,.08);backdrop-filter:blur(12px)}.mobile-nav a{display:flex;flex-direction:column;align-items:center;gap:3px;color:#0f172a;text-decoration:none;font-size:18px;font-weight:700}.mobile-nav span{font-size:11px}.home-hero{border-radius:18px;padding:22px}.home-copy h2{font-size:28px}.home-copy p{font-size:15px}.screen-preview{display:none}.stats-grid{gap:12px}.stat-card{min-height:112px;padding:16px}.stat-card strong{font-size:30px}.quick-actions{grid-template-columns:1fr 1fr}.table{min-width:720px}}
@media(max-width:560px){.login-card{border:0;box-shadow:none;padding:28px 20px}.login-wrap{padding:18px}.login-card h2{font-size:26px}.login-card .sub{font-size:16px}.input,.btn{height:54px}.home-copy h2{font-size:25px}.hero-actions{display:grid}.action-btn{width:100%}.stats-grid{grid-template-columns:1fr 1fr}.stat-card{border-radius:15px}.quick-actions{grid-template-columns:1fr}.panel-card{padding:18px}.section-head{display:block}.section-head a{display:inline-block;margin-top:10px}.responsive-table{overflow:visible}.table{min-width:0}.table tr:first-child{display:none}.table tr{display:block;border:1px solid #e2e8f0;border-radius:14px;margin-bottom:12px;padding:8px;background:#fff}.table td{display:flex;justify-content:space-between;gap:12px;border-bottom:1px solid #eef2f7;padding:10px;text-align:right}.table td:last-child{border-bottom:0}.table td:before{content:attr(data-label);font-weight:800;color:#64748b;text-align:left}.recent-card{padding:16px}}

/* Login no-scroll desktop fix */
@media (min-width:901px){
  html,body{height:100%;overflow:hidden;}
  body.login-page{height:100vh;height:100dvh;min-height:0;overflow:hidden;display:grid;grid-template-columns:43% 57%;}
  .login-page .hero,.login-page .login-wrap{height:100vh;height:100dvh;min-height:0;overflow:hidden;}
  .login-page .hero{padding:clamp(28px,4vh,58px) clamp(34px,4vw,62px);}
  .login-page .hero-brand{font-size:clamp(28px,3vw,38px);}
  .login-page .book-icon{font-size:clamp(34px,3.5vw,48px);}
  .login-page .hero-copy{margin-top:clamp(42px,8vh,105px);}
  .login-page .hero h1{font-size:clamp(32px,3vw,41px);line-height:1.22;margin-bottom:14px;}
  .login-page .hero p{font-size:clamp(16px,1.5vw,20px);}
  .login-page .manual-visual{margin-top:clamp(30px,6vh,68px);width:min(360px,70%);height:clamp(120px,16vh,170px);}
  .login-page .hero-features{gap:14px;}
  .login-page .feature i{width:46px;height:46px;font-size:19px;flex:0 0 46px;}
  .login-page .feature{font-size:13px;}
  .login-page .login-wrap{padding:clamp(18px,3vh,42px) clamp(30px,4vw,45px);}
  .login-page .login-card{max-width:690px;max-height:calc(100dvh - 56px);overflow:hidden;padding:clamp(30px,5vh,54px);}
  .login-page .login-card h2{font-size:clamp(28px,2.4vw,32px);}
  .login-page .login-card .sub{font-size:clamp(16px,1.45vw,20px);margin-bottom:clamp(18px,3vh,32px);}
  .login-page .field{margin-bottom:clamp(12px,2vh,18px);}
  .login-page .field label{margin-bottom:7px;}
  .login-page .input,.login-page .btn{height:clamp(46px,5.4vh,56px);}
  .login-page .divider{margin:clamp(18px,2.8vh,28px) 0;}
  .login-page .method-title{margin:clamp(12px,1.9vh,18px) 0 8px;}
  .login-page .login-links{margin:clamp(12px,2vh,20px) 0;}
  .login-page .terms{padding-top:clamp(12px,2vh,18px);font-size:14px;}
}

@media (max-width:900px){
  html,body{height:auto;overflow-x:hidden;overflow-y:auto;}
  body.login-page{min-height:100dvh;overflow-y:auto;}
  .login-wrap{min-height:100dvh;align-items:center;}
}


/* Premium login refresh */
@media (min-width: 901px){
  html, body{height:100%; overflow:hidden;}
  body.login-page{height:100vh; min-height:100vh; overflow:hidden;}
}
body.login-page{
  background:linear-gradient(120deg,#071a3a 0%,#071a3a 43%,#f7faff 43%,#ffffff 100%);
  font-family:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Arial, sans-serif;
}
.login-page{
  min-height:100svh;
  grid-template-columns:minmax(420px,43%) minmax(560px,57%);
}
.hero{
  padding:clamp(30px,4vw,58px) clamp(32px,4vw,64px);
  background:
    radial-gradient(circle at 78% 35%, rgba(58,132,255,.55), transparent 30%),
    radial-gradient(circle at 35% 105%, rgba(37,99,235,.65), transparent 34%),
    linear-gradient(145deg,#061832 0%,#0a3676 55%,#061832 100%);
}
.hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(120deg,rgba(255,255,255,.045),transparent 34%),
    radial-gradient(circle at 12% 12%,rgba(255,255,255,.08),transparent 18%);
  pointer-events:none;
}
.hero:after{
  height:430px;
  bottom:4%;
  opacity:.9;
  filter:drop-shadow(0 0 22px rgba(37,99,235,.25));
}
.hero-brand{font-size:clamp(28px,2.65vw,40px);letter-spacing:-.04em;position:relative;z-index:2}.book-icon{font-size:46px;filter:drop-shadow(0 8px 14px rgba(0,0,0,.22))}.hero-copy{margin-top:clamp(54px,9vh,110px)}.hero h1{font-size:clamp(36px,3.7vw,56px);line-height:1.18;letter-spacing:-.045em;margin-bottom:20px}.hero p{font-size:clamp(18px,1.45vw,22px);max-width:590px}.manual-visual{
  width:min(420px,70%);height:190px;border-radius:18px;margin-top:clamp(48px,7vh,76px);
  background:linear-gradient(145deg,#ffffff,#edf4ff);
  box-shadow:0 26px 45px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.9);
  transform:rotate(-2.5deg) perspective(650px) rotateX(3deg);
  position:relative;
}
.manual-visual:before{content:"";position:absolute;inset:24px 28px;border-radius:12px;background:linear-gradient(90deg,#dbeafe 0 25%,transparent 25% 100%);opacity:.75}.manual-visual:after{content:"";position:absolute;right:46px;top:46px;width:120px;height:12px;border-radius:99px;background:#cbd5e1;box-shadow:0 30px 0 #d5deea,0 60px 0 #e0e7f0}.manual-visual span{position:relative;z-index:2;box-shadow:0 10px 18px rgba(11,86,197,.28)}
.hero-features{gap:16px}.feature{padding:12px 10px;border-radius:16px;background:rgba(255,255,255,.05);backdrop-filter:blur(12px)}.feature i{background:rgba(255,255,255,.14);box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.login-wrap{padding:clamp(28px,5vw,64px);background:radial-gradient(circle at 70% 10%,#eaf2ff,transparent 32%)}
.login-card{
  max-width:720px;
  max-height:calc(100vh - 64px);
  overflow:hidden;
  padding:clamp(34px,4vw,58px) clamp(42px,4.2vw,66px);
  border-radius:24px;
  border:1px solid rgba(203,213,225,.9);
  background:rgba(255,255,255,.88);
  box-shadow:0 26px 70px rgba(15,23,42,.16), 0 4px 18px rgba(15,23,42,.06);
  backdrop-filter:blur(16px);
}
.login-card h2{font-size:clamp(32px,2.5vw,42px);letter-spacing:-.045em}.login-card .sub{font-size:20px;margin-bottom:32px}.field{margin-bottom:17px}.field label{font-size:15px}.input{height:56px;border-radius:13px;background:#fff;border-color:#cbd7e7;box-shadow:inset 0 1px 0 rgba(15,23,42,.03)}.input:focus{outline:none;border-color:#0b56c5;box-shadow:0 0 0 4px rgba(11,86,197,.12)}.btn{height:58px;border-radius:13px;background:linear-gradient(135deg,#1f7af0,#0751b8);box-shadow:0 12px 22px rgba(11,86,197,.24);transition:transform .15s ease, box-shadow .15s ease}.btn:hover{transform:translateY(-1px);box-shadow:0 16px 28px rgba(11,86,197,.28)}.btn.secondary{height:62px;display:flex;align-items:center;justify-content:center;gap:12px;border-radius:13px;border-color:#d7e0ec;box-shadow:none;background:linear-gradient(180deg,#ffffff,#fbfdff);line-height:1.15}.btn.secondary small{display:block;color:#64748b;font-weight:600}.divider{margin:28px 0 20px}.method-title{margin:18px 0 9px;color:#0f172a}.login-links{margin:20px 0}.terms{font-size:15px;padding-top:20px}.error{border:1px solid #fecaca}
@media(max-width:1100px) and (min-width:901px){.login-card{padding:34px}.hero-copy{margin-top:58px}.manual-visual{margin-top:46px}.feature small{display:none}.hero-features{grid-template-columns:1fr}.feature{align-items:center}.login-card .sub{margin-bottom:22px}.divider{margin:22px 0 14px}.method-title{margin:12px 0 8px}.terms{font-size:13px}.btn.secondary{height:56px}.input,.btn{height:54px}}
@media(max-width:900px){body.login-page{background:#f7faff}.login-page{display:block}.login-wrap{min-height:100svh;padding:calc(22px + env(safe-area-inset-top)) 18px calc(22px + env(safe-area-inset-bottom));background:linear-gradient(180deg,#eef5ff,#fff)}.login-card{max-height:none;border-radius:22px;padding:30px 22px}.login-card:before{content:"📖 Manual Portal";display:block;text-align:center;font-weight:900;font-size:24px;margin-bottom:22px;color:#0f172a}.terms{font-size:13px}.btn.secondary{height:60px}}

/* Passkey and settings UI */
.settings-form{display:grid;gap:14px;margin-top:18px}.toggle-row{display:flex;align-items:center;justify-content:space-between;gap:18px;border:1px solid #e2e8f0;border-radius:16px;padding:16px;background:#f8fafc}.toggle-row span{display:grid;gap:5px}.toggle-row small{color:#64748b;line-height:1.4}.toggle-row input{appearance:none;width:54px;height:30px;border-radius:999px;background:#cbd5e1;position:relative;cursor:pointer;flex:0 0 auto;transition:.2s}.toggle-row input:before{content:"";position:absolute;width:24px;height:24px;top:3px;left:3px;border-radius:50%;background:#fff;box-shadow:0 2px 6px rgba(0,0,0,.18);transition:.2s}.toggle-row input:checked{background:#0b56c5}.toggle-row input:checked:before{left:27px}.settings-save{max-width:220px}.settings-action{border:0;cursor:pointer}.button-link{border:0;background:transparent;cursor:pointer;padding:0;font:inherit}.success-card{margin-bottom:18px;background:#ecfdf5;border-color:#bbf7d0;color:#166534;font-weight:800}
@media(max-width:560px){.toggle-row{align-items:flex-start}.settings-save{max-width:none;width:100%}}


/* Compact premium login update - keeps terms visible and reduces content size */
@media (min-width:901px){
  body.login-page{height:100dvh;min-height:100dvh;overflow:hidden;}
  .login-page .hero{padding:28px 42px;}
  .login-page .hero-brand{font-size:30px;gap:12px;}
  .login-page .book-icon{font-size:36px;}
  .login-page .hero-copy{margin-top:54px;max-width:480px;}
  .login-page .hero h1{font-size:38px;line-height:1.15;margin-bottom:12px;}
  .login-page .hero p{font-size:17px;line-height:1.45;}
  .login-page .manual-visual{width:320px;height:138px;margin-top:40px;border-radius:16px;}
  .login-page .manual-visual span{font-size:22px;padding:7px 12px;}
  .login-page .hero-features{grid-template-columns:repeat(3,1fr);gap:10px;}
  .login-page .feature{padding:10px 8px;font-size:12px;gap:9px;}
  .login-page .feature i{width:38px;height:38px;font-size:17px;flex:0 0 38px;}
  .login-page .feature b{margin-bottom:4px;}
  .login-page .feature small{font-size:11px;line-height:1.3;}
  .login-page .login-wrap{padding:24px 42px;}
  .login-page .login-card{max-width:620px;max-height:calc(100dvh - 48px);padding:30px 44px;border-radius:22px;}
  .login-page .login-card h2{font-size:32px;margin-bottom:6px;}
  .login-page .login-card .sub{font-size:16px;margin-bottom:20px;}
  .login-page .field{margin-bottom:12px;}
  .login-page .field label{margin-bottom:6px;font-size:14px;}
  .login-page .input{height:48px;font-size:15px;border-radius:11px;}
  .login-page .btn{height:48px;font-size:16px;border-radius:11px;}
  .login-page .btn.secondary{height:50px;font-size:15px;}
  .login-page .divider{margin:18px 0 12px;gap:16px;font-size:13px;}
  .login-page .method-title{margin:11px 0 7px;font-size:14px;}
  .login-page .login-links{margin:13px 0;font-size:14px;}
  .login-page .terms{display:block;border-top:1px solid #e2e8f0;padding-top:13px;margin:0;text-align:center;color:#64748b;font-size:12.5px;line-height:1.45;}
  .login-page .terms a{color:#0757c2;text-decoration:none;font-weight:700;}
}
@media (max-height:760px) and (min-width:901px){
  .login-page .hero-copy{margin-top:34px;}
  .login-page .manual-visual{display:none;}
  .login-page .login-card{padding:24px 40px;}
  .login-page .btn.secondary{height:46px;}
  .login-page .divider{margin:12px 0 8px;}
  .login-page .method-title{margin:8px 0 5px;}
}


/* Fingerprint homepage action */
.fingerprint-box{display:flex;gap:14px;align-items:center;background:linear-gradient(135deg,#eff6ff,#ffffff);border:1px solid #dbeafe;border-radius:16px;padding:14px;margin:14px 0;box-shadow:inset 0 1px 0 rgba(255,255,255,.8)}
.fingerprint-icon{width:48px;height:48px;border-radius:16px;background:#0b56c5;color:#fff;display:grid;place-items:center;font-size:28px;box-shadow:0 10px 22px rgba(11,86,197,.22)}
.fingerprint-box b{display:block;font-size:16px;margin-bottom:4px;color:#0f172a}
.fingerprint-box small{display:block;color:#64748b;line-height:1.4}
.fingerprint-action{gap:8px}
.fingerprint-action:before{content:"◎";font-size:20px;line-height:1}
@media(max-width:560px){.fingerprint-box{align-items:flex-start}.fingerprint-icon{width:42px;height:42px;border-radius:14px;font-size:24px}.security-actions{display:grid}.security-actions .action-btn{width:100%}}

/* Social sign-in and provider settings */
.social-login-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:10px 0 4px}.social-login-btn{height:46px;border:1px solid #d7e0ec;border-radius:12px;background:#fff;color:#0f172a;text-decoration:none;font-weight:800;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 4px 12px rgba(15,23,42,.05)}.social-login-btn span{width:24px;height:24px;border-radius:999px;display:grid;place-items:center;background:#eff6ff;color:#0757c2;font-weight:900}.settings-section-title{font-weight:900;color:#0f172a;margin:10px 0 0;padding-top:10px;border-top:1px solid #e2e8f0}.provider-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.provider-card{border:1px solid #e2e8f0;border-radius:16px;padding:14px;background:#fff}.provider-card .field{margin-top:12px;margin-bottom:0}.provider-card .input{height:44px;font-size:14px}.toggle-row.compact{padding:12px;margin-bottom:6px}.callback-note{display:block;color:#64748b;line-height:1.45;margin-top:10px;word-break:break-word}.callback-note code{background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;padding:2px 5px;color:#0f172a}@media(max-width:1100px){.provider-grid{grid-template-columns:1fr}.social-login-grid{grid-template-columns:1fr}}@media(max-width:560px){.social-login-grid{grid-template-columns:1fr}.social-login-btn{height:48px}}

/* Branding controls */
.hero-brand .login-brand-logo{max-width:320px;max-height:88px;width:auto;height:auto;object-fit:contain;display:block;filter:drop-shadow(0 8px 18px rgba(0,0,0,.18))}.brand .sidebar-brand-logo{max-width:190px;max-height:58px;width:auto;height:auto;object-fit:contain;display:block}.brand{min-height:58px}.branding-panel{grid-template-columns:1fr .85fr}.branding-preview{min-height:210px;border:1px dashed #cbd5e1;background:linear-gradient(135deg,#f8fafc,#eef6ff);border-radius:18px;display:grid;place-items:center;padding:28px;margin-bottom:16px}.branding-preview img{max-width:100%;max-height:150px;object-fit:contain}.preview-brand-text{display:flex;align-items:center;gap:14px;font-size:28px;color:#0f172a}.preview-brand-text span{font-size:44px}.file-input{height:auto;padding:15px;background:#fff}.remove-logo-form{margin-top:16px}.success-card{background:#ecfdf5!important;color:#166534!important;border-color:#bbf7d0!important;margin-bottom:18px}.button-link{background:none;border:0;cursor:pointer;padding:0;font:inherit}
@media(max-width:900px){.hero-brand .login-brand-logo{max-width:230px;max-height:66px}.brand .sidebar-brand-logo{max-width:160px}.branding-panel{grid-template-columns:1fr}}

/* Users and access management page */
.breadcrumb{display:flex;align-items:center;gap:12px;margin:-8px 0 18px;color:#64748b;font-size:14px}.breadcrumb a{color:#0757c2;text-decoration:none;font-weight:800}.page-heading{font-size:28px;line-height:1.15;margin:0 0 6px;color:#111827}.page-intro{margin:0 0 22px;color:#64748b;font-size:16px}.users-create-grid{margin-bottom:22px}.user-form-card{display:grid;grid-template-columns:.85fr 1.15fr;gap:22px;align-items:start}.user-panel,.access-panel{height:100%}.user-panel h3,.access-panel h3{margin-top:0}.required{color:#ef4444}.user-panel .field{margin-bottom:20px}.user-panel .input,.access-panel .input{height:40px;border-radius:7px;font-size:14px}.status-toggle{display:flex;align-items:center;gap:12px;margin:14px 0 36px}.status-toggle input{position:absolute;opacity:0}.status-toggle span{width:42px;height:24px;border-radius:999px;background:#cbd5e1;position:relative;box-shadow:inset 0 1px 2px rgba(15,23,42,.12)}.status-toggle span:before{content:"";position:absolute;width:18px;height:18px;top:3px;left:3px;border-radius:50%;background:#fff;box-shadow:0 2px 5px rgba(15,23,42,.2);transition:.18s}.status-toggle input:checked+span{background:#0b56c5}.status-toggle input:checked+span:before{left:21px}.user-form-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:26px}.user-form-actions .btn{width:150px;height:46px}.cancel-btn{background:#fff!important;color:#0f172a!important;border:1px solid #d7e0ec;text-decoration:none;box-shadow:none!important;display:flex;align-items:center;justify-content:center}.info-strip{display:flex;align-items:center;gap:12px;background:#eef5ff;border-radius:7px;padding:12px 14px;margin:8px 0 18px;color:#1e293b}.info-strip span{color:#0b56c5;font-size:20px}.info-strip p{margin:0;flex:1;font-size:13px}.info-strip a{color:#0757c2;text-decoration:none;font-weight:800;font-size:13px}.no-border{border-top:0!important;padding-top:0!important;margin:18px 0 10px!important}.radio-row{display:flex;gap:12px;align-items:flex-start;margin:14px 0;cursor:pointer}.radio-row input{width:16px;height:16px;margin-top:3px;accent-color:#0b56c5}.radio-row span{display:grid;gap:5px}.radio-row small{color:#64748b}.permissions-table{border:1px solid #e2e8f0;border-radius:8px;overflow:hidden;background:#fff}.permissions-head,.permission-row{display:grid;grid-template-columns:42px 1fr 90px;align-items:center}.permissions-head{grid-template-columns:1fr 90px;padding:10px 12px;border-bottom:1px solid #e2e8f0;font-size:12px}.permissions-head b:last-child{text-align:center}.permission-row{min-height:54px;padding:9px 12px;border-bottom:1px solid #e2e8f0;cursor:pointer}.permission-row:last-child{border-bottom:0}.perm-icon{font-size:20px}.perm-copy{display:grid;gap:3px}.perm-copy b{font-size:14px}.perm-copy small{font-size:12px;color:#64748b}.perm-check{appearance:none;width:38px;height:22px;border-radius:999px;background:#cbd5e1;position:relative;justify-self:center;cursor:pointer;transition:.18s}.perm-check:before{content:"";position:absolute;width:18px;height:18px;top:2px;left:2px;background:#fff;border-radius:50%;box-shadow:0 2px 5px rgba(15,23,42,.2);transition:.18s}.perm-check:checked{background:#0b56c5}.perm-check:checked:before{left:18px}.info-note{display:flex;align-items:center;gap:14px;border:1px solid #b7cdfd;background:#eff6ff;border-radius:8px;padding:16px 20px;color:#334155;margin:0 0 22px}.info-note span{color:#0b56c5;font-size:20px}.users-list-card{margin-top:22px}
@media(max-width:1100px){.user-form-card{grid-template-columns:1fr}.user-form-actions{justify-content:stretch}.user-form-actions .btn{width:100%}}
@media(max-width:900px){.mobile-nav{grid-template-columns:repeat(6,1fr)}.breadcrumb{margin-top:0}.page-heading{font-size:25px}.permissions-head,.permission-row{grid-template-columns:34px 1fr 62px}.permissions-head{grid-template-columns:1fr 62px}.info-strip{align-items:flex-start}.user-form-actions{display:grid;grid-template-columns:1fr}}
@media(max-width:560px){.permissions-head{display:none}.permission-row{grid-template-columns:30px 1fr 52px;min-height:auto;padding:12px 10px}.perm-copy b{font-size:13px}.perm-copy small{font-size:11px}.info-note{align-items:flex-start;padding:14px}.user-panel .field{margin-bottom:14px}}

/* Fix dashboard/users page scrolling while keeping login locked to one screen */
html{overflow-y:auto!important;overflow-x:hidden!important;}
body.app-body{height:auto!important;min-height:100vh!important;overflow-y:auto!important;overflow-x:hidden!important;padding-bottom:0;}
body.app-body .main{min-height:100vh;overflow:visible;}
body.app-body .content{padding-bottom:48px;}
@media (min-width:901px){
  body.app-body{display:flex!important;}
  body.app-body .sidebar{position:sticky;top:0;height:100vh;overflow-y:auto;flex:0 0 270px;}
  body.app-body .main{min-width:0;}
}
@media (max-width:900px){
  body.app-body{display:block!important;padding-bottom:calc(86px + env(safe-area-inset-bottom));}
  body.app-body .content{padding-bottom:calc(112px + env(safe-area-inset-bottom));}
}

/* Users list and account actions */
.users-admin-table .table{min-width:980px}.user-actions{display:flex;flex-wrap:wrap;gap:7px;align-items:center}.user-actions form{display:inline;margin:0}.mini-btn{border:1px solid #cfe0f6;background:#f8fbff;color:#0757c2;border-radius:8px;padding:8px 10px;font-weight:800;font-size:12px;cursor:pointer;white-space:nowrap}.mini-btn:hover{background:#eaf3ff}.mini-btn.warn{color:#92400e;border-color:#fde68a;background:#fffbeb}.mini-btn.danger{color:#991b1b;border-color:#fecaca;background:#fff1f2}.badge.neutral{background:#e2e8f0;color:#475569}.edit-user-dialog{border:0;border-radius:18px;padding:0;max-width:850px;width:min(94vw,850px);box-shadow:0 24px 80px rgba(15,23,42,.28)}.edit-user-dialog::backdrop{background:rgba(2,6,23,.55);backdrop-filter:blur(3px)}.edit-user-form{padding:24px}.dialog-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:18px}.dialog-head h3{margin:0}.dialog-head button{width:38px;height:38px;border:1px solid #e2e8f0;border-radius:50%;background:#fff;font-size:24px;line-height:1;cursor:pointer}.edit-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.compact-permissions .permission-row{min-height:48px}.compact-permissions .perm-copy small{display:none}
@media(max-width:900px){.users-admin-table .table{min-width:0}.user-actions{justify-content:flex-end}.edit-grid{grid-template-columns:1fr}.edit-user-form{padding:18px}.users-admin-table .table td[data-label="Actions"]{display:block;text-align:left}.users-admin-table .table td[data-label="Actions"]:before{display:block;margin-bottom:8px}.user-actions{justify-content:flex-start}}

/* Manuals PDF library/viewer page */
.manuals-page-shell{display:grid;grid-template-columns:305px minmax(0,1fr);gap:16px;min-height:calc(100vh - 170px)}
.manuals-library-panel,.manual-viewer-panel{background:#fff;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 8px 24px rgba(15,23,42,.06);overflow:hidden}
.manuals-library-panel{display:flex;flex-direction:column}.upload-manual-box{padding:16px 14px;border-bottom:1px solid #e2e8f0}.upload-manual-box summary{list-style:none;cursor:pointer;display:inline-flex;align-items:center;gap:8px;background:linear-gradient(90deg,#1669d8,#0b56c5);color:#fff;border-radius:7px;padding:12px 16px;font-weight:800;box-shadow:0 8px 18px rgba(11,86,197,.22)}.upload-manual-box summary::-webkit-details-marker{display:none}.upload-manual-form{display:grid;gap:10px;margin-top:14px}.upload-manual-form label{display:grid;gap:6px;font-weight:700;font-size:13px}.upload-manual-form .input{height:42px}.upload-manual-form .btn{height:44px}.manual-search-box{position:relative;padding:16px 14px 10px}.manual-search-box .input{height:42px;padding-right:42px}.manual-search-box span{position:absolute;right:27px;top:25px;font-size:25px;color:#334155;line-height:1}.manual-filter-label{display:block;padding:12px 14px 8px;font-size:18px;font-weight:900}.manual-category-select{height:42px!important;margin:0 14px 16px;width:calc(100% - 28px)!important}.manual-list{border-top:1px solid #edf2f7;overflow:auto}.manual-list-item{width:100%;display:grid;grid-template-columns:34px 1fr;gap:10px;align-items:center;text-align:left;border:0;border-bottom:1px solid #e6edf5;background:#fff;padding:17px 16px;cursor:pointer;color:#0f172a}.manual-list-item:hover,.manual-list-item.active{background:linear-gradient(90deg,#eaf4ff,#f7fbff)}.pdf-badge{width:22px;height:26px;border-radius:4px;background:#dc2626;color:#fff;display:grid;place-items:center;font-size:13px;font-weight:900}.manual-meta b{display:block;font-size:16px;line-height:1.35}.manual-meta small{display:block;margin-top:6px;color:#64748b}.manual-pagination{margin-top:auto;border-top:1px solid #e6edf5;display:flex;align-items:center;gap:20px;padding:18px;color:#64748b}.manual-pagination span:first-child{margin-right:auto}.manual-viewer-panel{display:flex;flex-direction:column;min-width:0}.viewer-file-title{font-weight:900;font-size:17px;padding:18px;border-bottom:1px solid #e2e8f0}.pdf-toolbar{height:66px;background:linear-gradient(180deg,#252b2f,#1f2528);color:#fff;display:flex;align-items:center;gap:18px;padding:0 26px;font-size:17px}.pdf-toolbar button,.pdf-toolbar select{height:36px;border:1px solid rgba(255,255,255,.18);border-radius:7px;background:rgba(255,255,255,.06);color:#fff;padding:0 12px;font:inherit}.pdf-toolbar select option{color:#111}.hamburger{font-size:22px}.toolbar-sep{width:1px;height:34px;background:rgba(255,255,255,.14)}.toolbar-spacer{flex:1}.pdf-viewer-body{display:grid;grid-template-columns:272px minmax(0,1fr);min-height:620px;background:#242b2f}.pdf-thumbnails{background:linear-gradient(90deg,#20282c,#30383c);overflow:auto;padding:26px 26px 16px;display:grid;align-content:start;gap:22px}.thumb{text-align:center;color:#fff}.thumb-page{width:110px;height:145px;margin:0 auto 8px;background:#fff;border:1px solid #d7e0ec;box-shadow:0 8px 18px rgba(0,0,0,.26);display:grid;place-items:start;padding:14px;color:#0b56c5;font-size:9px;font-weight:900}.thumb.selected .thumb-page{outline:4px solid #3b82f6}.pdf-document-area{overflow:auto;padding:0 34px 0 0;display:flex;justify-content:center;align-items:flex-start}.mock-pdf-page{position:relative;margin:0 auto 28px;width:min(100%,700px);min-height:830px;background:#fff;overflow:hidden;box-shadow:0 0 0 1px rgba(0,0,0,.12),0 10px 28px rgba(0,0,0,.35);padding:86px 72px;color:#050505}.mock-title-block h2{font-size:42px;color:#1454a4;margin:0 0 8px}.mock-title-block h1{font-size:42px;line-height:1.08;margin:0 0 36px}.mock-title-block h3{font-size:28px;margin:0}.machine-illustration{position:absolute;right:86px;bottom:160px;width:360px;height:220px;background:linear-gradient(180deg,#f8fafc,#d5dae2);border-radius:8px 8px 4px 4px;border-bottom:44px solid #111827;box-shadow:0 20px 22px rgba(15,23,42,.2)}.machine-illustration:before{content:"";position:absolute;left:34px;top:40px;width:140px;height:110px;background:#1f2937;border-radius:3px;box-shadow:inset 18px 0 #1565c0}.machine-illustration:after{content:"";position:absolute;right:50px;top:48px;width:72px;height:98px;background:#26323d;border-radius:4px;box-shadow:inset 0 0 0 12px #111827}.machine-illustration div{position:absolute;right:68px;top:65px;width:38px;height:34px;background:#60a5fa;border-radius:3px}.machine-illustration span{position:absolute;right:93px;top:-44px;width:11px;height:44px;background:#111827}.machine-illustration span:after{content:"";position:absolute;top:0;left:-4px;width:19px;height:24px;background:linear-gradient(#ef4444 0 33%,#facc15 33% 66%,#22c55e 66%);border-radius:3px}.pdf-wave{position:absolute;left:-10%;right:-10%;bottom:-90px;height:260px;background:linear-gradient(135deg,#e5e7eb 0 32%,#1f5fa8 33% 100%);border-radius:50% 50% 0 0/45% 45% 0 0}.mock-pdf-page footer{position:absolute;right:54px;bottom:54px;color:#fff;display:grid;gap:8px;text-align:right;font-size:16px}.real-pdf-frame{width:100%;height:830px;border:0;background:#fff}
@media(max-width:1200px){.manuals-page-shell{grid-template-columns:280px 1fr}.pdf-viewer-body{grid-template-columns:170px 1fr}.pdf-thumbnails{padding:20px 16px}.thumb-page{width:86px;height:116px}.machine-illustration{right:45px;transform:scale(.84);transform-origin:bottom right}.mock-pdf-page{padding:70px 50px}}
@media(max-width:900px){.manuals-page-shell{grid-template-columns:1fr}.manuals-library-panel{max-height:none}.manual-list{max-height:390px}.pdf-viewer-body{grid-template-columns:1fr;min-height:auto}.pdf-thumbnails{display:none}.pdf-toolbar{overflow:auto;padding:0 14px}.pdf-document-area{padding:0;overflow:auto}.mock-pdf-page{width:100%;min-height:650px;margin:0;box-shadow:none}.machine-illustration{right:24px;bottom:125px;transform:scale(.68);transform-origin:bottom right}.mock-title-block h2,.mock-title-block h1{font-size:32px}.mock-title-block h3{font-size:23px}.real-pdf-frame{height:680px}}
@media(max-width:560px){.viewer-file-title{font-size:15px;padding:14px}.manuals-page-shell{gap:12px}.pdf-toolbar{height:54px;font-size:14px;gap:10px}.pdf-toolbar button,.pdf-toolbar select{height:32px;padding:0 8px}.mock-pdf-page{min-height:560px;padding:48px 28px}.mock-title-block h2,.mock-title-block h1{font-size:28px}.machine-illustration{right:-12px;bottom:110px;transform:scale(.52)}.mock-pdf-page footer{right:28px;bottom:36px;font-size:13px}.real-pdf-frame{height:560px}}

/* Working manuals/PDF viewer improvements */
.manual-list-item{text-decoration:none}.manual-list-item:focus{outline:3px solid rgba(37,99,235,.35);outline-offset:-3px}.toolbar-btn{height:36px;min-width:38px;border:1px solid rgba(255,255,255,.18);border-radius:7px;background:rgba(255,255,255,.06);color:#fff;padding:0 12px;font:inherit;text-decoration:none;display:inline-flex;align-items:center;justify-content:center}.pdf-toolbar button:disabled{opacity:.45;cursor:not-allowed}.pdf-document-area{min-height:0}.mock-pdf-page{transition:transform .18s ease}.success-card{background:#dcfce7;color:#166534;padding:12px;border-radius:8px;margin:12px 14px;font-weight:700}.manual-viewer-panel{height:calc(100vh - 170px)}.pdf-viewer-body{min-height:0;flex:1}.pdf-document-area{overflow:auto}.real-pdf-frame{min-height:100%;background:#fff}@media(max-width:900px){.manual-viewer-panel{height:auto}.pdf-viewer-body{min-height:auto}.real-pdf-frame{height:70vh}}
