:root{
  color-scheme:light;
  --bg:#eef3fb;
  --bg-2:#f8fbff;
  --panel:#ffffff;
  --panel-soft:#f7f9fd;
  --ink:#0b172a;
  --muted:#6c788e;
  --line:#e1e7f1;
  --line-strong:#cdd7e8;
  --accent:#3167ff;
  --accent-2:#6a4cff;
  --accent-soft:#eaf0ff;
  --navy:#0b1324;
  --navy-2:#111c33;
  --ok:#09874c;
  --ok-soft:#e9f9ef;
  --warn:#a86600;
  --warn-soft:#fff6dd;
  --danger:#b3261e;
  --danger-soft:#fff1f0;
  --shadow:0 22px 60px rgba(15,30,60,.11);
  --shadow-soft:0 12px 36px rgba(15,30,60,.08);
  --radius:20px;
}
*{box-sizing:border-box}
html{min-height:100%;background:var(--bg)}
body{margin:0;min-height:100vh;background:radial-gradient(circle at 10% -10%,#dfe8ff 0,#f7faff 32%,#eef3fb 72%),var(--bg);color:var(--ink);font-family:Inter,ui-sans-serif,system-ui,-apple-system,Segoe UI,Arial,sans-serif;font-size:14px;line-height:1.45}
a{color:var(--accent);text-decoration:none;font-weight:750}a:hover{text-decoration:none;color:#1747d6}
h1,h2,h3{letter-spacing:-.03em;color:#071225}h1{font-size:19px;margin:0}h2{font-size:25px;margin:0 0 16px}h3{font-size:17px;margin:0 0 12px}.muted{color:var(--muted);margin:.35rem 0}.eyebrow{text-transform:uppercase;letter-spacing:.13em;font-size:11px;font-weight:900;color:#7790bb}
.app-shell{display:grid;grid-template-columns:284px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;height:100vh;overflow:auto;background:linear-gradient(180deg,var(--navy),#0a1020 58%,#09101d);color:#eaf0ff;padding:22px 18px;box-shadow:18px 0 55px rgba(8,16,31,.17);z-index:20}.brand-block{display:flex;gap:13px;align-items:center;margin-bottom:24px;padding:6px 4px 18px;border-bottom:1px solid rgba(255,255,255,.10)}.brand-mark{width:46px;height:46px;border-radius:17px;display:grid;place-items:center;background:linear-gradient(135deg,#4f7bff,#8d5dff);color:#fff;font-weight:1000;letter-spacing:-.08em;box-shadow:0 16px 34px rgba(49,103,255,.35)}.brand-block h1{font-size:18px;color:#fff}.brand-block p{margin:3px 0 0;color:#aebbd4;font-size:12px;font-weight:700}.side-nav{display:grid;gap:7px}.side-nav a{display:flex;align-items:center;gap:11px;border-radius:15px;padding:11px 12px;color:#bdc9df;font-weight:850;transition:background .15s,transform .15s,color .15s}.side-nav a:hover{background:rgba(255,255,255,.08);color:#fff;transform:translateX(2px)}.side-nav a.active{background:linear-gradient(135deg,rgba(49,103,255,.95),rgba(106,76,255,.92));color:#fff;box-shadow:0 14px 30px rgba(49,103,255,.25)}.nav-icon{width:26px;height:26px;border-radius:10px;display:grid;place-items:center;background:rgba(255,255,255,.09);font-weight:1000}.side-nav a.active .nav-icon{background:rgba(255,255,255,.18)}.side-footer{margin-top:24px;border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:13px;display:flex;gap:10px;align-items:flex-start;background:rgba(255,255,255,.06)}.side-footer strong{display:block;color:#fff}.side-footer small{display:block;color:#aebbd4;margin-top:2px}.status-dot{width:10px;height:10px;border-radius:999px;background:#36d17f;margin-top:5px;box-shadow:0 0 0 6px rgba(54,209,127,.13),0 0 26px rgba(54,209,127,.75)}
.workspace{min-width:0}.topbar{position:sticky;top:0;z-index:15;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:18px 26px;background:rgba(248,251,255,.86);border-bottom:1px solid rgba(205,215,232,.7);backdrop-filter:blur(18px)}.topbar .page-title h2{margin:0;font-size:20px}.menu-toggle{display:none;width:42px;height:42px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--ink);font-weight:900;box-shadow:var(--shadow-soft)}.user-chip{display:flex;align-items:center;gap:10px;border:1px solid var(--line);background:#fff;border-radius:999px;padding:7px 8px 7px 7px;box-shadow:0 10px 30px rgba(15,30,60,.07)}.avatar{width:34px;height:34px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,#13284e,#3167ff);color:#fff;font-weight:1000}.user-chip strong{display:block;font-size:13px}.user-chip small{display:block;color:var(--muted);font-weight:750;text-transform:capitalize}.logout-link{margin-left:4px;background:#f0f4fb;color:#2b3851;border-radius:999px;padding:8px 11px;font-size:12px}.page{padding:26px;max-width:1680px;margin:auto}.foot{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;color:var(--muted);padding:20px 26px 28px}.foot span{background:rgba(255,255,255,.65);border:1px solid var(--line);border-radius:999px;padding:7px 11px;font-size:12px;font-weight:800}.flash,.alert,.success{max-width:calc(1680px - 52px);margin:16px 26px 0;padding:13px 16px;border-radius:16px;border:1px solid;font-weight:760}.alert{background:var(--danger-soft);color:var(--danger);border-color:#ffd3cf}.success,.flash{background:var(--ok-soft);color:var(--ok);border-color:#bfe9cf}
section,.panel,.card,.login{background:rgba(255,255,255,.93);border:1px solid rgba(205,215,232,.82);border-radius:var(--radius);box-shadow:var(--shadow-soft);margin-bottom:20px}.panel,section{padding:20px}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(210px,1fr));gap:16px;margin-bottom:20px}.cards.compact{grid-template-columns:repeat(4,minmax(0,1fr))}.card{position:relative;overflow:hidden;padding:18px;min-height:110px}.card:before{content:"";position:absolute;inset:auto -30px -60px auto;width:130px;height:130px;border-radius:999px;background:linear-gradient(135deg,rgba(49,103,255,.16),rgba(106,76,255,.08))}.card b{display:block;font-size:34px;line-height:1;font-weight:1000;letter-spacing:-.06em}.card span{display:block;color:var(--muted);font-weight:850;margin-top:10px}.card small{display:block;color:#8a98ae;font-weight:750;margin-top:4px}.metric-card{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.metric-icon{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:var(--accent-soft);color:#224fd7;font-weight:1000}.hero{position:relative;overflow:hidden;padding:0;background:linear-gradient(135deg,#0c1730,#102450 52%,#213b8e);color:#eef4ff;border:0;box-shadow:0 24px 70px rgba(13,32,78,.22)}.hero:before{content:"";position:absolute;inset:-120px -80px auto auto;width:360px;height:360px;border-radius:50%;background:radial-gradient(circle,rgba(110,138,255,.55),rgba(110,138,255,0) 65%)}.hero:after{content:"";position:absolute;inset:auto auto -150px -80px;width:320px;height:320px;border-radius:50%;background:radial-gradient(circle,rgba(53,209,127,.22),rgba(53,209,127,0) 70%)}.hero-inner{position:relative;display:grid;grid-template-columns:minmax(0,1fr) 340px;gap:24px;align-items:stretch;padding:25px}.hero h2{color:#fff;font-size:30px;margin:4px 0 8px}.hero p{color:#cdd8f2;max-width:760px}.hero-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.hero-card{background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.16);border-radius:22px;padding:18px;backdrop-filter:blur(14px)}.hero-card strong{display:block;font-size:16px;color:#fff}.hero-card code{display:block;margin-top:8px;color:#dce6ff}.health-list{display:grid;gap:10px;margin:14px 0 0}.health-item{display:flex;align-items:center;justify-content:space-between;gap:10px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);border-radius:14px;padding:10px 12px}.health-item span{color:#cdd8f2}.health-item b{color:#fff}.two-col{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(320px,.85fr);gap:18px;align-items:start}.mini-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.mini-stat{background:var(--panel-soft);border:1px solid var(--line);border-radius:16px;padding:14px}.mini-stat b{font-size:23px;display:block;letter-spacing:-.04em}.mini-stat span{display:block;color:var(--muted);font-weight:800;margin-top:2px}.steps{counter-reset:steps;display:grid;gap:10px;margin-top:12px}.step{counter-increment:steps;display:flex;gap:12px;padding:12px;border-radius:16px;background:var(--panel-soft);border:1px solid var(--line)}.step:before{content:counter(steps);width:28px;height:28px;display:grid;place-items:center;flex:0 0 auto;border-radius:10px;background:#111c33;color:#fff;font-weight:1000}.step strong{display:block}.step span{display:block;color:var(--muted);font-size:12px;margin-top:2px}.table-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:12px}.table-head h2,.table-head h3{margin:0}.table-actions{display:flex;gap:8px;flex-wrap:wrap}.table-wrap{overflow:auto;border:1px solid var(--line);border-radius:17px;background:#fff;box-shadow:0 8px 20px rgba(15,30,60,.04)}table{width:100%;border-collapse:separate;border-spacing:0;min-width:900px}th,td{border-bottom:1px solid var(--line);padding:12px 13px;text-align:left;vertical-align:top}th{position:sticky;top:0;background:#f4f7fc;color:#53627b;font-size:11px;text-transform:uppercase;letter-spacing:.08em;font-weight:1000;z-index:1}tr:last-child td{border-bottom:0}tr:hover td{background:#fbfdff}.empty-row td{text-align:center;color:var(--muted);font-weight:800;padding:28px}.row-title{font-weight:1000;color:#071225}.nowrap{white-space:nowrap}.device-online{color:var(--ok);font-weight:900}.device-offline{color:var(--warn);font-weight:900}.pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:1000;background:#eef1f7;color:#40506d}.pill:before{content:"";width:6px;height:6px;border-radius:999px;background:currentColor}.pill.present,.pill.active,.pill.done{background:var(--ok-soft);color:var(--ok)}.pill.absent,.pill.failed,.pill.disabled{background:var(--danger-soft);color:var(--danger)}.pill.missing_punch,.pill.pending,.pill.sent{background:var(--warn-soft);color:var(--warn)}.pill.weekend,.pill.holiday{background:var(--accent-soft);color:#224fd7}pre,code{white-space:pre-wrap;word-break:break-word;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:12px}.split{display:grid;grid-template-columns:minmax(0,1fr) minmax(330px,470px);gap:18px;align-items:start}.filter,.calc-bar{display:flex;flex-wrap:wrap;gap:10px;align-items:end;margin-bottom:14px}.filter input,.calc-bar input,.filter select{width:auto;min-width:170px}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.grid-form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.grid-form button{grid-column:1/-1}label{display:block;margin:10px 0;font-weight:850;color:#1b2a44}input,select,textarea{width:100%;padding:11px 12px;border:1px solid var(--line-strong);border-radius:13px;background:#fff;color:var(--ink);font:inherit;margin-top:6px;outline:0;transition:border-color .15s,box-shadow .15s}input:focus,select:focus,textarea:focus{border-color:#7b9bff;box-shadow:0 0 0 4px rgba(49,103,255,.12)}textarea{resize:vertical}.check{display:flex;align-items:center;gap:9px;font-weight:760}.check input{width:auto;margin:0}.button,button{border:0;border-radius:13px;background:linear-gradient(135deg,var(--accent),var(--accent-2));color:#fff;text-decoration:none;padding:11px 14px;font-weight:950;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 14px 26px rgba(49,103,255,.18)}button.is-busy{opacity:.75;pointer-events:none}.button.ghost{background:#eef2f8;color:#1c2b44;box-shadow:none}.button:hover,button:hover{filter:brightness(.98);transform:translateY(-1px)}fieldset{border:1px solid var(--line);border-radius:16px;margin:12px 0;padding:11px 13px;background:#fbfcff}legend{font-weight:1000;color:#53627b}.device-map{display:grid;grid-template-columns:minmax(220px,1fr) minmax(130px,200px);gap:10px;align-items:center;border-bottom:1px dashed var(--line);padding:9px 0}.device-map:last-child{border-bottom:0}.codebox{min-height:230px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}.login{max-width:445px;margin:8vh auto;padding:30px;background:rgba(255,255,255,.92);box-shadow:var(--shadow);position:relative;overflow:hidden}.login:before{content:"";position:absolute;inset:-120px -100px auto auto;width:260px;height:260px;border-radius:50%;background:radial-gradient(circle,rgba(49,103,255,.18),rgba(49,103,255,0) 68%)}.login h1{font-size:28px;margin-bottom:18px}.login form,.login h1,.login p,.login .alert{position:relative}.login.wide{max-width:850px}.connection-strip{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.connection-strip .mini-stat{background:rgba(255,255,255,.9)}
@media(max-width:1100px){.app-shell{grid-template-columns:1fr}.sidebar{position:fixed;inset:0 auto 0 0;width:286px;transform:translateX(-105%);transition:transform .2s ease}.sidebar.open{transform:translateX(0)}.menu-toggle{display:grid;place-items:center}.topbar{padding:14px 16px}.page{padding:16px}.hero-inner,.two-col,.split{grid-template-columns:1fr}.user-chip{margin-left:auto}.flash,.alert,.success{margin-left:16px;margin-right:16px}.cards.compact{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:720px){body{font-size:13px}.page-title .eyebrow{display:none}.topbar .page-title h2{font-size:16px}.user-chip div{display:none}.logout-link{display:none}.cards,.cards.compact,.mini-grid,.connection-strip,.grid-form,.form-row,.device-map{grid-template-columns:1fr}.filter input,.filter select,.calc-bar input{width:100%;min-width:0}.hero-inner{padding:18px}.hero h2{font-size:24px}.panel,section{padding:15px}.login{margin:4vh 12px}table{min-width:760px}.foot{padding-bottom:20px}}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto!important}}
.login-screen{display:grid;place-items:center;padding:20px}.login-brand{border-bottom:1px solid var(--line);margin-bottom:18px;padding:0 0 16px}.login-brand h1{color:var(--ink);font-size:23px}.login-brand p{color:var(--muted)}
.login .alert{margin:10px 0 16px;max-width:none}.login button{width:100%}
/* V3.2 layout hardening: cache-busted shell, readable fallback, no icon-font dependency */
body.zk-app{overflow-x:hidden}
body.zk-app .sidebar-backdrop{display:none;position:fixed;inset:0;background:rgba(8,16,31,.38);z-index:18}
body.zk-app .sidebar.open + .sidebar-backdrop{display:block}
body.zk-app .nav-icon{font-size:10px;letter-spacing:.04em;font-family:inherit}
body.zk-app .menu-toggle{font-size:12px;width:auto;min-width:56px;padding:0 12px}
body.zk-app .topbar{background:rgba(248,251,255,.92)!important;color:var(--ink)!important}
body.zk-app .brand-block a, body.zk-app .side-nav a{color:inherit}
body.zk-app .card b + span, body.zk-app .metric-card b + span{margin-top:7px}
body.zk-app .hero-actions a{white-space:nowrap}
@media(max-width:1100px){body.zk-app .sidebar.open + .sidebar-backdrop{display:block}body.zk-app .workspace{min-height:100vh}}
@media(min-width:1101px){body.zk-app .sidebar-backdrop{display:none!important}}

/* V4 company hierarchy + modal register UI */
.page-hero{display:flex;align-items:flex-start;justify-content:space-between;gap:18px;background:linear-gradient(135deg,rgba(255,255,255,.96),rgba(244,248,255,.92));}
.page-hero h2{margin-bottom:8px}.actions{display:flex;gap:8px;flex-wrap:wrap}.link-button{border:0;background:#eef2f8;color:#224fd7;border-radius:999px;padding:7px 11px;font-weight:950;box-shadow:none;cursor:pointer}.link-button:hover{background:#e3ebff}.permission-pills{display:flex;gap:6px;flex-wrap:wrap}.permission-pills span{display:inline-flex;border-radius:999px;padding:4px 8px;background:var(--accent-soft);color:#224fd7;font-weight:900;font-size:12px}.check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px}.modal{position:fixed;inset:0;display:none;align-items:center;justify-content:center;background:rgba(8,16,31,.52);z-index:80;padding:20px;backdrop-filter:blur(8px)}.modal[aria-hidden="false"]{display:flex}.modal-card{width:min(720px,96vw);max-height:92vh;overflow:auto;background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:0 34px 90px rgba(8,16,31,.3);padding:22px}.modal-card.wide{width:min(980px,96vw)}.modal-head{display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:12px}.modal-head h3{margin:0;font-size:22px}.modal-close{width:38px;height:38px;border-radius:50%;background:#eef2f8;color:#1c2b44;box-shadow:none;font-size:22px;line-height:1;padding:0}.modal-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:14px}.modal-open{overflow:hidden}.detail-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.detail-grid div,.detail-note{border:1px solid var(--line);border-radius:16px;background:var(--panel-soft);padding:13px}.detail-grid span{display:block;color:var(--muted);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em}.detail-grid b{display:block;margin-top:4px;word-break:break-word}.detail-note{margin-top:12px;color:#1c2b44;min-height:54px}.is-hidden-by-company{display:none!important}.modal .device-map{grid-template-columns:minmax(240px,1fr) minmax(150px,220px)}.modal fieldset{max-height:300px;overflow:auto}.modal .check{margin:6px 0}@media(max-width:720px){.page-hero{display:block}.page-hero .button{margin-top:12px}.check-grid,.detail-grid,.modal .device-map{grid-template-columns:1fr}.modal{padding:10px}.modal-card{padding:16px;border-radius:18px}}


.button.danger,.link-button.danger{background:#ef4444;color:#fff;border-color:#ef4444}.link-button.danger{background:transparent;color:#b91c1c}.danger-card{border-color:#fecaca}.danger-copy{background:#fff1f2;border:1px solid #fecdd3;color:#9f1239;padding:12px 14px;border-radius:14px}.delete-target{display:grid;gap:4px;background:#f8fafc;border:1px solid #dbe5f4;border-radius:14px;padding:12px 14px;margin:12px 0}.delete-target span{font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#64748b}.actions form{display:inline}.permission-pills span,.perm-pill{display:inline-flex;align-items:center;border-radius:999px;background:#eef2ff;color:#3730a3;padding:3px 8px;font-size:12px;margin:2px}.perm-row{display:grid;grid-template-columns:minmax(180px,1fr) 110px;gap:10px;align-items:center;border:1px solid #dbe5f4;border-radius:12px;padding:9px 10px;background:#f8fafc}.perm-row label{margin:0}.perm-row select{height:34px;padding:4px 8px}.permission-matrix{display:grid;gap:10px}.permission-section-title{font-weight:800;margin:14px 0 8px;color:#334155}.is-hidden-by-company{display:none!important}
