:root{
  color-scheme:light;
  --bg:#f7f8fb;--bg-soft:#eef2f7;--surface:#fff;--surface-2:#f8fafc;--surface-3:#f1f5f9;
  --line:#e5e7eb;--line-2:#cbd5e1;--text:#0f172a;--muted:#64748b;--muted-2:#94a3b8;
  --brand:#2563eb;--brand-2:#1d4ed8;--brand-soft:#eff6ff;--danger:#dc2626;--danger-2:#991b1b;--ok:#16a34a;--warn:#f59e0b;
  --sidebar:#0f172a;--sidebar-2:#111827;--sidebar-hover:#17233a;--sidebar-active:#1e293b;
  --shadow:0 18px 50px rgba(15,23,42,.08);--shadow-soft:0 8px 24px rgba(15,23,42,.06);
  --radius:18px;--radius-sm:12px;--focus:0 0 0 4px rgba(37,99,235,.13);
}
.theme-dark{color-scheme:dark;--bg:#0b1020;--bg-soft:#0f172a;--surface:#111827;--surface-2:#0f172a;--surface-3:#1f2937;--line:#243244;--line-2:#334155;--text:#e5e7eb;--muted:#9ca3af;--muted-2:#64748b;--brand:#60a5fa;--brand-2:#93c5fd;--brand-soft:#12233e;--sidebar:#080d19;--sidebar-2:#0b1120;--sidebar-hover:#111827;--sidebar-active:#1f2937;--shadow:0 18px 50px rgba(0,0,0,.26);--shadow-soft:0 8px 24px rgba(0,0,0,.22)}
*{box-sizing:border-box}html{height:100%;scrollbar-gutter:stable}body{margin:0;min-height:100%;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;background:radial-gradient(circle at top left,rgba(37,99,235,.08),transparent 32rem),var(--bg);color:var(--text);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--brand);text-decoration:none}a:hover{color:var(--brand-2)}::selection{background:rgba(37,99,235,.22)}
.app-shell{display:flex;min-height:100vh}.sidebar{width:292px;background:linear-gradient(180deg,var(--sidebar),var(--sidebar-2));color:#fff;padding:18px 16px;position:fixed;inset:0 auto 0 0;overflow:auto;scrollbar-width:none;-ms-overflow-style:none;display:flex;flex-direction:column;border-right:1px solid rgba(148,163,184,.14);box-shadow:12px 0 40px rgba(2,6,23,.16);transition:width .22s ease,padding .22s ease}.sidebar::-webkit-scrollbar{width:0;height:0}.main{margin-left:292px;width:calc(100% - 292px);min-height:100vh;padding:22px 30px 36px;transition:margin-left .22s ease,width .22s ease}.content-wrap{max-width:1500px;margin:0 auto}.brand{display:flex;align-items:center;gap:12px;margin:2px 0 22px;padding:12px;border-radius:20px;background:rgba(255,255,255,.05);border:1px solid rgba(148,163,184,.18)}.brand img{width:42px;height:42px;flex:0 0 42px;border-radius:14px}.brand strong{display:block;font-size:18px;letter-spacing:-.02em;color:#fff}.brand span{display:block;margin-top:1px;color:#9ca3af;font-size:12px}.sidebar-toggle{position:absolute;right:14px;top:84px;z-index:5;width:30px;height:30px;border:1px solid rgba(148,163,184,.22);border-radius:10px;background:rgba(255,255,255,.06);color:#cbd5e1;cursor:pointer;font-size:20px;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .15s,transform .15s}.sidebar-toggle:hover{background:rgba(96,165,250,.18);color:#fff}.collapse-closed{display:none}.nav-text,.brand div,.user-mini div,.logout-text{transition:opacity .16s ease,transform .16s ease}.is-nav-collapsed .sidebar{width:86px;padding-left:12px;padding-right:12px}.is-nav-collapsed .main{margin-left:86px;width:calc(100% - 86px)}.is-nav-collapsed .brand{justify-content:center;padding:10px;margin-bottom:18px}.is-nav-collapsed .brand div,.is-nav-collapsed .nav-title,.is-nav-collapsed .nav-text,.is-nav-collapsed .user-mini div,.is-nav-collapsed .logout-text{opacity:0;width:0;height:0;overflow:hidden;position:absolute;pointer-events:none}.is-nav-collapsed .sidebar a{justify-content:center;gap:0;padding:10px 8px}.is-nav-collapsed .nav-ico{margin:0}.is-nav-collapsed .nav-section{margin:12px 0}.is-nav-collapsed .user-mini{justify-content:center;padding:10px 0 12px}.is-nav-collapsed .logout-link:after{content:'⎋';font-size:16px;color:#fecaca}.is-nav-collapsed .sidebar-toggle{left:50%;right:auto;top:122px;transform:translateX(-50%);background:var(--sidebar-active);box-shadow:0 10px 24px rgba(0,0,0,.25);z-index:5}.is-nav-collapsed .nav-main{padding-top:34px}.is-nav-collapsed .collapse-open{display:none}.is-nav-collapsed .collapse-closed{display:inline}.nav-main{flex:1}.nav-section{margin:18px 0}.nav-title{padding:0 12px 7px;color:#64748b;text-transform:uppercase;letter-spacing:.11em;font-size:11px;font-weight:800}.sidebar a{display:flex;align-items:center;gap:11px;min-height:38px;color:#cbd5e1;padding:9px 11px;border-radius:12px;margin:2px 0;font-weight:650;transition:background .15s,color .15s,transform .15s}.sidebar a:hover{background:var(--sidebar-hover);color:#fff}.sidebar a.active{background:linear-gradient(90deg,rgba(37,99,235,.26),rgba(30,41,59,.84));color:#fff;box-shadow:inset 3px 0 0 #60a5fa}.nav-ico{width:28px;height:28px;display:inline-flex;align-items:center;justify-content:center;border-radius:10px;background:rgba(148,163,184,.10);color:#bfdbfe;font-size:13px;font-weight:900;flex:0 0 28px;box-shadow:inset 0 0 0 1px rgba(148,163,184,.08)}.sidebar-bottom{margin-top:auto;padding-top:16px;border-top:1px solid rgba(148,163,184,.18)}.user-mini{display:flex;align-items:center;gap:10px;padding:10px 8px 14px}.avatar{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:11px;background:#1d4ed8;color:white;font-weight:900}.user-mini strong{display:block;color:#fff;font-size:13px}.user-mini span{display:block;color:#9ca3af;font-size:12px}.logout-link{justify-content:center!important;background:rgba(220,38,38,.18)!important;color:#fecaca!important;border:1px solid rgba(248,113,113,.25);font-weight:850!important}.logout-link:hover{background:#991b1b!important;color:#fff!important}
.topbar{max-width:1500px;margin:0 auto 24px;display:flex;align-items:center;justify-content:space-between;gap:16px}.global-search{height:46px;flex:1;display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.78);backdrop-filter:blur(12px);border:1px solid var(--line);border-radius:16px;padding:0 13px;box-shadow:var(--shadow-soft)}.theme-dark .global-search{background:rgba(17,24,39,.84)}.global-search span{color:var(--muted);font-size:17px}.global-search input{border:0!important;box-shadow:none!important;background:transparent!important;padding:0!important;min-height:42px}.top-actions{display:flex;align-items:center;gap:12px}.icon-btn{width:44px;height:44px;border:1px solid var(--line);background:var(--surface);color:var(--text);border-radius:14px;cursor:pointer;box-shadow:var(--shadow-soft);font-weight:900}.top-user{min-width:160px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:8px 12px;box-shadow:var(--shadow-soft)}.top-user strong{display:block;font-size:13px}.top-user span{display:block;color:var(--muted);font-size:12px}
h1{font-size:32px;line-height:1.12;margin:6px 0 22px;letter-spacing:-.035em}h2{font-size:20px;letter-spacing:-.02em;margin:0 0 14px}h3{font-size:16px;margin:18px 0 10px}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-soft);margin-bottom:18px}.card>h2:first-child,.card>h3:first-child{margin-top:0}.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.grid3{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.tool-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.tool-card{position:relative;overflow:hidden;min-height:170px}.tool-card:before{content:"";position:absolute;right:-40px;top:-40px;width:150px;height:150px;border-radius:50%;background:rgba(37,99,235,.10)}.tool-icon{width:42px;height:42px;border-radius:14px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:900;margin-bottom:14px}.kpi-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:16px}.kpi-card{padding:18px;border-radius:18px;background:var(--surface);border:1px solid var(--line);box-shadow:var(--shadow-soft)}.kpi-card .num{font-size:30px;font-weight:900;letter-spacing:-.04em}.kpi-card .label{color:var(--muted);font-weight:750}
label{display:block;font-weight:780;margin-bottom:7px;color:var(--text)}input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line-2);border-radius:12px;background:var(--surface);color:var(--text);font:inherit;outline:none;transition:border-color .15s,box-shadow .15s,background .15s}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:var(--focus)}textarea{min-height:126px;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace}input[type=checkbox],input[type=radio]{width:auto!important;min-width:16px;height:16px;padding:0;margin:0;box-shadow:none;accent-color:var(--brand)}input[type=number]{appearance:textfield}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:0;background:var(--brand);color:white!important;padding:10px 14px;border-radius:12px;cursor:pointer;font-size:14px;font-weight:800;line-height:1.2;box-shadow:0 10px 22px rgba(37,99,235,.18);transition:transform .12s,box-shadow .12s,background .12s}.btn:hover{background:var(--brand-2);color:white;transform:translateY(-1px)}.btn.secondary{background:#475569;box-shadow:none}.btn.danger{background:var(--danger);box-shadow:0 10px 22px rgba(220,38,38,.16)}.btn.ok{background:var(--ok);box-shadow:0 10px 22px rgba(22,163,74,.16)}.btn.light{background:var(--surface-3);color:var(--text)!important;box-shadow:none;border:1px solid var(--line)}.btn.small,.small{font-size:12px;padding:7px 10px;border-radius:10px}.actions{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px}
.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:16px;background:var(--surface)}table{width:100%;border-collapse:separate;border-spacing:0;background:var(--surface);border:1px solid var(--line);border-radius:16px;overflow:hidden}th,td{padding:12px 13px;border-bottom:1px solid var(--line);text-align:left;vertical-align:middle}th{background:var(--surface-2);font-weight:850;color:var(--text);font-size:12px;text-transform:uppercase;letter-spacing:.045em} .table-wrap th,.target-list th{position:sticky;top:0;z-index:2;backdrop-filter:blur(10px)}tr:last-child td{border-bottom:0}tbody tr:hover td{background:var(--surface-2)}.muted{color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 9px;background:#eef2ff;color:#3730a3;border-radius:999px;font-size:12px;font-weight:800}.theme-dark .badge{background:#1e293b;color:#bfdbfe}.badge.ok{background:#dcfce7;color:#166534}.badge.bad{background:#fee2e2;color:#991b1b}.badge.warn{background:#fef3c7;color:#92400e}.theme-dark .badge.ok{background:#052e16;color:#86efac}.theme-dark .badge.bad{background:#450a0a;color:#fca5a5}.theme-dark .badge.warn{background:#451a03;color:#fcd34d}.searchbar{display:flex;gap:10px;margin-bottom:14px;align-items:center;flex-wrap:wrap}.searchbar input{max-width:460px}.searchbar select{max-width:360px}.login{max-width:430px;margin:80px auto}.qrbox{text-align:center}.qr40{width:40mm;height:40mm}.print-only{display:none}.hidden{display:none!important}
.quick-add-box{background:var(--surface);border:1px dashed var(--line-2);border-radius:18px;padding:18px;margin:12px 0 18px}.quick-add-box h3{margin-top:0}.quick-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.quick-add-box hr{border:0;border-top:1px solid var(--line);margin:16px 0}.dynamic-fields{border-top:1px solid var(--line);margin-top:14px;padding-top:14px}.searchable-select{display:flex;flex-direction:column;gap:7px;min-width:320px;flex:1}.target-list{max-height:440px;overflow:auto;border:1px solid var(--line);border-radius:16px;background:var(--surface)}.target-list table{border:0;border-radius:0}.target-list th{position:sticky;top:0;z-index:1}.check{display:inline-flex!important;gap:10px;align-items:center;margin:8px 16px 8px 0;font-weight:800}.check input{flex:0 0 auto}.ssh-warn{border-left:4px solid var(--warn);padding:16px;background:#fffbeb;border-radius:14px;margin:14px 0}.theme-dark .ssh-warn{background:#27180a}.ssh-warn .grid{align-items:end}.ssh-warn p{margin:0}.ssh-warn label.check{margin:0 0 10px 0;min-height:auto}.progress{height:14px;background:var(--surface-3);border-radius:999px;overflow:hidden;margin:12px 0}.progress>div{height:100%;background:linear-gradient(90deg,var(--brand),#60a5fa);transition:width .3s}
.scan-progress{margin-top:16px;border:1px solid #bfdbfe;background:var(--brand-soft);border-radius:18px;padding:16px}.scan-progress-head{display:flex;justify-content:space-between;gap:12px;margin-bottom:10px}.scan-progress-bar{height:14px;background:#dbeafe;border-radius:999px;overflow:hidden}.theme-dark .scan-progress-bar{background:#1e293b}.scan-progress-bar>div{height:100%;width:0;background:linear-gradient(90deg,var(--brand),#93c5fd);border-radius:999px;transition:width .35s ease}.scan-progress-text{margin-top:10px;color:var(--text)}.scan-progress-steps{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.scan-progress-steps span{display:inline-block;padding:5px 9px;border-radius:999px;background:var(--surface-3);color:var(--muted);font-size:12px}.scan-progress-steps span.active{background:#dbeafe;color:#1d4ed8;font-weight:800}.scan-progress-steps span.done{background:#dcfce7;color:#166534}.scan-results-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.scan-device-card{border:1px solid var(--line);border-radius:18px;background:var(--surface);padding:15px;box-shadow:var(--shadow-soft)}.scan-device-head{display:flex;align-items:flex-start;gap:12px}.scan-device-icon{width:40px;height:40px;border-radius:14px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;font-weight:900;flex:0 0 40px}.scan-device-title{font-size:16px;font-weight:900;letter-spacing:-.02em}.scan-device-meta{color:var(--muted);font-size:13px}.pill-row{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px}.pill{display:inline-flex;align-items:center;padding:4px 8px;border-radius:999px;background:var(--surface-3);color:var(--muted);font-size:12px;font-weight:750}.footer-dev{margin-top:34px;padding:14px 2px;color:var(--muted-2);font-size:12px;text-align:right}.footer-dev a{color:var(--muted)}pre{white-space:pre-wrap;background:#0f172a;color:#e2e8f0;padding:14px;border-radius:14px;overflow:auto;font-size:13px;line-height:1.45}details summary{cursor:pointer;font-weight:800;color:var(--text)}
@media(max-width:1250px){.tool-grid,.scan-results-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.quick-grid{grid-template-columns:1fr 1fr}.grid3{grid-template-columns:1fr 1fr}.main{padding:20px}}
@media(max-width:900px){.sidebar,.is-nav-collapsed .sidebar{position:relative;width:100%;inset:auto}.is-nav-collapsed .brand div,.is-nav-collapsed .nav-title,.is-nav-collapsed .nav-text,.is-nav-collapsed .user-mini div,.is-nav-collapsed .logout-text{opacity:1;width:auto;height:auto;position:static;pointer-events:auto}.is-nav-collapsed .sidebar a{justify-content:flex-start;gap:11px;padding:9px 11px}.is-nav-collapsed .main,.main{margin-left:0;width:100%;padding:14px}.sidebar-toggle{display:none}.app-shell{display:block}.topbar{display:block}.global-search{margin-bottom:12px}.grid,.grid3,.tool-grid,.scan-results-grid,.quick-grid{grid-template-columns:1fr}.searchbar{display:block}.searchbar input,.searchbar select{max-width:none;margin-bottom:8px}h1{font-size:26px}.top-user{display:none}}
@media print{.no-print,.sidebar,.topbar,.footer-dev{display:none!important}.main{margin:0;width:100%;padding:0}.card{box-shadow:none;border:0}.print-only{display:block}body{background:#fff;color:#000}a{color:#000}}

/* v7.1 polish */
.card,.kpi-card,.tool-card,.scan-device-card{transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.card:hover,.kpi-card:hover,.tool-card:hover,.scan-device-card:hover{border-color:rgba(37,99,235,.22);box-shadow:var(--shadow)}.status-dot{width:8px;height:8px;border-radius:99px;display:inline-block;background:var(--muted-2);margin-right:6px}.status-dot.ok{background:var(--ok)}.status-dot.warn{background:var(--warn)}.status-dot.bad{background:var(--danger)}.soft-divider{height:1px;background:var(--line);margin:16px 0}.theme-dark .icon-btn,.theme-dark .top-user,.theme-dark .card,.theme-dark .kpi-card,.theme-dark .tool-card{box-shadow:0 14px 34px rgba(0,0,0,.24)}


/* v7.1.2: collapsed-sidebar tooltips and sortable tables */
.is-nav-collapsed .nav-main a{position:relative;}
.is-nav-collapsed .nav-main a::after{
  content:attr(data-tooltip);
  position:absolute;
  left:calc(100% + 12px);
  top:50%;
  transform:translateY(-50%) translateX(-4px);
  background:#0f172a;
  color:#fff;
  border:1px solid rgba(148,163,184,.22);
  box-shadow:0 12px 30px rgba(2,6,23,.22);
  padding:8px 10px;
  border-radius:10px;
  font-size:13px;
  line-height:1.2;
  white-space:nowrap;
  opacity:0;
  pointer-events:none;
  transition:opacity .14s ease,transform .14s ease;
  z-index:5000;
}
.is-nav-collapsed .nav-main a::before{
  content:"";
  position:absolute;
  left:calc(100% + 6px);
  top:50%;
  transform:translateY(-50%);
  border:6px solid transparent;
  border-right-color:#0f172a;
  opacity:0;
  transition:opacity .14s ease;
  z-index:5001;
}
.is-nav-collapsed .nav-main a:hover::after,
.is-nav-collapsed .nav-main a:focus-visible::after,
.is-nav-collapsed .nav-main a:hover::before,
.is-nav-collapsed .nav-main a:focus-visible::before{opacity:1;transform:translateY(-50%) translateX(0);}
.sortable-th{cursor:pointer;user-select:none;position:relative;padding-right:28px!important;}
.sortable-th::after{content:"⇅";position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--muted-2);opacity:.65;}
.sortable-th.sort-asc::after{content:"↑";color:var(--brand);opacity:1;}
.sortable-th.sort-desc::after{content:"↓";color:var(--brand);opacity:1;}
.sortable-th:hover{background:var(--surface-3);}
.theme-dark .is-nav-collapsed .nav-main a::after{background:#111827;border-color:#334155;}
.theme-dark .is-nav-collapsed .nav-main a::before{border-right-color:#111827;}


/* v7.1.3: sidebar toggle fixed and backup UI */
.sidebar{overflow-x:visible;}
.brand{position:relative;padding-right:48px;min-height:70px;}
.sidebar-toggle{
  top:42px!important;
  right:28px!important;
  transform:translateY(-50%)!important;
  width:32px;height:32px;
  background:rgba(255,255,255,.08);
}
.sidebar-toggle:hover{transform:translateY(-50%) scale(1.04)!important;}
.is-nav-collapsed .brand{padding:10px!important;min-height:64px;margin-bottom:8px;}
.is-nav-collapsed .sidebar-toggle{
  position:relative!important;
  left:auto!important;right:auto!important;top:auto!important;
  transform:none!important;
  margin:0 auto 14px!important;
  display:flex!important;
}
.is-nav-collapsed .sidebar-toggle:hover{transform:scale(1.04)!important;}
.is-nav-collapsed .nav-main{padding-top:0!important;}
.backup-list code{font-size:12px;color:var(--muted)}
.backup-actions{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
.backup-upload{border:1px dashed var(--line-2);border-radius:16px;padding:16px;background:var(--surface-2)}

/* v7.1.4: bulk QR printing */
.qr-bulk-form .grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));align-items:end}
.qr-options{display:flex;gap:16px;flex-wrap:wrap;margin:16px 0 4px;color:var(--muted)}
.qr-options label{display:flex;gap:8px;align-items:center;background:var(--surface-2);border:1px solid var(--line);padding:10px 12px;border-radius:12px}
.qr-print-toolbar{display:flex;gap:12px;align-items:center;margin:0 0 18px}
.qr-sheet{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px;align-items:start}
.qr-sticker{display:flex;gap:10px;align-items:center;min-height:96px;padding:10px;border:1px solid #d8dee9;border-radius:12px;background:#fff;color:#0f172a;break-inside:avoid;page-break-inside:avoid}
.qr-sticker img{width:76px;height:76px;object-fit:contain;flex:0 0 auto}
.qr-sticker-text{min-width:0;display:flex;flex-direction:column;gap:2px;line-height:1.15}
.qr-sticker-text strong{font-size:14px;color:#0f172a}
.qr-sticker-text span{font-size:13px;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
.qr-sticker-text em{font-size:11px;font-style:normal;color:#64748b;text-transform:uppercase;letter-spacing:.04em}
.qr-sticker-text small{font-size:10px;color:#64748b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}
@media print{
  @page{size:A4;margin:8mm}
  body{background:#fff!important;color:#000!important}
  .app-shell,.main,.content-wrap{display:block!important;margin:0!important;padding:0!important;background:#fff!important;box-shadow:none!important}
  .sidebar,.topbar,.footer-dev,.no-print{display:none!important}
  .qr-sheet{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:5mm!important;width:100%!important}
  .qr-sticker{border:1px solid #888!important;border-radius:4mm!important;min-height:29mm!important;padding:3mm!important;background:#fff!important;color:#000!important;box-shadow:none!important}
  .qr-sticker img{width:21mm!important;height:21mm!important}
  .qr-sticker-text strong{font-size:10pt!important;color:#000!important}
  .qr-sticker-text span{font-size:9pt!important;color:#000!important;max-width:42mm!important}
  .qr-sticker-text em,.qr-sticker-text small{font-size:7pt!important;color:#333!important;max-width:42mm!important}
}
.progress-wrap{margin:12px 0 16px}.progress{height:10px;background:var(--border,#e5e7eb);border-radius:999px;overflow:hidden}.progress>div{height:100%;background:var(--accent,#2563eb);border-radius:999px;transition:width .25s ease}.logbox{max-height:420px;overflow:auto;background:var(--code-bg,#0f172a);color:#d1d5db;padding:14px;border-radius:12px;white-space:pre-wrap;font-size:12px}.dark .logbox{background:#020617;color:#cbd5e1}
.scan-device-card.scan-known{opacity:.78;border-style:dashed}
.scan-device-card.scan-known .scan-device-title{color:var(--muted)}

/* v7.3: built-in knowledge base */
.docs-shell{display:grid;grid-template-columns:320px minmax(0,1fr);gap:18px;align-items:start}
.docs-nav{position:sticky;top:18px;max-height:calc(100vh - 130px);overflow:auto;scrollbar-width:thin}
.docs-search{display:flex;gap:8px;margin-bottom:16px}
.docs-search input{min-width:0}
.docs-group{margin:14px 0 18px}
.docs-group-title{font-size:11px;text-transform:uppercase;letter-spacing:.11em;color:var(--muted);font-weight:900;margin:0 0 8px;padding:0 4px}
.docs-link{display:block;padding:9px 10px;border-radius:11px;color:var(--text);font-weight:720;margin:2px 0;border:1px solid transparent}
.docs-link:hover{background:var(--surface-3);color:var(--brand)}
.docs-link.active{background:var(--brand-soft);border-color:rgba(37,99,235,.20);color:var(--brand)}
.docs-article{padding:28px;max-width:980px}
.docs-breadcrumb{color:var(--muted);font-size:13px;font-weight:750;margin-bottom:8px}
.docs-content h2{font-size:24px;margin:8px 0 12px;letter-spacing:-.03em}
.docs-content h3{font-size:17px;margin:22px 0 8px}
.docs-content p,.docs-content li{font-size:15px;color:var(--text)}
.docs-content ul,.docs-content ol{padding-left:24px}
.docs-content code{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono",monospace;background:var(--surface-3);border:1px solid var(--line);padding:2px 6px;border-radius:7px;color:var(--text)}
.doc-callout{border-left:4px solid var(--brand);background:var(--brand-soft);padding:12px 14px;border-radius:12px;margin:16px 0;color:var(--text);font-weight:650}
.doc-callout.warn{border-left-color:var(--warn);background:#fffbeb;color:#713f12}.theme-dark .doc-callout.warn{background:#33260a;color:#fde68a}
@media(max-width:980px){.docs-shell{grid-template-columns:1fr}.docs-nav{position:static;max-height:none}.docs-article{padding:20px}}

/* v7.3.3 full docs rebuild: make instruction menu readable even with cached/global link styles */
.docs-nav .docs-group{display:block;margin:16px 0 20px!important;padding:0!important;clear:both}
.docs-nav .docs-group-title{display:block;margin:0 0 8px!important;line-height:1.2!important}
.docs-nav .docs-link-list{display:flex!important;flex-direction:column!important;gap:6px!important;align-items:stretch!important}
.docs-nav .docs-link-row{display:block!important;width:100%!important;clear:both!important}
.docs-nav a.docs-link{display:block!important;width:100%!important;box-sizing:border-box!important;white-space:normal!important;line-height:1.35!important;text-decoration:none!important;padding:9px 10px!important;margin:0!important}
.docs-content h2{border-top:1px solid var(--line);padding-top:18px;margin-top:24px}
.docs-content h2:first-child{border-top:0;padding-top:0;margin-top:0}
.docs-content h3{margin-top:22px!important}
.docs-content li{margin:4px 0}


/* v7.4.2: login redesign and bulk equipment actions */
.login-page{min-height:100vh;background:radial-gradient(circle at 15% 10%,rgba(37,99,235,.20),transparent 32%),radial-gradient(circle at 80% 20%,rgba(14,165,233,.16),transparent 30%),linear-gradient(135deg,#0f172a,#111827 42%,#020617);display:flex;align-items:center;justify-content:center;padding:32px;color:#e5e7eb}.login-shell{width:min(1080px,100%);display:grid;grid-template-columns:minmax(0,1.05fr) 430px;gap:28px;align-items:stretch}.login-hero{position:relative;overflow:hidden;border:1px solid rgba(148,163,184,.20);border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.10),rgba(255,255,255,.04));box-shadow:0 26px 80px rgba(0,0,0,.34);padding:44px;min-height:520px;display:flex;flex-direction:column;justify-content:space-between}.login-hero:before{content:"";position:absolute;inset:auto -80px -130px auto;width:360px;height:360px;border-radius:50%;background:rgba(37,99,235,.22);filter:blur(6px)}.login-logo-mark{width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#38bdf8);display:flex;align-items:center;justify-content:center;font-weight:950;letter-spacing:-.08em;color:white;box-shadow:0 18px 40px rgba(37,99,235,.36)}.login-hero h1{font-size:54px;letter-spacing:-.07em;margin:28px 0 12px;color:#fff}.login-hero p{font-size:17px;line-height:1.7;color:#cbd5e1;max-width:640px}.login-feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:28px;max-width:520px}.login-feature-grid span{border:1px solid rgba(148,163,184,.18);background:rgba(15,23,42,.38);border-radius:14px;padding:12px 14px;color:#e5e7eb;font-weight:750}.login-credit{margin:34px 0 0!important;font-size:13px!important;color:#94a3b8!important}.login-credit a{color:#bfdbfe;text-decoration:none;font-weight:800}.login-card{border:1px solid rgba(226,232,240,.18);border-radius:28px;background:rgba(255,255,255,.96);color:#0f172a;box-shadow:0 26px 80px rgba(0,0,0,.32);padding:34px;align-self:center}.login-card h2{font-size:30px;letter-spacing:-.05em;margin:0 0 8px;color:#0f172a}.login-card p{color:#64748b;margin:0 0 24px}.login-form label{font-weight:850;font-size:13px;color:#334155;margin:16px 0 7px;display:block}.login-form input{height:48px;border-radius:14px;border:1px solid #dbe3ef;background:#f8fafc;color:#0f172a;padding:0 14px;font-size:15px;outline:none}.login-form input:focus{border-color:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,.12);background:#fff}.login-submit{width:100%;height:48px;margin-top:22px;border-radius:14px;font-size:15px}.login-error{border:1px solid #fecaca;background:#fef2f2;color:#991b1b;border-radius:14px;padding:12px 14px;margin:14px 0;font-weight:750}.login-card-foot{margin-top:18px;text-align:center}.login-card-foot a{color:#2563eb;font-weight:800;text-decoration:none}.bulk-panel{margin-bottom:14px}.bulk-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.bulk-actions select,.bulk-actions input{max-width:280px}.btn.small{padding:6px 10px;font-size:12px;border-radius:10px}@media(max-width:900px){.login-shell{grid-template-columns:1fr}.login-hero{min-height:0}.login-hero h1{font-size:42px}.login-card{align-self:stretch}.login-feature-grid{grid-template-columns:1fr}}
.timeline-item{border-left:3px solid #d0d7de;padding:8px 12px;margin:10px 0;background:#fff;border-radius:10px}
.timeline-item p{margin:6px 0}


.employee-card-head{display:flex;gap:18px;align-items:flex-start}
.employee-avatar,.employee-avatar-sm,.employee-avatar-lg,.employee-avatar-xl{object-fit:cover;border-radius:50%;background:#eef2f7;display:inline-flex;align-items:center;justify-content:center;font-weight:700;color:#334155;flex:0 0 auto}
.employee-avatar{width:48px;height:48px}.employee-avatar-sm{width:36px;height:36px}.employee-avatar-lg{width:96px;height:96px;font-size:28px}.employee-avatar-xl{width:128px;height:128px;font-size:36px}
.employee-avatar-fallback{border:1px solid rgba(148,163,184,.45)}
.click-row td{vertical-align:middle}
@media(max-width:700px){.employee-card-head{display:block}.employee-avatar-lg,.employee-avatar-xl{margin-bottom:12px}}
.badge.vacation{background:#dbeafe;color:#1d4ed8}.badge.sick{background:#fee2e2;color:#991b1b}.badge.maternity{background:#fce7f3;color:#9d174d}.badge.away{background:#e5e7eb;color:#374151}.theme-dark .badge.vacation{background:#0f172a;color:#93c5fd}.theme-dark .badge.sick{background:#450a0a;color:#fca5a5}.theme-dark .badge.maternity{background:#500724;color:#f9a8d4}.theme-dark .badge.away{background:#374151;color:#e5e7eb}
