:root{--bg:#eef4ff;--card:#fff;--text:#0f172a;--muted:#64748b;--line:#dbeafe;--primary:#2563eb;--primary2:#7c3aed;--success:#16a34a;--danger:#dc2626;--warning:#f59e0b;--dark:#172033;--shadow:0 18px 45px rgba(15,23,42,.10);--radius:22px}
*{box-sizing:border-box}body{margin:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:radial-gradient(circle at top left,#dbeafe 0,#eef4ff 35%,#f8fafc 100%);color:var(--text);font-size:14px}a{text-decoration:none;color:inherit}.app-shell{display:flex;min-height:100vh}.sidebar{position:fixed;inset:0 auto 0 0;width:286px;background:linear-gradient(180deg,#0f172a,#1e3a8a 55%,#312e81);color:#fff;padding:18px;z-index:20;overflow:auto;transition:.25s}.brand{display:flex;gap:12px;align-items:center;padding:12px;border-radius:18px;background:rgba(255,255,255,.10);margin-bottom:16px}.brand-logo{width:48px;height:48px;border-radius:16px;background:#fff;color:#1d4ed8;display:grid;place-items:center;font-weight:900;overflow:hidden}.brand-logo img{width:100%;height:100%;object-fit:contain}.brand b{display:block;font-size:14px}.brand span{display:block;color:#cbd5e1;font-size:12px}.nav-menu{display:grid;gap:7px}.nav-menu a{padding:11px 12px;border-radius:14px;color:#e5edff;font-weight:700;font-size:13px}.nav-menu a:hover,.nav-menu a.active{background:rgba(255,255,255,.16);color:#fff}.main-content{margin-left:286px;width:calc(100% - 286px);min-height:100vh}.topbar{position:sticky;top:0;z-index:10;background:rgba(255,255,255,.78);backdrop-filter:blur(16px);display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 22px;border-bottom:1px solid rgba(148,163,184,.25)}.hamburger{display:none;border:0;background:var(--primary);color:#fff;width:42px;height:42px;border-radius:13px;font-size:22px}.top-title b{display:block;font-size:17px}.top-title span{font-size:12px;color:var(--muted)}.top-actions{display:flex;align-items:center;gap:12px}.notif{position:relative;width:42px;height:42px;border-radius:14px;background:#fff;display:grid;place-items:center;box-shadow:0 8px 20px rgba(15,23,42,.06)}.notif em{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;border-radius:999px;font-style:normal;font-size:10px;padding:2px 6px}.user-chip{display:flex;gap:8px;align-items:center;background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 11px;box-shadow:0 8px 20px rgba(15,23,42,.06)}.user-chip span{max-width:150px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-chip b{font-size:10px;background:#dbeafe;color:#1d4ed8;padding:4px 8px;border-radius:999px}.content-wrap{padding:22px;max-width:1450px;margin:0 auto}.hero-card{position:relative;overflow:hidden;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-radius:28px;padding:26px;box-shadow:var(--shadow);display:flex;justify-content:space-between;gap:18px;align-items:center}.hero-card h1{margin:6px 0;font-size:31px;line-height:1.08}.hero-card p{max-width:750px;margin:0;color:#e0e7ff}.eyebrow{text-transform:uppercase;letter-spacing:.12em;font-weight:900;font-size:11px;color:#bfdbfe}.hero-actions{display:flex;flex-wrap:wrap;gap:10px}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin:16px 0}.stat-card{background:#fff;border:1px solid var(--line);border-radius:22px;padding:18px;box-shadow:0 12px 24px rgba(15,23,42,.05)}.stat-card span{display:block;color:var(--muted);font-weight:800;font-size:12px}.stat-card b{display:block;font-size:24px;margin:5px 0}.stat-card small{color:var(--muted)}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:16px}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.card{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:18px;margin:16px 0;box-shadow:0 12px 28px rgba(15,23,42,.06)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.card-head h2,.card-head h3{margin:0}.card-head span{color:var(--muted);font-size:12px}.btn{border:0;border-radius:14px;padding:11px 14px;background:#eef2ff;color:#1e40af;font-weight:900;display:inline-flex;align-items:center;gap:8px;cursor:pointer;justify-content:center}.btn.primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}.btn.success{background:var(--success);color:#fff}.btn.danger{background:var(--danger);color:#fff}.btn.warn{background:var(--warning);color:#fff}.btn.ghost{background:rgba(255,255,255,.16);color:#fff;border:1px solid rgba(255,255,255,.25)}.btn.small{padding:7px 10px;border-radius:10px;font-size:12px}.btn.full{width:100%}.form-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:13px}.form-grid.two{grid-template-columns:repeat(2,1fr)}.form-stack{display:grid;gap:13px}.filter-row{display:flex;gap:12px;align-items:end;flex-wrap:wrap}.filter-row>div{min-width:190px}.span-2{grid-column:span 2}.span-3{grid-column:span 3}label{display:block;font-weight:900;font-size:12px;margin-bottom:7px;color:#334155}input,select,textarea{width:100%;border:1px solid #cbd5e1;border-radius:14px;padding:12px;background:#fff;color:#111827;outline:none}textarea{min-height:90px;resize:vertical}input:focus,select:focus,textarea:focus{border-color:#2563eb;box-shadow:0 0 0 4px rgba(37,99,235,.10)}.hint{font-size:12px;color:var(--muted);margin-top:6px}.table-wrap{overflow:auto;border-radius:16px;border:1px solid var(--line)}table{width:100%;border-collapse:collapse;min-width:850px;background:#fff}th,td{padding:12px;border-bottom:1px solid #e2e8f0;text-align:left;vertical-align:top}th{background:#f1f5ff;color:#1e3a8a;font-size:12px;text-transform:uppercase;letter-spacing:.03em}tr:hover td{background:#fafcff}.badge{display:inline-flex;border-radius:999px;padding:5px 9px;font-weight:900;font-size:11px;background:#e2e8f0;color:#334155}.badge.ok,.badge.approved,.badge.paid{background:#dcfce7;color:#166534}.badge.warn,.badge.pending,.badge.terlambat{background:#fef3c7;color:#92400e}.badge.danger,.badge.rejected,.badge.diluar_radius{background:#fee2e2;color:#991b1b}.badge.info{background:#dbeafe;color:#1d4ed8}.alert{padding:13px 15px;border-radius:16px;margin-bottom:12px;border:1px solid}.alert.success{background:#dcfce7;color:#166534;border-color:#bbf7d0}.alert.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}.alert.info{background:#dbeafe;color:#1e40af;border-color:#bfdbfe}.alert.warning{background:#fef3c7;color:#92400e;border-color:#fde68a}.empty{text-align:center;color:var(--muted);padding:24px}.notice{border:1px solid var(--line);border-radius:16px;padding:13px;margin-bottom:10px;background:#f8fbff}.notice b{display:block}.notice p{margin:6px 0;color:#475569}.gps-card{max-width:780px}.gps-status{padding:14px;border-radius:16px;background:#eff6ff;color:#1d4ed8;font-weight:900;margin-bottom:12px}.map-note{padding:13px;border:1px dashed #93c5fd;border-radius:16px;margin-bottom:13px;background:#f8fbff}.photo-thumb{width:62px;height:62px;border-radius:14px;object-fit:cover;border:1px solid #cbd5e1}.profile-list{display:grid;gap:8px}.profile-list p{margin:0;padding:10px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:14px}.login-page{min-height:100vh;display:grid;place-items:center;padding:20px;background:radial-gradient(circle at top,#bfdbfe,#eef2ff 45%,#fff)}.login-card{width:min(460px,100%);background:#fff;border-radius:30px;padding:28px;box-shadow:0 24px 70px rgba(15,23,42,.18);border:1px solid #dbeafe}.login-card h1{margin:0 0 8px}.login-card p{color:var(--muted);margin:0 0 20px}.slip-card{max-width:820px;margin:25px auto;background:#fff;border:1px solid #e2e8f0;border-radius:24px;padding:28px}.slip-title{display:flex;align-items:center;justify-content:space-between;border-bottom:2px solid #e2e8f0;padding-bottom:15px}.slip-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:16px}.slip-row{display:flex;justify-content:space-between;gap:12px;border-bottom:1px dashed #cbd5e1;padding:9px 0}.total-pay{font-size:26px;color:#16a34a}.print-body{background:#f8fafc}.tabs{display:flex;gap:8px;flex-wrap:wrap}.tabs a{padding:10px 13px;background:#eef2ff;border-radius:13px;font-weight:900;color:#1e40af}.tabs a.active{background:#1d4ed8;color:#fff}.pill-grid{display:flex;gap:8px;flex-wrap:wrap}.pill{padding:8px 10px;border-radius:999px;background:#f1f5f9;color:#334155;font-weight:800;font-size:12px}.camera-note{background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;border-radius:16px;padding:12px}.selfie-panel{border:1px solid #dbeafe;border-radius:18px;background:#f8fbff;padding:13px;display:grid;gap:10px}.selfie-stage{position:relative;overflow:hidden;border-radius:18px;background:#0f172a;min-height:310px;display:grid;place-items:center;border:1px solid #bfdbfe}.selfie-stage video,.selfie-stage img{width:100%;max-height:440px;object-fit:cover;display:none}.selfie-stage video{transform:scaleX(-1)}.selfie-placeholder{position:absolute;inset:0;display:grid;place-items:center;color:#cbd5e1;text-align:center;padding:18px;font-weight:900}.selfie-status{padding:11px 12px;border-radius:14px;background:#eef2ff;color:#1e40af;font-weight:800}.selfie-status.ok{background:#dcfce7;color:#166534;border:1px solid #86efac}.selfie-status.warn{background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.selfie-status.danger{background:#fee2e2;color:#991b1b;border:1px solid #fecaca}.camera-actions{display:flex;gap:8px;flex-wrap:wrap}
.no-print{display:inline-flex}@media (max-width:1100px){.stats-grid{grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{grid-template-columns:1fr}.form-grid{grid-template-columns:repeat(2,1fr)}.span-3{grid-column:span 2}}@media (max-width:800px){body{font-size:13px}.sidebar{transform:translateX(-105%);width:284px}.sidebar.open{transform:translateX(0)}.main-content{margin-left:0;width:100%}.hamburger{display:block}.topbar{padding:12px}.top-title span{display:none}.user-chip span{display:none}.content-wrap{padding:13px}.hero-card{display:block;padding:20px;border-radius:22px}.hero-card h1{font-size:24px}.hero-actions{margin-top:16px}.stats-grid{grid-template-columns:1fr}.form-grid,.form-grid.two{grid-template-columns:1fr}.span-2,.span-3{grid-column:auto}.card{padding:14px;border-radius:18px}.card-head{display:block}.card-head span{display:block;margin-top:5px}.filter-row{display:grid}.filter-row>div{min-width:100%}.btn{width:100%}.top-actions{gap:7px}.notif{width:38px;height:38px}.slip-grid{grid-template-columns:1fr}.no-mobile{display:none}}@media print{.sidebar,.topbar,.no-print{display:none!important}.main-content{margin:0;width:100%}.content-wrap{padding:0}.card,.slip-card{box-shadow:none;border:0;margin:0}.btn{display:none!important}}
.radius-status{padding:13px 14px;border-radius:16px;margin:-3px 0 12px 0;font-weight:900;line-height:1.45;background:#fef3c7;color:#92400e;border:1px solid #fcd34d}.radius-status.ok{background:#dcfce7;color:#166534;border-color:#86efac}.radius-status.warn{background:#fef3c7;color:#92400e;border-color:#fcd34d}.radius-status.danger{background:#fee2e2;color:#991b1b;border-color:#fecaca}


.gps-toolbar{display:flex;gap:8px;flex-wrap:wrap;margin:0 0 12px 0}.gps-toolbar .btn{width:auto}.map-card{border:1px solid #dbeafe;border-radius:18px;background:#f8fbff;padding:12px;margin-bottom:12px}.map-card-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.map-card-head b{display:block}.map-card-head span{color:#64748b;font-size:12px}.gps-map{width:100%;height:320px;border-radius:16px;overflow:hidden;border:1px solid #bfdbfe;background:#e2e8f0}.map-meta{margin-top:10px;padding:11px 12px;border-radius:14px;background:#eff6ff;color:#1e40af;font-weight:800;line-height:1.45}.leaflet-container{font:inherit}.leaflet-control-attribution{font-size:10px}@media (max-width:800px){.gps-toolbar{display:grid;grid-template-columns:1fr 1fr}.map-card-head{display:block}.gps-map{height:280px}}


/* ===== V7 PROFESSIONAL FRONT LOGIN ===== */
.pro-login-page{position:relative;overflow:hidden;min-height:100vh;display:flex;align-items:center;justify-content:center;padding:28px;background:linear-gradient(135deg,#07111f 0%,#0f172a 42%,#1d4ed8 100%);color:#e5e7eb}.login-bg-shape{position:fixed;border-radius:999px;filter:blur(12px);opacity:.7;pointer-events:none;animation:floatShape 9s ease-in-out infinite}.shape-a{width:320px;height:320px;background:rgba(59,130,246,.38);left:-90px;top:-80px}.shape-b{width:420px;height:420px;background:rgba(124,58,237,.30);right:-120px;bottom:-130px;animation-delay:-2.5s}.shape-c{width:220px;height:220px;background:rgba(34,197,94,.20);left:48%;bottom:8%;animation-delay:-5s}@keyframes floatShape{0%,100%{transform:translate3d(0,0,0) scale(1)}50%{transform:translate3d(18px,-18px,0) scale(1.05)}}.pro-login-wrap{position:relative;z-index:1;width:min(1180px,100%);display:grid;grid-template-columns:1.15fr .85fr;gap:24px;align-items:stretch}.login-showcase,.login-panel-pro{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.10);backdrop-filter:blur(22px);box-shadow:0 30px 90px rgba(0,0,0,.32);border-radius:34px}.login-showcase{padding:28px;min-height:650px;display:flex;flex-direction:column;justify-content:space-between}.login-showcase:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 10%,rgba(255,255,255,.18),transparent 28%),radial-gradient(circle at 82% 18%,rgba(96,165,250,.25),transparent 30%),linear-gradient(135deg,rgba(37,99,235,.18),rgba(15,23,42,.22));pointer-events:none}.showcase-top,.showcase-copy,.feature-mosaic,.showcase-bottom{position:relative;z-index:1}.showcase-top{display:flex;justify-content:space-between;align-items:center;gap:14px}.login-brand-pro{display:flex;gap:12px;align-items:center}.login-logo-pro{width:58px;height:58px;border-radius:20px;background:linear-gradient(135deg,#fff,#dbeafe);display:grid;place-items:center;color:#1d4ed8;font-weight:1000;box-shadow:0 16px 30px rgba(0,0,0,.18);overflow:hidden}.login-logo-pro img{width:100%;height:100%;object-fit:contain}.login-brand-pro b{display:block;font-size:16px;color:#fff}.login-brand-pro span{display:block;color:#cbd5e1;font-size:12px;margin-top:2px}.secure-chip{white-space:nowrap;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.12);color:#e0f2fe;border-radius:999px;padding:10px 13px;font-weight:900;font-size:12px}.pro-eyebrow{display:inline-flex;letter-spacing:.14em;font-size:11px;font-weight:1000;color:#bfdbfe;margin-bottom:12px}.showcase-copy{max-width:760px;margin:54px 0 24px}.showcase-copy h1{font-size:48px;line-height:1.02;letter-spacing:-.04em;color:#fff;margin:0 0 16px}.showcase-copy p{font-size:16px;line-height:1.72;color:#dbeafe;margin:0;max-width:690px}.feature-mosaic{display:grid;grid-template-columns:1.2fr 1fr;gap:14px;margin-top:22px}.mosaic-card{background:rgba(255,255,255,.13);border:1px solid rgba(255,255,255,.16);border-radius:24px;padding:18px;min-height:142px;display:flex;flex-direction:column;gap:7px}.mosaic-card.main{grid-row:span 2;justify-content:flex-end;background:linear-gradient(145deg,rgba(37,99,235,.45),rgba(124,58,237,.25));min-height:298px}.mosaic-icon{width:46px;height:46px;border-radius:16px;background:rgba(255,255,255,.14);display:grid;place-items:center;font-size:22px}.mosaic-card b{color:#fff;font-size:16px}.mosaic-card span{color:#cbd5e1;font-size:13px;line-height:1.45}.showcase-bottom{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-top:20px}.showcase-bottom div{padding:14px;border-radius:18px;background:rgba(15,23,42,.26);border:1px solid rgba(255,255,255,.12)}.showcase-bottom b{display:block;color:#fff;font-size:15px}.showcase-bottom span{display:block;color:#cbd5e1;font-size:12px;margin-top:4px}.login-panel-pro{background:rgba(255,255,255,.95);color:#0f172a;padding:30px;display:flex;flex-direction:column;justify-content:center}.panel-glow{position:absolute;width:260px;height:260px;border-radius:999px;background:rgba(37,99,235,.12);right:-80px;top:-80px;pointer-events:none}.panel-head-pro{position:relative;z-index:1;margin-bottom:22px}.login-badge{display:inline-flex;background:#dbeafe;color:#1d4ed8;border-radius:999px;padding:8px 12px;font-weight:1000;font-size:12px;margin-bottom:14px}.panel-head-pro h2{font-size:31px;letter-spacing:-.03em;margin:0 0 8px;color:#0f172a}.panel-head-pro p{color:#64748b;margin:0;line-height:1.55}.pro-login-form{display:grid;gap:14px}.input-shell label{display:block;margin-bottom:8px;color:#334155;font-weight:1000;font-size:12px}.input-icon-wrap{display:flex;align-items:center;gap:9px;background:#f8fafc;border:1px solid #dbeafe;border-radius:18px;padding:4px 12px;transition:.18s}.input-icon-wrap:focus-within{border-color:#2563eb;box-shadow:0 0 0 5px rgba(37,99,235,.10);background:#fff}.input-icon-wrap span{font-size:17px}.input-icon-wrap input{border:0;background:transparent;border-radius:0;padding:14px 0;box-shadow:none}.input-icon-wrap input:focus{border:0;box-shadow:none}.login-main-btn{height:54px;border-radius:18px;font-size:15px;box-shadow:0 18px 28px rgba(37,99,235,.25)}.login-quick-info{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:18px 0}.login-quick-info div{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:13px}.login-quick-info b{display:block;color:#0f172a}.login-quick-info span{display:block;color:#64748b;font-size:12px;line-height:1.45;margin-top:4px}.demo-account-box{border:1px dashed #bfdbfe;background:#eff6ff;border-radius:18px;padding:12px;margin-top:2px}.demo-account-box summary{cursor:pointer;font-weight:1000;color:#1e40af}.demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:12px}.demo-grid div{background:#fff;border-radius:14px;padding:11px}.demo-grid b{display:block;margin-bottom:8px}.demo-grid code{display:block;background:#f1f5f9;color:#0f172a;padding:7px 8px;border-radius:9px;margin-top:6px;font-size:12px;white-space:nowrap;overflow:auto}.login-footer-note{margin-top:14px;padding:13px;border-radius:16px;background:#fff7ed;border:1px solid #fed7aa;color:#9a3412;font-size:12px;line-height:1.5}.login-footer-note b{color:#7c2d12}@media (max-width:980px){.pro-login-page{display:block;padding:16px}.pro-login-wrap{grid-template-columns:1fr;gap:16px}.login-showcase{min-height:auto;border-radius:28px}.showcase-copy{margin:34px 0 20px}.showcase-copy h1{font-size:36px}.feature-mosaic{grid-template-columns:1fr 1fr}.mosaic-card.main{grid-row:auto;min-height:170px}.login-panel-pro{border-radius:28px}}@media (max-width:620px){.pro-login-page{padding:10px;background:linear-gradient(180deg,#0f172a,#1d4ed8)}.login-showcase{padding:18px;border-radius:24px}.showcase-top{align-items:flex-start}.secure-chip{display:none}.login-logo-pro{width:50px;height:50px;border-radius:17px}.showcase-copy h1{font-size:29px}.showcase-copy p{font-size:14px}.feature-mosaic,.showcase-bottom,.login-quick-info,.demo-grid{grid-template-columns:1fr}.mosaic-card,.mosaic-card.main{min-height:auto}.showcase-bottom{margin-top:14px}.login-panel-pro{padding:20px;border-radius:24px}.panel-head-pro h2{font-size:26px}.login-main-btn{height:52px}.shape-c{display:none}}


/* V8 clean GPS UI: status GPS/radius disembunyikan, fokus hanya peta posisi HP */
.gps-card{max-width:880px}.map-card{margin-top:4px}.map-card-head span{font-size:12px}.gps-status,.radius-status{display:none!important}


/* V9: tampilkan status Lokasi Benar */
.radius-status{margin:0 0 12px 0!important;font-size:13px}.radius-status.ok{font-size:14px}


/* V10 FIX LOGIN DEPAN HP - agar halaman bisa discroll dan form login bisa diklik */
html,body{max-width:100%;}
.pro-login-page{overflow-x:hidden!important;overflow-y:auto!important;height:auto!important;min-height:100dvh!important;align-items:flex-start!important;touch-action:auto!important;-webkit-overflow-scrolling:touch!important;}
.pro-login-wrap{position:relative;z-index:5;margin:0 auto;padding:0 0 24px 0;}
.login-bg-shape,.login-showcase:before,.panel-glow{pointer-events:none!important;}
.login-panel-pro,.login-panel-pro *{pointer-events:auto;}
.pro-login-form input,.pro-login-form button,.demo-account-box summary{position:relative;z-index:10;}
@media (max-width:980px){
  .pro-login-page{display:block!important;padding:14px!important;}
  .pro-login-wrap{display:flex!important;flex-direction:column!important;width:100%!important;gap:14px!important;}
  .login-panel-pro{order:1!important;min-height:auto!important;justify-content:flex-start!important;}
  .login-showcase{order:2!important;min-height:auto!important;}
  .showcase-copy{margin:22px 0 16px!important;}
  .feature-mosaic{margin-top:12px!important;}
  .showcase-bottom{display:none!important;}
}
@media (max-width:620px){
  .pro-login-page{padding:8px!important;}
  .login-panel-pro{padding:18px!important;border-radius:22px!important;}
  .login-showcase{padding:16px!important;border-radius:22px!important;}
  .panel-head-pro{margin-bottom:14px!important;}
  .panel-head-pro h2{font-size:24px!important;}
  .panel-head-pro p{font-size:13px!important;}
  .login-quick-info{display:none!important;}
  .login-footer-note{font-size:11px!important;}
  .showcase-copy h1{font-size:25px!important;}
  .showcase-copy p{font-size:13px!important;line-height:1.55!important;}
  .mosaic-card{padding:14px!important;border-radius:18px!important;}
}


/* V11 FIX GPS + LOGIN CLICK
   - Status lokasi benar ditampilkan lagi
   - GPS status ditampilkan sebagai Posisi HP, bukan tulisan GPS aktif
   - Login panel dibuat paling depan agar input/tombol pasti bisa diklik di HP
*/
.gps-status{display:block!important;visibility:visible!important;opacity:1!important;margin-bottom:10px!important;font-size:13px!important;line-height:1.45!important;}
.radius-status{display:block!important;visibility:visible!important;opacity:1!important;margin-bottom:12px!important;}
.map-card{position:relative;z-index:1!important;}
.selfie-panel,.form-stack{position:relative;z-index:2!important;}
.pro-login-page{position:relative!important;overflow-x:hidden!important;overflow-y:auto!important;min-height:100svh!important;height:auto!important;}
.pro-login-wrap{position:relative!important;z-index:30!important;pointer-events:auto!important;}
.login-panel-pro{position:relative!important;z-index:80!important;pointer-events:auto!important;isolation:isolate!important;}
.login-panel-pro form,.login-panel-pro input,.login-panel-pro button,.login-panel-pro details,.login-panel-pro summary{position:relative!important;z-index:120!important;pointer-events:auto!important;touch-action:manipulation!important;}
.login-showcase{position:relative!important;z-index:10!important;}
.login-bg-shape,.login-showcase:before,.panel-glow{pointer-events:none!important;z-index:0!important;}
.input-icon-wrap input{font-size:16px!important;min-height:44px!important;}
.login-main-btn{min-height:52px!important;pointer-events:auto!important;cursor:pointer!important;}
@media (max-width:980px){
  .pro-login-wrap{display:flex!important;flex-direction:column!important;}
  .login-panel-pro{order:1!important;}
  .login-showcase{order:2!important;}
}

.coord-panel{border:1px solid #dbeafe;border-radius:18px;background:#fff;padding:14px;margin:0 0 12px 0;box-shadow:0 10px 22px rgba(15,23,42,.04)}.coord-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:10px}.coord-head b{display:block}.coord-head span{color:#64748b;font-size:12px}.coord-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}.coord-item{border:1px solid #e2e8f0;background:#f8fbff;border-radius:14px;padding:12px}.coord-item span{display:block;font-size:12px;color:#64748b;font-weight:800;margin-bottom:4px}.coord-item b{font-size:14px;color:#0f172a;word-break:break-word}.coord-item b.ok{color:#166534}.coord-item b.danger{color:#991b1b}.coord-item b.warn{color:#92400e}@media (max-width:800px){.coord-grid{grid-template-columns:1fr 1fr}.coord-head{display:block}}

.radius-status.hide{display:none!important}


/* V18 - Modern Employee Mobile Portal */
.employee-dashboard-pro{display:grid;gap:16px}.employee-hero-pro{position:relative;overflow:hidden;border-radius:28px;padding:22px;background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 50%,#7c3aed 100%);color:#fff;box-shadow:0 22px 48px rgba(29,78,216,.24);display:grid;grid-template-columns:1.5fr .8fr;gap:18px;align-items:stretch}.hero-bg-orb{position:absolute;border-radius:999px;filter:blur(10px);opacity:.35;pointer-events:none}.hero-bg-orb.one{width:180px;height:180px;background:#60a5fa;right:-65px;top:-70px}.hero-bg-orb.two{width:160px;height:160px;background:#f472b6;left:-80px;bottom:-80px}.hero-main-pro,.hero-profile-pro{position:relative;z-index:1}.hero-kicker{display:inline-flex;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.22);padding:8px 11px;border-radius:999px;text-transform:uppercase;letter-spacing:.11em;font-weight:900;font-size:11px}.employee-hero-pro h1{font-size:31px;line-height:1.08;margin:14px 0 10px}.employee-hero-pro p{margin:0;color:#e0e7ff;line-height:1.65;max-width:720px}.hero-action-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.btn.soft-white{background:rgba(255,255,255,.17);border:1px solid rgba(255,255,255,.28);color:#fff}.hero-profile-pro{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.2);border-radius:24px;padding:16px;display:grid;align-content:center;justify-items:center;text-align:center;gap:10px;backdrop-filter:blur(12px)}.profile-avatar-pro{width:86px;height:86px;border-radius:28px;background:linear-gradient(135deg,#fff,#dbeafe);color:#1d4ed8;font-size:38px;font-weight:900;display:grid;place-items:center;overflow:hidden;box-shadow:0 15px 32px rgba(15,23,42,.2)}.profile-avatar-pro img{width:100%;height:100%;object-fit:cover}.hero-profile-pro b{display:block}.hero-profile-pro span{display:block;color:#dbeafe;font-size:12px;margin-top:3px}.status-dot{display:inline-flex;padding:7px 10px;border-radius:999px;font-style:normal;font-weight:900;font-size:12px;background:rgba(255,255,255,.18);color:#fff}.status-dot.active{background:#dcfce7;color:#166534}.status-dot.done{background:#dbeafe;color:#1d4ed8}.status-dot.wait{background:#fef3c7;color:#92400e}.quick-menu-pro{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.quick-menu-pro a{background:#fff;border:1px solid #dbeafe;border-radius:20px;padding:15px;box-shadow:0 12px 28px rgba(15,23,42,.06);display:grid;gap:6px;min-height:126px;transition:.18s}.quick-menu-pro a:hover{transform:translateY(-2px);box-shadow:0 18px 36px rgba(15,23,42,.10)}.quick-menu-pro i{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,#dbeafe,#eef2ff);display:grid;place-items:center;font-style:normal;font-size:22px}.quick-menu-pro b{font-size:14px}.quick-menu-pro span{font-size:12px;color:#64748b;font-weight:800}.attendance-today-pro,.modern-card-pro{background:rgba(255,255,255,.92);border:1px solid #dbeafe;border-radius:24px;padding:18px;box-shadow:0 14px 32px rgba(15,23,42,.07)}.section-title-pro{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.section-title-pro b{display:block;font-size:17px}.section-title-pro span{display:block;color:#64748b;font-size:12px;margin-top:3px}.section-title-pro a{font-weight:900;color:#1d4ed8;background:#eff6ff;border-radius:999px;padding:8px 11px;font-size:12px}.timeline-pro{display:grid;grid-template-columns:1fr 42px 1fr;align-items:center;gap:6px}.time-node{border:1px solid #e2e8f0;background:#f8fafc;border-radius:20px;padding:15px}.time-node.on{background:#ecfdf5;border-color:#86efac}.time-node i{display:block;font-style:normal;color:#64748b;font-weight:900;font-size:12px}.time-node b{display:block;font-size:28px;margin:5px 0}.time-node span{display:block;color:#64748b;font-size:12px;font-weight:800}.time-line{height:4px;border-radius:999px;background:linear-gradient(90deg,#2563eb,#7c3aed)}.dashboard-grid-pro{display:grid;grid-template-columns:1fr 1fr;gap:16px}.mini-stats-pro{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.mini-stats-pro div{background:#f8fbff;border:1px solid #e2e8f0;border-radius:18px;padding:13px}.mini-stats-pro span{font-size:12px;color:#64748b;font-weight:900}.mini-stats-pro b{display:block;font-size:24px;margin-top:5px}.mini-stats-pro small{color:#64748b;font-weight:800}.info-strip-pro{display:grid;grid-template-columns:1fr 1fr auto;gap:8px;align-items:center;background:#eff6ff;border-radius:16px;padding:12px;margin-top:12px}.info-strip-pro span,.info-strip-pro em{color:#64748b;font-size:12px;font-style:normal;font-weight:800}.info-strip-pro b{color:#1e3a8a}.salary-card-pro{background:linear-gradient(180deg,#fff,#f8fbff)}.salary-big-pro{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-radius:20px;padding:16px;margin-bottom:12px}.salary-big-pro span{display:block;color:#dbeafe;font-weight:800;font-size:12px}.salary-big-pro b{display:block;font-size:26px;margin-top:4px}.salary-list-pro{display:grid;gap:8px}.salary-list-pro p{display:flex;justify-content:space-between;gap:10px;margin:0;border-bottom:1px dashed #dbeafe;padding:8px 0}.salary-list-pro span{color:#64748b;font-weight:800}.announcement-pro{margin-top:0}.announcement-item-pro{display:flex;justify-content:space-between;gap:12px;border:1px solid #e2e8f0;background:#f8fbff;border-radius:18px;padding:13px;margin-bottom:10px}.announcement-item-pro b{display:block}.announcement-item-pro p{margin:5px 0 0;color:#475569}.announcement-item-pro>span{flex:0 0 auto;background:#e0e7ff;color:#1d4ed8;border-radius:12px;padding:7px 9px;font-weight:900;font-size:12px;align-self:flex-start}@media (max-width:1100px){.employee-hero-pro{grid-template-columns:1fr}.quick-menu-pro{grid-template-columns:repeat(3,1fr)}.dashboard-grid-pro{grid-template-columns:1fr}}@media (max-width:800px){.employee-dashboard-pro{gap:12px}.employee-hero-pro{border-radius:22px;padding:18px}.employee-hero-pro h1{font-size:25px}.hero-action-row{display:grid;grid-template-columns:1fr 1fr}.hero-profile-pro{grid-template-columns:auto 1fr;justify-items:start;text-align:left;border-radius:20px}.profile-avatar-pro{width:62px;height:62px;border-radius:20px;font-size:26px}.status-dot{grid-column:1 / -1}.quick-menu-pro{grid-template-columns:repeat(3,1fr);gap:9px}.quick-menu-pro a{min-height:106px;padding:12px;border-radius:17px}.quick-menu-pro i{width:40px;height:40px;border-radius:14px;font-size:19px}.quick-menu-pro b{font-size:12px}.quick-menu-pro span{font-size:11px}.attendance-today-pro,.modern-card-pro{border-radius:20px;padding:14px}.section-title-pro b{font-size:15px}.timeline-pro{grid-template-columns:1fr;gap:9px}.time-line{height:3px}.time-node b{font-size:23px}.mini-stats-pro{grid-template-columns:1fr 1fr}.mini-stats-pro div:last-child{grid-column:1 / -1}.info-strip-pro{grid-template-columns:1fr}.salary-big-pro b{font-size:22px}.announcement-item-pro{display:block}.announcement-item-pro>span{display:inline-flex;margin-top:10px}.hero-action-row .btn{width:100%}}@media (max-width:420px){.quick-menu-pro{grid-template-columns:repeat(2,1fr)}.hero-action-row{grid-template-columns:1fr}}

/* V19 - Rata tengah menu beranda portal karyawan */
.quick-menu-pro a{
  justify-items:center;
  align-content:center;
  text-align:center;
  place-items:center;
}
.quick-menu-pro i{
  margin:0 auto;
}
.quick-menu-pro b,
.quick-menu-pro span{
  display:block;
  width:100%;
  text-align:center;
}
@media (max-width:800px){
  .quick-menu-pro a{
    justify-items:center;
    align-content:center;
    text-align:center;
  }
}

.employee-info-card-pro{overflow:hidden}.employee-info-list-pro{display:grid;gap:9px}.employee-info-list-pro p{margin:0;display:flex;justify-content:space-between;gap:12px;align-items:center;border:1px solid #e2e8f0;background:linear-gradient(180deg,#ffffff,#f8fbff);border-radius:16px;padding:12px}.employee-info-list-pro span{font-size:12px;color:#64748b;font-weight:900}.employee-info-list-pro b{font-size:13px;color:#0f172a;text-align:right}


.dashboard-grid-pro{grid-template-columns:1fr!important}


/* V24 - Beranda portal karyawan sangat mewah + input uang otomatis */
.money-input{font-weight:900;text-align:right;letter-spacing:.03em;background:linear-gradient(180deg,#ffffff,#f8fbff)!important;border-color:#bfdbfe!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.75),0 8px 18px rgba(37,99,235,.06)!important}.money-input:focus{border-color:#7c3aed!important;box-shadow:0 0 0 4px rgba(124,58,237,.12),0 12px 26px rgba(37,99,235,.10)!important}
.employee-dashboard-pro{position:relative;isolation:isolate;border-radius:32px;padding:8px;background:radial-gradient(circle at 0% 0%,rgba(59,130,246,.18),transparent 31%),radial-gradient(circle at 100% 7%,rgba(236,72,153,.16),transparent 30%),radial-gradient(circle at 50% 110%,rgba(245,158,11,.14),transparent 35%)}
.employee-dashboard-pro:before{content:"";position:absolute;inset:-18px;z-index:-1;background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(124,58,237,.13),rgba(244,114,182,.12));filter:blur(32px);border-radius:42px;opacity:.9;pointer-events:none}.employee-dashboard-pro>*{position:relative;z-index:1}
.employee-hero-pro{min-height:245px;border-radius:34px;padding:28px;background:linear-gradient(132deg,#06112d 0%,#172554 23%,#1d4ed8 52%,#7c3aed 78%,#db2777 115%);border:1px solid rgba(255,255,255,.20);box-shadow:0 32px 80px rgba(29,78,216,.32),inset 0 1px 0 rgba(255,255,255,.20)}
.employee-hero-pro:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.14),transparent 30%,rgba(255,255,255,.09) 70%,transparent),radial-gradient(circle at 78% 22%,rgba(251,191,36,.35),transparent 18%),radial-gradient(circle at 22% 92%,rgba(96,165,250,.24),transparent 24%);pointer-events:none}.employee-hero-pro:after{content:"";position:absolute;width:260px;height:260px;right:-100px;bottom:-120px;background:conic-gradient(from 90deg,#fbbf24,#ec4899,#60a5fa,#22c55e,#fbbf24);border-radius:999px;filter:blur(28px);opacity:.34;pointer-events:none}.hero-bg-orb.one{background:#38bdf8;opacity:.50;filter:blur(14px)}.hero-bg-orb.two{background:#fbbf24;opacity:.35;filter:blur(16px)}
.hero-kicker{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.34);box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 12px 24px rgba(15,23,42,.15);backdrop-filter:blur(14px)}.employee-hero-pro h1{font-size:36px;letter-spacing:-.045em;text-shadow:0 10px 30px rgba(0,0,0,.28)}.employee-hero-pro p{color:#eef2ff;font-weight:650}.hero-action-row .btn{border-radius:18px;padding:13px 16px;box-shadow:0 14px 28px rgba(15,23,42,.20)}.hero-action-row .btn.primary{background:linear-gradient(135deg,#22c55e,#16a34a 48%,#0f766e);box-shadow:0 16px 32px rgba(34,197,94,.26)}.btn.soft-white{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.38);backdrop-filter:blur(12px)}
.hero-profile-pro{background:linear-gradient(180deg,rgba(255,255,255,.20),rgba(255,255,255,.10));border-color:rgba(255,255,255,.28);box-shadow:inset 0 1px 0 rgba(255,255,255,.22),0 24px 48px rgba(15,23,42,.17)}.profile-avatar-pro{border-radius:32px;background:linear-gradient(135deg,#fff 0%,#dbeafe 50%,#fce7f3 100%);box-shadow:0 22px 44px rgba(15,23,42,.28),0 0 0 6px rgba(255,255,255,.12)}.status-dot{box-shadow:0 10px 22px rgba(15,23,42,.12)}
.quick-menu-pro{gap:14px}.quick-menu-pro a{position:relative;overflow:hidden;min-height:136px;border-radius:26px;background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(239,246,255,.92));border:1px solid rgba(191,219,254,.95);box-shadow:0 18px 38px rgba(15,23,42,.09),inset 0 1px 0 rgba(255,255,255,.95)}.quick-menu-pro a:before{content:"";position:absolute;inset:auto -40px -65px auto;width:135px;height:135px;border-radius:999px;background:linear-gradient(135deg,rgba(37,99,235,.16),rgba(236,72,153,.18));transition:.25s}.quick-menu-pro a:after{content:"";position:absolute;left:16px;right:16px;top:0;height:3px;border-radius:999px;background:linear-gradient(90deg,#22c55e,#3b82f6,#a855f7,#ec4899);opacity:.85}.quick-menu-pro a:hover{transform:translateY(-4px) scale(1.01);box-shadow:0 26px 54px rgba(15,23,42,.14)}.quick-menu-pro a:hover:before{transform:scale(1.18);opacity:.95}.quick-menu-pro i{position:relative;z-index:1;width:54px;height:54px;border-radius:20px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;box-shadow:0 16px 30px rgba(37,99,235,.25);font-size:24px}.quick-menu-pro a:nth-child(2) i{background:linear-gradient(135deg,#06b6d4,#2563eb)}.quick-menu-pro a:nth-child(3) i{background:linear-gradient(135deg,#f59e0b,#ef4444)}.quick-menu-pro a:nth-child(4) i{background:linear-gradient(135deg,#22c55e,#0d9488)}.quick-menu-pro a:nth-child(5) i{background:linear-gradient(135deg,#a855f7,#ec4899)}.quick-menu-pro a:nth-child(6) i{background:linear-gradient(135deg,#0f172a,#475569)}.quick-menu-pro b{position:relative;z-index:1;font-size:15px;color:#0f172a}.quick-menu-pro span{position:relative;z-index:1;color:#64748b}
.attendance-today-pro,.modern-card-pro{border-radius:28px;background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,251,255,.94));border:1px solid rgba(191,219,254,.95);box-shadow:0 22px 48px rgba(15,23,42,.08),inset 0 1px 0 rgba(255,255,255,.95)}.section-title-pro b{font-size:18px;letter-spacing:-.02em}.section-title-pro a{background:linear-gradient(135deg,#dbeafe,#eef2ff);box-shadow:0 10px 20px rgba(37,99,235,.10)}.timeline-pro{gap:12px}.time-node{position:relative;overflow:hidden;border-radius:24px;background:linear-gradient(145deg,#ffffff,#f8fbff);border-color:#dbeafe;box-shadow:0 14px 28px rgba(15,23,42,.06)}.time-node:before{content:"";position:absolute;width:110px;height:110px;right:-45px;top:-45px;border-radius:999px;background:rgba(37,99,235,.08)}.time-node.on{background:linear-gradient(145deg,#ecfdf5,#ffffff);border-color:#86efac}.time-node b{letter-spacing:-.04em}.time-line{height:6px;background:linear-gradient(90deg,#22c55e,#3b82f6,#7c3aed);box-shadow:0 8px 18px rgba(37,99,235,.18)}.mini-stats-pro div{border-radius:22px;background:linear-gradient(145deg,#ffffff,#f8fbff);box-shadow:inset 0 1px 0 #fff,0 12px 24px rgba(15,23,42,.05)}.mini-stats-pro b{font-size:28px;color:#1d4ed8}.announcement-pro{background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(255,251,235,.60))}.announcement-item-pro{border-radius:22px;background:linear-gradient(145deg,#fff,#f8fbff);box-shadow:0 10px 22px rgba(15,23,42,.05)}.announcement-item-pro>span{background:linear-gradient(135deg,#dbeafe,#fce7f3);color:#1d4ed8}
@media (max-width:800px){.employee-dashboard-pro{padding:3px;border-radius:24px}.employee-hero-pro{border-radius:28px;padding:21px;min-height:auto}.employee-hero-pro h1{font-size:29px}.hero-profile-pro{background:rgba(255,255,255,.16)}.quick-menu-pro{grid-template-columns:repeat(3,1fr);gap:10px}.quick-menu-pro a{min-height:118px;border-radius:22px}.quick-menu-pro i{width:46px;height:46px;border-radius:18px}.attendance-today-pro,.modern-card-pro{border-radius:24px}.mini-stats-pro b{font-size:24px}}@media (max-width:420px){.quick-menu-pro{grid-template-columns:repeat(2,1fr)}.employee-hero-pro h1{font-size:27px}}


.wa-panel-inline{background:linear-gradient(135deg,#dcfce7,#ecfeff);border:1px solid #bbf7d0;border-radius:18px;padding:15px}.wa-panel-inline h3{margin:0 0 4px;color:#166534}.wa-panel-inline p{margin:0;color:#047857;font-weight:700}


/* V31 Pengaturan submenu mewah */
.settings-luxury{display:grid;gap:16px}
.settings-lux-hero{position:relative;overflow:hidden;border-radius:30px;padding:28px;color:#fff;background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 38%,#7c3aed 72%,#f97316 120%);box-shadow:0 26px 70px rgba(59,130,246,.32);display:flex;align-items:center;justify-content:space-between;gap:18px}
.settings-lux-hero:before{content:"";position:absolute;inset:-40% -10% auto auto;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.18);filter:blur(2px)}
.settings-lux-hero:after{content:"";position:absolute;left:-120px;bottom:-160px;width:340px;height:340px;border-radius:50%;background:rgba(34,211,238,.22)}
.settings-lux-hero>*{position:relative;z-index:1}
.settings-kicker{display:inline-flex;letter-spacing:.14em;text-transform:uppercase;font-size:11px;font-weight:1000;color:#bfdbfe;margin-bottom:8px}
.settings-lux-hero h1{margin:0;font-size:34px;line-height:1.05}
.settings-lux-hero p{margin:9px 0 0;color:#e0f2fe;max-width:720px;font-weight:700}
.settings-hero-badges{display:grid;grid-template-columns:1fr 1fr;gap:10px;min-width:300px}
.settings-hero-badges span{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.23);border-radius:18px;padding:12px 14px;font-weight:900;backdrop-filter:blur(12px)}
.settings-subnav{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.settings-subnav button{border:0;border-radius:24px;padding:16px;background:linear-gradient(180deg,#fff,#f8fbff);box-shadow:0 18px 38px rgba(15,23,42,.08);border:1px solid #dbeafe;text-align:left;cursor:pointer;color:#0f172a;transition:.2s;min-height:94px}
.settings-subnav button i{display:grid;place-items:center;width:42px;height:42px;border-radius:16px;background:linear-gradient(135deg,#dbeafe,#ede9fe);font-style:normal;font-size:22px;margin-bottom:8px}
.settings-subnav button b{display:block;font-size:15px}
.settings-subnav button small{display:block;color:#64748b;font-weight:800;margin-top:3px}
.settings-subnav button.active,.settings-subnav button:hover{transform:translateY(-2px);color:#fff;background:linear-gradient(135deg,#2563eb,#7c3aed);border-color:rgba(255,255,255,.18);box-shadow:0 24px 50px rgba(37,99,235,.25)}
.settings-subnav button.active i,.settings-subnav button:hover i{background:rgba(255,255,255,.2)}
.settings-subnav button.active small,.settings-subnav button:hover small{color:#dbeafe}
.settings-pane{display:none}
.settings-pane.active{display:block;animation:settingsFade .22s ease}
@keyframes settingsFade{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}
.lux-panel{position:relative;overflow:hidden;border-radius:28px;padding:20px;background:#fff;border:1px solid #dbeafe;box-shadow:0 18px 42px rgba(15,23,42,.07);margin:0 0 16px}
.lux-panel:before{content:"";position:absolute;inset:0 0 auto 0;height:8px;background:linear-gradient(90deg,#06b6d4,#2563eb,#7c3aed,#ec4899,#f97316)}
.lux-panel-head{position:relative;display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px}
.lux-panel-head span{display:grid;place-items:center;width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg,#dbeafe,#ede9fe);font-size:25px;margin-bottom:8px}
.lux-panel-head h2{margin:0;font-size:22px}
.lux-panel-head p{margin:4px 0 0;color:#64748b;font-weight:700}
.user-panel{background:linear-gradient(135deg,#ffffff,#f0f9ff)}
.company-panel{background:linear-gradient(135deg,#ffffff,#fff7ed)}
.whatsapp-panel{background:linear-gradient(135deg,#ffffff,#ecfdf5)}
.payroll-panel{background:linear-gradient(135deg,#ffffff,#fefce8)}
.wa-test-panel{background:linear-gradient(135deg,#ffffff,#f0fdf4)}
.wa-log-panel{background:linear-gradient(135deg,#ffffff,#f8fafc)}
.lux-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.lux-info-card{border:1px solid #dbeafe;background:rgba(255,255,255,.78);border-radius:24px;padding:18px;box-shadow:0 14px 30px rgba(15,23,42,.06)}
.lux-info-card i{display:grid;place-items:center;width:52px;height:52px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-style:normal;font-size:24px;margin-bottom:12px}
.lux-info-card b{display:block;font-size:17px}
.lux-info-card p{color:#64748b;font-weight:700;line-height:1.5}
.lux-warning{padding:14px;border-radius:18px;background:linear-gradient(135deg,#fff7ed,#fef3c7);border:1px solid #fed7aa;color:#9a3412;font-weight:800}
.settings-savebar{position:sticky;bottom:12px;z-index:9;margin:8px 0 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-radius:22px;background:rgba(15,23,42,.86);color:#fff;backdrop-filter:blur(16px);box-shadow:0 20px 44px rgba(15,23,42,.24)}
.settings-savebar b{display:block}
.settings-savebar span{display:block;color:#cbd5e1;font-size:12px;margin-top:2px}
.settings-savebar .btn{width:auto}
.settings-lux-form input,.settings-lux-form select,.settings-lux-form textarea,.wa-test-panel input{background:rgba(255,255,255,.88);border-color:#bfdbfe}
.settings-lux-form input:focus,.settings-lux-form select:focus,.settings-lux-form textarea:focus,.wa-test-panel input:focus{background:#fff;box-shadow:0 0 0 4px rgba(124,58,237,.11);border-color:#7c3aed}
@media (max-width:1100px){.settings-subnav{grid-template-columns:repeat(2,1fr)}.lux-grid{grid-template-columns:1fr}.settings-lux-hero{display:block}.settings-hero-badges{margin-top:16px;min-width:0}}
@media (max-width:800px){.settings-lux-hero{padding:20px;border-radius:24px}.settings-lux-hero h1{font-size:27px}.settings-hero-badges{grid-template-columns:1fr 1fr}.settings-subnav{grid-template-columns:1fr 1fr;gap:10px}.settings-subnav button{min-height:86px;padding:13px;text-align:center}.settings-subnav button i{margin:0 auto 7px}.lux-panel{padding:16px;border-radius:22px}.settings-savebar{display:grid;text-align:center}.settings-savebar .btn{width:100%}}


/* PATCH V32 - SUPERADMIN LUXURY UI */
body.admin-lux-mode{background:
 radial-gradient(circle at 8% 0%,rgba(59,130,246,.28),transparent 32%),
 radial-gradient(circle at 95% 10%,rgba(236,72,153,.22),transparent 35%),
 linear-gradient(135deg,#eef6ff 0%,#f8fbff 42%,#eef2ff 100%);}
body.admin-lux-mode:before{content:"";position:fixed;inset:0;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.32) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.32) 1px,transparent 1px);background-size:42px 42px;mask-image:linear-gradient(to bottom,rgba(0,0,0,.7),transparent 75%);z-index:-1}
body.admin-lux-mode .sidebar{background:linear-gradient(180deg,#08111f 0%,#102a5c 42%,#3b0764 100%);box-shadow:22px 0 55px rgba(15,23,42,.22);border-right:1px solid rgba(255,255,255,.12);padding:16px}
body.admin-lux-mode .sidebar:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 30% 10%,rgba(34,211,238,.28),transparent 28%),radial-gradient(circle at 80% 60%,rgba(236,72,153,.23),transparent 32%);pointer-events:none}
body.admin-lux-mode .sidebar>*{position:relative;z-index:1}
body.admin-lux-mode .brand{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);box-shadow:0 22px 45px rgba(0,0,0,.18);backdrop-filter:blur(18px);padding:14px;border-radius:24px}
body.admin-lux-mode .brand-logo{width:54px;height:54px;border-radius:20px;background:linear-gradient(135deg,#e0f2fe,#fff,#f5d0fe);color:#1d4ed8;box-shadow:0 10px 24px rgba(34,211,238,.23)}
body.admin-lux-mode .brand b{font-size:15px;letter-spacing:.01em}body.admin-lux-mode .brand span{color:#dbeafe;font-weight:700}
body.admin-lux-mode .nav-menu{gap:8px}body.admin-lux-mode .nav-menu a{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.08);background:rgba(255,255,255,.055);border-radius:17px;padding:12px 13px;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}
body.admin-lux-mode .nav-menu a:hover,body.admin-lux-mode .nav-menu a.active{background:linear-gradient(135deg,rgba(37,99,235,.88),rgba(124,58,237,.86));border-color:rgba(255,255,255,.2);box-shadow:0 16px 34px rgba(37,99,235,.28);transform:translateX(3px)}
body.admin-lux-mode .topbar{background:rgba(255,255,255,.82);border-bottom:1px solid rgba(147,197,253,.38);box-shadow:0 14px 44px rgba(37,99,235,.10);backdrop-filter:blur(18px)}
body.admin-lux-mode .hamburger{background:linear-gradient(135deg,#2563eb,#7c3aed);box-shadow:0 12px 25px rgba(37,99,235,.24)}
body.admin-lux-mode .top-title b{font-size:18px;background:linear-gradient(135deg,#0f172a,#2563eb,#7c3aed);-webkit-background-clip:text;background-clip:text;color:transparent}
body.admin-lux-mode .notif,body.admin-lux-mode .user-chip{box-shadow:0 14px 34px rgba(37,99,235,.13);border:1px solid #dbeafe}
body.admin-lux-mode .user-chip b{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff}
body.admin-lux-mode .card{border-color:#dbeafe;border-radius:28px;box-shadow:0 22px 52px rgba(37,99,235,.10);background:rgba(255,255,255,.88);backdrop-filter:blur(12px)}
body.admin-lux-mode .content-wrap{max-width:1540px}
body.admin-lux-mode .btn.primary{background:linear-gradient(135deg,#2563eb,#7c3aed,#ec4899);box-shadow:0 14px 28px rgba(124,58,237,.20)}
body.admin-lux-mode .table-wrap{border-color:#dbeafe;box-shadow:0 10px 26px rgba(37,99,235,.06)}
body.admin-lux-mode th{background:linear-gradient(135deg,#eff6ff,#f5f3ff);color:#1e3a8a}
.admin-lux-dashboard{display:grid;gap:18px}.admin-lux-hero{position:relative;overflow:hidden;border-radius:34px;padding:30px;color:#fff;background:linear-gradient(135deg,#0f172a 0%,#1d4ed8 42%,#7c3aed 78%,#ec4899 120%);box-shadow:0 34px 84px rgba(37,99,235,.32);display:flex;align-items:stretch;justify-content:space-between;gap:20px;min-height:250px}.admin-lux-hero:before{content:"";position:absolute;right:-90px;top:-110px;width:360px;height:360px;border-radius:50%;background:rgba(255,255,255,.16);filter:blur(1px)}.admin-lux-hero:after{content:"";position:absolute;left:40%;bottom:-170px;width:420px;height:420px;border-radius:50%;background:rgba(34,211,238,.15)}.admin-lux-hero>*{position:relative;z-index:1}.admin-lux-orb{position:absolute;border-radius:50%;filter:blur(2px);opacity:.78}.orb-a{width:130px;height:130px;left:35px;bottom:25px;background:rgba(34,211,238,.18)}.orb-b{width:90px;height:90px;right:34%;top:34px;background:rgba(251,191,36,.20)}.lux-kicker{display:inline-flex;align-items:center;gap:8px;letter-spacing:.14em;text-transform:uppercase;font-weight:1000;font-size:11px;color:#bfdbfe}.admin-lux-hero h1{margin:10px 0 10px;font-size:42px;line-height:1.02;max-width:760px}.admin-lux-hero p{margin:0;color:#e0f2fe;font-weight:700;max-width:820px;line-height:1.7}.hero-buttons{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px}.btn.luxury-light{background:rgba(255,255,255,.15);color:#fff;border:1px solid rgba(255,255,255,.24);backdrop-filter:blur(12px);box-shadow:0 14px 30px rgba(0,0,0,.12)}.hero-right{display:grid;align-content:space-between;min-width:300px;gap:14px}.lux-clock-card{background:rgba(255,255,255,.15);border:1px solid rgba(255,255,255,.22);border-radius:26px;padding:18px;backdrop-filter:blur(16px)}.lux-clock-card span{display:block;color:#bfdbfe;font-weight:900;font-size:12px;text-transform:uppercase}.lux-clock-card b{display:block;font-size:25px;margin:5px 0}.lux-clock-card small{color:#e0f2fe;font-weight:800}.lux-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.lux-mini-grid div{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.18);border-radius:22px;padding:15px;text-align:center}.lux-mini-grid b{display:block;font-size:28px}.lux-mini-grid span{font-size:12px;color:#dbeafe;font-weight:900}.admin-lux-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.admin-lux-stat{position:relative;overflow:hidden;border-radius:28px;padding:20px;background:#fff;box-shadow:0 24px 58px rgba(37,99,235,.12);border:1px solid #dbeafe;transition:.2s;min-height:178px}.admin-lux-stat:hover{transform:translateY(-4px);box-shadow:0 30px 65px rgba(37,99,235,.18)}.admin-lux-stat:after{content:"";position:absolute;right:-60px;top:-60px;width:150px;height:150px;border-radius:50%;background:var(--stat-glow,#dbeafe)}.admin-lux-stat i{position:relative;z-index:1;display:grid;place-items:center;width:56px;height:56px;border-radius:20px;background:linear-gradient(135deg,#eff6ff,#ede9fe);font-style:normal;font-size:26px;margin-bottom:12px}.admin-lux-stat span{position:relative;z-index:1;display:block;color:#64748b;font-weight:1000;font-size:12px;text-transform:uppercase}.admin-lux-stat b{position:relative;z-index:1;display:block;font-size:28px;margin:6px 0;color:#0f172a;word-break:break-word}.admin-lux-stat small{position:relative;z-index:1;color:#64748b;font-weight:800}.admin-lux-stat.blue{--stat-glow:rgba(59,130,246,.18)}.admin-lux-stat.green{--stat-glow:rgba(34,197,94,.18)}.admin-lux-stat.amber{--stat-glow:rgba(245,158,11,.18)}.admin-lux-stat.purple{--stat-glow:rgba(124,58,237,.18)}.admin-lux-action-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.lux-action-card{display:flex;align-items:center;gap:14px;border-radius:24px;padding:18px;background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(248,250,252,.86));border:1px solid #dbeafe;box-shadow:0 18px 42px rgba(37,99,235,.10)}.lux-action-card i{display:grid;place-items:center;width:54px;height:54px;border-radius:19px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-size:24px;font-style:normal;box-shadow:0 14px 26px rgba(37,99,235,.20)}.lux-action-card b{display:block;font-size:16px}.lux-action-card span{display:block;color:#64748b;font-weight:800;font-size:12px;margin-top:3px}.admin-lux-grid-2{display:grid;grid-template-columns:1.25fr .95fr;gap:16px}.lux-data-panel{border:1px solid #dbeafe;background:rgba(255,255,255,.9);backdrop-filter:blur(12px);border-radius:30px;padding:18px;box-shadow:0 24px 58px rgba(37,99,235,.10)}.lux-data-head{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px}.lux-data-head span{display:block;color:#2563eb;font-size:11px;font-weight:1000;letter-spacing:.12em}.lux-data-head h2{margin:4px 0 0;font-size:22px}.lux-list{display:grid;gap:10px}.lux-row-card{display:grid;grid-template-columns:auto 1fr auto auto;align-items:center;gap:12px;padding:13px;border-radius:20px;background:linear-gradient(135deg,#f8fbff,#fff);border:1px solid #e0ecff}.avatar-dot{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#2563eb,#06b6d4);color:#fff;font-weight:1000;box-shadow:0 12px 24px rgba(37,99,235,.18)}.avatar-dot.money{background:linear-gradient(135deg,#7c3aed,#ec4899)}.lux-row-main b{display:block}.lux-row-main span,.lux-row-time span{display:block;color:#64748b;font-size:12px;font-weight:800;margin-top:3px}.lux-row-time{text-align:right}.lux-row-time b{display:block}.lux-ann-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.lux-ann-card{border-radius:22px;padding:16px;background:linear-gradient(135deg,#eff6ff,#fff,#f5f3ff);border:1px solid #dbeafe}.lux-ann-card b{display:block}.lux-ann-card p{color:#64748b;font-weight:700;line-height:1.45}.lux-ann-card small{color:#94a3b8;font-weight:800}.settings-luxury,.settings-lux-form{position:relative}.settings-luxury:before{content:"";position:absolute;right:20px;top:10px;width:180px;height:180px;border-radius:50%;background:rgba(124,58,237,.10);filter:blur(8px);pointer-events:none}.settings-lux-hero{box-shadow:0 34px 80px rgba(124,58,237,.27)!important}.settings-subnav button{box-shadow:0 20px 50px rgba(37,99,235,.10)!important}.lux-panel{box-shadow:0 24px 58px rgba(37,99,235,.10)!important}.form-grid>div,.form-stack>div{position:relative}@media(max-width:1200px){.admin-lux-stats,.admin-lux-action-grid{grid-template-columns:repeat(2,1fr)}.admin-lux-grid-2{grid-template-columns:1fr}.lux-ann-grid{grid-template-columns:repeat(2,1fr)}.admin-lux-hero{display:block}.hero-right{min-width:0;margin-top:18px}}@media(max-width:800px){body.admin-lux-mode .sidebar{width:292px}.admin-lux-hero{padding:22px;border-radius:26px}.admin-lux-hero h1{font-size:30px}.admin-lux-stats,.admin-lux-action-grid,.lux-ann-grid{grid-template-columns:1fr}.lux-row-card{grid-template-columns:auto 1fr}.lux-row-time,.lux-row-card .badge{grid-column:2;text-align:left}.hero-buttons .btn{width:100%}.hero-right{display:block}.lux-clock-card{margin-bottom:10px}.content-wrap{padding:13px}}


/* V33 - Login super profesional */
.login-v33-body{position:relative;min-height:100vh;overflow-x:hidden;background:#081225;color:#fff}
.login-v33-bg{position:fixed;inset:0;background:radial-gradient(circle at 10% 15%,rgba(59,130,246,.22),transparent 22%),radial-gradient(circle at 88% 18%,rgba(168,85,247,.24),transparent 20%),radial-gradient(circle at 55% 80%,rgba(236,72,153,.18),transparent 22%),linear-gradient(135deg,#050b16 0%,#09162b 35%,#0e2244 65%,#111827 100%);z-index:0}
.login-v33-noise{position:fixed;inset:0;pointer-events:none;background-image:radial-gradient(rgba(255,255,255,.06) .7px, transparent .7px);background-size:18px 18px;mix-blend-mode:soft-light;opacity:.22;z-index:0}
.login-v33-orb{position:fixed;border-radius:999px;filter:blur(30px);opacity:.45;pointer-events:none;z-index:0}.login-v33-orb.orb-one{width:220px;height:220px;left:-40px;top:80px;background:#38bdf8}.login-v33-orb.orb-two{width:300px;height:300px;right:-70px;top:120px;background:#a855f7}.login-v33-orb.orb-three{width:260px;height:260px;left:45%;bottom:-90px;background:#ec4899}
.login-v33-shell{position:relative;z-index:1;display:grid;grid-template-columns:1.12fr .88fr;gap:24px;align-items:stretch;min-height:100vh;padding:28px}
.login-v33-hero,.login-v33-panel{position:relative;border:1px solid rgba(255,255,255,.12);box-shadow:0 24px 60px rgba(0,0,0,.35),inset 0 1px 0 rgba(255,255,255,.08);backdrop-filter:blur(18px)}
.login-v33-hero{border-radius:36px;padding:28px;background:linear-gradient(145deg,rgba(255,255,255,.10),rgba(255,255,255,.03));display:grid;gap:22px;overflow:hidden}
.login-v33-hero:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,.10),transparent 32%,transparent 70%,rgba(255,255,255,.07));pointer-events:none}
.login-v33-panel{border-radius:36px;padding:28px;background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(243,247,255,.94));color:#0f172a;overflow:hidden;display:grid;align-content:start}
.login-v33-panel-shine{position:absolute;inset:-1px auto auto -10%;width:65%;height:220px;background:radial-gradient(circle,rgba(255,255,255,.85),transparent 62%);opacity:.35;pointer-events:none}
.login-v33-brand-row{display:flex;justify-content:space-between;gap:14px;align-items:center;flex-wrap:wrap}.login-v33-brand{display:flex;align-items:center;gap:14px}.login-v33-logo{width:66px;height:66px;border-radius:22px;background:linear-gradient(145deg,rgba(255,255,255,.95),rgba(191,219,254,.92));display:grid;place-items:center;overflow:hidden;box-shadow:0 18px 38px rgba(8,18,37,.24)}.login-v33-logo img{width:100%;height:100%;object-fit:contain}.login-v33-logo span{font-size:24px;font-weight:900;color:#1d4ed8}.login-v33-brand b{display:block;font-size:17px}.login-v33-brand span{display:block;color:#dbeafe;font-size:12px;margin-top:3px}.login-v33-chip{padding:10px 14px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.14);color:#fff;font-weight:900;font-size:12px;backdrop-filter:blur(8px)}
.login-v33-copy{max-width:760px}.login-v33-eyebrow{display:inline-flex;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.18);font-size:11px;font-weight:900;letter-spacing:.14em;text-transform:uppercase;color:#bfdbfe}.login-v33-copy h1{margin:16px 0 12px;font-size:44px;line-height:1.05;letter-spacing:-.045em;text-shadow:0 10px 30px rgba(0,0,0,.28)}.login-v33-copy p{margin:0;color:#e2e8f0;font-size:15px;line-height:1.8;max-width:720px}
.login-v33-feature-grid{display:grid;grid-template-columns:1.2fr 1fr 1fr;gap:14px}.login-v33-feature{display:flex;gap:12px;padding:18px;border-radius:24px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.12);min-height:118px}.login-v33-feature.large{grid-row:span 2;min-height:250px;align-items:flex-start;background:linear-gradient(145deg,rgba(37,99,235,.28),rgba(15,23,42,.18))}.login-v33-feature i{flex:0 0 54px;width:54px;height:54px;border-radius:18px;display:grid;place-items:center;background:rgba(255,255,255,.16);font-style:normal;font-size:24px}.login-v33-feature b{display:block;font-size:15px;margin-bottom:6px}.login-v33-feature span{display:block;color:#dbeafe;font-size:12px;line-height:1.6}
.login-v33-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.login-v33-stats div{padding:16px 18px;border-radius:22px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.11)}.login-v33-stats b{display:block;font-size:14px}.login-v33-stats span{display:block;color:#dbeafe;font-size:12px;margin-top:4px}
.login-v33-panel-head{position:relative;z-index:1;margin-bottom:16px}.login-v33-badge{display:inline-flex;padding:9px 13px;border-radius:999px;background:linear-gradient(135deg,#dbeafe,#eff6ff);color:#1d4ed8;font-size:12px;font-weight:900;border:1px solid #bfdbfe}.login-v33-panel-head h2{margin:14px 0 6px;font-size:34px;line-height:1.05;letter-spacing:-.04em;color:#0f172a}.login-v33-panel-head p{margin:0;color:#64748b;line-height:1.7}
.login-v33-form{display:grid;gap:14px;position:relative;z-index:1}.login-v33-field label{display:block;font-size:12px;font-weight:900;color:#334155;margin-bottom:7px}.login-v33-input{display:flex;align-items:center;gap:12px;padding:4px 14px;border-radius:20px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbeafe;box-shadow:0 12px 24px rgba(37,99,235,.06)}.login-v33-input span{font-size:18px}.login-v33-input input{border:0;background:transparent;box-shadow:none;padding:14px 0;border-radius:0}.login-v33-input input:focus{box-shadow:none}.login-v33-note-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}.login-v33-mini-note{display:flex;align-items:center;gap:8px;padding:11px 12px;border-radius:16px;background:#f8fbff;border:1px solid #e2e8f0;color:#475569;font-weight:800;font-size:12px}.login-v33-mini-note i{font-style:normal}.login-v33-btn{margin-top:6px;border-radius:20px;padding:15px 18px;background:linear-gradient(135deg,#0f172a,#1d4ed8 48%,#7c3aed);box-shadow:0 18px 35px rgba(29,78,216,.26);font-size:15px}
.login-v33-access-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px;position:relative;z-index:1}.login-v33-access-grid>div{padding:15px;border-radius:20px;background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbeafe;box-shadow:0 10px 18px rgba(15,23,42,.04)}.login-v33-access-grid b{display:block;font-size:14px;margin-bottom:5px}.login-v33-access-grid span{display:block;color:#64748b;font-size:12px;line-height:1.6}.login-v33-demo{margin-top:15px;position:relative;z-index:1;border:1px solid #dbeafe;background:#fff;border-radius:20px;padding:2px 14px}.login-v33-demo summary{cursor:pointer;list-style:none;padding:14px 0;font-weight:900;color:#1e3a8a}.login-v33-demo summary::-webkit-details-marker{display:none}.login-v33-demo-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:0 0 14px}.login-v33-demo-grid>div{background:#f8fbff;border:1px solid #e2e8f0;border-radius:16px;padding:12px;display:grid;gap:6px}.login-v33-demo-grid b{display:block}.login-v33-demo-grid code{display:block;background:#0f172a;color:#f8fafc;border-radius:12px;padding:8px 10px;font-size:12px;overflow:auto}
.login-v33-footer-note{margin-top:15px;padding:14px 15px;border-radius:18px;background:linear-gradient(180deg,#fff7ed,#fff);border:1px solid #fed7aa;color:#9a3412;line-height:1.7;position:relative;z-index:1}
@media (max-width:1200px){.login-v33-shell{grid-template-columns:1fr}.login-v33-copy h1{font-size:38px}.login-v33-feature-grid{grid-template-columns:1fr 1fr}.login-v33-feature.large{grid-column:1 / -1;grid-row:auto;min-height:140px}.login-v33-stats{grid-template-columns:1fr 1fr 1fr}}
@media (max-width:800px){.login-v33-shell{padding:14px;gap:14px;min-height:auto}.login-v33-hero,.login-v33-panel{border-radius:24px;padding:18px}.login-v33-brand-row{align-items:flex-start}.login-v33-logo{width:56px;height:56px;border-radius:18px}.login-v33-copy h1{font-size:29px}.login-v33-copy p{font-size:13px;line-height:1.72}.login-v33-feature-grid,.login-v33-stats,.login-v33-access-grid,.login-v33-demo-grid,.login-v33-note-row{grid-template-columns:1fr}.login-v33-feature{min-height:auto;border-radius:18px;padding:14px}.login-v33-feature.large{min-height:auto}.login-v33-panel-head h2{font-size:27px}.login-v33-btn{padding:14px 16px}.login-v33-input{border-radius:17px}.login-v33-demo{border-radius:18px}.login-v33-footer-note{border-radius:16px}}


/* V34 - Login diperkecil agar lebih ringkas */
.login-v33-shell{max-width:1180px;margin:0 auto;min-height:100vh;padding:22px;grid-template-columns:1.04fr .82fr;gap:18px;align-items:center}
.login-v33-hero{border-radius:28px;padding:22px;gap:16px;align-content:center;min-height:620px}
.login-v33-panel{border-radius:28px;padding:22px;max-width:430px;width:100%;justify-self:center}
.login-v33-logo{width:54px;height:54px;border-radius:18px}.login-v33-brand b{font-size:15px}.login-v33-brand span{font-size:11px}.login-v33-chip{padding:8px 11px;font-size:11px}
.login-v33-eyebrow{padding:7px 10px;font-size:10px}.login-v33-copy h1{font-size:34px;line-height:1.06;margin:12px 0 9px}.login-v33-copy p{font-size:13px;line-height:1.65;max-width:650px}
.login-v33-feature-grid{gap:10px}.login-v33-feature{min-height:92px;border-radius:18px;padding:13px;gap:10px}.login-v33-feature.large{min-height:200px}.login-v33-feature i{width:44px;height:44px;flex-basis:44px;border-radius:15px;font-size:20px}.login-v33-feature b{font-size:13px;margin-bottom:4px}.login-v33-feature span{font-size:11px;line-height:1.45}
.login-v33-stats{gap:9px}.login-v33-stats div{padding:12px 13px;border-radius:17px}.login-v33-stats b{font-size:12px}.login-v33-stats span{font-size:11px}
.login-v33-panel-head{margin-bottom:12px}.login-v33-badge{padding:7px 10px;font-size:11px}.login-v33-panel-head h2{font-size:26px;margin:10px 0 5px}.login-v33-panel-head p{font-size:12px;line-height:1.55}
.login-v33-form{gap:11px}.login-v33-field label{font-size:11px;margin-bottom:6px}.login-v33-input{border-radius:16px;padding:2px 12px}.login-v33-input input{padding:12px 0;font-size:13px}.login-v33-input span{font-size:16px}
.login-v33-note-row{gap:8px}.login-v33-mini-note{padding:9px 10px;border-radius:14px;font-size:11px}.login-v33-btn{border-radius:16px;padding:13px 15px;font-size:14px}
.login-v33-access-grid{gap:9px;margin-top:12px}.login-v33-access-grid>div{padding:12px;border-radius:16px}.login-v33-access-grid b{font-size:12px}.login-v33-access-grid span{font-size:11px;line-height:1.45}
.login-v33-demo{margin-top:11px;border-radius:16px;padding:1px 12px}.login-v33-demo summary{padding:11px 0;font-size:12px}.login-v33-demo-grid{gap:8px;padding-bottom:11px}.login-v33-demo-grid>div{border-radius:13px;padding:10px}.login-v33-demo-grid code{padding:7px 8px;font-size:11px}
.login-v33-footer-note{margin-top:11px;padding:11px 12px;border-radius:15px;font-size:11px;line-height:1.55}
.login-v33-orb.orb-one{width:170px;height:170px}.login-v33-orb.orb-two{width:230px;height:230px}.login-v33-orb.orb-three{width:210px;height:210px}
@media (max-width:1200px){.login-v33-shell{max-width:960px;grid-template-columns:1fr}.login-v33-hero{min-height:auto}.login-v33-panel{max-width:520px}.login-v33-copy h1{font-size:31px}.login-v33-feature.large{min-height:120px}}
@media (max-width:800px){.login-v33-shell{padding:10px;gap:10px}.login-v33-hero,.login-v33-panel{border-radius:20px;padding:14px}.login-v33-logo{width:46px;height:46px;border-radius:15px}.login-v33-chip{display:none}.login-v33-copy h1{font-size:23px;margin:9px 0 7px}.login-v33-copy p{font-size:12px;line-height:1.55}.login-v33-feature{padding:10px;border-radius:15px}.login-v33-feature i{width:38px;height:38px;flex-basis:38px;border-radius:13px;font-size:18px}.login-v33-stats div{padding:10px}.login-v33-panel-head h2{font-size:23px}.login-v33-input input{padding:11px 0}.login-v33-access-grid{display:none}.login-v33-footer-note{font-size:10.5px}}


/* V35 - Tema super premium seluruh website */
.premium-global-theme{background:
 radial-gradient(circle at 0% 0%, rgba(59,130,246,.16), transparent 24%),
 radial-gradient(circle at 100% 10%, rgba(168,85,247,.14), transparent 22%),
 radial-gradient(circle at 50% 100%, rgba(236,72,153,.10), transparent 20%),
 linear-gradient(180deg,#f7faff 0%,#eef4ff 42%,#f8fbff 100%)}
.premium-global-theme .main-content{background:transparent}
.premium-global-theme .content-wrap{max-width:1520px;padding:24px}
.premium-global-theme .sidebar{background:linear-gradient(180deg,#071225 0%,#0f1f3d 30%,#182b58 68%,#21194e 100%);border-right:1px solid rgba(255,255,255,.08);box-shadow:22px 0 50px rgba(2,6,23,.22)}
.premium-global-theme .brand{background:linear-gradient(135deg,rgba(255,255,255,.16),rgba(255,255,255,.08));border:1px solid rgba(255,255,255,.10);box-shadow:inset 0 1px 0 rgba(255,255,255,.10),0 18px 34px rgba(2,6,23,.16);border-radius:22px;padding:14px}
.premium-global-theme .brand-logo{background:linear-gradient(135deg,#ffffff,#dbeafe);box-shadow:0 14px 28px rgba(15,23,42,.16);width:54px;height:54px;border-radius:18px}.premium-global-theme .brand-fallback{font-size:18px;font-weight:900}
.premium-nav-menu{gap:9px}.premium-nav-menu a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:16px;font-weight:800;color:#e8efff;position:relative;transition:.18s;background:rgba(255,255,255,.03);border:1px solid transparent}.premium-nav-menu a span{flex:1}.premium-nav-menu a:hover{background:rgba(255,255,255,.10);border-color:rgba(255,255,255,.08);transform:translateX(2px)}.premium-nav-menu a.active{background:linear-gradient(135deg,rgba(37,99,235,.95),rgba(124,58,237,.92));color:#fff;border-color:rgba(255,255,255,.12);box-shadow:0 16px 32px rgba(37,99,235,.24)}
.premium-nav-menu .nav-ico{flex:0 0 36px;width:36px;height:36px;border-radius:12px;display:grid;place-items:center;background:rgba(255,255,255,.10);font-size:15px;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)}.premium-nav-menu a.active .nav-ico{background:rgba(255,255,255,.18)}
.premium-global-theme .topbar{background:linear-gradient(135deg,rgba(255,255,255,.88),rgba(255,255,255,.72));border-bottom:1px solid rgba(191,219,254,.7);box-shadow:0 12px 32px rgba(15,23,42,.06);backdrop-filter:blur(18px)}
.premium-global-theme .hamburger{background:linear-gradient(135deg,#0f172a,#1d4ed8);box-shadow:0 12px 25px rgba(29,78,216,.2)}.premium-global-theme .top-title b{font-size:18px;letter-spacing:-.02em}.premium-global-theme .top-title span{color:#475569}
.premium-global-theme .notif,.premium-global-theme .user-chip{background:linear-gradient(180deg,#fff,#f8fbff);border:1px solid #dbeafe;box-shadow:0 12px 24px rgba(15,23,42,.06)}.premium-global-theme .notif{font-size:16px}.premium-global-theme .user-chip{gap:10px}.premium-global-theme .user-chip i{font-size:18px;color:#1d4ed8}.premium-global-theme .user-chip b{background:linear-gradient(135deg,#dbeafe,#eef2ff);color:#1d4ed8}
.premium-global-theme .card,.premium-global-theme .stat-card,.premium-global-theme .modern-card-pro,.premium-global-theme .attendance-today-pro,.premium-global-theme .employee-info-card-pro,.premium-global-theme .login-card,.premium-global-theme .map-card,.premium-global-theme .coord-panel,.premium-global-theme .selfie-panel,.premium-global-theme .notice{background:linear-gradient(180deg,rgba(255,255,255,.97),rgba(248,251,255,.96));border:1px solid #d9e7ff;box-shadow:0 20px 40px rgba(15,23,42,.07), inset 0 1px 0 rgba(255,255,255,.65)}
.premium-global-theme .card,.premium-global-theme .stat-card,.premium-global-theme .modern-card-pro,.premium-global-theme .attendance-today-pro{border-radius:24px}
.premium-global-theme .hero-card{background:linear-gradient(135deg,#09152f 0%,#1d4ed8 35%,#7c3aed 72%,#db2777 100%);box-shadow:0 28px 56px rgba(29,78,216,.24)}
.premium-global-theme .btn{border-radius:16px;padding:11px 15px;font-weight:900;box-shadow:0 10px 20px rgba(15,23,42,.05)}.premium-global-theme .btn.primary{background:linear-gradient(135deg,#1d4ed8,#7c3aed)}.premium-global-theme .btn.success{background:linear-gradient(135deg,#16a34a,#059669)}.premium-global-theme .btn.warn{background:linear-gradient(135deg,#f59e0b,#ea580c)}.premium-global-theme .btn.danger{background:linear-gradient(135deg,#ef4444,#dc2626)}
.premium-global-theme input,.premium-global-theme select,.premium-global-theme textarea{border-radius:16px;border:1px solid #cfe1ff;background:linear-gradient(180deg,#ffffff,#fbfdff);box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 8px 18px rgba(15,23,42,.03)}.premium-global-theme input:focus,.premium-global-theme select:focus,.premium-global-theme textarea:focus{border-color:#7c3aed;box-shadow:0 0 0 4px rgba(124,58,237,.10),0 12px 26px rgba(29,78,216,.08)}
.premium-global-theme th{background:linear-gradient(135deg,#eff6ff,#eef2ff);color:#1e3a8a}.premium-global-theme .table-wrap{border-radius:20px;border:1px solid #dbeafe;box-shadow:0 16px 34px rgba(15,23,42,.05)}.premium-global-theme table{background:linear-gradient(180deg,#fff,#fcfdff)}.premium-global-theme tr:hover td{background:#f8fbff}
.premium-global-theme .alert{border-radius:18px;box-shadow:0 10px 22px rgba(15,23,42,.04)}
.premium-global-theme .badge{border-radius:999px;padding:6px 10px}
.premium-global-theme .employee-dashboard-pro,.premium-global-theme .admin-dashboard-lux{position:relative;isolation:isolate}.premium-global-theme .employee-dashboard-pro:before,.premium-global-theme .admin-dashboard-lux:before{content:"";position:absolute;inset:-12px;z-index:-1;background:linear-gradient(135deg,rgba(37,99,235,.08),rgba(124,58,237,.08),rgba(236,72,153,.07));filter:blur(30px);border-radius:36px;opacity:.9}
.premium-global-theme .stats-grid .stat-card{background:linear-gradient(160deg,#ffffff,#f7fbff)}.premium-global-theme .stat-card b{font-size:28px}
.premium-global-theme .tabs a{background:linear-gradient(135deg,#f8fbff,#eef2ff);border:1px solid #dbeafe}.premium-global-theme .tabs a.active{background:linear-gradient(135deg,#1d4ed8,#7c3aed);color:#fff;border-color:transparent}
.premium-global-theme .pill{background:linear-gradient(135deg,#eef2ff,#f8fbff);border:1px solid #dbeafe}
.premium-global-theme .login-v33-panel,.premium-global-theme .login-v33-hero{box-shadow:0 28px 70px rgba(0,0,0,.28)}
@media (max-width:800px){.premium-global-theme .content-wrap{padding:14px}.premium-nav-menu a{padding:11px 12px;border-radius:14px}.premium-nav-menu .nav-ico{width:34px;height:34px}.premium-global-theme .topbar{padding:12px}.premium-global-theme .user-chip i{display:none}}


/* V36 - Final polish: semua halaman lebih rapi, icon kecil mewah, admin eksklusif */
:root{--premium-blue:#1d4ed8;--premium-purple:#7c3aed;--premium-pink:#db2777;--premium-gold:#f59e0b;--premium-navy:#071225}
.premium-global-theme{font-size:13.5px}
.premium-global-theme .content-wrap{animation:premiumFadeIn .22s ease-out}
@keyframes premiumFadeIn{from{opacity:0;transform:translateY(5px)}to{opacity:1;transform:none}}

/* Sidebar lebih kecil, elegan, premium */
.premium-global-theme .sidebar{width:272px;padding:16px}
.premium-global-theme .main-content{margin-left:272px;width:calc(100% - 272px)}
.premium-global-theme .brand{margin-bottom:14px}
.premium-global-theme .brand-logo{width:46px;height:46px;border-radius:16px}
.premium-global-theme .brand b{font-size:13px;letter-spacing:-.01em}
.premium-global-theme .brand span{font-size:11px;color:#c7d2fe}
.premium-nav-menu{gap:7px}
.premium-nav-menu a{padding:9px 11px;border-radius:14px;font-size:12.5px;min-height:42px}
.premium-nav-menu .nav-ico{flex:0 0 31px;width:31px;height:31px;border-radius:11px;font-size:13px}
.premium-nav-menu a.active:before{content:"";position:absolute;left:-3px;top:11px;bottom:11px;width:3px;border-radius:999px;background:#fbbf24;box-shadow:0 0 14px rgba(251,191,36,.75)}
.premium-nav-menu a.active .nav-ico{box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 10px 20px rgba(15,23,42,.15)}

/* Topbar premium compact */
.premium-global-theme .topbar{padding:11px 20px}
.premium-global-theme .top-title b{font-size:16px}
.premium-global-theme .top-title span{font-size:11px}
.premium-global-theme .notif{width:38px;height:38px;border-radius:14px;color:#1d4ed8}
.premium-global-theme .user-chip{padding:7px 10px}
.premium-global-theme .user-chip span{font-size:12.5px}
.premium-global-theme .premium-user-chip i{color:#f59e0b;text-shadow:0 4px 14px rgba(245,158,11,.30)}
.premium-global-theme .user-chip b{font-size:9.5px}

/* Admin/superadmin dibuat lebih eksklusif */
.admin-lux-mode .topbar{background:linear-gradient(135deg,rgba(7,18,37,.96),rgba(30,41,91,.88),rgba(29,78,216,.80));color:#fff;border-bottom:1px solid rgba(255,255,255,.12)}
.admin-lux-mode .top-title span{color:#dbeafe}
.admin-lux-mode .notif,.admin-lux-mode .user-chip{background:rgba(255,255,255,.12);color:#fff;border-color:rgba(255,255,255,.15);backdrop-filter:blur(12px)}
.admin-lux-mode .user-chip b{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#111827}
.admin-lux-mode .sidebar{background:linear-gradient(180deg,#050b16 0%,#0b1530 34%,#172554 70%,#312e81 100%)}
.admin-lux-mode .brand{background:linear-gradient(135deg,rgba(251,191,36,.16),rgba(37,99,235,.10),rgba(255,255,255,.06));border-color:rgba(251,191,36,.18)}
.admin-lux-mode .brand-logo{background:linear-gradient(135deg,#fef3c7,#ffffff,#dbeafe);color:#1e3a8a}
.admin-lux-mode .content-wrap:before{content:"SUPERADMIN PREMIUM CONTROL";display:inline-flex;margin-bottom:12px;padding:8px 12px;border-radius:999px;background:linear-gradient(135deg,#111827,#1d4ed8,#7c3aed);color:#fff;font-size:10px;font-weight:900;letter-spacing:.13em;box-shadow:0 12px 26px rgba(29,78,216,.20)}

/* Karyawan lebih soft premium */
.employee-mode .topbar{background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(239,246,255,.84))}
.employee-mode .sidebar{background:linear-gradient(180deg,#0f172a,#1e3a8a 54%,#0f766e 120%)}

/* Cards, tables, forms lebih seragam */
.premium-global-theme .card-head{border-bottom:1px solid #e6efff;padding-bottom:12px;margin-bottom:14px}
.premium-global-theme .card-head h2,.premium-global-theme .card-head h3{letter-spacing:-.025em}
.premium-global-theme .card-head h2:before,.premium-global-theme .card-head h3:before{content:"";display:inline-block;width:8px;height:8px;border-radius:999px;background:linear-gradient(135deg,#1d4ed8,#7c3aed);margin-right:8px;vertical-align:middle;box-shadow:0 0 0 4px rgba(29,78,216,.10)}
.premium-global-theme .card,.premium-global-theme .stat-card{transition:.18s}
.premium-global-theme .card:hover,.premium-global-theme .stat-card:hover{box-shadow:0 26px 54px rgba(15,23,42,.09),inset 0 1px 0 rgba(255,255,255,.75)}
.premium-global-theme label{font-size:11.5px;color:#334155;letter-spacing:.01em}
.premium-global-theme input,.premium-global-theme select,.premium-global-theme textarea{font-size:13px;padding:10px 12px}
.premium-global-theme textarea{min-height:82px}
.premium-global-theme .form-grid{gap:11px}
.premium-global-theme .btn.small{padding:6px 9px;border-radius:10px;font-size:11.5px}
.premium-global-theme .btn{min-height:38px}
.premium-global-theme .table-wrap{overflow:auto}
.premium-global-theme th{font-size:11px}
.premium-global-theme td{font-size:12.5px}
.premium-global-theme th,.premium-global-theme td{padding:10px}

/* Stats warna mewah */
.premium-global-theme .stats-grid{gap:12px}
.premium-global-theme .stat-card{position:relative;overflow:hidden;padding:16px}
.premium-global-theme .stat-card:after{content:"";position:absolute;right:-26px;top:-30px;width:92px;height:92px;border-radius:999px;background:linear-gradient(135deg,rgba(29,78,216,.12),rgba(124,58,237,.10));pointer-events:none}
.premium-global-theme .stat-card span{font-size:11px;text-transform:uppercase;letter-spacing:.06em}
.premium-global-theme .stat-card b{font-size:24px;letter-spacing:-.035em}

/* Quick menu portal karyawan lebih elegan */
.premium-global-theme .quick-menu-pro{gap:10px}
.premium-global-theme .quick-menu-pro a{border-radius:19px;min-height:112px;background:linear-gradient(160deg,#ffffff 0%,#f8fbff 64%,#eef2ff 130%);border:1px solid #dbeafe;box-shadow:0 16px 32px rgba(15,23,42,.065)}
.premium-global-theme .quick-menu-pro a:hover{transform:translateY(-3px) scale(1.01)}
.premium-global-theme .quick-menu-pro i{background:linear-gradient(135deg,#1d4ed8,#7c3aed);color:#fff;box-shadow:0 14px 26px rgba(29,78,216,.22)}
.premium-global-theme .quick-menu-pro b{letter-spacing:-.02em}

/* Pengaturan submenu dan tab terlihat premium */
.premium-global-theme .settings-nav,.premium-global-theme .setting-tabs,.premium-global-theme .lux-tabs,.premium-global-theme .tabs{padding:8px;border-radius:20px;background:linear-gradient(135deg,#ffffff,#f8fbff);border:1px solid #dbeafe;box-shadow:0 14px 28px rgba(15,23,42,.05)}
.premium-global-theme .settings-nav a,.premium-global-theme .setting-tabs a,.premium-global-theme .lux-tabs a,.premium-global-theme .tabs a{display:inline-flex;align-items:center;gap:8px;border-radius:15px}

/* Login compact tetap mewah */
.login-v33-shell{max-width:1180px;margin:0 auto}
.login-v33-copy h1{font-size:34px}
.login-v33-feature-grid{gap:10px}
.login-v33-feature{min-height:96px;padding:14px;border-radius:20px}
.login-v33-feature i{width:44px;height:44px;flex-basis:44px;font-size:20px}
.login-v33-panel{padding:22px}
.login-v33-panel-head h2{font-size:27px}
.login-v33-input{border-radius:16px}
.login-v33-input input{padding:11px 0}
.login-v33-btn{padding:13px 16px;border-radius:17px}

/* Mobile polish */
@media (max-width:800px){
  .premium-global-theme .sidebar{width:280px}
  .premium-global-theme .main-content{margin-left:0;width:100%}
  .admin-lux-mode .content-wrap:before{font-size:9px;margin-left:2px}
  .premium-global-theme .content-wrap{padding:12px}
  .premium-global-theme .card,.premium-global-theme .stat-card,.premium-global-theme .modern-card-pro,.premium-global-theme .attendance-today-pro{border-radius:19px}
  .premium-global-theme .stats-grid{gap:10px}
  .premium-global-theme .stat-card b{font-size:22px}
  .premium-global-theme .quick-menu-pro{grid-template-columns:repeat(2,1fr)}
  .premium-global-theme .quick-menu-pro a{min-height:98px;padding:11px}
  .premium-global-theme .quick-menu-pro i{width:38px;height:38px;font-size:17px}
  .premium-global-theme .table-wrap{border-radius:16px}
  .login-v33-copy h1{font-size:25px}
  .login-v33-hero,.login-v33-panel{padding:15px}
}


/* V37 - Compact UI + Light/Dark Mode */
html[data-theme="light"]{color-scheme:light}
html[data-theme="dark"]{color-scheme:dark}
:root{--compact-font:12.5px;--compact-radius:16px;--compact-gap:10px}
body{font-size:var(--compact-font)!important}.content-wrap{padding:16px!important}.sidebar{width:252px!important;padding:13px!important}.main-content{margin-left:252px!important;width:calc(100% - 252px)!important}.brand{padding:10px!important;border-radius:16px!important}.brand-logo{width:42px!important;height:42px!important;border-radius:14px!important}.brand b{font-size:12px!important}.brand span{font-size:10.5px!important}.nav-menu{gap:5px!important}.premium-nav-menu a,.nav-menu a{padding:8px 10px!important;border-radius:12px!important;font-size:11.5px!important}.premium-nav-menu .nav-ico{width:28px!important;height:28px!important;flex-basis:28px!important;border-radius:10px!important;font-size:12px!important}.topbar{padding:9px 15px!important}.top-title b{font-size:14px!important}.top-title span{font-size:10.5px!important}.hamburger,.notif{width:34px!important;height:34px!important;border-radius:11px!important}.user-chip{padding:6px 9px!important;font-size:11.5px!important}.user-chip b{font-size:9px!important;padding:3px 6px!important}.card,.stat-card,.modern-card-pro,.attendance-today-pro,.map-card,.coord-panel,.selfie-panel,.notice{padding:13px!important;border-radius:var(--compact-radius)!important;margin:10px 0!important}.card-head{margin-bottom:10px!important}.card-head h2,.card-head h3{font-size:16px!important}.card-head span{font-size:10.5px!important}.stats-grid{gap:10px!important;margin:10px 0!important}.stat-card b{font-size:20px!important}.stat-card span,.stat-card small{font-size:10.5px!important}.grid-2,.grid-3,.dashboard-grid-pro{gap:10px!important}.btn{padding:8px 11px!important;border-radius:12px!important;font-size:11.5px!important}.btn.small{padding:5px 8px!important;border-radius:9px!important;font-size:10.5px!important}input,select,textarea{padding:9px 10px!important;border-radius:12px!important;font-size:12px!important}label{font-size:10.5px!important;margin-bottom:5px!important}textarea{min-height:70px!important}.form-grid,.form-stack{gap:9px!important}.table-wrap{border-radius:13px!important}th,td{padding:8px 9px!important;font-size:11.5px!important}th{font-size:10px!important}.badge{padding:4px 7px!important;font-size:9.5px!important}.alert{padding:10px 12px!important;border-radius:13px!important}.hero-card{padding:18px!important;border-radius:20px!important}.hero-card h1{font-size:24px!important}.hero-card p{font-size:12px!important}.employee-hero-pro{min-height:180px!important;padding:18px!important;border-radius:22px!important}.employee-hero-pro h1{font-size:25px!important}.employee-hero-pro p{font-size:12px!important}.hero-kicker{font-size:10px!important;padding:6px 9px!important}.hero-action-row{gap:7px!important;margin-top:12px!important}.profile-avatar-pro{width:58px!important;height:58px!important;border-radius:17px!important;font-size:25px!important}.quick-menu-pro{gap:8px!important}.quick-menu-pro a{min-height:92px!important;padding:10px!important;border-radius:14px!important}.quick-menu-pro i{width:34px!important;height:34px!important;border-radius:12px!important;font-size:16px!important}.quick-menu-pro b{font-size:11.5px!important}.quick-menu-pro span{font-size:10px!important}.section-title-pro{margin-bottom:9px!important}.section-title-pro b{font-size:14px!important}.section-title-pro span{font-size:10.5px!important}.time-node{padding:10px!important;border-radius:14px!important}.time-node b{font-size:20px!important}.mini-stats-pro{gap:8px!important}.mini-stats-pro div{padding:10px!important;border-radius:13px!important}.mini-stats-pro b{font-size:20px!important}.gps-map{height:250px!important}.coord-grid{gap:8px!important}.coord-item{padding:9px!important;border-radius:12px!important}.coord-item b{font-size:11.5px!important}.coord-item span{font-size:10px!important}.selfie-stage{min-height:235px!important}.slip-card{padding:18px!important;border-radius:18px!important}.login-v33-shell{padding:16px!important;gap:14px!important}.login-v33-hero,.login-v33-panel{border-radius:22px!important;padding:18px!important}.login-v33-copy h1{font-size:29px!important}.login-v33-copy p{font-size:12px!important}.login-v33-logo{width:48px!important;height:48px!important;border-radius:15px!important}.login-v33-feature{min-height:88px!important;padding:12px!important;border-radius:16px!important}.login-v33-feature.large{min-height:170px!important}.login-v33-feature i{width:38px!important;height:38px!important;flex-basis:38px!important;border-radius:13px!important;font-size:17px!important}.login-v33-panel-head h2{font-size:24px!important}.login-v33-input{border-radius:14px!important}.login-v33-input input{padding:10px 0!important}.login-v33-btn{padding:11px 14px!important;border-radius:14px!important}.login-v33-access-grid>div,.login-v33-demo,.login-v33-footer-note{border-radius:14px!important;padding:10px!important}.login-v33-stats div{padding:10px!important;border-radius:14px!important}.login-v33-demo-grid code{padding:6px 8px!important;font-size:10.5px!important}.theme-toggle,.login-theme-toggle{border:1px solid #dbeafe;background:linear-gradient(180deg,#fff,#f8fbff);color:#1e3a8a;box-shadow:0 10px 22px rgba(15,23,42,.06);border-radius:999px;font-weight:900;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:6px}.theme-toggle{height:34px;padding:0 10px;font-size:11px}.theme-toggle i{font-size:12px}.login-theme-toggle{position:fixed;right:18px;top:18px;z-index:20;height:34px;padding:0 11px;font-size:11px}.login-theme-toggle span{font-size:13px}.login-theme-toggle b{font-size:11px}
@media (max-width:800px){.sidebar{width:248px!important}.main-content{margin-left:0!important;width:100%!important}.content-wrap{padding:10px!important}.theme-toggle span{display:none}.theme-toggle{width:34px;padding:0}.login-theme-toggle{right:12px;top:12px}.login-v33-shell{padding:10px!important}.quick-menu-pro{grid-template-columns:repeat(3,1fr)!important}.quick-menu-pro a{min-height:84px!important}.stats-grid{grid-template-columns:1fr 1fr!important}.top-actions{gap:6px!important}.user-chip span{display:none!important}}
@media (max-width:430px){.quick-menu-pro{grid-template-columns:repeat(2,1fr)!important}.stats-grid{grid-template-columns:1fr!important}.card,.stat-card,.modern-card-pro,.attendance-today-pro{padding:11px!important}.login-v33-hero,.login-v33-panel{padding:14px!important}.login-v33-copy h1{font-size:24px!important}}
html[data-theme="dark"] body,html[data-theme="dark"] .premium-global-theme{background:radial-gradient(circle at 0% 0%,rgba(59,130,246,.18),transparent 23%),radial-gradient(circle at 100% 8%,rgba(124,58,237,.20),transparent 22%),linear-gradient(180deg,#060b16 0%,#0a1222 50%,#0f172a 100%)!important;color:#e5e7eb!important}html[data-theme="dark"] .sidebar{background:linear-gradient(180deg,#020617 0%,#071226 46%,#111827 100%)!important;border-right-color:rgba(148,163,184,.12)!important}html[data-theme="dark"] .brand,html[data-theme="dark"] .premium-nav-menu a{background:rgba(255,255,255,.04)!important;border-color:rgba(148,163,184,.10)!important}html[data-theme="dark"] .premium-nav-menu a:hover{background:rgba(255,255,255,.08)!important}html[data-theme="dark"] .premium-nav-menu a.active{background:linear-gradient(135deg,#1d4ed8,#7c3aed)!important}html[data-theme="dark"] .topbar{background:linear-gradient(135deg,rgba(15,23,42,.92),rgba(17,24,39,.78))!important;border-bottom-color:rgba(148,163,184,.14)!important}html[data-theme="dark"] .top-title span{color:#94a3b8!important}html[data-theme="dark"] .card,html[data-theme="dark"] .stat-card,html[data-theme="dark"] .modern-card-pro,html[data-theme="dark"] .attendance-today-pro,html[data-theme="dark"] .employee-info-card-pro,html[data-theme="dark"] .map-card,html[data-theme="dark"] .coord-panel,html[data-theme="dark"] .selfie-panel,html[data-theme="dark"] .notice,html[data-theme="dark"] .time-node,html[data-theme="dark"] .mini-stats-pro div,html[data-theme="dark"] .coord-item,html[data-theme="dark"] .user-chip,html[data-theme="dark"] .notif{background:linear-gradient(180deg,rgba(15,23,42,.96),rgba(17,24,39,.92))!important;border-color:rgba(148,163,184,.16)!important;color:#e5e7eb!important;box-shadow:0 18px 38px rgba(0,0,0,.26)!important}html[data-theme="dark"] .card-head span,html[data-theme="dark"] .stat-card span,html[data-theme="dark"] .stat-card small,html[data-theme="dark"] .notice p,html[data-theme="dark"] .section-title-pro span,html[data-theme="dark"] .quick-menu-pro span,html[data-theme="dark"] .time-node span,html[data-theme="dark"] .coord-item span,html[data-theme="dark"] .profile-list p,html[data-theme="dark"] .hint{color:#94a3b8!important}html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#0b1220!important;border-color:rgba(148,163,184,.22)!important;color:#e5e7eb!important}html[data-theme="dark"] input::placeholder,html[data-theme="dark"] textarea::placeholder{color:#64748b!important}html[data-theme="dark"] label{color:#cbd5e1!important}html[data-theme="dark"] table{background:#0f172a!important;color:#e5e7eb!important}html[data-theme="dark"] th{background:linear-gradient(135deg,#0f1e3a,#111827)!important;color:#bfdbfe!important}html[data-theme="dark"] td{border-bottom-color:rgba(148,163,184,.13)!important}html[data-theme="dark"] tr:hover td{background:#111c31!important}html[data-theme="dark"] .table-wrap{border-color:rgba(148,163,184,.18)!important}html[data-theme="dark"] .btn{box-shadow:0 10px 22px rgba(0,0,0,.20)!important}html[data-theme="dark"] .btn:not(.primary):not(.success):not(.danger):not(.warn):not(.ghost){background:#111827!important;color:#bfdbfe!important;border:1px solid rgba(148,163,184,.16)!important}html[data-theme="dark"] .theme-toggle,html[data-theme="dark"] .login-theme-toggle{background:linear-gradient(180deg,#111827,#0b1220)!important;border-color:rgba(148,163,184,.22)!important;color:#f8fafc!important}html[data-theme="dark"] .alert.info{background:#0f1e3a!important;color:#bfdbfe!important;border-color:#1d4ed8!important}html[data-theme="dark"] .alert.success{background:#052e1a!important;color:#bbf7d0!important;border-color:#166534!important}html[data-theme="dark"] .alert.danger{background:#3a0a0a!important;color:#fecaca!important;border-color:#991b1b!important}html[data-theme="dark"] .alert.warning{background:#3b2605!important;color:#fde68a!important;border-color:#92400e!important}html[data-theme="dark"] .login-v33-body{background:#050b16!important}html[data-theme="dark"] .login-v33-panel{background:linear-gradient(180deg,rgba(15,23,42,.96),rgba(17,24,39,.94))!important;color:#e5e7eb!important;border-color:rgba(148,163,184,.16)!important}html[data-theme="dark"] .login-v33-panel-head h2{color:#f8fafc!important}html[data-theme="dark"] .login-v33-panel-head p,html[data-theme="dark"] .login-v33-access-grid span{color:#94a3b8!important}html[data-theme="dark"] .login-v33-input,html[data-theme="dark"] .login-v33-access-grid>div,html[data-theme="dark"] .login-v33-demo,html[data-theme="dark"] .login-v33-mini-note{background:#0b1220!important;border-color:rgba(148,163,184,.18)!important;color:#e5e7eb!important}html[data-theme="dark"] .login-v33-footer-note{background:#251706!important;color:#fed7aa!important;border-color:#92400e!important}html[data-theme="dark"] .gps-map{filter:saturate(.85) brightness(.82)!important}


/* V38 - Icon menu luxury + auto NIP + dokumen karyawan */
.premium-nav-menu a{overflow:hidden;isolation:isolate}.premium-nav-menu a:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.12),transparent 45%);opacity:0;transition:.18s;pointer-events:none}.premium-nav-menu a:hover:before,.premium-nav-menu a.active:before{opacity:1}.premium-nav-menu .nav-ico{position:relative;overflow:hidden;color:#fff;background:linear-gradient(135deg,#1d4ed8,#7c3aed)!important;box-shadow:0 10px 22px rgba(37,99,235,.25),inset 0 1px 0 rgba(255,255,255,.25)!important}.premium-nav-menu .nav-ico:after{content:"";position:absolute;inset:-40%;background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);transform:translateX(-120%) rotate(20deg);transition:.38s}.premium-nav-menu a:hover .nav-ico:after,.premium-nav-menu a.active .nav-ico:after{transform:translateX(120%) rotate(20deg)}
.premium-nav-menu a:nth-child(2n) .nav-ico{background:linear-gradient(135deg,#0891b2,#2563eb)!important}.premium-nav-menu a:nth-child(3n) .nav-ico{background:linear-gradient(135deg,#7c3aed,#db2777)!important}.premium-nav-menu a:nth-child(4n) .nav-ico{background:linear-gradient(135deg,#16a34a,#0f766e)!important}.premium-nav-menu a:nth-child(5n) .nav-ico{background:linear-gradient(135deg,#f59e0b,#ea580c)!important}.premium-nav-menu a span{letter-spacing:-.01em}.premium-nav-menu a.active{box-shadow:0 16px 34px rgba(37,99,235,.28),inset 0 1px 0 rgba(255,255,255,.16)}
.employee-form-card{position:relative;overflow:hidden}.employee-form-card:before{content:"";position:absolute;right:-70px;top:-70px;width:190px;height:190px;border-radius:999px;background:radial-gradient(circle,rgba(124,58,237,.20),transparent 68%);pointer-events:none}.employee-form-card .card-head h2{display:flex;align-items:center;gap:10px}.employee-premium-form{position:relative}.employee-premium-form label{display:flex;align-items:center;gap:7px}.file-card-premium{padding:14px;border:1px solid #dbeafe;border-radius:20px;background:linear-gradient(180deg,#ffffff,#f8fbff);box-shadow:0 12px 24px rgba(15,23,42,.04)}.file-card-premium label{font-weight:900;color:#1e3a8a;margin-bottom:8px}.file-card-premium label i{width:32px;height:32px;border-radius:12px;background:linear-gradient(135deg,#dbeafe,#eef2ff);display:grid;place-items:center;color:#1d4ed8}.file-card-premium input[type=file]{padding:10px;background:#fff;border-style:dashed}.employee-doc-pills{display:grid;gap:6px;min-width:110px}.employee-doc-pills a,.employee-doc-pills span{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 9px;font-size:11px;font-weight:900;background:linear-gradient(135deg,#eff6ff,#f8fbff);border:1px solid #dbeafe;color:#1e40af}.employee-doc-pills span{color:#64748b;background:#f8fafc}.doc-empty{color:#94a3b8;font-weight:900}.photo-thumb{border:2px solid #dbeafe;box-shadow:0 8px 18px rgba(15,23,42,.10)}
html[data-theme="dark"] .file-card-premium{background:linear-gradient(180deg,#111827,#0b1220);border-color:rgba(148,163,184,.22)}html[data-theme="dark"] .file-card-premium label{color:#dbeafe}html[data-theme="dark"] .file-card-premium input[type=file]{background:#0f172a;border-color:rgba(148,163,184,.25);color:#e5e7eb}html[data-theme="dark"] .employee-doc-pills a{background:rgba(37,99,235,.14);border-color:rgba(96,165,250,.25);color:#bfdbfe}html[data-theme="dark"] .employee-doc-pills span{background:rgba(148,163,184,.10);border-color:rgba(148,163,184,.18);color:#94a3b8}
@media (max-width:800px){.file-card-premium{padding:12px;border-radius:17px}.employee-doc-pills{min-width:0}.employee-doc-pills a,.employee-doc-pills span{font-size:10px;padding:5px 7px}}


/* V39 - Menu navigasi grouped + user superadmin/admin */
.grouped-nav-menu{gap:8px}.grouped-nav-menu .nav-main,.grouped-nav-menu .nav-logout{display:flex;align-items:center;gap:10px}
.nav-group{border-radius:17px;background:linear-gradient(135deg,rgba(255,255,255,.055),rgba(255,255,255,.025));border:1px solid rgba(255,255,255,.06);overflow:hidden;transition:.2s}.nav-group[open]{background:linear-gradient(135deg,rgba(37,99,235,.18),rgba(124,58,237,.12));border-color:rgba(255,255,255,.12);box-shadow:0 16px 28px rgba(2,6,23,.14)}.nav-group summary{list-style:none;cursor:pointer;display:flex;align-items:center;gap:10px;padding:10px 12px;color:#eaf1ff;font-weight:900;font-size:12.5px}.nav-group summary::-webkit-details-marker{display:none}.nav-group summary span{flex:1}.nav-group summary em{font-style:normal;font-size:10px;opacity:.82;transition:.2s}.nav-group[open] summary em{transform:rotate(180deg)}.nav-group summary .nav-ico{flex:0 0 30px;width:30px;height:30px;border-radius:11px;background:linear-gradient(135deg,rgba(255,255,255,.18),rgba(255,255,255,.08));display:grid;place-items:center;color:#fff;box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.nav-sub{display:grid;gap:6px;padding:0 8px 9px 12px}.nav-sub a{display:flex!important;align-items:center;gap:9px;margin-left:8px;padding:9px 10px!important;border-radius:13px!important;font-size:12px!important;background:rgba(255,255,255,.045)!important;color:#dbeafe!important;border:1px solid transparent}.nav-sub a i{width:22px;height:22px;border-radius:8px;display:grid;place-items:center;background:rgba(255,255,255,.09);font-size:11px}.nav-sub a:hover,.nav-sub a.active{background:linear-gradient(135deg,rgba(59,130,246,.34),rgba(168,85,247,.24))!important;color:#fff!important;border-color:rgba(255,255,255,.12);transform:translateX(2px)}.nav-sub a.active i{background:rgba(255,255,255,.18)}.grouped-nav-menu .nav-logout{margin-top:6px;background:linear-gradient(135deg,rgba(239,68,68,.20),rgba(249,115,22,.12))!important;border:1px solid rgba(248,113,113,.18)!important;color:#fff!important}
.premium-global-theme .premium-nav-menu .nav-ico{width:30px;height:30px;flex-basis:30px;border-radius:11px}.premium-global-theme .premium-nav-menu a{font-size:12.5px;padding:10px 12px}.premium-global-theme .sidebar{width:266px}.premium-global-theme .main-content{margin-left:266px;width:calc(100% - 266px)}
.admin-user-panel,.admin-user-list-panel{margin-top:16px}.admin-user-form{align-items:end}.admin-user-actions{display:flex;gap:9px;align-items:end;flex-wrap:wrap}.role-pill{display:inline-flex;align-items:center;gap:7px;border-radius:999px;padding:7px 10px;font-size:11px;font-weight:950;letter-spacing:.03em}.role-pill.superadmin{background:linear-gradient(135deg,#fef3c7,#fde68a);color:#92400e;border:1px solid #fbbf24}.role-pill.admin{background:linear-gradient(135deg,#dbeafe,#eef2ff);color:#1d4ed8;border:1px solid #bfdbfe}.admin-user-list-panel table td{vertical-align:middle}.admin-user-list-panel .btn.small{margin:2px}
html[data-theme="dark"] .nav-group{background:linear-gradient(135deg,rgba(255,255,255,.07),rgba(255,255,255,.025));border-color:rgba(148,163,184,.14)}html[data-theme="dark"] .nav-sub a{background:rgba(15,23,42,.42)!important;color:#dbeafe!important}html[data-theme="dark"] .role-pill.admin{background:rgba(59,130,246,.18);border-color:rgba(96,165,250,.32);color:#bfdbfe}html[data-theme="dark"] .role-pill.superadmin{background:rgba(245,158,11,.18);border-color:rgba(251,191,36,.32);color:#fde68a}
@media (max-width:800px){.premium-global-theme .sidebar{width:280px}.premium-global-theme .main-content{margin-left:0;width:100%}.nav-group summary{padding:10px 11px}.nav-sub a{padding:9px 10px!important}.admin-user-actions .btn{width:100%}}


/* V40 - Perbaikan tampilan melebar kanan + compact semua halaman */
html,body{max-width:100%;overflow-x:hidden!important}.app-shell,.main-content,.content-wrap{max-width:100%!important;min-width:0!important}.premium-global-theme .content-wrap{width:100%!important;max-width:100%!important;padding:12px 14px!important}.premium-global-theme .main-content{overflow-x:hidden!important}.premium-global-theme .topbar{padding:9px 14px!important;min-width:0!important}.premium-global-theme .top-title{min-width:0!important}.premium-global-theme .top-title b{font-size:14px!important}.premium-global-theme .top-title span{font-size:10px!important}.premium-global-theme .top-actions{min-width:0!important;gap:7px!important}.premium-global-theme .user-chip{padding:6px 8px!important;max-width:220px!important}.premium-global-theme .user-chip span{max-width:95px!important}.premium-global-theme .notif{width:34px!important;height:34px!important;border-radius:12px!important}
.premium-global-theme .grid-2{grid-template-columns:repeat(2,minmax(0,1fr))!important;gap:12px!important;width:100%!important;max-width:100%!important}.premium-global-theme .grid-3{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:12px!important}.premium-global-theme .grid-2>*,.premium-global-theme .grid-3>*,.premium-global-theme .card,.premium-global-theme .table-wrap{min-width:0!important;max-width:100%!important}.premium-global-theme .card{padding:13px!important;margin:10px 0!important;border-radius:18px!important;overflow:hidden!important}.premium-global-theme .card-head{margin-bottom:9px!important}.premium-global-theme .card-head h2,.premium-global-theme .card-head h3{font-size:15px!important}.premium-global-theme .table-wrap{overflow-x:auto!important;border-radius:14px!important}.premium-global-theme .grid-2 .table-wrap table{min-width:560px!important}.premium-global-theme table{min-width:720px!important}.premium-global-theme th,.premium-global-theme td{padding:7px 8px!important;font-size:11px!important}.premium-global-theme th{font-size:9.5px!important}.premium-global-theme label{font-size:10px!important;margin-bottom:4px!important}.premium-global-theme input,.premium-global-theme select,.premium-global-theme textarea{padding:8px 9px!important;border-radius:11px!important;font-size:11.5px!important}.premium-global-theme .btn{padding:7px 10px!important;border-radius:11px!important;font-size:11px!important}.premium-global-theme .btn.small{padding:5px 7px!important;font-size:10px!important}.premium-global-theme .badge{padding:3px 6px!important;font-size:9px!important}.premium-global-theme .form-grid{gap:8px!important}.premium-global-theme .filter-row{gap:8px!important}.premium-global-theme .filter-row>div{min-width:150px!important}.premium-global-theme .stats-grid{gap:10px!important}.premium-global-theme .stat-card{padding:12px!important;border-radius:17px!important}.premium-global-theme .stat-card b{font-size:20px!important}.premium-global-theme .stat-card span,.premium-global-theme .stat-card small{font-size:10.5px!important}
.premium-global-theme .sidebar{width:246px!important;padding:12px!important}.premium-global-theme .main-content{margin-left:246px!important;width:calc(100% - 246px)!important}.premium-global-theme .brand{padding:10px!important;border-radius:17px!important;margin-bottom:10px!important}.premium-global-theme .brand-logo{width:42px!important;height:42px!important;border-radius:14px!important}.premium-global-theme .brand b{font-size:12px!important}.premium-global-theme .brand span{font-size:10px!important}.premium-global-theme .premium-nav-menu{gap:6px!important}.premium-global-theme .premium-nav-menu a{padding:8px 9px!important;border-radius:13px!important;font-size:11px!important;gap:8px!important}.premium-global-theme .premium-nav-menu .nav-ico{width:27px!important;height:27px!important;flex-basis:27px!important;border-radius:10px!important;font-size:12px!important}.premium-global-theme .nav-group{margin-bottom:6px!important}.premium-global-theme .nav-group summary{padding:8px 9px!important;border-radius:13px!important;font-size:11px!important}.premium-global-theme .nav-sub{gap:5px!important}.premium-global-theme .nav-sub a{padding:7px 8px!important;font-size:10.5px!important;border-radius:12px!important}.premium-global-theme .nav-group-icon{width:28px!important;height:28px!important;border-radius:10px!important;font-size:12px!important}.premium-global-theme .nav-group-title{font-size:11px!important}.premium-global-theme .nav-group-chevron{font-size:10px!important}
.premium-global-theme .hero-card{padding:14px!important;border-radius:18px!important}.premium-global-theme .hero-card h1{font-size:21px!important}.premium-global-theme .hero-card p{font-size:11.5px!important}.premium-global-theme .tabs{gap:6px!important}.premium-global-theme .tabs a{padding:7px 9px!important;border-radius:11px!important;font-size:11px!important}.premium-global-theme .alert{padding:9px 11px!important;border-radius:12px!important;font-size:11.5px!important}.premium-global-theme .quick-menu-pro{gap:7px!important}.premium-global-theme .quick-menu-pro a{min-height:80px!important;padding:8px!important;border-radius:13px!important}.premium-global-theme .quick-menu-pro i{width:30px!important;height:30px!important;border-radius:10px!important;font-size:14px!important}.premium-global-theme .quick-menu-pro b{font-size:10.5px!important}.premium-global-theme .quick-menu-pro span{font-size:9.5px!important}.premium-global-theme .employee-hero-pro{min-height:160px!important;padding:14px!important;border-radius:19px!important}.premium-global-theme .employee-hero-pro h1{font-size:22px!important}.premium-global-theme .employee-hero-pro p{font-size:11px!important}.premium-global-theme .attendance-today-pro,.premium-global-theme .modern-card-pro{padding:12px!important;border-radius:17px!important}.premium-global-theme .time-node{padding:9px!important}.premium-global-theme .time-node b{font-size:18px!important}
@media (max-width:1200px){.premium-global-theme .grid-2,.premium-global-theme .grid-3{grid-template-columns:1fr!important}.premium-global-theme .grid-2 .table-wrap table,.premium-global-theme table{min-width:620px!important}}
@media (max-width:800px){.premium-global-theme .sidebar{width:260px!important}.premium-global-theme .main-content{margin-left:0!important;width:100%!important}.premium-global-theme .content-wrap{padding:9px!important}.premium-global-theme .grid-2,.premium-global-theme .grid-3{grid-template-columns:1fr!important}.premium-global-theme .topbar{padding:8px 10px!important}.premium-global-theme .top-title b{font-size:13px!important}.premium-global-theme .user-chip{max-width:70px!important;padding:6px!important}.premium-global-theme .card{padding:11px!important;border-radius:16px!important}.premium-global-theme table{min-width:560px!important}.premium-global-theme .grid-2 .table-wrap table{min-width:520px!important}}


/* V41 - Light/Dark mode fix: semua warna mengikuti mode, semua teks jelas */
html[data-theme="light"]{
  color-scheme:light;
  --page-bg:#f4f8ff;
  --panel-bg:#ffffff;
  --panel-bg2:#f8fbff;
  --panel-border:#d7e7ff;
  --text-main:#0f172a;
  --text-soft:#334155;
  --text-muted:#64748b;
  --input-bg:#ffffff;
  --input-border:#bfdbfe;
  --table-head:#eef5ff;
  --table-row:#ffffff;
  --table-hover:#f8fbff;
  --sidebar-bg:#f6f9ff;
  --nav-bg:#ffffff;
  --nav-text:#1e293b;
}
html[data-theme="dark"]{
  color-scheme:dark;
  --page-bg:#050914;
  --panel-bg:#0b1220;
  --panel-bg2:#111827;
  --panel-border:#263449;
  --text-main:#f8fafc;
  --text-soft:#e2e8f0;
  --text-muted:#cbd5e1;
  --input-bg:#0f172a;
  --input-border:#334155;
  --table-head:#111c31;
  --table-row:#0b1220;
  --table-hover:#162033;
  --sidebar-bg:#060b16;
  --nav-bg:#111827;
  --nav-text:#f8fafc;
}

html[data-theme="light"] body,
html[data-theme="light"] .premium-global-theme,
html[data-theme="light"] .main-content,
html[data-theme="light"] .content-wrap{
  background:linear-gradient(180deg,#f6f9ff 0%,#eef5ff 48%,#f8fbff 100%)!important;
  color:var(--text-main)!important;
}
html[data-theme="dark"] body,
html[data-theme="dark"] .premium-global-theme,
html[data-theme="dark"] .main-content,
html[data-theme="dark"] .content-wrap{
  background:linear-gradient(180deg,#050914 0%,#07101f 48%,#0b1220 100%)!important;
  color:var(--text-main)!important;
}

/* text visibility */
html[data-theme="light"] .premium-global-theme,
html[data-theme="light"] .premium-global-theme *:not(.btn):not(.btn *):not(.badge):not(.badge *):not(.alert):not(.alert *):not(.fa):not(.fa-solid):not(i),
html[data-theme="light"] .login-v33-body,
html[data-theme="light"] .login-v33-body *:not(.btn):not(.btn *):not(.alert):not(.alert *):not(i){color:var(--text-main)}
html[data-theme="dark"] .premium-global-theme,
html[data-theme="dark"] .premium-global-theme *:not(.btn):not(.btn *):not(.badge):not(.badge *):not(.alert):not(.alert *):not(.fa):not(.fa-solid):not(i),
html[data-theme="dark"] .login-v33-body,
html[data-theme="dark"] .login-v33-body *:not(.btn):not(.btn *):not(.alert):not(.alert *):not(i){color:var(--text-main)}
html[data-theme="light"] .muted,html[data-theme="light"] small,html[data-theme="light"] .hint,html[data-theme="light"] .card-head span,html[data-theme="light"] .section-title-pro span,html[data-theme="light"] .quick-menu-pro span,html[data-theme="light"] .time-node span,html[data-theme="light"] .coord-item span,html[data-theme="light"] .login-v33-panel-head p,html[data-theme="light"] .login-v33-access-grid span{color:var(--text-muted)!important}
html[data-theme="dark"] .muted,html[data-theme="dark"] small,html[data-theme="dark"] .hint,html[data-theme="dark"] .card-head span,html[data-theme="dark"] .section-title-pro span,html[data-theme="dark"] .quick-menu-pro span,html[data-theme="dark"] .time-node span,html[data-theme="dark"] .coord-item span,html[data-theme="dark"] .login-v33-panel-head p,html[data-theme="dark"] .login-v33-access-grid span{color:var(--text-muted)!important}

/* light mode: semua panel terang */
html[data-theme="light"] .sidebar{background:linear-gradient(180deg,#ffffff 0%,#f2f7ff 55%,#eaf2ff 100%)!important;border-right:1px solid #d7e7ff!important;box-shadow:14px 0 34px rgba(15,23,42,.08)!important}
html[data-theme="light"] .brand,
html[data-theme="light"] .nav-group,
html[data-theme="light"] .premium-nav-menu a,
html[data-theme="light"] .nav-sub a,
html[data-theme="light"] .topbar,
html[data-theme="light"] .notif,
html[data-theme="light"] .user-chip,
html[data-theme="light"] .theme-toggle,
html[data-theme="light"] .card,
html[data-theme="light"] .stat-card,
html[data-theme="light"] .modern-card-pro,
html[data-theme="light"] .attendance-today-pro,
html[data-theme="light"] .employee-info-card-pro,
html[data-theme="light"] .map-card,
html[data-theme="light"] .coord-panel,
html[data-theme="light"] .selfie-panel,
html[data-theme="light"] .notice,
html[data-theme="light"] .time-node,
html[data-theme="light"] .mini-stats-pro div,
html[data-theme="light"] .coord-item,
html[data-theme="light"] .quick-menu-pro a,
html[data-theme="light"] .announcement-item-pro,
html[data-theme="light"] .employee-info-list-pro p,
html[data-theme="light"] .salary-list-pro p,
html[data-theme="light"] .admin-user-panel,
html[data-theme="light"] .admin-user-list-panel,
html[data-theme="light"] .setting-tab-pane,
html[data-theme="light"] .settings-premium-box{
  background:linear-gradient(180deg,#ffffff,#f8fbff)!important;
  border-color:var(--panel-border)!important;
  color:var(--text-main)!important;
  box-shadow:0 12px 28px rgba(15,23,42,.055)!important;
}
html[data-theme="light"] .premium-nav-menu a:hover,
html[data-theme="light"] .nav-sub a:hover{background:#eef5ff!important;color:var(--text-main)!important;border-color:#bfdbfe!important}
html[data-theme="light"] .premium-nav-menu a.active,
html[data-theme="light"] .nav-sub a.active,
html[data-theme="light"] .nav-group[open] summary{background:linear-gradient(135deg,#dbeafe,#ede9fe)!important;color:#172554!important;border-color:#bfdbfe!important}
html[data-theme="light"] .nav-logout{background:linear-gradient(135deg,#fff1f2,#fff7ed)!important;color:#7f1d1d!important;border-color:#fecaca!important}
html[data-theme="light"] .nav-ico,html[data-theme="light"] .nav-sub a i,html[data-theme="light"] .nav-group summary .nav-ico{background:#eaf2ff!important;color:#1d4ed8!important}
html[data-theme="light"] .brand span,html[data-theme="light"] .nav-group summary span,html[data-theme="light"] .nav-sub a span{color:#1e293b!important}
html[data-theme="light"] .topbar{border-bottom:1px solid #d7e7ff!important;backdrop-filter:blur(14px)!important}
html[data-theme="light"] .hero-card,
html[data-theme="light"] .employee-hero-pro,
html[data-theme="light"] .login-v33-hero{
  background:linear-gradient(135deg,#ffffff 0%,#eff6ff 45%,#f5f3ff 100%)!important;
  color:var(--text-main)!important;
  border:1px solid #d7e7ff!important;
  box-shadow:0 18px 40px rgba(15,23,42,.08)!important;
}
html[data-theme="light"] .hero-card p,html[data-theme="light"] .employee-hero-pro p,html[data-theme="light"] .login-v33-copy p,html[data-theme="light"] .login-v33-feature span,html[data-theme="light"] .login-v33-stats span{color:#475569!important}
html[data-theme="light"] .hero-card h1,html[data-theme="light"] .employee-hero-pro h1,html[data-theme="light"] .login-v33-copy h1{color:#0f172a!important;text-shadow:none!important}
html[data-theme="light"] .login-v33-body{background:#f4f8ff!important;color:#0f172a!important}
html[data-theme="light"] .login-v33-bg{background:linear-gradient(180deg,#f6f9ff,#eef5ff)!important}
html[data-theme="light"] .login-v33-panel,
html[data-theme="light"] .login-v33-input,
html[data-theme="light"] .login-v33-access-grid>div,
html[data-theme="light"] .login-v33-demo,
html[data-theme="light"] .login-v33-mini-note,
html[data-theme="light"] .login-v33-footer-note{background:linear-gradient(180deg,#ffffff,#f8fbff)!important;border-color:#d7e7ff!important;color:#0f172a!important}

/* dark mode: semua panel gelap */
html[data-theme="dark"] .sidebar{background:linear-gradient(180deg,#020617 0%,#060b16 58%,#0b1220 100%)!important;border-right:1px solid #1f2937!important;box-shadow:14px 0 34px rgba(0,0,0,.32)!important}
html[data-theme="dark"] .brand,
html[data-theme="dark"] .nav-group,
html[data-theme="dark"] .premium-nav-menu a,
html[data-theme="dark"] .nav-sub a,
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .notif,
html[data-theme="dark"] .user-chip,
html[data-theme="dark"] .theme-toggle,
html[data-theme="dark"] .card,
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .modern-card-pro,
html[data-theme="dark"] .attendance-today-pro,
html[data-theme="dark"] .employee-info-card-pro,
html[data-theme="dark"] .map-card,
html[data-theme="dark"] .coord-panel,
html[data-theme="dark"] .selfie-panel,
html[data-theme="dark"] .notice,
html[data-theme="dark"] .time-node,
html[data-theme="dark"] .mini-stats-pro div,
html[data-theme="dark"] .coord-item,
html[data-theme="dark"] .quick-menu-pro a,
html[data-theme="dark"] .announcement-item-pro,
html[data-theme="dark"] .employee-info-list-pro p,
html[data-theme="dark"] .salary-list-pro p,
html[data-theme="dark"] .admin-user-panel,
html[data-theme="dark"] .admin-user-list-panel,
html[data-theme="dark"] .setting-tab-pane,
html[data-theme="dark"] .settings-premium-box{
  background:linear-gradient(180deg,#0b1220,#111827)!important;
  border-color:var(--panel-border)!important;
  color:var(--text-main)!important;
  box-shadow:0 16px 34px rgba(0,0,0,.28)!important;
}
html[data-theme="dark"] .premium-nav-menu a:hover,
html[data-theme="dark"] .nav-sub a:hover{background:#172033!important;color:#f8fafc!important;border-color:#334155!important}
html[data-theme="dark"] .premium-nav-menu a.active,
html[data-theme="dark"] .nav-sub a.active,
html[data-theme="dark"] .nav-group[open] summary{background:linear-gradient(135deg,#1e3a8a,#4c1d95)!important;color:#f8fafc!important;border-color:#334155!important}
html[data-theme="dark"] .nav-logout{background:linear-gradient(135deg,#451a1a,#431407)!important;color:#fee2e2!important;border-color:#7f1d1d!important}
html[data-theme="dark"] .nav-ico,html[data-theme="dark"] .nav-sub a i,html[data-theme="dark"] .nav-group summary .nav-ico{background:#172033!important;color:#93c5fd!important}
html[data-theme="dark"] .brand span,html[data-theme="dark"] .nav-group summary span,html[data-theme="dark"] .nav-sub a span{color:#f8fafc!important}
html[data-theme="dark"] .topbar{border-bottom:1px solid #1f2937!important;backdrop-filter:blur(14px)!important}
html[data-theme="dark"] .hero-card,
html[data-theme="dark"] .employee-hero-pro,
html[data-theme="dark"] .login-v33-hero{
  background:linear-gradient(135deg,#07101f 0%,#0b1220 48%,#111827 100%)!important;
  color:#f8fafc!important;
  border:1px solid #263449!important;
  box-shadow:0 20px 44px rgba(0,0,0,.34)!important;
}
html[data-theme="dark"] .hero-card p,html[data-theme="dark"] .employee-hero-pro p,html[data-theme="dark"] .login-v33-copy p,html[data-theme="dark"] .login-v33-feature span,html[data-theme="dark"] .login-v33-stats span{color:#cbd5e1!important}
html[data-theme="dark"] .hero-card h1,html[data-theme="dark"] .employee-hero-pro h1,html[data-theme="dark"] .login-v33-copy h1{color:#f8fafc!important;text-shadow:none!important}
html[data-theme="dark"] .login-v33-body{background:#050914!important;color:#f8fafc!important}
html[data-theme="dark"] .login-v33-bg{background:linear-gradient(180deg,#050914,#0b1220)!important}
html[data-theme="dark"] .login-v33-panel,
html[data-theme="dark"] .login-v33-input,
html[data-theme="dark"] .login-v33-access-grid>div,
html[data-theme="dark"] .login-v33-demo,
html[data-theme="dark"] .login-v33-mini-note,
html[data-theme="dark"] .login-v33-footer-note{background:linear-gradient(180deg,#0b1220,#111827)!important;border-color:#263449!important;color:#f8fafc!important}

/* form, table, modal, list clear contrast */
html[data-theme="light"] input,html[data-theme="light"] select,html[data-theme="light"] textarea{background:#ffffff!important;color:#0f172a!important;border-color:#bfdbfe!important}
html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#0f172a!important;color:#f8fafc!important;border-color:#334155!important}
html[data-theme="light"] input::placeholder,html[data-theme="light"] textarea::placeholder{color:#94a3b8!important}
html[data-theme="dark"] input::placeholder,html[data-theme="dark"] textarea::placeholder{color:#94a3b8!important}
html[data-theme="light"] label{color:#1e293b!important}html[data-theme="dark"] label{color:#e2e8f0!important}
html[data-theme="light"] .table-wrap{background:#fff!important;border-color:#d7e7ff!important}html[data-theme="dark"] .table-wrap{background:#0b1220!important;border-color:#263449!important}
html[data-theme="light"] table{background:#ffffff!important;color:#0f172a!important}html[data-theme="dark"] table{background:#0b1220!important;color:#f8fafc!important}
html[data-theme="light"] th{background:#eef5ff!important;color:#172554!important}html[data-theme="dark"] th{background:#111c31!important;color:#dbeafe!important}
html[data-theme="light"] td{background:#ffffff!important;color:#0f172a!important;border-bottom-color:#e2e8f0!important}html[data-theme="dark"] td{background:#0b1220!important;color:#f8fafc!important;border-bottom-color:#1f2937!important}
html[data-theme="light"] tr:hover td{background:#f8fbff!important}html[data-theme="dark"] tr:hover td{background:#162033!important}
html[data-theme="light"] a:not(.btn){color:#1d4ed8}html[data-theme="dark"] a:not(.btn){color:#93c5fd}
html[data-theme="light"] .btn.ghost{background:#ffffff!important;color:#1d4ed8!important;border-color:#bfdbfe!important}html[data-theme="dark"] .btn.ghost{background:#111827!important;color:#dbeafe!important;border-color:#334155!important}

/* remove hidden/low contrast decorative overlays in theme modes */
html[data-theme="light"] .employee-hero-pro:before,
html[data-theme="light"] .employee-hero-pro:after,
html[data-theme="light"] .login-v33-hero:before,
html[data-theme="dark"] .employee-hero-pro:before,
html[data-theme="dark"] .employee-hero-pro:after,
html[data-theme="dark"] .login-v33-hero:before{opacity:.08!important}
html[data-theme="light"] .gps-map{filter:none!important}html[data-theme="dark"] .gps-map{filter:saturate(.9) brightness(.78)!important}


/* V42 - Fix total kontras Light/Dark: semua teks dan gambar harus jelas */
html[data-theme="light"],html[data-theme="light"] body,html[data-theme="light"] .premium-global-theme{background:#f4f7ff!important;color:#0f172a!important}
html[data-theme="dark"],html[data-theme="dark"] body,html[data-theme="dark"] .premium-global-theme{background:#07101f!important;color:#f8fafc!important}

html[data-theme="light"] .admin-lux-hero:before,html[data-theme="light"] .admin-lux-hero:after,html[data-theme="light"] .admin-lux-orb,html[data-theme="light"] .employee-hero-pro:before,html[data-theme="light"] .employee-hero-pro:after,html[data-theme="light"] .hero-bg-orb,html[data-theme="dark"] .admin-lux-hero:before,html[data-theme="dark"] .admin-lux-hero:after,html[data-theme="dark"] .admin-lux-orb,html[data-theme="dark"] .employee-hero-pro:before,html[data-theme="dark"] .employee-hero-pro:after,html[data-theme="dark"] .hero-bg-orb{display:none!important}
html[data-theme="light"] *:not(i):not(.fa):not(.fas):not(.far):not(.fab){text-shadow:none!important}
html[data-theme="dark"] *:not(i):not(.fa):not(.fas):not(.far):not(.fab){text-shadow:none!important}

html[data-theme="light"] .main-content,html[data-theme="light"] .content-wrap{background:#f4f7ff!important;color:#0f172a!important}
html[data-theme="light"] .card,html[data-theme="light"] .stat-card,html[data-theme="light"] .admin-lux-stat,html[data-theme="light"] .lux-action-card,html[data-theme="light"] .lux-data-panel,html[data-theme="light"] .lux-row-card,html[data-theme="light"] .lux-ann-card,html[data-theme="light"] .modern-card-pro,html[data-theme="light"] .attendance-today-pro,html[data-theme="light"] .quick-menu-pro a,html[data-theme="light"] .time-node,html[data-theme="light"] .mini-stats-pro div,html[data-theme="light"] .salary-big-pro,html[data-theme="light"] .announcement-item-pro,html[data-theme="light"] .employee-info-list-pro p,html[data-theme="light"] .settings-premium-box,html[data-theme="light"] .setting-tab-pane,html[data-theme="light"] .file-card-premium,html[data-theme="light"] .login-v33-panel,html[data-theme="light"] .login-v33-access-grid>div,html[data-theme="light"] .login-v33-mini-note,html[data-theme="light"] .login-v33-demo{background:#ffffff!important;color:#0f172a!important;border-color:#cfe0ff!important;box-shadow:0 14px 30px rgba(15,23,42,.07)!important}
html[data-theme="light"] .admin-lux-stat:after{opacity:.10!important;z-index:0!important;pointer-events:none!important}
html[data-theme="light"] .admin-lux-stat *,html[data-theme="light"] .lux-action-card *,html[data-theme="light"] .lux-data-panel *,html[data-theme="light"] .lux-row-card *,html[data-theme="light"] .lux-ann-card *,html[data-theme="light"] .card *,html[data-theme="light"] .stat-card *,html[data-theme="light"] .modern-card-pro *,html[data-theme="light"] .attendance-today-pro *,html[data-theme="light"] .quick-menu-pro a *,html[data-theme="light"] .employee-info-list-pro p *,html[data-theme="light"] .settings-premium-box *,html[data-theme="light"] .setting-tab-pane *{color:#0f172a!important;opacity:1!important}
html[data-theme="light"] .admin-lux-stat span,html[data-theme="light"] .admin-lux-stat small,html[data-theme="light"] .lux-action-card span,html[data-theme="light"] .lux-row-main span,html[data-theme="light"] .lux-row-time span,html[data-theme="light"] .lux-ann-card p,html[data-theme="light"] .lux-ann-card small,html[data-theme="light"] .card small,html[data-theme="light"] .hint,html[data-theme="light"] .empty,html[data-theme="light"] .top-title span{color:#334155!important;opacity:1!important}
html[data-theme="light"] .admin-lux-stat b,html[data-theme="light"] .lux-action-card b,html[data-theme="light"] .lux-data-head h2,html[data-theme="light"] .card h1,html[data-theme="light"] .card h2,html[data-theme="light"] .card h3{color:#0f172a!important}
html[data-theme="light"] .admin-lux-hero,html[data-theme="light"] .employee-hero-pro,html[data-theme="light"] .hero-card,html[data-theme="light"] .settings-lux-hero,html[data-theme="light"] .login-v33-hero{background:linear-gradient(135deg,#ffffff 0%,#eef5ff 54%,#f7f2ff 100%)!important;color:#0f172a!important;border:1px solid #cfe0ff!important;box-shadow:0 18px 36px rgba(15,23,42,.08)!important}
html[data-theme="light"] .admin-lux-hero h1,html[data-theme="light"] .employee-hero-pro h1,html[data-theme="light"] .hero-card h1,html[data-theme="light"] .settings-lux-hero h1,html[data-theme="light"] .login-v33-hero h1{color:#0f172a!important;opacity:1!important}
html[data-theme="light"] .admin-lux-hero p,html[data-theme="light"] .employee-hero-pro p,html[data-theme="light"] .hero-card p,html[data-theme="light"] .settings-lux-hero p,html[data-theme="light"] .login-v33-hero p{color:#1e293b!important;opacity:1!important}
html[data-theme="light"] .lux-kicker,html[data-theme="light"] .login-v33-eyebrow,html[data-theme="light"] .hero-kicker{background:#eaf2ff!important;border:1px solid #bfd5ff!important;color:#1d4ed8!important}
html[data-theme="light"] .lux-clock-card,html[data-theme="light"] .lux-mini-grid div{background:#ffffff!important;border:1px solid #cfe0ff!important;color:#0f172a!important;box-shadow:0 10px 22px rgba(15,23,42,.06)!important}
html[data-theme="light"] .lux-clock-card span,html[data-theme="light"] .lux-clock-card small,html[data-theme="light"] .lux-mini-grid span{color:#334155!important;opacity:1!important}
html[data-theme="light"] .lux-clock-card b,html[data-theme="light"] .lux-mini-grid b{color:#0f172a!important;opacity:1!important}
html[data-theme="light"] .btn.luxury-light{background:#ffffff!important;color:#0f172a!important;border:1px solid #bfd5ff!important;box-shadow:0 10px 20px rgba(15,23,42,.08)!important}
html[data-theme="light"] .admin-lux-stat i,html[data-theme="light"] .lux-action-card i,html[data-theme="light"] .avatar-dot{color:#ffffff!important;background:linear-gradient(135deg,#1d4ed8,#7c3aed)!important}

html[data-theme="dark"] .main-content,html[data-theme="dark"] .content-wrap{background:#07101f!important;color:#f8fafc!important}
html[data-theme="dark"] .card,html[data-theme="dark"] .stat-card,html[data-theme="dark"] .admin-lux-stat,html[data-theme="dark"] .lux-action-card,html[data-theme="dark"] .lux-data-panel,html[data-theme="dark"] .lux-row-card,html[data-theme="dark"] .lux-ann-card,html[data-theme="dark"] .modern-card-pro,html[data-theme="dark"] .attendance-today-pro,html[data-theme="dark"] .quick-menu-pro a,html[data-theme="dark"] .time-node,html[data-theme="dark"] .mini-stats-pro div,html[data-theme="dark"] .salary-big-pro,html[data-theme="dark"] .announcement-item-pro,html[data-theme="dark"] .employee-info-list-pro p,html[data-theme="dark"] .settings-premium-box,html[data-theme="dark"] .setting-tab-pane,html[data-theme="dark"] .file-card-premium,html[data-theme="dark"] .login-v33-panel,html[data-theme="dark"] .login-v33-access-grid>div,html[data-theme="dark"] .login-v33-mini-note,html[data-theme="dark"] .login-v33-demo{background:#0f172a!important;color:#f8fafc!important;border-color:#334155!important;box-shadow:0 18px 34px rgba(0,0,0,.32)!important}
html[data-theme="dark"] .admin-lux-stat:after{opacity:.10!important;z-index:0!important;pointer-events:none!important;background:#60a5fa!important}
html[data-theme="dark"] .admin-lux-stat *,html[data-theme="dark"] .lux-action-card *,html[data-theme="dark"] .lux-data-panel *,html[data-theme="dark"] .lux-row-card *,html[data-theme="dark"] .lux-ann-card *,html[data-theme="dark"] .card *,html[data-theme="dark"] .stat-card *,html[data-theme="dark"] .modern-card-pro *,html[data-theme="dark"] .attendance-today-pro *,html[data-theme="dark"] .quick-menu-pro a *,html[data-theme="dark"] .employee-info-list-pro p *,html[data-theme="dark"] .settings-premium-box *,html[data-theme="dark"] .setting-tab-pane *{color:#f8fafc!important;opacity:1!important}
html[data-theme="dark"] .admin-lux-stat span,html[data-theme="dark"] .admin-lux-stat small,html[data-theme="dark"] .lux-action-card span,html[data-theme="dark"] .lux-row-main span,html[data-theme="dark"] .lux-row-time span,html[data-theme="dark"] .lux-ann-card p,html[data-theme="dark"] .lux-ann-card small,html[data-theme="dark"] .card small,html[data-theme="dark"] .hint,html[data-theme="dark"] .empty,html[data-theme="dark"] .top-title span{color:#cbd5e1!important;opacity:1!important}
html[data-theme="dark"] .admin-lux-stat b,html[data-theme="dark"] .lux-action-card b,html[data-theme="dark"] .lux-data-head h2,html[data-theme="dark"] .card h1,html[data-theme="dark"] .card h2,html[data-theme="dark"] .card h3{color:#ffffff!important}
html[data-theme="dark"] .admin-lux-hero,html[data-theme="dark"] .employee-hero-pro,html[data-theme="dark"] .hero-card,html[data-theme="dark"] .settings-lux-hero,html[data-theme="dark"] .login-v33-hero{background:#0f172a!important;color:#f8fafc!important;border:1px solid #334155!important;box-shadow:0 22px 44px rgba(0,0,0,.34)!important}
html[data-theme="dark"] .admin-lux-hero h1,html[data-theme="dark"] .employee-hero-pro h1,html[data-theme="dark"] .hero-card h1,html[data-theme="dark"] .settings-lux-hero h1,html[data-theme="dark"] .login-v33-hero h1{color:#ffffff!important;opacity:1!important}
html[data-theme="dark"] .admin-lux-hero p,html[data-theme="dark"] .employee-hero-pro p,html[data-theme="dark"] .hero-card p,html[data-theme="dark"] .settings-lux-hero p,html[data-theme="dark"] .login-v33-hero p{color:#e2e8f0!important;opacity:1!important}
html[data-theme="dark"] .lux-kicker,html[data-theme="dark"] .login-v33-eyebrow,html[data-theme="dark"] .hero-kicker{background:#172033!important;border:1px solid #334155!important;color:#bfdbfe!important}
html[data-theme="dark"] .lux-clock-card,html[data-theme="dark"] .lux-mini-grid div{background:#111827!important;border:1px solid #334155!important;color:#f8fafc!important;box-shadow:0 14px 26px rgba(0,0,0,.28)!important}
html[data-theme="dark"] .lux-clock-card span,html[data-theme="dark"] .lux-clock-card small,html[data-theme="dark"] .lux-mini-grid span{color:#cbd5e1!important;opacity:1!important}
html[data-theme="dark"] .lux-clock-card b,html[data-theme="dark"] .lux-mini-grid b{color:#ffffff!important;opacity:1!important}
html[data-theme="dark"] .btn.luxury-light{background:#172033!important;color:#f8fafc!important;border:1px solid #475569!important;box-shadow:0 12px 24px rgba(0,0,0,.25)!important}
html[data-theme="dark"] .admin-lux-stat i,html[data-theme="dark"] .lux-action-card i,html[data-theme="dark"] .avatar-dot{color:#ffffff!important;background:linear-gradient(135deg,#2563eb,#7c3aed)!important}

html[data-theme="light"] input,html[data-theme="light"] select,html[data-theme="light"] textarea{background:#ffffff!important;color:#0f172a!important;border-color:#93b7ff!important}
html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:#111827!important;color:#f8fafc!important;border-color:#475569!important}
html[data-theme="light"] label,html[data-theme="light"] th,html[data-theme="light"] td{color:#0f172a!important;opacity:1!important}
html[data-theme="dark"] label,html[data-theme="dark"] th,html[data-theme="dark"] td{color:#f8fafc!important;opacity:1!important}
html[data-theme="light"] th{background:#eaf2ff!important;color:#172554!important}
html[data-theme="dark"] th{background:#172033!important;color:#dbeafe!important}
html[data-theme="light"] td{background:#ffffff!important;border-bottom-color:#dbeafe!important}
html[data-theme="dark"] td{background:#0f172a!important;border-bottom-color:#334155!important}
html[data-theme="light"] .badge{background:#eaf2ff!important;color:#1e3a8a!important;border:1px solid #bfdbfe!important}
html[data-theme="dark"] .badge{background:#172033!important;color:#dbeafe!important;border:1px solid #475569!important}
html[data-theme="light"] .badge.success,html[data-theme="light"] .badge.active{background:#dcfce7!important;color:#166534!important;border-color:#86efac!important}
html[data-theme="dark"] .badge.success,html[data-theme="dark"] .badge.active{background:#14532d!important;color:#dcfce7!important;border-color:#22c55e!important}
html[data-theme="light"] .badge.danger,html[data-theme="light"] .badge.rejected{background:#fee2e2!important;color:#991b1b!important;border-color:#fecaca!important}
html[data-theme="dark"] .badge.danger,html[data-theme="dark"] .badge.rejected{background:#7f1d1d!important;color:#fee2e2!important;border-color:#ef4444!important}
html[data-theme="light"] img,html[data-theme="light"] video,html[data-theme="light"] canvas,html[data-theme="light"] .brand-logo,html[data-theme="light"] .photo-thumb,html[data-theme="light"] .gps-map{opacity:1!important;filter:none!important}
html[data-theme="dark"] img,html[data-theme="dark"] video,html[data-theme="dark"] canvas,html[data-theme="dark"] .brand-logo,html[data-theme="dark"] .photo-thumb{opacity:1!important;filter:none!important}
html[data-theme="dark"] .gps-map{opacity:1!important;filter:brightness(.92) contrast(1.05)!important}


/* V43 - Warna premium kembali, tetapi semua teks tetap jelas */
html[data-theme="light"] body.premium-global-theme,
html[data-theme="light"] .premium-global-theme{
  background:
    radial-gradient(circle at 0% 0%, rgba(37,99,235,.16), transparent 25%),
    radial-gradient(circle at 100% 0%, rgba(236,72,153,.14), transparent 25%),
    radial-gradient(circle at 50% 100%, rgba(16,185,129,.12), transparent 28%),
    linear-gradient(180deg,#f8fbff 0%,#eef6ff 45%,#f7f3ff 100%)!important;
  color:#0f172a!important;
}
html[data-theme="dark"] body.premium-global-theme,
html[data-theme="dark"] .premium-global-theme{
  background:
    radial-gradient(circle at 0% 0%, rgba(37,99,235,.22), transparent 25%),
    radial-gradient(circle at 100% 0%, rgba(168,85,247,.20), transparent 25%),
    radial-gradient(circle at 50% 100%, rgba(14,165,233,.12), transparent 28%),
    linear-gradient(180deg,#020617 0%,#071426 42%,#0b1020 100%)!important;
  color:#f8fafc!important;
}

/* area utama tetap berwarna lembut */
html[data-theme="light"] .main-content,
html[data-theme="light"] .content-wrap{
  background:transparent!important;
  color:#0f172a!important;
}
html[data-theme="dark"] .main-content,
html[data-theme="dark"] .content-wrap{
  background:transparent!important;
  color:#f8fafc!important;
}

/* Card umum: tidak polos, tetapi kontras */
html[data-theme="light"] .card,
html[data-theme="light"] .stat-card,
html[data-theme="light"] .modern-card-pro,
html[data-theme="light"] .attendance-today-pro,
html[data-theme="light"] .lux-data-panel,
html[data-theme="light"] .lux-row-card,
html[data-theme="light"] .lux-ann-card,
html[data-theme="light"] .settings-premium-box,
html[data-theme="light"] .setting-tab-pane,
html[data-theme="light"] .file-card-premium{
  background:
    linear-gradient(180deg,rgba(255,255,255,.98),rgba(248,251,255,.95)),
    radial-gradient(circle at 100% 0%,rgba(124,58,237,.10),transparent 38%)!important;
  border:1px solid #bfd7ff!important;
  color:#0f172a!important;
  box-shadow:0 18px 38px rgba(29,78,216,.08)!important;
}
html[data-theme="dark"] .card,
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .modern-card-pro,
html[data-theme="dark"] .attendance-today-pro,
html[data-theme="dark"] .lux-data-panel,
html[data-theme="dark"] .lux-row-card,
html[data-theme="dark"] .lux-ann-card,
html[data-theme="dark"] .settings-premium-box,
html[data-theme="dark"] .setting-tab-pane,
html[data-theme="dark"] .file-card-premium{
  background:
    linear-gradient(180deg,rgba(15,23,42,.98),rgba(17,24,39,.96)),
    radial-gradient(circle at 100% 0%,rgba(96,165,250,.14),transparent 38%)!important;
  border:1px solid #334155!important;
  color:#f8fafc!important;
  box-shadow:0 20px 42px rgba(0,0,0,.34)!important;
}

/* Hero dashboard berwarna, teks putih sangat jelas */
html[data-theme="light"] .admin-lux-hero,
html[data-theme="light"] .employee-hero-pro,
html[data-theme="light"] .hero-card,
html[data-theme="light"] .settings-lux-hero,
html[data-theme="light"] .login-v33-hero,
html[data-theme="dark"] .admin-lux-hero,
html[data-theme="dark"] .employee-hero-pro,
html[data-theme="dark"] .hero-card,
html[data-theme="dark"] .settings-lux-hero,
html[data-theme="dark"] .login-v33-hero{
  position:relative!important;
  overflow:hidden!important;
  background:
    linear-gradient(135deg,rgba(2,6,23,.92) 0%,rgba(29,78,216,.92) 43%,rgba(124,58,237,.90) 72%,rgba(219,39,119,.86) 100%)!important;
  color:#ffffff!important;
  border:1px solid rgba(191,219,254,.42)!important;
  box-shadow:0 24px 55px rgba(29,78,216,.22)!important;
}
html[data-theme="light"] .admin-lux-hero:before,
html[data-theme="light"] .employee-hero-pro:before,
html[data-theme="light"] .hero-card:before,
html[data-theme="light"] .settings-lux-hero:before,
html[data-theme="light"] .login-v33-hero:before,
html[data-theme="dark"] .admin-lux-hero:before,
html[data-theme="dark"] .employee-hero-pro:before,
html[data-theme="dark"] .hero-card:before,
html[data-theme="dark"] .settings-lux-hero:before,
html[data-theme="dark"] .login-v33-hero:before{
  content:""!important;
  position:absolute!important;
  inset:0!important;
  background:linear-gradient(90deg,rgba(2,6,23,.42),rgba(2,6,23,.16),rgba(2,6,23,.32))!important;
  z-index:0!important;
  pointer-events:none!important;
}
html[data-theme="light"] .admin-lux-hero > *,
html[data-theme="light"] .employee-hero-pro > *,
html[data-theme="light"] .hero-card > *,
html[data-theme="light"] .settings-lux-hero > *,
html[data-theme="light"] .login-v33-hero > *,
html[data-theme="dark"] .admin-lux-hero > *,
html[data-theme="dark"] .employee-hero-pro > *,
html[data-theme="dark"] .hero-card > *,
html[data-theme="dark"] .settings-lux-hero > *,
html[data-theme="dark"] .login-v33-hero > *{
  position:relative!important;
  z-index:2!important;
}
html[data-theme="light"] .admin-lux-hero h1,
html[data-theme="light"] .employee-hero-pro h1,
html[data-theme="light"] .hero-card h1,
html[data-theme="light"] .settings-lux-hero h1,
html[data-theme="light"] .login-v33-hero h1,
html[data-theme="dark"] .admin-lux-hero h1,
html[data-theme="dark"] .employee-hero-pro h1,
html[data-theme="dark"] .hero-card h1,
html[data-theme="dark"] .settings-lux-hero h1,
html[data-theme="dark"] .login-v33-hero h1{
  color:#ffffff!important;
  text-shadow:0 3px 12px rgba(0,0,0,.45)!important;
}
html[data-theme="light"] .admin-lux-hero p,
html[data-theme="light"] .employee-hero-pro p,
html[data-theme="light"] .hero-card p,
html[data-theme="light"] .settings-lux-hero p,
html[data-theme="light"] .login-v33-hero p,
html[data-theme="dark"] .admin-lux-hero p,
html[data-theme="dark"] .employee-hero-pro p,
html[data-theme="dark"] .hero-card p,
html[data-theme="dark"] .settings-lux-hero p,
html[data-theme="dark"] .login-v33-hero p{
  color:#eef2ff!important;
  text-shadow:0 2px 8px rgba(0,0,0,.35)!important;
}

/* Kartu statistik: warna premium + tulisan terbaca */
html[data-theme="light"] .admin-lux-stat{
  color:#0f172a!important;
  border:1px solid #bfd7ff!important;
  box-shadow:0 18px 35px rgba(29,78,216,.10)!important;
}
html[data-theme="light"] .admin-lux-stat.blue{background:linear-gradient(135deg,#ffffff 0%,#eaf2ff 58%,#dbeafe 100%)!important}
html[data-theme="light"] .admin-lux-stat.green{background:linear-gradient(135deg,#ffffff 0%,#ecfdf5 58%,#d1fae5 100%)!important}
html[data-theme="light"] .admin-lux-stat.amber{background:linear-gradient(135deg,#ffffff 0%,#fff7ed 58%,#fed7aa 100%)!important}
html[data-theme="light"] .admin-lux-stat.purple{background:linear-gradient(135deg,#ffffff 0%,#f5f3ff 58%,#ddd6fe 100%)!important}
html[data-theme="dark"] .admin-lux-stat{
  color:#f8fafc!important;
  border:1px solid #334155!important;
  box-shadow:0 20px 40px rgba(0,0,0,.36)!important;
}
html[data-theme="dark"] .admin-lux-stat.blue{background:linear-gradient(135deg,#0f172a 0%,#132857 58%,#1e3a8a 100%)!important}
html[data-theme="dark"] .admin-lux-stat.green{background:linear-gradient(135deg,#0f172a 0%,#0f3b2e 58%,#065f46 100%)!important}
html[data-theme="dark"] .admin-lux-stat.amber{background:linear-gradient(135deg,#0f172a 0%,#4a2f0b 58%,#92400e 100%)!important}
html[data-theme="dark"] .admin-lux-stat.purple{background:linear-gradient(135deg,#0f172a 0%,#2e1a62 58%,#581c87 100%)!important}
html[data-theme="light"] .admin-lux-stat span,
html[data-theme="light"] .admin-lux-stat b,
html[data-theme="light"] .admin-lux-stat small{color:#0f172a!important;opacity:1!important}
html[data-theme="dark"] .admin-lux-stat span,
html[data-theme="dark"] .admin-lux-stat b,
html[data-theme="dark"] .admin-lux-stat small{color:#ffffff!important;opacity:1!important}
html[data-theme="light"] .admin-lux-stat i,
html[data-theme="dark"] .admin-lux-stat i{
  color:#ffffff!important;
  background:linear-gradient(135deg,#2563eb,#7c3aed)!important;
  box-shadow:0 10px 22px rgba(37,99,235,.26)!important;
}

/* Aksi cepat tetap berwarna dan jelas */
html[data-theme="light"] .lux-action-card{
  background:linear-gradient(135deg,#ffffff,#eef6ff 58%,#f5f3ff)!important;
  color:#0f172a!important;
  border:1px solid #bfd7ff!important;
}
html[data-theme="dark"] .lux-action-card{
  background:linear-gradient(135deg,#0f172a,#172554 58%,#312e81)!important;
  color:#ffffff!important;
  border:1px solid #334155!important;
}
html[data-theme="light"] .lux-action-card b,
html[data-theme="light"] .lux-action-card span{color:#0f172a!important;opacity:1!important}
html[data-theme="dark"] .lux-action-card b,
html[data-theme="dark"] .lux-action-card span{color:#ffffff!important;opacity:1!important}
html[data-theme="light"] .lux-action-card i,
html[data-theme="dark"] .lux-action-card i{
  background:linear-gradient(135deg,#2563eb,#7c3aed,#db2777)!important;
  color:#fff!important;
}

/* kotak tanggal & mini card di hero */
html[data-theme="light"] .lux-clock-card,
html[data-theme="light"] .lux-mini-grid div,
html[data-theme="dark"] .lux-clock-card,
html[data-theme="dark"] .lux-mini-grid div{
  background:rgba(255,255,255,.18)!important;
  border:1px solid rgba(255,255,255,.28)!important;
  color:#fff!important;
  backdrop-filter:blur(12px)!important;
}
html[data-theme="light"] .lux-clock-card span,
html[data-theme="light"] .lux-clock-card b,
html[data-theme="light"] .lux-clock-card small,
html[data-theme="light"] .lux-mini-grid b,
html[data-theme="light"] .lux-mini-grid span,
html[data-theme="dark"] .lux-clock-card span,
html[data-theme="dark"] .lux-clock-card b,
html[data-theme="dark"] .lux-clock-card small,
html[data-theme="dark"] .lux-mini-grid b,
html[data-theme="dark"] .lux-mini-grid span{
  color:#ffffff!important;
  opacity:1!important;
  text-shadow:0 2px 8px rgba(0,0,0,.35)!important;
}

/* tombol di hero harus terlihat */
html[data-theme="light"] .btn.luxury-light,
html[data-theme="dark"] .btn.luxury-light{
  background:rgba(255,255,255,.16)!important;
  color:#ffffff!important;
  border:1px solid rgba(255,255,255,.35)!important;
  box-shadow:0 12px 24px rgba(0,0,0,.18)!important;
  backdrop-filter:blur(10px)!important;
}
html[data-theme="light"] .btn.luxury-light *,
html[data-theme="dark"] .btn.luxury-light *{color:#ffffff!important}

/* tabel dan input tetap jelas */
html[data-theme="light"] th{background:linear-gradient(135deg,#eaf2ff,#f5f3ff)!important;color:#172554!important}
html[data-theme="dark"] th{background:linear-gradient(135deg,#172033,#1e1b4b)!important;color:#eaf2ff!important}
html[data-theme="light"] td{background:rgba(255,255,255,.96)!important;color:#0f172a!important}
html[data-theme="dark"] td{background:rgba(15,23,42,.96)!important;color:#f8fafc!important}
html[data-theme="light"] input,
html[data-theme="light"] select,
html[data-theme="light"] textarea{
  background:#ffffff!important;
  color:#0f172a!important;
  border-color:#93c5fd!important;
}
html[data-theme="dark"] input,
html[data-theme="dark"] select,
html[data-theme="dark"] textarea{
  background:#0f172a!important;
  color:#f8fafc!important;
  border-color:#475569!important;
}
html[data-theme="light"] input::placeholder,
html[data-theme="light"] textarea::placeholder{color:#64748b!important}
html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder{color:#cbd5e1!important}

/* label, teks kecil, dan link tidak boleh redup */
html[data-theme="light"] label,
html[data-theme="light"] .hint,
html[data-theme="light"] .empty,
html[data-theme="light"] small{color:#1e293b!important;opacity:1!important}
html[data-theme="dark"] label,
html[data-theme="dark"] .hint,
html[data-theme="dark"] .empty,
html[data-theme="dark"] small{color:#e2e8f0!important;opacity:1!important}

/* dekorasi boleh ada, tapi tidak menutupi tulisan */
.admin-lux-orb,
.hero-bg-orb,
.login-v33-orb{
  opacity:.16!important;
  pointer-events:none!important;
  z-index:0!important;
}


/* V44 - Lebih berwarna lagi + gambar pengumuman */
:root{--v44-blue:#2563eb;--v44-purple:#7c3aed;--v44-pink:#ec4899;--v44-orange:#f97316;--v44-green:#16a34a;--v44-cyan:#06b6d4}
body:not(.theme-dark) .premium-global-theme, body:not(.theme-dark).premium-global-theme{
  background:
    radial-gradient(circle at 7% 9%, rgba(37,99,235,.18), transparent 22%),
    radial-gradient(circle at 92% 12%, rgba(236,72,153,.16), transparent 22%),
    radial-gradient(circle at 54% 96%, rgba(249,115,22,.12), transparent 24%),
    linear-gradient(135deg,#eef7ff 0%,#f7f0ff 48%,#fff7ed 100%)!important;
}
body:not(.theme-dark) .premium-global-theme .card,
body:not(.theme-dark).premium-global-theme .card,
body:not(.theme-dark) .premium-global-theme .lux-data-panel,
body:not(.theme-dark).premium-global-theme .lux-data-panel,
body:not(.theme-dark) .premium-global-theme .modern-card-pro,
body:not(.theme-dark).premium-global-theme .modern-card-pro{
  background:linear-gradient(145deg,#ffffff 0%,#f5fbff 48%,#fff7fb 100%)!important;
  border:1px solid #c7ddff!important;
  box-shadow:0 18px 38px rgba(37,99,235,.08),0 8px 18px rgba(236,72,153,.05)!important;
}
body:not(.theme-dark) .premium-global-theme .card-head h2,
body:not(.theme-dark).premium-global-theme .card-head h2,
body:not(.theme-dark) .premium-global-theme h1,
body:not(.theme-dark).premium-global-theme h1,
body:not(.theme-dark) .premium-global-theme h2,
body:not(.theme-dark).premium-global-theme h2,
body:not(.theme-dark) .premium-global-theme h3,
body:not(.theme-dark).premium-global-theme h3{color:#0f172a!important;text-shadow:none!important}
body:not(.theme-dark) .premium-global-theme .admin-lux-hero,
body:not(.theme-dark).premium-global-theme .admin-lux-hero{
  background:linear-gradient(135deg,#0f2e7a 0%,#2563eb 38%,#7c3aed 70%,#ec4899 100%)!important;
  color:#fff!important;
  box-shadow:0 24px 50px rgba(37,99,235,.24),0 12px 28px rgba(236,72,153,.12)!important;
}
body:not(.theme-dark) .premium-global-theme .admin-lux-hero h1,
body:not(.theme-dark).premium-global-theme .admin-lux-hero h1,
body:not(.theme-dark) .premium-global-theme .admin-lux-hero p,
body:not(.theme-dark).premium-global-theme .admin-lux-hero p,
body:not(.theme-dark) .premium-global-theme .admin-lux-hero .lux-kicker,
body:not(.theme-dark).premium-global-theme .admin-lux-hero .lux-kicker{color:#fff!important;text-shadow:0 3px 12px rgba(0,0,0,.25)!important}
.admin-lux-stats .admin-lux-stat{position:relative;overflow:hidden;border:0!important;color:#fff!important;box-shadow:0 18px 36px rgba(15,23,42,.14)!important}.admin-lux-stats .admin-lux-stat:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,.24),transparent 34%,rgba(255,255,255,.14));pointer-events:none}.admin-lux-stats .admin-lux-stat *{position:relative;z-index:1;color:#fff!important;text-shadow:0 2px 8px rgba(0,0,0,.22)!important}.admin-lux-stats .admin-lux-stat.blue{background:linear-gradient(135deg,#1d4ed8,#06b6d4)!important}.admin-lux-stats .admin-lux-stat.green{background:linear-gradient(135deg,#15803d,#22c55e)!important}.admin-lux-stats .admin-lux-stat.amber{background:linear-gradient(135deg,#c2410c,#f59e0b)!important}.admin-lux-stats .admin-lux-stat.purple{background:linear-gradient(135deg,#6d28d9,#ec4899)!important}
.lux-action-card{background:linear-gradient(135deg,#1d4ed8,#7c3aed)!important;color:#fff!important;border:0!important}.lux-action-card:nth-child(2){background:linear-gradient(135deg,#059669,#22c55e)!important}.lux-action-card:nth-child(3){background:linear-gradient(135deg,#ea580c,#f59e0b)!important}.lux-action-card:nth-child(4){background:linear-gradient(135deg,#db2777,#7c3aed)!important}.lux-action-card *{color:#fff!important;text-shadow:0 2px 8px rgba(0,0,0,.22)!important}
.announcement-create-card{background:linear-gradient(135deg,#ffffff,#eff6ff 46%,#fff1f2)!important;border:1px solid #bfdbfe!important}.announcement-form-premium textarea{min-height:120px}.announcement-thumb{width:96px;height:58px;object-fit:cover;border-radius:14px;border:2px solid #dbeafe;box-shadow:0 8px 18px rgba(37,99,235,.14)}.empty-mini{display:inline-flex;padding:7px 10px;border-radius:999px;background:#f1f5f9;color:#475569;font-size:12px;font-weight:900}.colorful-ann-card{overflow:hidden;padding:0!important;background:linear-gradient(145deg,#fff,#f8fbff)!important;border:1px solid #dbeafe!important}.colorful-ann-card>img{width:100%;height:145px;object-fit:cover;display:block}.colorful-ann-card>div{padding:14px}.colorful-ann-card b{color:#0f172a!important}.colorful-ann-card p{color:#334155!important}.colorful-ann-card small{color:#475569!important}.colorful-ann-item{align-items:stretch!important;background:linear-gradient(135deg,#ffffff,#eff6ff 52%,#fff7ed)!important;border:1px solid #bfdbfe!important;color:#0f172a!important}.colorful-ann-item>img{width:132px;min-height:90px;object-fit:cover;border-radius:14px;border:2px solid #dbeafe;box-shadow:0 10px 18px rgba(37,99,235,.12);align-self:center}.colorful-ann-item b{color:#0f172a!important}.colorful-ann-item p{color:#334155!important}.colorful-ann-item>span{background:linear-gradient(135deg,#2563eb,#7c3aed)!important;color:#fff!important}
.theme-dark .premium-global-theme, body.theme-dark.premium-global-theme{
  background:
    radial-gradient(circle at 9% 8%, rgba(37,99,235,.28), transparent 24%),
    radial-gradient(circle at 92% 13%, rgba(236,72,153,.22), transparent 22%),
    radial-gradient(circle at 55% 98%, rgba(6,182,212,.17), transparent 24%),
    linear-gradient(135deg,#020617 0%,#081225 48%,#111033 100%)!important;
}
.theme-dark .card,.theme-dark .modern-card-pro,.theme-dark .attendance-today-pro,.theme-dark .lux-data-panel,.theme-dark .announcement-create-card,.theme-dark .announcement-list-card{background:linear-gradient(145deg,#0f172a 0%,#111c35 52%,#1e1b4b 100%)!important;border-color:#334155!important;box-shadow:0 18px 38px rgba(0,0,0,.28)!important}.theme-dark .card *,.theme-dark .modern-card-pro *,.theme-dark .attendance-today-pro *,.theme-dark .lux-data-panel *{color:#f8fafc!important}.theme-dark input,.theme-dark select,.theme-dark textarea{background:#020617!important;color:#f8fafc!important;border-color:#475569!important}.theme-dark input::placeholder,.theme-dark textarea::placeholder{color:#94a3b8!important}.theme-dark .colorful-ann-card{background:linear-gradient(145deg,#0f172a,#1e1b4b)!important;border-color:#475569!important}.theme-dark .colorful-ann-card b,.theme-dark .colorful-ann-card p,.theme-dark .colorful-ann-card small{color:#f8fafc!important}.theme-dark .colorful-ann-item{background:linear-gradient(135deg,#0f172a,#1e293b 50%,#312e81)!important;border-color:#475569!important;color:#f8fafc!important}.theme-dark .colorful-ann-item b,.theme-dark .colorful-ann-item p{color:#f8fafc!important}.theme-dark .empty-mini{background:#1e293b;color:#e2e8f0}.theme-dark th{background:#172554!important;color:#f8fafc!important}.theme-dark td{color:#f8fafc!important;border-color:#334155!important}
@media(max-width:800px){.colorful-ann-item{display:block!important}.colorful-ann-item>img{width:100%;height:145px;margin-bottom:10px}.announcement-thumb{width:78px;height:50px}}


/* V45 - DARK MODE FULL FIX: semua panel harus gelap, teks tetap jelas, warna tetap premium */
html[data-theme="dark"] body,
html[data-theme="dark"] body.premium-global-theme,
html[data-theme="dark"] .premium-global-theme,
body.theme-dark.premium-global-theme{
  background:
    radial-gradient(circle at 8% 8%, rgba(37,99,235,.25), transparent 22%),
    radial-gradient(circle at 92% 12%, rgba(168,85,247,.22), transparent 24%),
    radial-gradient(circle at 55% 105%, rgba(6,182,212,.14), transparent 26%),
    linear-gradient(135deg,#020617 0%,#06111f 45%,#0b1027 100%)!important;
  color:#f8fafc!important;
}
html[data-theme="dark"] .main-content,
html[data-theme="dark"] .content-wrap{
  background:transparent!important;
  color:#f8fafc!important;
}
html[data-theme="dark"] .topbar{
  background:linear-gradient(135deg,rgba(2,6,23,.96),rgba(15,23,42,.92))!important;
  border-bottom:1px solid #1f3157!important;
  box-shadow:0 12px 30px rgba(0,0,0,.30)!important;
}
html[data-theme="dark"] .topbar *,
html[data-theme="dark"] .top-title b,
html[data-theme="dark"] .top-title span{
  color:#f8fafc!important;
  opacity:1!important;
}
html[data-theme="dark"] .notif,
html[data-theme="dark"] .user-chip,
html[data-theme="dark"] .theme-toggle{
  background:#0f172a!important;
  color:#f8fafc!important;
  border:1px solid #334155!important;
  box-shadow:0 10px 22px rgba(0,0,0,.32)!important;
}
html[data-theme="dark"] .notif *,
html[data-theme="dark"] .user-chip *,
html[data-theme="dark"] .theme-toggle *{color:#f8fafc!important}
html[data-theme="dark"] .user-chip b{background:#1e3a8a!important;color:#dbeafe!important}

/* semua card putih di screenshot dibuat gelap */
html[data-theme="dark"] .card,
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .modern-card-pro,
html[data-theme="dark"] .attendance-today-pro,
html[data-theme="dark"] .lux-data-panel,
html[data-theme="dark"] .lux-row-card,
html[data-theme="dark"] .lux-ann-card,
html[data-theme="dark"] .announcement-create-card,
html[data-theme="dark"] .announcement-list-card,
html[data-theme="dark"] .settings-premium-box,
html[data-theme="dark"] .setting-tab-pane,
html[data-theme="dark"] .file-card-premium,
html[data-theme="dark"] .quick-menu-pro a,
html[data-theme="dark"] .time-node,
html[data-theme="dark"] .employee-info-list-pro p,
html[data-theme="dark"] .salary-card-pro,
html[data-theme="dark"] .login-v33-panel,
html[data-theme="dark"] .login-v33-access-grid>div,
html[data-theme="dark"] .login-v33-demo,
html[data-theme="dark"] .login-v33-mini-note{
  background:linear-gradient(145deg,#0b1220 0%,#101b32 55%,#151b3d 100%)!important;
  color:#f8fafc!important;
  border:1px solid #273957!important;
  box-shadow:0 18px 38px rgba(0,0,0,.34)!important;
}
html[data-theme="dark"] .card *,
html[data-theme="dark"] .stat-card *,
html[data-theme="dark"] .modern-card-pro *,
html[data-theme="dark"] .attendance-today-pro *,
html[data-theme="dark"] .lux-data-panel *,
html[data-theme="dark"] .lux-row-card *,
html[data-theme="dark"] .lux-ann-card *,
html[data-theme="dark"] .announcement-create-card *,
html[data-theme="dark"] .announcement-list-card *,
html[data-theme="dark"] .settings-premium-box *,
html[data-theme="dark"] .setting-tab-pane *,
html[data-theme="dark"] .file-card-premium *,
html[data-theme="dark"] .quick-menu-pro a *,
html[data-theme="dark"] .time-node *,
html[data-theme="dark"] .employee-info-list-pro p *,
html[data-theme="dark"] .salary-card-pro *,
html[data-theme="dark"] .login-v33-panel *,
html[data-theme="dark"] .login-v33-access-grid>div *,
html[data-theme="dark"] .login-v33-demo *,
html[data-theme="dark"] .login-v33-mini-note *{
  color:#f8fafc!important;
  opacity:1!important;
  text-shadow:none!important;
}
html[data-theme="dark"] .empty,
html[data-theme="dark"] .empty-mini,
html[data-theme="dark"] small,
html[data-theme="dark"] .hint,
html[data-theme="dark"] .muted,
html[data-theme="dark"] .card small,
html[data-theme="dark"] .lux-row-main span,
html[data-theme="dark"] .lux-row-time span,
html[data-theme="dark"] .card-head span,
html[data-theme="dark"] .section-title-pro span,
html[data-theme="dark"] .lux-data-head span{
  color:#dbeafe!important;
  opacity:1!important;
}
html[data-theme="dark"] .empty-mini{
  background:#172033!important;
  border:1px solid #334155!important;
  border-radius:999px!important;
}

/* statistik tetap berwarna, bukan putih */
html[data-theme="dark"] .admin-lux-stats .admin-lux-stat,
html[data-theme="dark"] .admin-lux-stat{
  border:1px solid rgba(148,163,184,.22)!important;
  color:#ffffff!important;
  box-shadow:0 18px 36px rgba(0,0,0,.38)!important;
}
html[data-theme="dark"] .admin-lux-stats .admin-lux-stat.blue,
html[data-theme="dark"] .admin-lux-stat.blue{background:linear-gradient(135deg,#0f1f47 0%,#1d4ed8 58%,#4338ca 100%)!important}
html[data-theme="dark"] .admin-lux-stats .admin-lux-stat.green,
html[data-theme="dark"] .admin-lux-stat.green{background:linear-gradient(135deg,#052e2b 0%,#047857 58%,#065f46 100%)!important}
html[data-theme="dark"] .admin-lux-stats .admin-lux-stat.amber,
html[data-theme="dark"] .admin-lux-stat.amber{background:linear-gradient(135deg,#3a2408 0%,#92400e 58%,#9a3412 100%)!important}
html[data-theme="dark"] .admin-lux-stats .admin-lux-stat.purple,
html[data-theme="dark"] .admin-lux-stat.purple{background:linear-gradient(135deg,#24104c 0%,#6d28d9 58%,#be185d 100%)!important}
html[data-theme="dark"] .admin-lux-stat:before{opacity:.14!important;background:linear-gradient(120deg,rgba(255,255,255,.20),transparent 35%,rgba(255,255,255,.10))!important}
html[data-theme="dark"] .admin-lux-stat *{color:#ffffff!important;text-shadow:0 2px 8px rgba(0,0,0,.45)!important;opacity:1!important}
html[data-theme="dark"] .admin-lux-stat span,
html[data-theme="dark"] .admin-lux-stat small{color:#f8fafc!important}

/* hero dark tetap warna, tapi bukan putih */
html[data-theme="dark"] .admin-lux-hero,
html[data-theme="dark"] .employee-hero-pro,
html[data-theme="dark"] .hero-card,
html[data-theme="dark"] .settings-lux-hero,
html[data-theme="dark"] .login-v33-hero{
  background:linear-gradient(135deg,#071225 0%,#0f2e7a 35%,#4c1d95 72%,#831843 100%)!important;
  color:#ffffff!important;
  border:1px solid rgba(148,163,184,.28)!important;
  box-shadow:0 24px 50px rgba(0,0,0,.42)!important;
}
html[data-theme="dark"] .admin-lux-hero *,
html[data-theme="dark"] .employee-hero-pro *,
html[data-theme="dark"] .hero-card *,
html[data-theme="dark"] .settings-lux-hero *,
html[data-theme="dark"] .login-v33-hero *{
  color:#ffffff!important;
  opacity:1!important;
  text-shadow:0 2px 10px rgba(0,0,0,.35)!important;
}
html[data-theme="dark"] .lux-clock-card,
html[data-theme="dark"] .lux-mini-grid div,
html[data-theme="dark"] .hero-profile-pro{
  background:rgba(15,23,42,.62)!important;
  border:1px solid rgba(226,232,240,.20)!important;
  color:#ffffff!important;
  backdrop-filter:blur(12px)!important;
}

/* form, tabel, list, dan item kecil dark */
html[data-theme="dark"] input,
html[data-theme="dark"] select,
html[data-theme="dark"] textarea{
  background:#020617!important;
  color:#f8fafc!important;
  border-color:#475569!important;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 8px 18px rgba(0,0,0,.20)!important;
}
html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder{color:#94a3b8!important}
html[data-theme="dark"] .table-wrap,
html[data-theme="dark"] table{
  background:#0b1220!important;
  border-color:#273957!important;
  color:#f8fafc!important;
}
html[data-theme="dark"] th{background:#111f3a!important;color:#dbeafe!important;border-color:#273957!important}
html[data-theme="dark"] td{background:#0b1220!important;color:#f8fafc!important;border-color:#273957!important}
html[data-theme="dark"] tr:hover td{background:#111c35!important}
html[data-theme="dark"] .badge{background:#172033!important;color:#dbeafe!important;border:1px solid #475569!important}
html[data-theme="dark"] .badge.success,
html[data-theme="dark"] .badge.active{background:#14532d!important;color:#dcfce7!important;border-color:#22c55e!important}
html[data-theme="dark"] .badge.danger,
html[data-theme="dark"] .badge.rejected{background:#7f1d1d!important;color:#fee2e2!important;border-color:#ef4444!important}

/* pengumuman bergambar dark */
html[data-theme="dark"] .colorful-ann-card,
html[data-theme="dark"] .colorful-ann-item{
  background:linear-gradient(145deg,#0b1220 0%,#101b32 56%,#1e1b4b 100%)!important;
  color:#f8fafc!important;
  border:1px solid #334155!important;
}
html[data-theme="dark"] .colorful-ann-card b,
html[data-theme="dark"] .colorful-ann-card p,
html[data-theme="dark"] .colorful-ann-card small,
html[data-theme="dark"] .colorful-ann-item b,
html[data-theme="dark"] .colorful-ann-item p,
html[data-theme="dark"] .colorful-ann-item small{color:#f8fafc!important;opacity:1!important}
html[data-theme="dark"] img,
html[data-theme="dark"] video,
html[data-theme="dark"] canvas,
html[data-theme="dark"] .brand-logo,
html[data-theme="dark"] .photo-thumb,
html[data-theme="dark"] .announcement-thumb{opacity:1!important;filter:none!important}
html[data-theme="dark"] .gps-map{filter:brightness(.88) contrast(1.08) saturate(.92)!important}

/* light mode tetap terang dan kontras */
html[data-theme="light"] body.premium-global-theme,
html[data-theme="light"] .premium-global-theme{color:#0f172a!important}
html[data-theme="light"] .card *,
html[data-theme="light"] .lux-data-panel *,
html[data-theme="light"] .modern-card-pro *{opacity:1!important}


/* V46 - TOTAL LUXURY PREMIUM UI RESET: mewah, berwarna, tetap jelas light/dark */
:root{
  --lux-radius-lg:24px;
  --lux-radius-md:18px;
  --lux-shadow-light:0 20px 45px rgba(30,64,175,.12),0 8px 20px rgba(236,72,153,.06);
  --lux-shadow-dark:0 22px 48px rgba(0,0,0,.42),0 8px 20px rgba(59,130,246,.10);
  --lux-border-light:rgba(37,99,235,.18);
  --lux-border-dark:rgba(148,163,184,.20);
  --lux-blue:#2563eb;--lux-violet:#7c3aed;--lux-pink:#db2777;--lux-cyan:#06b6d4;--lux-gold:#f59e0b;
}
html[data-theme="light"] body.premium-global-theme,
html[data-theme="light"] body,
body.theme-light.premium-global-theme{
  background:
    radial-gradient(circle at 8% -3%,rgba(37,99,235,.18),transparent 26%),
    radial-gradient(circle at 98% 6%,rgba(236,72,153,.16),transparent 25%),
    radial-gradient(circle at 48% 104%,rgba(6,182,212,.13),transparent 28%),
    linear-gradient(135deg,#f8fbff 0%,#eef6ff 48%,#fff6fb 100%)!important;
  color:#0b1220!important;
}
html[data-theme="dark"] body.premium-global-theme,
html[data-theme="dark"] body,
body.theme-dark.premium-global-theme{
  background:
    radial-gradient(circle at 8% 0%,rgba(37,99,235,.26),transparent 30%),
    radial-gradient(circle at 96% 8%,rgba(219,39,119,.24),transparent 28%),
    radial-gradient(circle at 50% 112%,rgba(6,182,212,.16),transparent 30%),
    linear-gradient(135deg,#030712 0%,#071224 42%,#120f2f 72%,#171025 100%)!important;
  color:#f8fafc!important;
}
.premium-global-theme .content-wrap{padding:18px!important;max-width:1500px!important;overflow-x:hidden!important}.premium-global-theme .main-content{overflow-x:hidden!important}.premium-global-theme .app-shell{background:transparent!important}
/* Sidebar luxury */
.premium-global-theme .sidebar{
  width:268px!important;padding:14px!important;background:
    radial-gradient(circle at 20% 0%,rgba(96,165,250,.25),transparent 25%),
    radial-gradient(circle at 100% 86%,rgba(236,72,153,.22),transparent 27%),
    linear-gradient(180deg,#071427 0%,#0d1e3b 40%,#171448 72%,#26073d 100%)!important;
  border-right:1px solid rgba(255,255,255,.10)!important;box-shadow:20px 0 46px rgba(0,0,0,.24)!important;
}
.premium-global-theme .main-content{margin-left:268px!important;width:calc(100% - 268px)!important}.premium-global-theme .brand{min-height:76px!important;border-radius:22px!important;background:linear-gradient(135deg,rgba(255,255,255,.15),rgba(255,255,255,.06))!important;border:1px solid rgba(255,255,255,.13)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.12),0 15px 30px rgba(0,0,0,.18)!important}.premium-global-theme .brand-logo{width:50px!important;height:50px!important;border-radius:17px!important;background:linear-gradient(145deg,#fff,#dbeafe)!important}.premium-global-theme .brand b{font-size:13px!important;color:#fff!important}.premium-global-theme .brand span{font-size:11px!important;color:#dbeafe!important}
.premium-global-theme .grouped-nav-menu{gap:8px!important}.premium-global-theme .grouped-nav-menu a,.premium-global-theme .nav-group summary{height:48px!important;border-radius:16px!important;padding:8px 11px!important;display:flex!important;align-items:center!important;gap:10px!important;color:#eef6ff!important;font-size:12px!important;font-weight:900!important;background:rgba(255,255,255,.045)!important;border:1px solid rgba(255,255,255,.08)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.05)!important}.premium-global-theme .grouped-nav-menu a:hover,.premium-global-theme .nav-group summary:hover{background:rgba(255,255,255,.12)!important;transform:translateX(2px)!important}.premium-global-theme .grouped-nav-menu a.active,.premium-global-theme .nav-main.active,.premium-global-theme .nav-group[open]>summary{background:linear-gradient(135deg,#2563eb,#7c3aed 58%,#db2777)!important;color:#fff!important;border-color:rgba(255,255,255,.18)!important;box-shadow:0 14px 28px rgba(37,99,235,.25)!important}.premium-global-theme .nav-ico{width:34px!important;height:34px!important;flex:0 0 34px!important;border-radius:13px!important;background:linear-gradient(135deg,rgba(255,255,255,.22),rgba(255,255,255,.09))!important;display:grid!important;place-items:center!important;color:#fff!important}.premium-global-theme .nav-sub{padding:7px 0 0 13px!important;display:grid!important;gap:6px!important}.premium-global-theme .nav-sub a{height:40px!important;border-radius:14px!important;font-size:11px!important;background:rgba(255,255,255,.055)!important}.premium-global-theme .nav-sub a i{width:26px!important;height:26px!important;display:grid!important;place-items:center!important;border-radius:10px!important;background:rgba(255,255,255,.10)!important}.premium-global-theme .nav-logout{margin-top:8px!important;background:linear-gradient(135deg,rgba(239,68,68,.35),rgba(219,39,119,.25))!important;border-color:rgba(248,113,113,.25)!important}
/* Topbar */
.premium-global-theme .topbar{min-height:66px!important;padding:10px 18px!important;background:linear-gradient(135deg,rgba(255,255,255,.86),rgba(255,255,255,.67))!important;border-bottom:1px solid rgba(191,219,254,.75)!important;box-shadow:0 12px 30px rgba(37,99,235,.08)!important;backdrop-filter:blur(20px)!important}.premium-global-theme .top-title b{font-size:15px!important;color:#0f172a!important}.premium-global-theme .top-title span{font-size:11px!important;color:#64748b!important}.premium-global-theme .theme-toggle,.premium-global-theme .notif,.premium-global-theme .user-chip{height:40px!important;border-radius:15px!important;background:linear-gradient(180deg,#fff,#f8fbff)!important;border:1px solid #dbeafe!important;color:#1e3a8a!important;box-shadow:0 10px 22px rgba(37,99,235,.08)!important}.premium-global-theme .theme-toggle{padding:0 12px!important;display:inline-flex!important;align-items:center!important;gap:7px!important;font-weight:900!important}.premium-global-theme .user-chip{padding:7px 10px!important}.premium-global-theme .user-chip span{font-size:12px!important}.premium-global-theme .user-chip b{font-size:9px!important;border-radius:999px!important;background:linear-gradient(135deg,#2563eb,#7c3aed)!important;color:#fff!important}.premium-global-theme .hamburger{width:40px!important;height:40px!important;border-radius:14px!important;background:linear-gradient(135deg,#2563eb,#7c3aed)!important}
/* Cards: luxury glass with color accents, no polos */
.premium-global-theme .card,.premium-global-theme .lux-data-panel,.premium-global-theme .modern-card-pro,.premium-global-theme .attendance-today-pro,.premium-global-theme .settings-premium-box,.premium-global-theme .setting-tab-pane,.premium-global-theme .announcement-create-card,.premium-global-theme .announcement-list-card,.premium-global-theme .file-card-premium,.premium-global-theme .stat-card{
  position:relative!important;overflow:hidden!important;border-radius:var(--lux-radius-lg)!important;background:
    linear-gradient(145deg,rgba(255,255,255,.98),rgba(247,251,255,.94) 55%,rgba(255,247,251,.93))!important;
  border:1px solid var(--lux-border-light)!important;box-shadow:var(--lux-shadow-light)!important;color:#0f172a!important;
}
.premium-global-theme .card:before,.premium-global-theme .lux-data-panel:before,.premium-global-theme .modern-card-pro:before,.premium-global-theme .attendance-today-pro:before,.premium-global-theme .settings-premium-box:before,.premium-global-theme .announcement-create-card:before,.premium-global-theme .announcement-list-card:before,.premium-global-theme .stat-card:before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#2563eb,#06b6d4,#7c3aed,#db2777,#f59e0b);opacity:.95!important;z-index:1}.premium-global-theme .card>*,.premium-global-theme .lux-data-panel>*,.premium-global-theme .modern-card-pro>*,.premium-global-theme .attendance-today-pro>*{position:relative;z-index:2}.premium-global-theme .card-head h2,.premium-global-theme .card-head h3,.premium-global-theme .lux-data-head h2,.premium-global-theme h1,.premium-global-theme h2,.premium-global-theme h3{color:#0f172a!important;text-shadow:none!important}.premium-global-theme .card-head span,.premium-global-theme .lux-data-head span,.premium-global-theme .section-title-pro span,.premium-global-theme small,.premium-global-theme .muted{color:#475569!important;opacity:1!important}
/* Dashboard hero */
.premium-global-theme .admin-lux-dashboard{display:grid!important;gap:16px!important}.premium-global-theme .admin-lux-hero,.premium-global-theme .employee-hero-pro,.premium-global-theme .hero-card,.premium-global-theme .settings-lux-hero{
  background:
    linear-gradient(135deg,rgba(5,12,31,.74),rgba(29,78,216,.95) 36%,rgba(124,58,237,.94) 70%,rgba(219,39,119,.92))!important;
  border:1px solid rgba(255,255,255,.18)!important;border-radius:28px!important;box-shadow:0 26px 58px rgba(37,99,235,.28),0 12px 28px rgba(219,39,119,.14)!important;overflow:hidden!important;color:#fff!important;min-height:220px!important;padding:26px!important;
}
.premium-global-theme .admin-lux-hero:before,.premium-global-theme .employee-hero-pro:before,.premium-global-theme .hero-card:before{content:""!important;position:absolute!important;inset:0!important;background:linear-gradient(90deg,rgba(255,255,255,.15),transparent 32%,rgba(255,255,255,.08) 75%,transparent),radial-gradient(circle at 85% 0%,rgba(255,255,255,.23),transparent 25%),radial-gradient(circle at 15% 90%,rgba(6,182,212,.24),transparent 24%)!important;pointer-events:none!important;opacity:1!important}.premium-global-theme .admin-lux-hero *,.premium-global-theme .employee-hero-pro *,.premium-global-theme .hero-card *,.premium-global-theme .settings-lux-hero *{color:#fff!important;text-shadow:0 2px 10px rgba(0,0,0,.28)!important;opacity:1!important}.premium-global-theme .admin-lux-hero h1{font-size:38px!important;line-height:1.05!important}.premium-global-theme .lux-clock-card,.premium-global-theme .lux-mini-grid div,.premium-global-theme .hero-profile-pro{background:rgba(255,255,255,.16)!important;border:1px solid rgba(255,255,255,.22)!important;border-radius:22px!important;backdrop-filter:blur(14px)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.16),0 14px 28px rgba(0,0,0,.12)!important}
/* Dashboard stats and action cards */
.premium-global-theme .admin-lux-stats{grid-template-columns:repeat(4,minmax(0,1fr))!important;gap:14px!important}.premium-global-theme .admin-lux-stat{border-radius:24px!important;min-height:160px!important;padding:22px!important;color:#fff!important;box-shadow:0 20px 44px rgba(15,23,42,.17)!important;border:1px solid rgba(255,255,255,.14)!important}.premium-global-theme .admin-lux-stat i{width:52px!important;height:52px!important;border-radius:18px!important;background:rgba(255,255,255,.18)!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.16)!important}.premium-global-theme .admin-lux-stat *{color:#fff!important;text-shadow:0 2px 10px rgba(0,0,0,.30)!important}.premium-global-theme .admin-lux-stat.blue{background:linear-gradient(135deg,#1e3a8a,#2563eb 54%,#06b6d4)!important}.premium-global-theme .admin-lux-stat.green{background:linear-gradient(135deg,#064e3b,#059669 54%,#22c55e)!important}.premium-global-theme .admin-lux-stat.amber{background:linear-gradient(135deg,#7c2d12,#ea580c 54%,#f59e0b)!important}.premium-global-theme .admin-lux-stat.purple{background:linear-gradient(135deg,#4c1d95,#7c3aed 54%,#db2777)!important}.premium-global-theme .admin-lux-action-grid{gap:14px!important}.premium-global-theme .lux-action-card{min-height:96px!important;border-radius:23px!important;background:linear-gradient(135deg,#1e3a8a,#2563eb,#7c3aed)!important;color:#fff!important;border:1px solid rgba(255,255,255,.14)!important;box-shadow:0 18px 34px rgba(37,99,235,.18)!important}.premium-global-theme .lux-action-card:nth-child(2){background:linear-gradient(135deg,#047857,#0d9488,#06b6d4)!important}.premium-global-theme .lux-action-card:nth-child(3){background:linear-gradient(135deg,#7c2d12,#ea580c,#f59e0b)!important}.premium-global-theme .lux-action-card:nth-child(4){background:linear-gradient(135deg,#7e22ce,#db2777,#f43f5e)!important}.premium-global-theme .lux-action-card *{color:#fff!important;text-shadow:0 2px 8px rgba(0,0,0,.27)!important}
/* Lists, form, table */
.premium-global-theme .lux-row-card{background:linear-gradient(135deg,#f8fbff,#eef6ff)!important;border:1px solid #dbeafe!important;border-radius:18px!important;color:#0f172a!important}.premium-global-theme .lux-row-card *{color:#0f172a!important;text-shadow:none!important}.premium-global-theme .avatar-dot{background:linear-gradient(135deg,#2563eb,#7c3aed)!important;color:#fff!important}.premium-global-theme .table-wrap{border-radius:18px!important;border:1px solid #cfe1ff!important;box-shadow:0 14px 28px rgba(37,99,235,.07)!important;overflow:auto!important}.premium-global-theme table{background:#fff!important}.premium-global-theme th{background:linear-gradient(135deg,#eaf2ff,#f3e8ff)!important;color:#1e3a8a!important;font-size:11px!important}.premium-global-theme td{color:#111827!important;background:#fff!important}.premium-global-theme tr:hover td{background:#f8fbff!important}.premium-global-theme input,.premium-global-theme select,.premium-global-theme textarea{height:auto!important;border-radius:15px!important;border:1px solid #bed6ff!important;background:linear-gradient(180deg,#fff,#f8fbff)!important;color:#0f172a!important;box-shadow:0 8px 18px rgba(37,99,235,.05)!important}.premium-global-theme input:focus,.premium-global-theme select:focus,.premium-global-theme textarea:focus{border-color:#7c3aed!important;box-shadow:0 0 0 4px rgba(124,58,237,.12)!important}.premium-global-theme label{color:#1e293b!important}.premium-global-theme .btn{border-radius:15px!important;font-size:12px!important}.premium-global-theme .btn.primary{background:linear-gradient(135deg,#2563eb,#7c3aed,#db2777)!important;color:#fff!important}.premium-global-theme .btn.success{background:linear-gradient(135deg,#059669,#22c55e)!important;color:#fff!important}.premium-global-theme .btn.danger{background:linear-gradient(135deg,#ef4444,#be123c)!important;color:#fff!important}.premium-global-theme .badge{font-weight:900!important;border-radius:999px!important}.premium-global-theme .badge.success,.premium-global-theme .badge.active{background:#dcfce7!important;color:#166534!important}.premium-global-theme .empty{color:#334155!important;background:rgba(239,246,255,.75)!important;border:1px dashed #bfdbfe!important;border-radius:18px!important;padding:16px!important}
/* Announcement image cards colorful */
.premium-global-theme .colorful-ann-card,.premium-global-theme .colorful-ann-item{background:linear-gradient(145deg,#ffffff,#eff6ff 45%,#fff1f2)!important;border:1px solid #c7ddff!important;border-radius:22px!important;color:#0f172a!important;box-shadow:0 16px 34px rgba(37,99,235,.09)!important}.premium-global-theme .colorful-ann-card b,.premium-global-theme .colorful-ann-card p,.premium-global-theme .colorful-ann-card small,.premium-global-theme .colorful-ann-item b,.premium-global-theme .colorful-ann-item p{color:#0f172a!important;opacity:1!important}.premium-global-theme .announcement-thumb,.premium-global-theme .colorful-ann-card>img,.premium-global-theme .colorful-ann-item>img{filter:none!important;opacity:1!important;border-color:#dbeafe!important}
/* Login compact luxury */
.login-v33-body .login-v33-panel{background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(248,251,255,.94))!important;border:1px solid rgba(219,234,254,.85)!important}.login-v33-body .login-v33-hero{background:linear-gradient(135deg,rgba(5,12,31,.76),rgba(29,78,216,.92),rgba(124,58,237,.88),rgba(219,39,119,.78))!important}
/* TRUE DARK LUXURY: no white cards, but still colorful */
html[data-theme="dark"] .premium-global-theme .topbar,html[data-theme="dark"] .topbar{background:linear-gradient(135deg,rgba(3,7,18,.94),rgba(15,23,42,.86))!important;border-bottom:1px solid rgba(148,163,184,.18)!important;box-shadow:0 12px 34px rgba(0,0,0,.36)!important}.theme-dark .top-title b,.theme-dark .top-title span,html[data-theme="dark"] .top-title b,html[data-theme="dark"] .top-title span{color:#f8fafc!important}.theme-dark .theme-toggle,.theme-dark .notif,.theme-dark .user-chip,html[data-theme="dark"] .theme-toggle,html[data-theme="dark"] .notif,html[data-theme="dark"] .user-chip{background:linear-gradient(145deg,#0f172a,#111c35)!important;border:1px solid #334155!important;color:#f8fafc!important}.theme-dark .theme-toggle *,.theme-dark .notif *,.theme-dark .user-chip *,html[data-theme="dark"] .theme-toggle *,html[data-theme="dark"] .notif *,html[data-theme="dark"] .user-chip *{color:#f8fafc!important}
html[data-theme="dark"] .card,html[data-theme="dark"] .lux-data-panel,html[data-theme="dark"] .modern-card-pro,html[data-theme="dark"] .attendance-today-pro,html[data-theme="dark"] .settings-premium-box,html[data-theme="dark"] .setting-tab-pane,html[data-theme="dark"] .announcement-create-card,html[data-theme="dark"] .announcement-list-card,html[data-theme="dark"] .file-card-premium,html[data-theme="dark"] .stat-card,html[data-theme="dark"] .login-v33-panel{
  background:linear-gradient(145deg,rgba(10,18,32,.98),rgba(16,27,53,.96) 52%,rgba(30,27,75,.92))!important;border:1px solid var(--lux-border-dark)!important;box-shadow:var(--lux-shadow-dark)!important;color:#f8fafc!important;
}
html[data-theme="dark"] .card:before,html[data-theme="dark"] .lux-data-panel:before,html[data-theme="dark"] .modern-card-pro:before,html[data-theme="dark"] .attendance-today-pro:before,html[data-theme="dark"] .settings-premium-box:before,html[data-theme="dark"] .announcement-create-card:before,html[data-theme="dark"] .announcement-list-card:before{opacity:.82!important}
html[data-theme="dark"] .card *,html[data-theme="dark"] .lux-data-panel *,html[data-theme="dark"] .modern-card-pro *,html[data-theme="dark"] .attendance-today-pro *,html[data-theme="dark"] .settings-premium-box *,html[data-theme="dark"] .setting-tab-pane *,html[data-theme="dark"] .announcement-create-card *,html[data-theme="dark"] .announcement-list-card *,html[data-theme="dark"] .file-card-premium *,html[data-theme="dark"] .login-v33-panel *{color:#f8fafc!important;opacity:1!important;text-shadow:none!important}
html[data-theme="dark"] .card-head span,html[data-theme="dark"] .lux-data-head span,html[data-theme="dark"] .section-title-pro span,html[data-theme="dark"] small,html[data-theme="dark"] .muted,html[data-theme="dark"] .empty{color:#cbd5e1!important}.theme-dark .lux-row-card,html[data-theme="dark"] .lux-row-card{background:linear-gradient(135deg,#0f172a,#111c35)!important;border:1px solid #334155!important}.theme-dark .lux-row-card *,html[data-theme="dark"] .lux-row-card *{color:#f8fafc!important}.theme-dark .table-wrap,.theme-dark table,html[data-theme="dark"] .table-wrap,html[data-theme="dark"] table{background:#0b1220!important;border-color:#334155!important}.theme-dark th,html[data-theme="dark"] th{background:linear-gradient(135deg,#111f3a,#241b4b)!important;color:#dbeafe!important}.theme-dark td,html[data-theme="dark"] td{background:#0b1220!important;color:#f8fafc!important;border-color:#273957!important}.theme-dark tr:hover td,html[data-theme="dark"] tr:hover td{background:#111c35!important}.theme-dark input,.theme-dark select,.theme-dark textarea,html[data-theme="dark"] input,html[data-theme="dark"] select,html[data-theme="dark"] textarea{background:linear-gradient(180deg,#020617,#0b1220)!important;color:#f8fafc!important;border-color:#475569!important}.theme-dark input::placeholder,.theme-dark textarea::placeholder,html[data-theme="dark"] input::placeholder,html[data-theme="dark"] textarea::placeholder{color:#94a3b8!important}.theme-dark label,html[data-theme="dark"] label{color:#e2e8f0!important}.theme-dark .empty,html[data-theme="dark"] .empty{background:rgba(15,23,42,.8)!important;border-color:#334155!important}.theme-dark .colorful-ann-card,.theme-dark .colorful-ann-item,html[data-theme="dark"] .colorful-ann-card,html[data-theme="dark"] .colorful-ann-item{background:linear-gradient(145deg,#0b1220,#111c35 46%,#241b4b)!important;border-color:#334155!important}.theme-dark img,html[data-theme="dark"] img{opacity:1!important;filter:none!important}
@media(max-width:1180px){.premium-global-theme .admin-lux-stats{grid-template-columns:repeat(2,minmax(0,1fr))!important}.premium-global-theme .admin-lux-grid-2{grid-template-columns:1fr!important}.premium-global-theme .admin-lux-hero{grid-template-columns:1fr!important}.premium-global-theme .admin-lux-hero h1{font-size:31px!important}}
@media(max-width:800px){.premium-global-theme .sidebar{width:280px!important;transform:translateX(-105%)!important}.premium-global-theme .sidebar.open{transform:translateX(0)!important}.premium-global-theme .main-content{margin-left:0!important;width:100%!important}.premium-global-theme .content-wrap{padding:12px!important}.premium-global-theme .admin-lux-stats,.premium-global-theme .admin-lux-action-grid{grid-template-columns:1fr!important}.premium-global-theme .admin-lux-stat{min-height:128px!important;padding:18px!important}.premium-global-theme .admin-lux-hero{padding:20px!important;border-radius:22px!important}.premium-global-theme .admin-lux-hero h1{font-size:26px!important}.premium-global-theme .top-actions{gap:7px!important}.premium-global-theme .theme-toggle span{display:none!important}.premium-global-theme .user-chip span{max-width:92px!important}.premium-global-theme .lux-action-card{min-height:84px!important}}


/* V47 - Background lebih berwarna, tidak polos, dark mode full gelap mewah */
html[data-theme="light"],html[data-theme="light"] body{
  background:
    radial-gradient(circle at 12% 10%, rgba(59,130,246,.13), transparent 22%),
    radial-gradient(circle at 92% 18%, rgba(168,85,247,.11), transparent 20%),
    radial-gradient(circle at 50% 82%, rgba(236,72,153,.08), transparent 20%),
    linear-gradient(180deg,#eef4ff 0%,#f7fbff 48%,#eef5ff 100%)!important;
}
html[data-theme="light"] .main-content,
html[data-theme="light"] .content-wrap{
  background:transparent!important;
}
html[data-theme="light"] .content-wrap::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.4;
  background-image:radial-gradient(rgba(99,102,241,.09) 1px, transparent 1px);
  background-size:24px 24px;
}
html[data-theme="light"] .card,
html[data-theme="light"] .stat-card,
html[data-theme="light"] .lux-data-panel,
html[data-theme="light"] .lux-ann-card,
html[data-theme="light"] .lux-row-card,
html[data-theme="light"] .announcement-list-card,
html[data-theme="light"] .announcement-create-card,
html[data-theme="light"] .announcement-panel,
html[data-theme="light"] .payroll-panel,
html[data-theme="light"] .company-panel,
html[data-theme="light"] .whatsapp-panel,
html[data-theme="light"] .wa-log-panel,
html[data-theme="light"] .wa-test-panel,
html[data-theme="light"] .settings-pane,
html[data-theme="light"] .settings-lux-form,
html[data-theme="light"] .settings-subnav,
html[data-theme="light"] .employee-form-card,
html[data-theme="light"] .employee-editor-premium,
html[data-theme="light"] .employee-premium-form,
html[data-theme="light"] .gps-card,
html[data-theme="light"] .slip-card,
html[data-theme="light"] .admin-user-panel,
html[data-theme="light"] .admin-user-list-panel{
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(246,250,255,.95))!important;
}

html[data-theme="dark"],html[data-theme="dark"] body{
  background:
    radial-gradient(circle at 10% 10%, rgba(37,99,235,.18), transparent 24%),
    radial-gradient(circle at 90% 14%, rgba(124,58,237,.16), transparent 22%),
    radial-gradient(circle at 52% 88%, rgba(236,72,153,.10), transparent 22%),
    linear-gradient(180deg,#030712 0%,#07111f 52%,#0b1220 100%)!important;
}
html[data-theme="dark"] .main-content,
html[data-theme="dark"] .content-wrap{
  background:transparent!important;
}
html[data-theme="dark"] .content-wrap::before{
  content:"";position:fixed;inset:0;pointer-events:none;z-index:-1;opacity:.22;
  background-image:radial-gradient(rgba(148,163,184,.16) 1px, transparent 1px);
  background-size:26px 26px;
}
html[data-theme="dark"] .premium-global-theme,
html[data-theme="dark"] .admin-lux-dashboard,
html[data-theme="dark"] .employee-dashboard-pro,
html[data-theme="dark"] .settings-luxury{
  background:transparent!important;
}
html[data-theme="dark"] .brand,
html[data-theme="dark"] .nav-group,
html[data-theme="dark"] .premium-nav-menu a,
html[data-theme="dark"] .nav-sub a,
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .notif,
html[data-theme="dark"] .user-chip,
html[data-theme="dark"] .theme-toggle,
html[data-theme="dark"] .card,
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .modern-card-pro,
html[data-theme="dark"] .attendance-today-pro,
html[data-theme="dark"] .employee-info-card-pro,
html[data-theme="dark"] .map-card,
html[data-theme="dark"] .coord-panel,
html[data-theme="dark"] .selfie-panel,
html[data-theme="dark"] .notice,
html[data-theme="dark"] .time-node,
html[data-theme="dark"] .mini-stats-pro div,
html[data-theme="dark"] .coord-item,
html[data-theme="dark"] .quick-menu-pro a,
html[data-theme="dark"] .announcement-item-pro,
html[data-theme="dark"] .announcement-panel,
html[data-theme="dark"] .announcement-list-card,
html[data-theme="dark"] .announcement-create-card,
html[data-theme="dark"] .employee-info-list-pro p,
html[data-theme="dark"] .salary-list-pro p,
html[data-theme="dark"] .admin-user-panel,
html[data-theme="dark"] .admin-user-list-panel,
html[data-theme="dark"] .setting-tab-pane,
html[data-theme="dark"] .settings-premium-box,
html[data-theme="dark"] .settings-pane,
html[data-theme="dark"] .settings-lux-form,
html[data-theme="dark"] .settings-subnav,
html[data-theme="dark"] .payroll-panel,
html[data-theme="dark"] .company-panel,
html[data-theme="dark"] .whatsapp-panel,
html[data-theme="dark"] .wa-log-panel,
html[data-theme="dark"] .wa-test-panel,
html[data-theme="dark"] .gps-card,
html[data-theme="dark"] .slip-card,
html[data-theme="dark"] .employee-form-card,
html[data-theme="dark"] .employee-editor-premium,
html[data-theme="dark"] .employee-premium-form,
html[data-theme="dark"] .lux-data-panel,
html[data-theme="dark"] .lux-row-card,
html[data-theme="dark"] .lux-ann-card,
html[data-theme="dark"] .lux-action-card,
html[data-theme="dark"] .lux-info-card,
html[data-theme="dark"] .lux-panel,
html[data-theme="dark"] .lux-clock-card,
html[data-theme="dark"] .lux-mini-grid div,
html[data-theme="dark"] .file-card-premium,
html[data-theme="dark"] .sick-letter-box,
html[data-theme="dark"] .admin-lux-stat,
html[data-theme="dark"] .announcement-pro,
html[data-theme="dark"] .colorful-ann-card,
html[data-theme="dark"] .colorful-ann-item{
  background:linear-gradient(180deg,rgba(11,18,32,.96),rgba(17,24,39,.95))!important;
  border-color:#243042!important;
  color:#f8fafc!important;
  box-shadow:0 16px 34px rgba(0,0,0,.28)!important;
}
html[data-theme="dark"] .table-wrap,
html[data-theme="dark"] table,
html[data-theme="dark"] td,
html[data-theme="dark"] th{
  background:#0b1220!important;
  color:#f8fafc!important;
}
html[data-theme="dark"] th{background:#111c31!important;color:#dbeafe!important}
html[data-theme="dark"] td{border-bottom-color:#1f2937!important}
html[data-theme="dark"] .table-wrap{border-color:#243042!important}
html[data-theme="dark"] .empty,
html[data-theme="dark"] .hint,
html[data-theme="dark"] .muted,
html[data-theme="dark"] small,
html[data-theme="dark"] .top-title span,
html[data-theme="dark"] .lux-row-main span,
html[data-theme="dark"] .lux-row-time span,
html[data-theme="dark"] .quick-menu-pro span,
html[data-theme="dark"] .card-head span,
html[data-theme="dark"] .section-title-pro span,
html[data-theme="dark"] .employee-info-list-pro small,
html[data-theme="dark"] .salary-list-pro small,
html[data-theme="dark"] .announcement-item-pro small{
  color:#cbd5e1!important;
  opacity:1!important;
}
html[data-theme="dark"] .lux-data-head h2,
html[data-theme="dark"] .card h1,
html[data-theme="dark"] .card h2,
html[data-theme="dark"] .card h3,
html[data-theme="dark"] .lux-ann-card h3,
html[data-theme="dark"] .lux-action-card b,
html[data-theme="dark"] .admin-lux-stat b,
html[data-theme="dark"] .quick-menu-pro b,
html[data-theme="dark"] .top-title b{color:#f8fafc!important}
html[data-theme="dark"] input,
html[data-theme="dark"] select,
html[data-theme="dark"] textarea{
  background:linear-gradient(180deg,#0f172a,#111827)!important;
  color:#f8fafc!important;
  border-color:#334155!important;
}
html[data-theme="dark"] input::placeholder,
html[data-theme="dark"] textarea::placeholder{color:#94a3b8!important}
html[data-theme="dark"] .hero-card,
html[data-theme="dark"] .employee-hero-pro,
html[data-theme="dark"] .settings-lux-hero,
html[data-theme="dark"] .admin-lux-hero,
html[data-theme="dark"] .login-v33-hero{
  background:
    radial-gradient(circle at 82% 18%, rgba(168,85,247,.24), transparent 26%),
    radial-gradient(circle at 20% 76%, rgba(59,130,246,.20), transparent 22%),
    linear-gradient(135deg,#07101f 0%,#0d1b31 36%,#152642 72%,#231b40 100%)!important;
  border:1px solid #2d3b52!important;
  color:#f8fafc!important;
}
html[data-theme="dark"] .hero-card p,
html[data-theme="dark"] .employee-hero-pro p,
html[data-theme="dark"] .settings-lux-hero p,
html[data-theme="dark"] .admin-lux-hero p,
html[data-theme="dark"] .login-v33-copy p{color:#dbe4f0!important}
html[data-theme="dark"] .admin-lux-stat:after,
html[data-theme="dark"] .stat-card:after{opacity:.16!important}
html[data-theme="dark"] .quick-menu-pro a{background:linear-gradient(135deg,#101b31,#172554)!important}
html[data-theme="dark"] .quick-menu-pro a:nth-child(2n){background:linear-gradient(135deg,#101b31,#312e81)!important}
html[data-theme="dark"] .quick-menu-pro a:nth-child(3n){background:linear-gradient(135deg,#102133,#0f766e)!important}
html[data-theme="dark"] .quick-menu-pro a:nth-child(4n){background:linear-gradient(135deg,#2a1a08,#7c2d12)!important}
html[data-theme="dark"] .quick-menu-pro a:nth-child(5n){background:linear-gradient(135deg,#24104a,#6d28d9)!important}
html[data-theme="dark"] .quick-menu-pro a:nth-child(6n){background:linear-gradient(135deg,#2a1026,#db2777)!important}
html[data-theme="dark"] .login-v33-panel,
html[data-theme="dark"] .login-v33-input,
html[data-theme="dark"] .login-v33-access-grid>div,
html[data-theme="dark"] .login-v33-demo,
html[data-theme="dark"] .login-v33-mini-note,
html[data-theme="dark"] .login-v33-footer-note{
  background:linear-gradient(180deg,rgba(11,18,32,.98),rgba(17,24,39,.97))!important;
  border-color:#243042!important;
  color:#f8fafc!important;
}


/* V48 - Dark mode dibuat lebih soft, tidak terlalu hitam */
html[data-theme="dark"],
html[data-theme="dark"] body{
  background:
    radial-gradient(circle at 12% 10%, rgba(59,130,246,.22), transparent 24%),
    radial-gradient(circle at 88% 16%, rgba(168,85,247,.18), transparent 22%),
    radial-gradient(circle at 50% 85%, rgba(236,72,153,.12), transparent 20%),
    linear-gradient(180deg,#0b1426 0%,#101a31 48%,#131d36 100%) !important;
}
html[data-theme="dark"] .content-wrap::before{
  opacity:.16 !important;
  background-image:radial-gradient(rgba(148,163,184,.18) 1px, transparent 1px) !important;
}
html[data-theme="dark"] .sidebar{
  background:linear-gradient(180deg,#0e1a30 0%,#12203a 30%,#182848 70%,#1d2148 100%) !important;
}
html[data-theme="dark"] .brand,
html[data-theme="dark"] .nav-group,
html[data-theme="dark"] .topbar,
html[data-theme="dark"] .notif,
html[data-theme="dark"] .user-chip,
html[data-theme="dark"] .theme-toggle,
html[data-theme="dark"] .premium-nav-menu a,
html[data-theme="dark"] .nav-sub a{
  background:linear-gradient(180deg,rgba(20,30,52,.94),rgba(24,37,64,.93)) !important;
  border-color:#334155 !important;
}
html[data-theme="dark"] .premium-nav-menu a.active,
html[data-theme="dark"] .nav-sub a.active{
  background:linear-gradient(135deg,#2563eb,#6d28d9) !important;
  border-color:rgba(255,255,255,.12) !important;
}
html[data-theme="dark"] .card,
html[data-theme="dark"] .stat-card,
html[data-theme="dark"] .modern-card-pro,
html[data-theme="dark"] .attendance-today-pro,
html[data-theme="dark"] .employee-info-card-pro,
html[data-theme="dark"] .map-card,
html[data-theme="dark"] .coord-panel,
html[data-theme="dark"] .selfie-panel,
html[data-theme="dark"] .notice,
html[data-theme="dark"] .time-node,
html[data-theme="dark"] .mini-stats-pro div,
html[data-theme="dark"] .coord-item,
html[data-theme="dark"] .quick-menu-pro a,
html[data-theme="dark"] .announcement-item-pro,
html[data-theme="dark"] .announcement-panel,
html[data-theme="dark"] .announcement-list-card,
html[data-theme="dark"] .announcement-create-card,
html[data-theme="dark"] .employee-info-list-pro p,
html[data-theme="dark"] .salary-list-pro p,
html[data-theme="dark"] .admin-user-panel,
html[data-theme="dark"] .admin-user-list-panel,
html[data-theme="dark"] .setting-tab-pane,
html[data-theme="dark"] .settings-premium-box,
html[data-theme="dark"] .settings-pane,
html[data-theme="dark"] .settings-lux-form,
html[data-theme="dark"] .settings-subnav,
html[data-theme="dark"] .payroll-panel,
html[data-theme="dark"] .company-panel,
html[data-theme="dark"] .whatsapp-panel,
html[data-theme="dark"] .wa-log-panel,
html[data-theme="dark"] .wa-test-panel,
html[data-theme="dark"] .gps-card,
html[data-theme="dark"] .slip-card,
html[data-theme="dark"] .employee-form-card,
html[data-theme="dark"] .employee-editor-premium,
html[data-theme="dark"] .employee-premium-form,
html[data-theme="dark"] .lux-data-panel,
html[data-theme="dark"] .lux-row-card,
html[data-theme="dark"] .lux-ann-card,
html[data-theme="dark"] .lux-action-card,
html[data-theme="dark"] .lux-info-card,
html[data-theme="dark"] .lux-panel,
html[data-theme="dark"] .lux-clock-card,
html[data-theme="dark"] .lux-mini-grid div,
html[data-theme="dark"] .file-card-premium,
html[data-theme="dark"] .sick-letter-box,
html[data-theme="dark"] .admin-lux-stat,
html[data-theme="dark"] .announcement-pro,
html[data-theme="dark"] .colorful-ann-card,
html[data-theme="dark"] .colorful-ann-item,
html[data-theme="dark"] .table-wrap,
html[data-theme="dark"] table,
html[data-theme="dark"] td,
html[data-theme="dark"] th{
  background:linear-gradient(180deg,rgba(18,28,48,.97),rgba(25,37,62,.96)) !important;
  border-color:#334155 !important;
}
html[data-theme="dark"] th{background:linear-gradient(180deg,#1d2a44,#243552) !important; color:#e2e8f0 !important;}
html[data-theme="dark"] td{color:#f8fafc !important;}
html[data-theme="dark"] input,
html[data-theme="dark"] select,
html[data-theme="dark"] textarea{
  background:linear-gradient(180deg,#172236,#1d2942) !important;
  border-color:#475569 !important;
  color:#f8fafc !important;
}
html[data-theme="dark"] .hero-card,
html[data-theme="dark"] .employee-hero-pro,
html[data-theme="dark"] .settings-lux-hero,
html[data-theme="dark"] .admin-lux-hero,
html[data-theme="dark"] .login-v33-hero{
  background:
    radial-gradient(circle at 82% 18%, rgba(168,85,247,.22), transparent 26%),
    radial-gradient(circle at 20% 76%, rgba(59,130,246,.18), transparent 22%),
    linear-gradient(135deg,#12203a 0%,#17305a 36%,#203a68 72%,#35205c 100%) !important;
  border-color:#3b4c68 !important;
}
html[data-theme="dark"] .hero-card p,
html[data-theme="dark"] .employee-hero-pro p,
html[data-theme="dark"] .settings-lux-hero p,
html[data-theme="dark"] .admin-lux-hero p,
html[data-theme="dark"] .login-v33-copy p,
html[data-theme="dark"] .empty,
html[data-theme="dark"] .hint,
html[data-theme="dark"] .muted,
html[data-theme="dark"] small,
html[data-theme="dark"] .top-title span,
html[data-theme="dark"] .lux-row-main span,
html[data-theme="dark"] .lux-row-time span,
html[data-theme="dark"] .quick-menu-pro span,
html[data-theme="dark"] .card-head span,
html[data-theme="dark"] .section-title-pro span,
html[data-theme="dark"] .employee-info-list-pro small,
html[data-theme="dark"] .salary-list-pro small,
html[data-theme="dark"] .announcement-item-pro small{
  color:#d5deea !important;
}
html[data-theme="dark"] .admin-lux-stat{box-shadow:0 18px 34px rgba(0,0,0,.22) !important;}
html[data-theme="dark"] .admin-lux-stat:nth-child(1){background:linear-gradient(135deg,#2850c7,#445fe5) !important;}
html[data-theme="dark"] .admin-lux-stat:nth-child(2){background:linear-gradient(135deg,#0f7a62,#159981) !important;}
html[data-theme="dark"] .admin-lux-stat:nth-child(3){background:linear-gradient(135deg,#a95512,#d56a18) !important;}
html[data-theme="dark"] .admin-lux-stat:nth-child(4){background:linear-gradient(135deg,#6d28d9,#db2777) !important;}
html[data-theme="dark"] .lux-action-card:nth-child(1){background:linear-gradient(135deg,#192844,#233e77) !important;}
html[data-theme="dark"] .lux-action-card:nth-child(2){background:linear-gradient(135deg,#12364c,#0f766e) !important;}
html[data-theme="dark"] .lux-action-card:nth-child(3){background:linear-gradient(135deg,#39211b,#c2410c) !important;}
html[data-theme="dark"] .lux-action-card:nth-child(4){background:linear-gradient(135deg,#4a1940,#db2777) !important;}
html[data-theme="dark"] .btn.primary{background:linear-gradient(135deg,#2563eb,#7c3aed) !important;}
html[data-theme="dark"] .btn.success{background:linear-gradient(135deg,#16a34a,#059669) !important;}
html[data-theme="dark"] .btn.warn{background:linear-gradient(135deg,#f59e0b,#ea580c) !important;}
html[data-theme="dark"] .btn.danger{background:linear-gradient(135deg,#ef4444,#dc2626) !important;}


.inline-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center}.inline-actions form{display:inline-flex;margin:0}


/* V55 - Pilih 1 atau 2 shift karyawan */
.shift-check-grid{display:grid;grid-template-columns:repeat(4,minmax(160px,1fr));gap:10px;margin-top:8px}.shift-check-item{display:flex;align-items:center;gap:10px;border:1px solid #bfdbfe;background:linear-gradient(180deg,#ffffff,#f8fbff);border-radius:16px;padding:12px;cursor:pointer;font-weight:900}.shift-check-item input{width:18px;height:18px;min-height:auto;accent-color:#2563eb}.shift-check-item span{display:block}.shift-check-item small{display:block;color:#64748b;font-weight:700;margin-left:auto}.shift-check-item:has(input:checked){border-color:#7c3aed;background:linear-gradient(135deg,#eff6ff,#f5f3ff);box-shadow:0 10px 22px rgba(37,99,235,.10)}html[data-theme="dark"] .shift-check-item{background:linear-gradient(180deg,#172236,#1d2942)!important;border-color:#475569!important;color:#f8fafc!important}html[data-theme="dark"] .shift-check-item small{color:#cbd5e1!important}html[data-theme="dark"] .shift-check-item:has(input:checked){background:linear-gradient(135deg,#1e3a8a,#4c1d95)!important;border-color:#818cf8!important}@media(max-width:1100px){.shift-check-grid{grid-template-columns:repeat(2,minmax(140px,1fr))}}@media(max-width:650px){.shift-check-grid{grid-template-columns:1fr}}


/* V56 - Custom jam khusus hari Jumat */
.friday-shift-box{background:linear-gradient(135deg,rgba(37,99,235,.06),rgba(236,72,153,.06));border:1px solid rgba(147,197,253,.65);border-radius:18px;padding:14px!important}.shift-friday-toggle{display:flex!important;align-items:center;gap:10px;margin-bottom:7px}.shift-friday-toggle input{width:18px;height:18px;min-height:auto}.friday-time-grid{margin-top:10px}.shift-check-item small{line-height:1.45}.dark .friday-shift-box,html[data-theme="dark"] .friday-shift-box{background:linear-gradient(135deg,rgba(37,99,235,.15),rgba(236,72,153,.11));border-color:rgba(96,165,250,.35)}


/* V58 - Aksi kasbon dibuat kecil dan rapi */
.cashbon-action-mini{display:grid;gap:7px;min-width:230px;max-width:280px;margin:0}.cashbon-action-mini .cashbon-mini-row{display:grid;grid-template-columns:1fr 1fr;gap:7px;align-items:center}.cashbon-action-mini input{height:34px!important;min-height:34px!important;padding:7px 10px!important;border-radius:12px!important;font-size:12px!important;font-weight:800!important}.cashbon-action-mini .btn.mini{min-height:34px!important;height:34px!important;padding:7px 10px!important;border-radius:12px!important;font-size:12px!important;font-weight:900!important;width:100%;justify-content:center}.cashbon-action-mini.pay{min-width:260px}.cashbon-action-mini.pay .cashbon-mini-row:first-of-type{grid-template-columns:1fr 1fr}.cashbon-action-mini.pay .cashbon-mini-row:last-of-type{grid-template-columns:1fr 92px}.cashbon-action-mini input[type="date"]{font-size:11.5px!important}@media(max-width:900px){.cashbon-action-mini,.cashbon-action-mini.pay{min-width:220px;max-width:100%}.cashbon-action-mini .cashbon-mini-row,.cashbon-action-mini.pay .cashbon-mini-row:first-of-type,.cashbon-action-mini.pay .cashbon-mini-row:last-of-type{grid-template-columns:1fr}.cashbon-action-mini input,.cashbon-action-mini .btn.mini{height:32px!important;min-height:32px!important;font-size:11.5px!important}}


/* V59 - Tenor kasbon 1 sampai 5 bulan */
.cashbon-installment-preview{background:linear-gradient(180deg,#f8fbff,#eef5ff)!important;font-weight:900!important;color:#1e3a8a!important;text-align:right!important}
.cashbon-action-mini select{height:34px!important;min-height:34px!important;padding:7px 10px!important;border-radius:12px!important;font-size:12px!important;font-weight:800!important}
.cashbon-action-mini .cashbon-installment-preview{height:34px!important;min-height:34px!important;padding:7px 10px!important;border-radius:12px!important;font-size:12px!important;margin:0!important}
.cashbon-form .cashbon-installment-preview{pointer-events:none}
html[data-theme="dark"] .cashbon-installment-preview{background:linear-gradient(180deg,#172236,#1d2942)!important;color:#dbeafe!important;border-color:#43566f!important}


/* V60 - Preview cicilan kasbon otomatis sesuai tenor */
.cashbon-summary{margin-top:7px;padding:9px 11px;border-radius:12px;background:linear-gradient(135deg,#eff6ff,#f5f3ff);border:1px solid #cfe0ff;color:#1e3a8a;font-weight:900;font-size:12px;line-height:1.45}
.cashbon-summary.mini{font-size:11px;padding:6px 8px;margin-top:6px;text-align:center}
html[data-theme="dark"] .cashbon-summary{background:linear-gradient(135deg,#172554,#312e81);border-color:#334155;color:#dbeafe}
.cashbon-installment-preview{font-weight:900!important;text-align:right!important;background:linear-gradient(180deg,#ffffff,#f8fbff)!important}
html[data-theme="dark"] .cashbon-installment-preview{background:linear-gradient(180deg,#172236,#1d2942)!important;color:#f8fafc!important}


/* V61 - Hilangkan blok pada text SUPERADMIN PANEL agar jelas */
.premium-global-theme .admin-lux-hero .lux-kicker,
html[data-theme="light"] .premium-global-theme .admin-lux-hero .lux-kicker,
html[data-theme="dark"] .premium-global-theme .admin-lux-hero .lux-kicker,
body:not(.theme-dark) .premium-global-theme .admin-lux-hero .lux-kicker,
body:not(.theme-dark).premium-global-theme .admin-lux-hero .lux-kicker{
  background:transparent!important;
  border:0!important;
  box-shadow:none!important;
  backdrop-filter:none!important;
  padding:0!important;
  border-radius:0!important;
  color:#ffffff!important;
  text-shadow:0 2px 12px rgba(0,0,0,.35)!important;
  letter-spacing:.12em!important;
  opacity:1!important;
}
.premium-global-theme .admin-lux-hero .lux-kicker:before,
.premium-global-theme .admin-lux-hero .lux-kicker:after{
  display:none!important;
  content:none!important;
}
html[data-theme="light"] .premium-global-theme .admin-lux-hero .lux-kicker,
html[data-theme="dark"] .premium-global-theme .admin-lux-hero .lux-kicker{
  color:#ffffff!important;
}


/* V62 - Perjelas badge status absen di portal karyawan */
.employee-hero-pro .hero-profile-pro .status-dot,
.premium-global-theme .employee-hero-pro .hero-profile-pro .status-dot{
  opacity:1!important;
  text-shadow:none!important;
  font-weight:950!important;
  letter-spacing:.01em!important;
  border:1px solid rgba(255,255,255,.65)!important;
  box-shadow:0 12px 26px rgba(15,23,42,.18), inset 0 1px 0 rgba(255,255,255,.55)!important;
}
.employee-hero-pro .hero-profile-pro .status-dot.wait,
.premium-global-theme .employee-hero-pro .hero-profile-pro .status-dot.wait,
html[data-theme="light"] .employee-hero-pro .hero-profile-pro .status-dot.wait,
html[data-theme="dark"] .employee-hero-pro .hero-profile-pro .status-dot.wait{
  background:linear-gradient(135deg,#ffffff 0%,#fef3c7 42%,#fbbf24 100%)!important;
  color:#111827!important;
  border-color:#fde68a!important;
}
.employee-hero-pro .hero-profile-pro .status-dot.active,
.premium-global-theme .employee-hero-pro .hero-profile-pro .status-dot.active,
html[data-theme="light"] .employee-hero-pro .hero-profile-pro .status-dot.active,
html[data-theme="dark"] .employee-hero-pro .hero-profile-pro .status-dot.active{
  background:linear-gradient(135deg,#ffffff 0%,#dcfce7 45%,#22c55e 100%)!important;
  color:#052e16!important;
  border-color:#86efac!important;
}
.employee-hero-pro .hero-profile-pro .status-dot.done,
.premium-global-theme .employee-hero-pro .hero-profile-pro .status-dot.done,
html[data-theme="light"] .employee-hero-pro .hero-profile-pro .status-dot.done,
html[data-theme="dark"] .employee-hero-pro .hero-profile-pro .status-dot.done{
  background:linear-gradient(135deg,#ffffff 0%,#dbeafe 45%,#60a5fa 100%)!important;
  color:#172554!important;
  border-color:#bfdbfe!important;
}
.employee-hero-pro .hero-profile-pro .status-dot.wait *,
.employee-hero-pro .hero-profile-pro .status-dot.active *,
.employee-hero-pro .hero-profile-pro .status-dot.done *{
  color:inherit!important;
  text-shadow:none!important;
}


/* V63 - Slip gaji logo, tanda tangan, cap */
.payroll-upload-preview{display:block;width:100%;max-width:220px;height:120px;object-fit:contain;background:#fff;border:1px solid #dbeafe;border-radius:14px;padding:8px;margin-top:8px}
.slip-pro{max-width:900px;background:linear-gradient(180deg,#ffffff,#fbfdff);box-shadow:0 18px 45px rgba(15,23,42,.08)}
.slip-head-pro{display:flex;justify-content:space-between;gap:18px;align-items:flex-start;border-bottom:2px solid #dbeafe;padding-bottom:18px;margin-bottom:12px}
.slip-brand-pro{display:flex;gap:16px;align-items:center}.slip-brand-pro img{width:72px;height:72px;object-fit:contain;border-radius:16px;border:1px solid #dbeafe;background:#fff;padding:6px}.slip-logo-fallback{width:72px;height:72px;border-radius:16px;display:grid;place-items:center;font-weight:900;color:#1d4ed8;background:#eef4ff;border:1px solid #dbeafe}.slip-brand-pro h1{margin:0 0 8px;font-size:26px}.slip-brand-pro p{margin:0;color:#334155;line-height:1.55}.slip-head-side{display:grid;justify-items:end;gap:12px}.slip-pay-month{padding:12px 16px;border-radius:16px;background:linear-gradient(135deg,#eef2ff,#f5f3ff);text-align:left;min-width:160px;color:#334155;border:1px solid #dbeafe}.slip-pay-month b{display:block;color:#111827;font-size:18px;margin-top:4px}.slip-meta-grid{margin-top:10px}.slip-note{margin-top:14px;padding:12px 14px;border-radius:14px;background:#f8fbff;border:1px solid #dbeafe}.slip-sign-zone{display:flex;justify-content:flex-end;margin-top:48px}.slip-sign-box{min-width:260px;text-align:center;position:relative}.slip-sign-box p{margin:0 0 10px;color:#334155}.slip-sign-box b{display:block;margin-top:10px;font-size:18px}.slip-sign-media{position:relative;height:155px;display:flex;align-items:flex-end;justify-content:center}.slip-signature{position:relative;z-index:2;max-width:180px;max-height:90px;object-fit:contain;filter:contrast(1.05)}.slip-stamp{position:absolute;right:28px;top:20px;z-index:1;width:110px;height:110px;object-fit:contain;opacity:.34;transform:rotate(-12deg)}.slip-sign-spacer{height:90px}
@media (max-width:800px){.slip-head-pro{display:block}.slip-brand-pro{align-items:flex-start}.slip-head-side{justify-items:start;margin-top:12px}.slip-sign-zone{justify-content:center}.slip-brand-pro img,.slip-logo-fallback{width:62px;height:62px}.slip-brand-pro h1{font-size:22px}}
@media print{.slip-pro{max-width:none;padding:0}.slip-card{padding:0}.slip-head-pro{margin-bottom:16px}.slip-sign-zone{margin-top:52px}.slip-stamp{opacity:.28}}


/* V64 - Edit hapus payroll */
.payroll-edit-card{border-top:5px solid #7c3aed!important;background:linear-gradient(180deg,#ffffff,#f8fbff)!important}
.payroll-edit-summary{padding:14px 16px;border-radius:16px;background:linear-gradient(135deg,#eef2ff,#f5f3ff);border:1px solid #dbeafe;color:#0f172a}.payroll-edit-summary b{margin-right:8px}.inline-actions{display:flex;flex-wrap:wrap;gap:7px;align-items:center}.inline-actions form{display:inline-flex;margin:0}
html[data-theme="dark"] .payroll-edit-card{background:linear-gradient(180deg,#172236,#1d2942)!important;border-top-color:#a78bfa!important}
html[data-theme="dark"] .payroll-edit-summary{background:linear-gradient(135deg,#1e293b,#312e81)!important;border-color:#475569!important;color:#f8fafc!important}


/* V65 - cap mengenai nama dan jabatan, cap di bawah text */
.slip-sign-zone{display:flex;justify-content:flex-end;margin-top:48px}
.slip-sign-box{min-width:280px;text-align:center;position:relative}
.slip-sign-media{position:relative;height:110px;display:flex;align-items:flex-end;justify-content:center;margin-bottom:6px}
.slip-signature{position:relative;z-index:3;max-width:190px;max-height:92px;object-fit:contain;filter:contrast(1.05)}
.slip-sign-spacer{height:92px}
.slip-sign-text-wrap{position:relative;display:flex;justify-content:center;align-items:center;min-height:170px;padding:12px 10px 8px}
.slip-stamp.under-text{position:absolute;left:50%;top:50%;transform:translate(-50%,-52%) rotate(-10deg);z-index:1;width:142px;height:142px;object-fit:contain;opacity:.28}
.slip-signer-text{position:relative;z-index:2;display:grid;gap:10px;justify-items:center}
.slip-signer-text p{margin:0;color:#334155;font-size:16px;font-weight:500}
.slip-signer-text b{display:block;font-size:18px;color:#0f172a;padding-top:58px}
@media print{.slip-stamp.under-text{opacity:.24}}


/* V66 - Input kehadiran manual */
.manual-presence-card{position:relative;overflow:hidden}
.manual-presence-card:before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#16a34a,#22c55e,#2563eb,#7c3aed)}
.manual-presence-card .card-head h2 i{color:#16a34a}
.manual-presence-card .btn.success{background:linear-gradient(135deg,#16a34a,#059669);color:#fff}


/* V67 - cap di atas text penandatangan slip */
.slip-sign-text-wrap{position:relative;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;min-height:185px;padding:8px 10px 8px}
.slip-stamp-wrap{display:flex;justify-content:center;align-items:center;height:110px;margin-bottom:6px}
.slip-stamp.above-text{position:static;transform:rotate(-10deg);width:132px;height:132px;object-fit:contain;opacity:.30}
.slip-signer-text{position:relative;z-index:2;display:grid;gap:8px;justify-items:center;margin-top:0}
.slip-signer-text p{margin:0;color:#334155;font-size:16px;font-weight:500}
.slip-signer-text b{display:block;font-size:18px;color:#0f172a;padding-top:0}
@media print{.slip-stamp.above-text{opacity:.26}}


/* V68 - jabatan di atas cap, cap/logo sebelum nama */
.slip-sign-text-wrap{position:relative;display:flex;flex-direction:column;justify-content:flex-start;align-items:center;min-height:190px;padding:8px 10px 8px}
.slip-signer-text{position:relative;z-index:2;display:grid;gap:8px;justify-items:center;margin-top:0}
.slip-signer-title{margin:0;color:#334155;font-size:16px;font-weight:600}
.slip-stamp-wrap{display:flex;justify-content:center;align-items:center;height:112px;margin:2px 0 6px}
.slip-stamp.between-text{position:static;transform:rotate(-10deg);width:132px;height:132px;object-fit:contain;opacity:.30}
.slip-signer-name{display:block;font-size:18px;color:#0f172a;padding-top:0}
@media print{.slip-stamp.between-text{opacity:.26}}


/* V69 - cap mengenai nama penandatangan dan jabatan */
.slip-sign-text-wrap{position:relative;display:flex;justify-content:center;align-items:center;min-height:190px;padding:10px 14px 12px}
.slip-stamp.cover-signer{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%) rotate(-10deg);z-index:1;width:150px;height:150px;object-fit:contain;opacity:.28}
.slip-signer-text.overlap-stamp{position:relative;z-index:2;display:grid;gap:18px;justify-items:center;text-align:center;padding:26px 14px}
.slip-signer-text.overlap-stamp .slip-signer-title{margin:0;color:#334155;font-size:16px;font-weight:600;line-height:1.4}
.slip-signer-text.overlap-stamp .slip-signer-name{display:block;margin:0;font-size:18px;color:#0f172a;line-height:1.4}
@media print{.slip-stamp.cover-signer{opacity:.24}}


/* V70 - Jabatan penandatangan digeser ke atas */
.slip-signer-text.overlap-stamp{padding:16px 14px 26px !important;gap:14px !important}
.slip-signer-text.overlap-stamp .slip-signer-title{transform:translateY(-14px);margin-bottom:-8px !important}
@media print{.slip-signer-text.overlap-stamp .slip-signer-title{transform:translateY(-12px)}}


/* V72 - Login Super Premium Full Animasi */
.login-v72-body{min-height:100vh;margin:0;position:relative;overflow-x:hidden;background:#071023;color:#f8fafc;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;isolation:isolate}.login-v72-body:before{content:"";position:fixed;inset:0;background:radial-gradient(circle at var(--mx,20%) var(--my,20%),rgba(255,255,255,.08),transparent 28%);pointer-events:none;z-index:2}.login-v72-bg{position:fixed;inset:0;z-index:-6;background:linear-gradient(135deg,#050816 0%,#071a3d 34%,#172554 58%,#4c1d95 78%,#831843 100%);background-size:180% 180%;animation:v72Gradient 14s ease infinite}.login-v72-grid{position:fixed;inset:0;z-index:-4;background-image:linear-gradient(rgba(255,255,255,.06) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.06) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(circle at center,#000 0,transparent 72%);opacity:.38;animation:v72Grid 16s linear infinite}.login-v72-aurora{position:fixed;border-radius:999px;filter:blur(34px);opacity:.58;z-index:-5;pointer-events:none;mix-blend-mode:screen}.login-v72-aurora.aurora-a{width:360px;height:360px;left:-90px;top:70px;background:#22d3ee;animation:v72FloatA 10s ease-in-out infinite}.login-v72-aurora.aurora-b{width:420px;height:420px;right:-120px;top:110px;background:#a855f7;animation:v72FloatB 12s ease-in-out infinite}.login-v72-aurora.aurora-c{width:410px;height:410px;left:42%;bottom:-150px;background:#fb7185;animation:v72FloatC 11s ease-in-out infinite}.login-v72-particles{position:fixed;inset:0;pointer-events:none;z-index:-3;overflow:hidden}.login-v72-particles i{position:absolute;width:8px;height:8px;border-radius:999px;background:rgba(255,255,255,.72);box-shadow:0 0 22px rgba(99,102,241,.75);animation:v72Particle 13s linear infinite}.login-v72-particles i:nth-child(1){left:8%;animation-delay:0s}.login-v72-particles i:nth-child(2){left:18%;animation-delay:3s}.login-v72-particles i:nth-child(3){left:29%;animation-delay:6s}.login-v72-particles i:nth-child(4){left:39%;animation-delay:1s}.login-v72-particles i:nth-child(5){left:50%;animation-delay:4s}.login-v72-particles i:nth-child(6){left:62%;animation-delay:7s}.login-v72-particles i:nth-child(7){left:73%;animation-delay:2s}.login-v72-particles i:nth-child(8){left:84%;animation-delay:5s}.login-v72-particles i:nth-child(9){left:92%;animation-delay:8s}.login-v72-particles i:nth-child(10){left:45%;animation-delay:9s}.login-v72-theme{position:fixed;right:22px;top:22px;z-index:20;border:1px solid rgba(255,255,255,.20);background:rgba(255,255,255,.14);backdrop-filter:blur(18px);color:#fff;border-radius:999px;height:44px;padding:0 16px;display:inline-flex;align-items:center;gap:8px;font-weight:950;box-shadow:0 16px 34px rgba(2,6,23,.24);cursor:pointer}.login-v72-shell{position:relative;z-index:1;min-height:100vh;width:min(1360px,100%);margin:0 auto;padding:38px;display:grid;grid-template-columns:1.08fr .78fr;gap:28px;align-items:center}.login-v72-showcase,.login-v72-panel{position:relative;overflow:hidden;border:1px solid rgba(255,255,255,.18);box-shadow:0 30px 90px rgba(2,6,23,.40),inset 0 1px 0 rgba(255,255,255,.14);backdrop-filter:blur(22px);transform:translateZ(0)}.login-v72-showcase:after,.login-v72-panel:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--mx,50%) var(--my,25%),rgba(255,255,255,.18),transparent 35%);pointer-events:none;opacity:.82}.login-v72-showcase{min-height:700px;border-radius:42px;padding:34px;background:linear-gradient(135deg,rgba(15,23,42,.74),rgba(37,99,235,.54) 42%,rgba(124,58,237,.48) 70%,rgba(236,72,153,.40));display:grid;align-content:space-between;gap:26px}.login-v72-glowline{position:absolute;left:24px;right:24px;top:0;height:4px;border-radius:999px;background:linear-gradient(90deg,#22d3ee,#6366f1,#e879f9,#fb7185,#f97316);box-shadow:0 0 28px rgba(168,85,247,.75)}.login-v72-brand-row{position:relative;z-index:2;display:flex;align-items:center;justify-content:space-between;gap:14px;flex-wrap:wrap}.login-v72-brand{display:flex;align-items:center;gap:14px}.login-v72-logo{width:66px;height:66px;border-radius:22px;display:grid;place-items:center;overflow:hidden;background:linear-gradient(145deg,#fff,#dbeafe);box-shadow:0 18px 44px rgba(2,6,23,.26),0 0 0 6px rgba(255,255,255,.10)}.login-v72-logo img{width:100%;height:100%;object-fit:contain;padding:5px}.login-v72-logo span{font-weight:950;color:#1d4ed8;font-size:19px}.login-v72-brand b{display:block;font-size:18px;letter-spacing:-.02em}.login-v72-brand small{display:block;color:#dbeafe;margin-top:3px}.login-v72-edition{display:inline-flex;align-items:center;gap:9px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.12);border-radius:999px;padding:10px 14px;font-weight:950;backdrop-filter:blur(12px)}.login-v72-edition span{width:9px;height:9px;border-radius:999px;background:#22c55e;box-shadow:0 0 18px #22c55e}.login-v72-hero-copy{position:relative;z-index:2;max-width:780px}.login-v72-kicker{display:inline-flex;border-radius:999px;padding:9px 13px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.19);font-size:11px;font-weight:950;letter-spacing:.16em;color:#dbeafe}.login-v72-hero-copy h1{font-size:54px;line-height:1.02;letter-spacing:-.055em;margin:16px 0 14px;text-shadow:0 18px 42px rgba(0,0,0,.28)}.login-v72-hero-copy p{font-size:16px;line-height:1.85;color:#e2e8f0;margin:0;max-width:760px}.login-v72-dashboard-preview{position:relative;z-index:2;border-radius:30px;padding:18px;background:linear-gradient(145deg,rgba(255,255,255,.15),rgba(255,255,255,.055));border:1px solid rgba(255,255,255,.16);box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}.v72-preview-top{display:flex;align-items:center;gap:8px;color:#dbeafe;font-weight:900;margin-bottom:18px}.v72-preview-top span{width:10px;height:10px;border-radius:999px;background:#fb7185}.v72-preview-top span:nth-child(2){background:#fbbf24}.v72-preview-top span:nth-child(3){background:#22c55e}.v72-preview-top b{margin-left:auto}.v72-preview-main{display:grid;grid-template-columns:230px 1fr;gap:18px;align-items:center}.v72-radar{height:230px;border-radius:999px;display:grid;place-items:center;position:relative;background:radial-gradient(circle,rgba(34,211,238,.20) 0 15%,rgba(59,130,246,.16) 16% 31%,rgba(255,255,255,.06) 32% 48%,rgba(255,255,255,.04) 49%);border:1px solid rgba(255,255,255,.16);overflow:hidden}.v72-radar:before{content:"";position:absolute;width:50%;height:2px;left:50%;top:50%;background:linear-gradient(90deg,#22d3ee,transparent);transform-origin:left;animation:v72Radar 3.6s linear infinite}.v72-radar em{position:absolute;inset:38px;border-radius:999px;border:1px dashed rgba(255,255,255,.28)}.v72-radar strong{position:relative;z-index:2;font-size:28px;letter-spacing:.12em}.v72-preview-list{display:grid;gap:12px}.v72-preview-list div{padding:16px 18px;border-radius:20px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.12)}.v72-preview-list b{display:block;font-size:15px}.v72-preview-list span{display:block;color:#dbeafe;margin-top:5px}.login-v72-feature-row{position:relative;z-index:2;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.login-v72-feature-row div{min-height:112px;border-radius:24px;padding:16px;background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.14);transition:.22s}.login-v72-feature-row div:hover{transform:translateY(-5px);background:rgba(255,255,255,.16)}.login-v72-feature-row i{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:rgba(255,255,255,.16);font-style:normal;font-size:22px;margin-bottom:12px}.login-v72-feature-row b{display:block}.login-v72-feature-row span{display:block;color:#dbeafe;font-size:12px;margin-top:4px}.login-v72-panel{border-radius:40px;padding:32px;background:linear-gradient(145deg,rgba(255,255,255,.98),rgba(243,247,255,.92));color:#0f172a}.login-v72-panel-light{position:absolute;inset:-110px -130px auto auto;width:330px;height:330px;border-radius:999px;background:radial-gradient(circle,rgba(59,130,246,.20),transparent 67%)}.login-v72-panel-head,.login-v72-form,.login-v72-role-grid,.login-v72-note,.login-v72-alert{position:relative;z-index:2}.login-v72-secure{display:inline-flex;align-items:center;gap:8px;padding:9px 13px;border-radius:999px;background:linear-gradient(135deg,#e0f2fe,#eef2ff);border:1px solid #bfdbfe;color:#1d4ed8;font-weight:950;font-size:12px}.login-v72-panel-head h2{font-size:36px;line-height:1.05;letter-spacing:-.045em;margin:14px 0 8px}.login-v72-panel-head p{margin:0 0 18px;color:#64748b;line-height:1.7}.login-v72-form{display:grid;gap:14px}.login-v72-field>span{display:block;font-size:12px;font-weight:950;margin-bottom:7px;color:#334155}.login-v72-input{position:relative;display:flex;align-items:center;gap:12px;border:1px solid #dbeafe;background:linear-gradient(180deg,#fff,#f8fbff);border-radius:22px;padding:4px 14px;box-shadow:0 14px 30px rgba(37,99,235,.08)}.login-v72-input i{font-style:normal;font-size:19px}.login-v72-input input{border:0;background:transparent;box-shadow:none;padding:15px 0;color:#0f172a}.login-v72-input input:focus{box-shadow:none}.login-v72-eye{border:0;background:rgba(37,99,235,.08);border-radius:999px;width:34px;height:34px;cursor:pointer}.login-v72-mini-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.login-v72-mini-grid div{display:flex;align-items:center;gap:8px;border-radius:17px;padding:11px 12px;background:#f8fbff;border:1px solid #e2e8f0;color:#475569;font-weight:850;font-size:12px}.login-v72-mini-grid i{font-style:normal}.login-v72-submit{height:54px;border:0;border-radius:22px;background:linear-gradient(135deg,#2563eb,#7c3aed 55%,#db2777);color:#fff;font-weight:950;font-size:15px;display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 18px 36px rgba(124,58,237,.28);cursor:pointer;position:relative;overflow:hidden}.login-v72-submit:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.28),transparent);transform:translateX(-120%);animation:v72Shine 2.8s ease-in-out infinite}.login-v72-submit span,.login-v72-submit em{position:relative;z-index:1}.login-v72-submit em{font-style:normal;font-size:20px}.login-v72-role-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:16px}.login-v72-role-grid div{border:1px solid #dbeafe;background:linear-gradient(180deg,#fff,#f8fbff);border-radius:22px;padding:15px;box-shadow:0 12px 24px rgba(15,23,42,.04)}.login-v72-role-grid b{display:block;margin-bottom:5px}.login-v72-role-grid span{display:block;color:#64748b;font-size:12px;line-height:1.55}.login-v72-note{margin-top:16px;padding:14px 15px;border-radius:20px;background:linear-gradient(135deg,#fff7ed,#fff);border:1px solid #fed7aa;color:#9a3412;line-height:1.65}.login-v72-alert{border-radius:18px}.login-v72-tilt{transition:transform .22s ease,box-shadow .22s ease}.login-v72-tilt:hover{transform:translateY(-4px)}html[data-theme="light"] .login-v72-body{background:#f3f8ff;color:#0f172a}html[data-theme="light"] .login-v72-bg{background:linear-gradient(135deg,#eaf5ff,#f7fbff 38%,#eef2ff 64%,#fff1f2)!important}html[data-theme="light"] .login-v72-showcase{color:#fff;background:linear-gradient(135deg,#0f172a,#1d4ed8 45%,#7c3aed 72%,#db2777)!important}html[data-theme="dark"] .login-v72-panel{background:linear-gradient(145deg,rgba(15,23,42,.96),rgba(2,6,23,.92))!important;color:#f8fafc!important;border-color:rgba(148,163,184,.24)!important}html[data-theme="dark"] .login-v72-panel-head h2,html[data-theme="dark"] .login-v72-field>span{color:#f8fafc!important}html[data-theme="dark"] .login-v72-panel-head p,html[data-theme="dark"] .login-v72-role-grid span{color:#cbd5e1!important}html[data-theme="dark"] .login-v72-input,html[data-theme="dark"] .login-v72-role-grid div,html[data-theme="dark"] .login-v72-mini-grid div{background:rgba(15,23,42,.80)!important;border-color:rgba(148,163,184,.22)!important;color:#f8fafc!important}html[data-theme="dark"] .login-v72-input input{color:#f8fafc!important}html[data-theme="dark"] .login-v72-note{background:rgba(251,146,60,.12)!important;color:#fed7aa!important;border-color:rgba(251,146,60,.24)!important}@keyframes v72Gradient{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes v72Grid{0%{transform:translateY(0)}100%{transform:translateY(54px)}}@keyframes v72FloatA{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(50px,40px) scale(1.08)}}@keyframes v72FloatB{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-55px,35px) scale(1.06)}}@keyframes v72FloatC{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(35px,-45px) scale(1.08)}}@keyframes v72Particle{0%{top:110%;transform:translateX(0) scale(.75);opacity:0}12%{opacity:.8}100%{top:-10%;transform:translateX(55px) scale(1.25);opacity:0}}@keyframes v72Radar{0%{transform:rotate(0deg)}100%{transform:rotate(360deg)}}@keyframes v72Shine{0%{transform:translateX(-120%)}55%,100%{transform:translateX(120%)}}@media (max-width:1180px){.login-v72-shell{grid-template-columns:1fr;max-width:860px}.login-v72-showcase{min-height:auto}.login-v72-panel{max-width:none}.login-v72-hero-copy h1{font-size:42px}.v72-preview-main{grid-template-columns:190px 1fr}.v72-radar{height:190px}.login-v72-feature-row{grid-template-columns:repeat(2,1fr)}}@media (max-width:760px){.login-v72-shell{padding:14px;gap:16px}.login-v72-theme{top:12px;right:12px;height:38px;padding:0 12px}.login-v72-showcase,.login-v72-panel{border-radius:26px;padding:18px}.login-v72-brand-row{align-items:flex-start}.login-v72-logo{width:54px;height:54px;border-radius:18px}.login-v72-edition{font-size:11px;padding:8px 10px}.login-v72-hero-copy h1{font-size:31px}.login-v72-hero-copy p{font-size:13px;line-height:1.7}.login-v72-dashboard-preview{border-radius:22px;padding:13px}.v72-preview-main{grid-template-columns:1fr}.v72-radar{height:180px}.login-v72-feature-row,.login-v72-role-grid,.login-v72-mini-grid{grid-template-columns:1fr}.login-v72-feature-row div{min-height:auto;border-radius:18px}.login-v72-panel-head h2{font-size:28px}.login-v72-input{border-radius:18px}.login-v72-submit{height:50px;border-radius:18px}}


/* V73 - Perkecil showcase login agar seimbang dengan panel login */
.login-v72-shell{
  width:min(1240px,100%);
  padding:28px;
  grid-template-columns:minmax(0,1fr) minmax(480px,560px);
  gap:22px;
}
.login-v72-showcase{
  min-height:610px;
  padding:26px;
  gap:18px;
  border-radius:36px;
  align-self:stretch;
}
.login-v72-panel{
  max-width:560px;
  width:100%;
  justify-self:start;
  border-radius:34px;
  padding:28px;
}
.login-v72-glowline{left:18px;right:18px;height:3px}
.login-v72-brand-row{gap:12px}
.login-v72-brand{gap:12px}
.login-v72-logo{width:58px;height:58px;border-radius:18px}
.login-v72-brand b{font-size:16px}
.login-v72-brand small{font-size:12px}
.login-v72-edition{padding:8px 12px;font-size:12px}
.login-v72-kicker{padding:8px 12px;font-size:10px;letter-spacing:.14em}
.login-v72-hero-copy{max-width:640px}
.login-v72-hero-copy h1{font-size:42px;line-height:1.04;margin:12px 0 10px}
.login-v72-hero-copy p{font-size:14px;line-height:1.72;max-width:610px}
.login-v72-dashboard-preview{padding:14px;border-radius:24px}
.v72-preview-top{margin-bottom:12px;font-size:12px}
.v72-preview-main{grid-template-columns:180px 1fr;gap:14px}
.v72-radar{height:180px}
.v72-radar em{inset:28px}
.v72-radar strong{font-size:20px}
.v72-preview-list{gap:10px}
.v72-preview-list div{padding:12px 14px;border-radius:16px}
.v72-preview-list b{font-size:14px}
.v72-preview-list span{font-size:12px;margin-top:3px}
.login-v72-feature-row{gap:10px}
.login-v72-feature-row div{min-height:96px;padding:14px;border-radius:20px}
.login-v72-feature-row i{width:38px;height:38px;border-radius:14px;font-size:18px;margin-bottom:10px}
.login-v72-feature-row b{font-size:13px}
.login-v72-feature-row span{font-size:11px}
.login-v72-panel-head h2{font-size:31px}
.login-v72-panel-head p{font-size:14px;margin-bottom:16px}
.login-v72-field>span{font-size:12px}
.login-v72-input{border-radius:19px;padding:3px 12px}
.login-v72-input input{padding:13px 0;font-size:14px}
.login-v72-mini-grid div{padding:10px 12px;font-size:12px}
.login-v72-submit{height:50px;border-radius:18px;font-size:14px}
.login-v72-role-grid{margin-top:14px}
.login-v72-role-grid div{padding:13px;border-radius:18px}
.login-v72-note{margin-top:14px;padding:13px 14px;border-radius:18px;font-size:13px}
@media (max-width:1180px){
  .login-v72-shell{max-width:860px;grid-template-columns:1fr;padding:18px}
  .login-v72-showcase,.login-v72-panel{max-width:none;justify-self:stretch}
}
@media (max-width:760px){
  .login-v72-shell{padding:14px;gap:14px}
  .login-v72-showcase,.login-v72-panel{padding:18px;border-radius:24px}
  .login-v72-hero-copy h1{font-size:30px}
  .v72-preview-main{grid-template-columns:1fr}
  .v72-radar{height:160px}
}


/* V74 - Samakan tinggi panel kiri dan kanan pada login */
.login-v72-shell{
  align-items:stretch !important;
}
.login-v72-showcase,
.login-v72-panel{
  align-self:stretch !important;
}
.login-v72-showcase{
  min-height:640px !important;
  height:100% !important;
}
.login-v72-panel{
  min-height:640px !important;
  height:100% !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:center !important;
}
.login-v72-panel-head,
.login-v72-form,
.login-v72-role-grid,
.login-v72-note,
.login-v72-alert{
  width:100%;
}
@media (max-width:1180px){
  .login-v72-shell{align-items:initial !important}
  .login-v72-showcase,
  .login-v72-panel{
    min-height:auto !important;
    height:auto !important;
  }
}


/* V75 - Tinggi showcase login dikurangi agar setara dengan panel login user */
.login-v72-shell{
  align-items:start !important;
}
.login-v72-showcase,
.login-v72-panel{
  align-self:start !important;
  height:auto !important;
}
.login-v72-showcase{
  min-height:560px !important;
  max-height:none !important;
  padding:24px !important;
  gap:16px !important;
}
.login-v72-panel{
  min-height:auto !important;
  justify-content:flex-start !important;
}
.login-v72-hero-copy h1{
  font-size:38px !important;
  line-height:1.05 !important;
  margin:10px 0 10px !important;
}
.login-v72-hero-copy p{
  font-size:14px !important;
  line-height:1.65 !important;
  margin-bottom:0 !important;
}
.login-v72-dashboard-preview{
  padding:12px !important;
}
.v72-preview-main{
  grid-template-columns:160px 1fr !important;
  gap:12px !important;
}
.v72-radar{
  height:155px !important;
}
.v72-radar em{inset:24px !important}
.v72-radar strong{font-size:18px !important}
.v72-preview-list div{
  padding:10px 12px !important;
}
.login-v72-feature-row{
  gap:8px !important;
}
.login-v72-feature-row div{
  min-height:82px !important;
  padding:12px !important;
}
.login-v72-feature-row i{
  width:34px !important;
  height:34px !important;
  margin-bottom:8px !important;
}
.login-v72-feature-row b{font-size:12px !important}
.login-v72-feature-row span{font-size:11px !important}
@media (max-width:1180px){
  .login-v72-shell{align-items:initial !important}
  .login-v72-showcase,
  .login-v72-panel{
    align-self:stretch !important;
  }
  .login-v72-showcase{
    min-height:auto !important;
  }
}


/* V76 - Ratakan tinggi showcase kiri agar setara dengan panel login user */
.login-v72-shell{
  width:min(1260px,100%) !important;
  grid-template-columns:minmax(0,1fr) minmax(500px,580px) !important;
  gap:22px !important;
  align-items:start !important;
}
.login-v72-showcase,
.login-v72-panel{
  align-self:start !important;
  height:auto !important;
}
.login-v72-showcase{
  min-height:auto !important;
  padding:20px !important;
  gap:12px !important;
  border-radius:32px !important;
}
.login-v72-glowline{left:14px !important;right:14px !important;height:3px !important}
.login-v72-brand-row{gap:10px !important;margin-bottom:0 !important}
.login-v72-brand{gap:10px !important}
.login-v72-logo{width:52px !important;height:52px !important;border-radius:16px !important}
.login-v72-brand b{font-size:15px !important}
.login-v72-brand small{font-size:11px !important;line-height:1.35 !important}
.login-v72-edition{padding:7px 11px !important;font-size:11px !important}
.login-v72-kicker{padding:7px 12px !important;font-size:10px !important;margin-bottom:2px !important}
.login-v72-hero-copy{max-width:none !important}
.login-v72-hero-copy h1{
  font-size:31px !important;
  line-height:1.05 !important;
  letter-spacing:-.03em !important;
  margin:8px 0 8px !important;
}
.login-v72-hero-copy p{
  font-size:13px !important;
  line-height:1.58 !important;
  margin:0 !important;
  max-width:none !important;
}
.login-v72-dashboard-preview{
  padding:10px !important;
  border-radius:22px !important;
}
.v72-preview-top{font-size:11px !important;margin-bottom:10px !important}
.v72-preview-main{
  grid-template-columns:130px 1fr !important;
  gap:10px !important;
}
.v72-radar{
  height:120px !important;
}
.v72-radar em{inset:19px !important}
.v72-radar strong{font-size:16px !important}
.v72-preview-list{gap:8px !important}
.v72-preview-list div{
  padding:9px 10px !important;
  border-radius:14px !important;
}
.v72-preview-list b{font-size:12px !important}
.v72-preview-list span{font-size:11px !important;margin-top:2px !important}
.login-v72-feature-row{
  gap:8px !important;
  grid-template-columns:repeat(4,minmax(0,1fr)) !important;
}
.login-v72-feature-row div{
  min-height:66px !important;
  padding:10px !important;
  border-radius:16px !important;
}
.login-v72-feature-row i{
  width:30px !important;
  height:30px !important;
  border-radius:11px !important;
  font-size:15px !important;
  margin-bottom:7px !important;
}
.login-v72-feature-row b{font-size:11px !important;line-height:1.25 !important}
.login-v72-feature-row span{font-size:10px !important;line-height:1.25 !important}
.login-v72-panel{
  max-width:580px !important;
  padding:30px !important;
}
@media (max-width:1180px){
  .login-v72-shell{grid-template-columns:1fr !important;width:min(860px,100%) !important}
  .login-v72-showcase,.login-v72-panel{align-self:stretch !important}
  .login-v72-showcase{padding:18px !important}
}
@media (max-width:760px){
  .login-v72-shell{padding:14px !important}
  .login-v72-showcase,.login-v72-panel{padding:18px !important;border-radius:24px !important}
  .login-v72-hero-copy h1{font-size:28px !important}
  .v72-preview-main{grid-template-columns:1fr !important}
  .v72-radar{height:128px !important}
  .login-v72-feature-row{grid-template-columns:repeat(2,minmax(0,1fr)) !important}
}


/* V77 - Samakan lebar, tinggi, dan posisi tengah panel login */
.login-v72-shell{
  width:min(1148px, calc(100vw - 40px)) !important;
  min-height:100vh !important;
  margin:0 auto !important;
  padding:26px 20px !important;
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0, 540px)) !important;
  justify-content:center !important;
  align-content:center !important;
  align-items:stretch !important;
  gap:24px !important;
}
.login-v72-showcase,
.login-v72-panel{
  width:100% !important;
  max-width:540px !important;
  min-height:620px !important;
  height:620px !important;
  align-self:stretch !important;
  justify-self:center !important;
  box-sizing:border-box !important;
}
.login-v72-showcase{
  padding:18px !important;
  border-radius:30px !important;
  display:grid !important;
  align-content:space-between !important;
  gap:10px !important;
}
.login-v72-panel{
  padding:24px !important;
  border-radius:30px !important;
  display:flex !important;
  flex-direction:column !important;
  justify-content:flex-start !important;
}
.login-v72-glowline{left:14px !important;right:14px !important;height:3px !important}
.login-v72-brand-row{gap:10px !important;margin-bottom:0 !important}
.login-v72-brand{gap:10px !important}
.login-v72-logo{width:50px !important;height:50px !important;border-radius:16px !important}
.login-v72-brand b{font-size:14px !important}
.login-v72-brand small{font-size:11px !important;line-height:1.3 !important;margin-top:1px !important}
.login-v72-edition{padding:7px 11px !important;font-size:11px !important;gap:7px !important}
.login-v72-kicker{padding:7px 12px !important;font-size:10px !important;letter-spacing:.13em !important}
.login-v72-hero-copy h1{font-size:31px !important;line-height:1.06 !important;margin:8px 0 8px !important;letter-spacing:-.04em !important}
.login-v72-hero-copy p{font-size:13px !important;line-height:1.58 !important;max-width:none !important}
.login-v72-dashboard-preview{padding:10px !important;border-radius:20px !important}
.v72-preview-top{margin-bottom:10px !important;font-size:11px !important}
.v72-preview-main{grid-template-columns:120px 1fr !important;gap:10px !important}
.v72-radar{height:118px !important}
.v72-radar em{inset:18px !important}
.v72-radar strong{font-size:15px !important}
.v72-preview-list{gap:8px !important}
.v72-preview-list div{padding:8px 10px !important;border-radius:14px !important}
.v72-preview-list b{font-size:12px !important}
.v72-preview-list span{font-size:10px !important;margin-top:2px !important}
.login-v72-feature-row{grid-template-columns:repeat(4,minmax(0,1fr)) !important;gap:8px !important}
.login-v72-feature-row div{min-height:74px !important;padding:10px !important;border-radius:16px !important}
.login-v72-feature-row i{width:30px !important;height:30px !important;font-size:15px !important;border-radius:11px !important;margin-bottom:7px !important}
.login-v72-feature-row b{font-size:11px !important;line-height:1.2 !important}
.login-v72-feature-row span{font-size:10px !important;line-height:1.2 !important;margin-top:3px !important}
.login-v72-panel-head h2{font-size:30px !important;line-height:1.05 !important;margin:12px 0 8px !important}
.login-v72-panel-head p{font-size:13px !important;line-height:1.6 !important;margin:0 0 16px !important}
.login-v72-form{gap:12px !important}
.login-v72-field>span{font-size:12px !important;margin-bottom:6px !important}
.login-v72-input{border-radius:19px !important;padding:3px 12px !important}
.login-v72-input input{padding:13px 0 !important;font-size:14px !important}
.login-v72-mini-grid{gap:10px !important}
.login-v72-mini-grid div{padding:10px 12px !important;border-radius:16px !important;font-size:12px !important}
.login-v72-submit{height:50px !important;border-radius:18px !important;font-size:14px !important}
.login-v72-role-grid{gap:10px !important;margin-top:14px !important}
.login-v72-role-grid div{padding:12px !important;border-radius:18px !important}
.login-v72-role-grid b{font-size:13px !important}
.login-v72-role-grid span{font-size:12px !important;line-height:1.45 !important}
.login-v72-note{margin-top:14px !important;padding:13px 14px !important;border-radius:18px !important;font-size:13px !important}
@media (max-width:1180px){
  .login-v72-shell{
    width:min(860px, calc(100vw - 28px)) !important;
    grid-template-columns:1fr !important;
    gap:16px !important;
    padding:16px 14px !important;
  }
  .login-v72-showcase,
  .login-v72-panel{
    max-width:none !important;
    min-height:auto !important;
    height:auto !important;
  }
}
@media (max-width:760px){
  .login-v72-showcase,
  .login-v72-panel{padding:18px !important;border-radius:24px !important}
  .login-v72-hero-copy h1{font-size:28px !important}
  .v72-preview-main{grid-template-columns:1fr !important}
  .v72-radar{height:124px !important}
  .login-v72-feature-row{grid-template-columns:repeat(2,minmax(0,1fr)) !important}
}


/* V78 - GPS Face ID */
.faceid-card{display:flex;align-items:center;gap:14px;border-radius:20px;padding:14px;margin:0 0 14px;border:1px solid #bfdbfe;background:linear-gradient(135deg,#eff6ff,#f5f3ff);box-shadow:0 12px 26px rgba(37,99,235,.08)}
.faceid-card.ready{border-color:#86efac;background:linear-gradient(135deg,#ecfdf5,#eff6ff)}
.faceid-card.missing{border-color:#fecaca;background:linear-gradient(135deg,#fff1f2,#fff7ed)}
.faceid-icon{width:48px;height:48px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-size:22px;box-shadow:0 12px 24px rgba(37,99,235,.24)}
.faceid-copy{flex:1;min-width:0}.faceid-copy b{display:block;font-size:15px;color:#0f172a}.faceid-copy span{display:block;margin-top:4px;color:#475569;font-size:12px;line-height:1.5}.faceid-card img{width:58px;height:58px;border-radius:18px;object-fit:cover;border:3px solid #fff;box-shadow:0 10px 24px rgba(15,23,42,.14)}
.selfie-panel label:before{content:'🔐 ';}.selfie-status.ok{background:linear-gradient(135deg,#dcfce7,#ecfeff)!important;color:#064e3b!important}.selfie-status.warn{background:linear-gradient(135deg,#fef3c7,#fff7ed)!important;color:#92400e!important}.selfie-status.danger{background:linear-gradient(135deg,#fee2e2,#fff1f2)!important;color:#991b1b!important}
@media(max-width:800px){.faceid-card{align-items:flex-start}.faceid-card img{width:50px;height:50px}.faceid-icon{width:42px;height:42px;border-radius:14px}}


/* V79 - Portal karyawan daftar Face ID */
.faceid-register-page{overflow:hidden;position:relative}
.faceid-register-page:before{content:"";position:absolute;right:-100px;top:-120px;width:260px;height:260px;border-radius:999px;background:radial-gradient(circle,rgba(37,99,235,.18),transparent 68%);pointer-events:none}
.faceid-register-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:14px;margin:12px 0 16px}
.faceid-current-card,.faceid-rules-card{position:relative;border-radius:22px;padding:16px;border:1px solid #dbeafe;background:linear-gradient(135deg,#f8fbff,#eef4ff);box-shadow:0 14px 30px rgba(37,99,235,.08)}
.faceid-current-card{display:flex;align-items:center;gap:14px;overflow:hidden}.faceid-current-card.ready{background:linear-gradient(135deg,#ecfdf5,#eff6ff);border-color:#86efac}.faceid-current-card.missing{background:linear-gradient(135deg,#fff1f2,#fff7ed);border-color:#fecaca}.faceid-current-photo{width:78px;height:78px;border-radius:22px;object-fit:cover;border:4px solid #fff;box-shadow:0 14px 28px rgba(15,23,42,.18)}
.faceid-rules-card b{display:block;margin-bottom:8px;color:#0f172a}.faceid-rules-card ul{margin:0;padding-left:18px;color:#475569;line-height:1.7}.faceid-enroll-form{position:relative;z-index:1}.faceid-enroll-panel{background:linear-gradient(135deg,#eff6ff,#faf5ff)!important;border:1px solid #bfdbfe!important}.faceid-enroll-actions{display:flex;flex-wrap:wrap;gap:8px}.faceid-enroll-actions .btn{width:auto}.faceid-card .btn{width:auto;display:inline-flex}.quick-menu-pro a:nth-child(2) i{background:linear-gradient(135deg,#06b6d4,#2563eb)!important}
html[data-theme="dark"] .faceid-current-card,html[data-theme="dark"] .faceid-rules-card,html[data-theme="dark"] .faceid-enroll-panel{background:linear-gradient(135deg,#0b1220,#111827)!important;border-color:rgba(148,163,184,.22)!important}html[data-theme="dark"] .faceid-rules-card b{color:#f8fafc!important}html[data-theme="dark"] .faceid-rules-card ul{color:#cbd5e1!important}
@media(max-width:800px){.faceid-register-grid{grid-template-columns:1fr}.faceid-current-card{align-items:flex-start}.faceid-current-photo{width:62px;height:62px}.faceid-enroll-actions{display:grid}.faceid-enroll-actions .btn{width:100%}}


/* V80 - Kotak deteksi Face ID merah / hijau */
.selfie-stage{position:relative!important;overflow:hidden!important}
.face-match-box{display:none;position:absolute;left:50%;top:50%;width:44%;height:56%;transform:translate(-50%,-50%);border:3px solid #f59e0b;border-radius:28px;z-index:8;pointer-events:none;box-shadow:0 0 0 999px rgba(15,23,42,.10),0 0 22px rgba(245,158,11,.55);transition:.2s ease}
.face-match-box.show{display:block}
.face-match-box span{position:absolute;left:50%;bottom:-16px;transform:translateX(-50%);white-space:nowrap;border-radius:999px;padding:5px 10px;background:#f59e0b;color:#111827;font-weight:950;font-size:11px;box-shadow:0 8px 18px rgba(15,23,42,.22)}
.face-match-box.ok{border-color:#22c55e;box-shadow:0 0 0 999px rgba(22,163,74,.06),0 0 28px rgba(34,197,94,.75)}
.face-match-box.ok span{background:#22c55e;color:#052e16}
.face-match-box.danger{border-color:#ef4444;box-shadow:0 0 0 999px rgba(239,68,68,.08),0 0 28px rgba(239,68,68,.75)}
.face-match-box.danger span{background:#ef4444;color:#fff}
.face-match-box.checking{border-color:#f59e0b;animation:faceBoxPulse 1s infinite}
.face-match-box.pending{border-style:dashed;opacity:.92}
@keyframes faceBoxPulse{0%,100%{transform:translate(-50%,-50%) scale(1)}50%{transform:translate(-50%,-50%) scale(1.035)}}
@media(max-width:760px){.face-match-box{width:52%;height:58%;border-radius:24px}.face-match-box span{font-size:10px}}


/* V81 - Kotak kamera Face ID portrait otomatis */
#selfiePanel .selfie-stage{
  width:min(360px,100%)!important;
  aspect-ratio:3/4!important;
  min-height:0!important;
  height:auto!important;
  margin:0 auto!important;
  border-radius:28px!important;
  background:#020617!important;
  overflow:hidden!important;
}
#selfiePanel .selfie-stage video,
#selfiePanel .selfie-stage img{
  width:100%!important;
  height:100%!important;
  max-height:none!important;
  object-fit:cover!important;
  display:none;
}
#selfiePanel .selfie-stage video{transform:scaleX(-1)!important}
#selfiePanel .selfie-placeholder{
  padding:18px!important;
  font-size:13px!important;
}
#selfiePanel .face-match-box{
  display:block!important;
  width:62%!important;
  height:64%!important;
  border-width:4px!important;
  border-radius:30px!important;
  opacity:.96!important;
}
#selfiePanel .face-match-box.pending{border-color:#f59e0b!important;box-shadow:0 0 0 999px rgba(15,23,42,.16),0 0 24px rgba(245,158,11,.65)!important}
#selfiePanel .face-match-box.checking{border-color:#f59e0b!important;box-shadow:0 0 0 999px rgba(245,158,11,.09),0 0 34px rgba(245,158,11,.85)!important;animation:faceBoxPulse .8s infinite!important}
#selfiePanel .face-match-box.ok{border-color:#22c55e!important;box-shadow:0 0 0 999px rgba(34,197,94,.07),0 0 36px rgba(34,197,94,.95)!important}
#selfiePanel .face-match-box.danger{border-color:#ef4444!important;box-shadow:0 0 0 999px rgba(239,68,68,.10),0 0 36px rgba(239,68,68,.95)!important}
#selfiePanel .face-match-box span{bottom:-18px!important;font-size:10.5px!important;letter-spacing:.03em!important}
#attendanceSubmitBtn:disabled{opacity:.86!important;cursor:wait!important}
@media(max-width:760px){#selfiePanel .selfie-stage{width:min(310px,100%)!important;border-radius:24px!important}#selfiePanel .face-match-box{width:66%!important;height:64%!important;border-radius:26px!important}}


/* V83 - Face ID kamera standar, tidak terlalu zoom */
#selfiePanel .selfie-stage,
.faceid-enroll-panel .selfie-stage{
  width:min(340px,100%)!important;
  aspect-ratio:3/4!important;
  background:#020617!important;
}
#selfiePanel .selfie-stage video,
#selfiePanel .selfie-stage img,
.faceid-enroll-panel .selfie-stage video,
.faceid-enroll-panel .selfie-stage img{
  width:100%!important;
  height:100%!important;
  object-fit:contain!important;
  background:#020617!important;
}
#selfiePanel .face-match-box{
  width:54%!important;
  height:56%!important;
  border-radius:24px!important;
}
#selfiePanel .selfie-placeholder,
.faceid-enroll-panel .selfie-placeholder{
  background:linear-gradient(135deg,rgba(15,23,42,.86),rgba(30,41,59,.70))!important;
}
@media(max-width:760px){
  #selfiePanel .selfie-stage,.faceid-enroll-panel .selfie-stage{width:min(300px,100%)!important}
  #selfiePanel .face-match-box{width:58%!important;height:56%!important}
}


/* V85 - Portal karyawan profesional, menu mobile sensitif, request lembur/cuti */
.hamburger{position:relative!important;z-index:60!important;touch-action:manipulation!important;-webkit-tap-highlight-color:transparent!important;cursor:pointer!important;min-width:46px!important;min-height:46px!important;display:inline-grid;place-items:center}.hamburger i{pointer-events:none!important}.hamburger:after{content:"";position:absolute;inset:-12px;border-radius:20px}.sidebar{will-change:transform}.sidebar.open{box-shadow:0 24px 80px rgba(15,23,42,.38)!important}
.quick-menu-employee-v85{grid-template-columns:repeat(3,minmax(0,1fr))!important}.quick-menu-employee-v85 a{position:relative;overflow:hidden}.quick-menu-employee-v85 a:before{content:"";position:absolute;left:16px;right:16px;top:0;height:4px;border-radius:999px;background:linear-gradient(90deg,#34d399,#3b82f6,#a855f7,#ec4899)}
.employee-request-page{display:grid;gap:14px}.employee-request-hero{position:relative;overflow:hidden;display:flex;justify-content:space-between;gap:16px;align-items:center;padding:20px;border-radius:24px;background:linear-gradient(135deg,#1d4ed8,#7c3aed 62%,#db2777);color:#fff;box-shadow:0 20px 46px rgba(37,99,235,.18);border:1px solid rgba(255,255,255,.20)}.employee-request-hero.leave{background:linear-gradient(135deg,#0f766e,#2563eb 58%,#7c3aed)}.employee-request-hero:before{content:"";position:absolute;right:-80px;top:-90px;width:260px;height:260px;border-radius:999px;background:radial-gradient(circle,rgba(255,255,255,.24),transparent 68%)}.employee-request-hero>*{position:relative;z-index:1}.employee-request-hero span{display:inline-flex;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.24);font-size:11px;font-weight:950;letter-spacing:.08em;text-transform:uppercase}.employee-request-hero h2{margin:10px 0 6px;font-size:25px;line-height:1.1;color:#fff}.employee-request-hero p{margin:0;max-width:760px;color:#eef2ff;line-height:1.55}.employee-request-hero .btn{background:rgba(255,255,255,.18)!important;color:#fff!important;border:1px solid rgba(255,255,255,.26)!important;width:auto!important;white-space:nowrap}.request-card-pro{border:1px solid #dbeafe!important;background:linear-gradient(180deg,#ffffff,#f8fbff)!important;box-shadow:0 18px 42px rgba(37,99,235,.08)!important}.employee-request-form textarea{min-height:105px!important}.employee-request-form .btn.primary{background:linear-gradient(135deg,#2563eb,#7c3aed,#db2777)!important}
html[data-theme="dark"] .request-card-pro{background:linear-gradient(135deg,#0b1220,#111827)!important;border-color:rgba(148,163,184,.22)!important}html[data-theme="dark"] .employee-request-hero p{color:#dbeafe!important}
@media(max-width:800px){.hamburger{width:50px!important;height:50px!important;min-width:50px!important;min-height:50px!important;border-radius:16px!important;font-size:22px!important}.premium-global-theme .sidebar{z-index:80!important}.quick-menu-employee-v85{grid-template-columns:repeat(3,1fr)!important}.employee-request-hero{display:block;padding:16px;border-radius:20px}.employee-request-hero .btn{margin-top:12px;width:100%!important}.employee-request-hero h2{font-size:21px}.employee-request-hero p{font-size:12px}.employee-request-form .span-3{grid-column:auto!important}}


/* V86 - Monitoring pelanggan offline */
.monitor-page-v86{display:grid;gap:14px}.monitor-hero-v86{position:relative;overflow:hidden;border-radius:28px;padding:22px;background:linear-gradient(135deg,#0f172a,#1d4ed8 48%,#7c3aed 75%,#db2777);color:#fff;display:flex;justify-content:space-between;gap:16px;align-items:center;box-shadow:0 22px 55px rgba(15,23,42,.20)}.monitor-hero-v86:before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 15% 20%,rgba(34,211,238,.28),transparent 28%),radial-gradient(circle at 88% 10%,rgba(255,255,255,.18),transparent 25%);pointer-events:none}.monitor-hero-v86>*{position:relative;z-index:1}.monitor-kicker-v86{display:inline-flex;padding:7px 12px;border-radius:999px;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.22);font-weight:950;font-size:11px;letter-spacing:.12em}.monitor-hero-v86 h1{font-size:30px;line-height:1.05;margin:10px 0 8px;color:#fff}.monitor-hero-v86 p{margin:0;color:#e0e7ff;max-width:780px;line-height:1.6}.monitor-refresh-v86{display:grid;gap:9px;justify-items:end}.monitor-refresh-v86 b{padding:9px 12px;border-radius:14px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.20)}.monitor-stats-v86{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px}.monitor-stat{border-radius:22px;padding:16px;background:#fff;border:1px solid #dbeafe;box-shadow:0 12px 26px rgba(15,23,42,.06);position:relative;overflow:hidden}.monitor-stat:before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,#38bdf8,#8b5cf6,#ec4899)}.monitor-stat span{display:block;color:#64748b;font-weight:900;font-size:12px}.monitor-stat b{display:block;font-size:30px;line-height:1.1;margin:6px 0;color:#0f172a}.monitor-stat small{color:#64748b}.monitor-stat.danger b{color:#dc2626}.monitor-stat.ok b{color:#16a34a}.monitor-stat.info b{color:#2563eb}.monitor-stat.warn b{color:#f97316}.monitor-settings-v86 summary{display:flex;align-items:center;justify-content:space-between;gap:12px;cursor:pointer}.monitor-settings-v86 summary span{color:#64748b;font-size:12px}.monitor-table-v86 table{min-width:960px}.monitor-table-v86 small{display:block;color:#64748b;max-width:420px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.monitor-actions-v86{display:flex;gap:8px;flex-wrap:wrap}.monitor-help-v86{display:grid;grid-template-columns:1fr 1fr;gap:12px}.monitor-help-v86 div{border-radius:20px;background:linear-gradient(135deg,#eff6ff,#fff);border:1px solid #dbeafe;padding:14px;box-shadow:0 10px 22px rgba(15,23,42,.04)}.monitor-help-v86 b{display:block;color:#0f172a;margin-bottom:5px}.monitor-help-v86 span{color:#475569;line-height:1.55;font-size:12px}@media(max-width:900px){.monitor-hero-v86{display:block;padding:18px;border-radius:22px}.monitor-refresh-v86{justify-items:start;margin-top:12px}.monitor-stats-v86{grid-template-columns:repeat(2,minmax(0,1fr))}.monitor-help-v86{grid-template-columns:1fr}}@media(max-width:560px){.monitor-stats-v86{grid-template-columns:1fr}.monitor-hero-v86 h1{font-size:24px}.monitor-stat{padding:13px;border-radius:18px}.monitor-stat b{font-size:26px}}


/* V87 - Monitoring pelanggan OFF dalam bentuk mapping map */
.monitor-map-card-v87{overflow:hidden;position:relative}
.monitor-map-card-v87:before{content:"";position:absolute;left:0;right:0;top:0;height:5px;background:linear-gradient(90deg,#06b6d4,#2563eb,#a855f7,#ec4899,#f97316)}
.monitor-map-v87{min-height:430px;width:100%;border-radius:20px;border:1px solid #bfdbfe;overflow:hidden;background:linear-gradient(135deg,#e0f2fe,#eef2ff);box-shadow:inset 0 1px 0 rgba(255,255,255,.55),0 18px 45px rgba(37,99,235,.10);position:relative}
.monitor-map-empty-v87{position:absolute;inset:16px;border:1px dashed #93c5fd;border-radius:18px;background:rgba(255,255,255,.72);display:grid;place-items:center;text-align:center;padding:22px;color:#0f172a}.monitor-map-empty-v87 b{display:block;font-size:18px}.monitor-map-empty-v87 span{display:block;color:#475569;margin-top:8px;max-width:620px;line-height:1.6}.monitor-map-legend-v87{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-top:12px;color:#475569;font-size:12px}.monitor-map-legend-v87 span{background:#f8fbff;border:1px solid #dbeafe;border-radius:999px;padding:8px 11px;font-weight:800}.monitor-map-legend-v87 i{display:inline-block;width:10px;height:10px;border-radius:999px;background:#ef4444;box-shadow:0 0 0 4px rgba(239,68,68,.16);margin-right:6px}.monitor-map-legend-v87 .warn{background:#fff7ed;border-color:#fed7aa;color:#9a3412}.monitor-map-popup{display:grid;gap:4px;min-width:210px;color:#0f172a}.monitor-map-popup b{font-size:15px;color:#b91c1c}.monitor-map-popup span{font-size:12px;color:#334155}.monitor-map-popup a{margin-top:6px;display:inline-flex;justify-content:center;border-radius:10px;padding:7px 9px;background:#2563eb;color:#fff;font-weight:900;text-decoration:none}.monitor-leaflet-marker-v87 span{display:block;width:22px;height:22px;border-radius:999px;background:#ef4444;border:3px solid #fff;box-shadow:0 10px 24px rgba(239,68,68,.45),0 0 0 6px rgba(239,68,68,.20);animation:monitorPulseV87 1.6s ease-in-out infinite}@keyframes monitorPulseV87{0%,100%{transform:scale(1)}50%{transform:scale(1.18)}}.monitor-stat.map{background:linear-gradient(135deg,#ecfeff,#dbeafe)!important;color:#0f172a!important;border-color:#bfdbfe!important}.monitor-table-v86 .btn.small{white-space:nowrap}
@media(max-width:800px){.monitor-map-v87{min-height:340px;border-radius:16px}.monitor-map-legend-v87 span{border-radius:14px}.monitor-map-empty-v87{inset:10px}.monitor-map-empty-v87 b{font-size:15px}}


/* V88 - Perbaiki mapping monitoring agar selalu muncul */
.monitor-map-card-v87 .card-head h2{display:flex;align-items:center;gap:8px}
.monitor-map-v87{min-height:520px!important;background:linear-gradient(135deg,#dbeafe,#eef2ff 48%,#ecfeff)!important;isolation:isolate}
.monitor-map-leaflet-ready-v88{background:#dbeafe!important}.monitor-map-leaflet-ready-v88 .leaflet-container{height:100%!important;width:100%!important;border-radius:20px!important;background:#dbeafe!important}.monitor-map-leaflet-ready-v88 .leaflet-tile-container img{filter:saturate(1.08) contrast(1.02)}.monitor-map-leaflet-ready-v88 .leaflet-popup-content-wrapper{border-radius:16px!important;box-shadow:0 18px 40px rgba(15,23,42,.22)!important}.monitor-map-leaflet-ready-v88 .leaflet-popup-content{margin:12px 13px!important}.monitor-leaflet-marker-v88 span{display:grid;place-items:center;width:30px;height:30px;border-radius:999px;background:#ef4444;border:4px solid #fff;box-shadow:0 16px 30px rgba(239,68,68,.52),0 0 0 8px rgba(239,68,68,.18);animation:monitorPulseV87 1.45s ease-in-out infinite}.monitor-leaflet-marker-v88 span i{display:block;width:9px;height:9px;border-radius:999px;background:#fff}.monitor-map-empty-v87 code{display:block;margin-top:12px;padding:10px 12px;border-radius:12px;background:#eef2ff;color:#1e3a8a;font-weight:800;white-space:normal}.monitor-fallback-map-v88{position:absolute;inset:0;overflow:hidden;background:radial-gradient(circle at 20% 25%,rgba(14,165,233,.25),transparent 28%),radial-gradient(circle at 80% 70%,rgba(34,197,94,.22),transparent 25%),linear-gradient(135deg,#dcfce7,#e0f2fe 42%,#dbeafe);}.fallback-map-grid-v88{position:absolute;inset:0;background-image:linear-gradient(rgba(37,99,235,.12) 1px,transparent 1px),linear-gradient(90deg,rgba(37,99,235,.12) 1px,transparent 1px);background-size:52px 52px;opacity:.65}.fallback-map-road{position:absolute;height:18px;border-radius:999px;background:rgba(255,255,255,.65);box-shadow:0 0 0 1px rgba(148,163,184,.25),0 12px 22px rgba(15,23,42,.08)}.fallback-map-road.r1{left:-8%;right:-6%;top:35%;transform:rotate(-9deg)}.fallback-map-road.r2{left:18%;right:10%;top:63%;transform:rotate(17deg)}.fallback-map-road.r3{left:42%;right:42%;top:-8%;height:120%;width:18px;transform:rotate(8deg)}.fallback-map-info-v88{position:absolute;left:18px;top:18px;z-index:3;display:grid;gap:3px;max-width:360px;padding:13px 15px;border-radius:18px;background:rgba(255,255,255,.86);border:1px solid rgba(191,219,254,.9);box-shadow:0 18px 42px rgba(15,23,42,.12);backdrop-filter:blur(10px)}.fallback-map-info-v88 b{color:#0f172a}.fallback-map-info-v88 span{font-size:12px;color:#475569}.fallback-marker-v88{position:absolute;z-index:5;transform:translate(-50%,-50%);display:flex;align-items:center;gap:7px;text-decoration:none;color:#991b1b;font-weight:950;font-size:12px;padding:7px 10px;border-radius:999px;background:rgba(255,255,255,.92);border:1px solid rgba(254,202,202,.95);box-shadow:0 14px 34px rgba(239,68,68,.24),0 0 0 7px rgba(239,68,68,.10)}.fallback-marker-v88 i{width:16px;height:16px;border-radius:999px;background:#ef4444;border:3px solid #fff;box-shadow:0 0 0 5px rgba(239,68,68,.18);animation:monitorPulseV87 1.5s ease-in-out infinite}.fallback-marker-v88 span{white-space:nowrap;max-width:160px;overflow:hidden;text-overflow:ellipsis}.monitor-map-legend-v87 .warn{background:#ecfeff!important;border-color:#bae6fd!important;color:#075985!important}@media(max-width:800px){.monitor-map-v87{min-height:430px!important}.fallback-map-info-v88{left:10px;right:10px;max-width:none}.fallback-marker-v88 span{max-width:92px}}


/* V89 - Monitoring map ala Fakhira / Netwatch full mapping */
.monitor-fullmap-v89{position:relative;margin:-8px -8px 0;min-height:calc(100vh - 115px)}
.monitor-map-shell-v89{position:relative;min-height:760px;height:calc(100vh - 135px);border-radius:26px;overflow:hidden;background:#07111f;border:1px solid rgba(15,23,42,.15);box-shadow:0 24px 70px rgba(15,23,42,.20)}
.monitor-map-v89{position:absolute;inset:0;z-index:1;background:#0b1220}
.monitor-map-v89 .leaflet-container{background:#0b1220}
.monitor-side-v89{position:absolute;right:14px;top:14px;width:330px;max-height:calc(100% - 28px);z-index:5;background:rgba(8,16,30,.88);backdrop-filter:blur(14px);border:1px solid rgba(148,163,184,.22);border-radius:18px;padding:10px;box-shadow:0 18px 42px rgba(0,0,0,.34);color:#e5f0ff;overflow:hidden}
.monitor-side-v89 select{height:42px;border-radius:12px;background:#111827!important;border:1px solid rgba(148,163,184,.22)!important;color:#e5f0ff!important;margin-bottom:8px;padding:0 12px!important;font-weight:800}
.monitor-counts-v89{display:flex;align-items:center;gap:7px;margin:4px 0 8px;flex-wrap:wrap}
.monitor-counts-v89 span,.monitor-counts-v89 time{border-radius:8px;padding:6px 8px;font-size:11px;font-weight:950}
.monitor-counts-v89 .off{background:#ef4444;color:#fff}.monitor-counts-v89 .on{background:#22c55e;color:#fff}.monitor-counts-v89 time{margin-left:auto;background:#111827;border:1px solid rgba(148,163,184,.25);color:#fff}
.monitor-offline-list-v89{display:grid;gap:4px;max-height:570px;overflow:auto;padding-right:2px}
.monitor-offline-item-v89{display:grid;grid-template-columns:18px 1fr auto;gap:6px;align-items:start;padding:3px 0;color:#e5f0ff}
.monitor-offline-item-v89:hover{background:rgba(255,255,255,.05);border-radius:8px}
.monitor-offline-item-v89 i{width:15px;height:15px;margin-top:2px;border-radius:50%;background:#ef4444;box-shadow:0 0 0 2px #111827,0 0 0 4px rgba(239,68,68,.3);position:relative}
.monitor-offline-item-v89 i:after{content:"";position:absolute;left:4px;top:4px;width:7px;height:7px;border-radius:50%;background:#111827}
.monitor-offline-item-v89 b{display:block;font-size:11px;color:#cbd5e1;line-height:1.1}
.monitor-offline-item-v89 span{display:block;font-size:10px;color:#64748b;line-height:1.1;margin-top:2px}.monitor-offline-item-v89 em{font-style:normal;color:#3b82f6;font-weight:900}
.monitor-offline-item-v89 strong{font-size:10px;color:#ef4444;white-space:nowrap;line-height:1.1;text-align:right}
.monitor-marker-wrap-v89{background:transparent!important;border:0!important}
.monitor-marker-v89{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;position:relative;box-shadow:0 0 0 2px #030712,0 0 18px rgba(0,0,0,.35)}
.monitor-marker-v89 img{width:18px;height:18px;object-fit:contain;position:relative;z-index:2;filter:drop-shadow(0 1px 1px rgba(0,0,0,.6))}
.monitor-marker-v89.online{background:#00ff47;border:2px solid #001b08}.monitor-marker-v89.offline{background:#ff1d1d;border:2px solid #2a0000;animation:monitorBlinkV89 1.1s infinite}
.monitor-marker-v89:after{content:"";position:absolute;inset:4px;border-radius:50%;background:rgba(0,0,0,.16)}
@keyframes monitorBlinkV89{0%,100%{box-shadow:0 0 0 2px #030712,0 0 12px rgba(239,68,68,.35)}50%{box-shadow:0 0 0 2px #030712,0 0 0 8px rgba(239,68,68,.32),0 0 22px rgba(239,68,68,.70)}}
.monitor-popup-v89{display:grid;gap:5px;min-width:210px}.monitor-popup-v89 b{font-size:14px;color:#0f172a}.monitor-popup-v89 span{display:block;font-size:12px;color:#334155}.monitor-popup-v89 a{display:inline-flex;justify-content:center;margin-top:5px;background:#2563eb;color:#fff!important;border-radius:10px;padding:8px 10px;font-weight:900}
.monitor-floating-legend-v89{position:absolute;left:14px;bottom:14px;z-index:4;display:flex;gap:8px;flex-wrap:wrap;background:rgba(8,16,30,.78);border:1px solid rgba(148,163,184,.22);backdrop-filter:blur(12px);border-radius:999px;padding:8px 10px;color:#e5f0ff;font-size:11px;font-weight:900}
.monitor-floating-legend-v89 span{display:flex;align-items:center;gap:6px}.monitor-floating-legend-v89 i{display:inline-block;width:12px;height:12px;border-radius:999px}.monitor-floating-legend-v89 .green{background:#22c55e}.monitor-floating-legend-v89 .red{background:#ef4444}.monitor-floating-legend-v89 .line{width:22px;height:2px;border-radius:0;background:repeating-linear-gradient(90deg,#a855f7 0 5px,transparent 5px 9px)}
.monitor-settings-float-v89{position:absolute;left:14px;top:14px;z-index:6;width:min(680px,calc(100% - 380px));background:rgba(255,255,255,.94);border:1px solid #dbeafe;border-radius:16px;padding:10px;box-shadow:0 16px 38px rgba(15,23,42,.18)}
.monitor-settings-float-v89 summary{font-weight:950;cursor:pointer}.monitor-settings-grid-v89{display:grid;grid-template-columns:1.4fr 1fr 1fr .7fr auto;gap:8px;margin-top:10px}.monitor-settings-grid-v89 input{height:38px;border-radius:10px;padding:0 10px!important}.monitor-alert-v89{position:absolute;left:14px;top:76px;z-index:7;background:#fee2e2;color:#991b1b;border:1px solid #fecaca;border-radius:14px;padding:12px 14px;box-shadow:0 12px 28px rgba(127,29,29,.18)}.monitor-alert-v89 b{display:block}.monitor-alert-v89 span{display:block;margin-top:3px}
.monitor-empty-v89{position:absolute;inset:0;display:grid;place-items:center;text-align:center;color:#e5f0ff;z-index:3;padding:25px;background:linear-gradient(135deg,rgba(15,23,42,.78),rgba(30,64,175,.60))}.monitor-empty-v89 b{font-size:20px}.monitor-empty-v89 span{display:block;margin-top:8px;max-width:720px}.monitor-empty-v89 code{display:block;margin-top:10px;background:rgba(0,0,0,.35);padding:8px;border-radius:10px}
.monitor-mobile-list-v89{display:none}
.monitor-empty-side-v89{padding:18px;text-align:center;color:#94a3b8;font-weight:900}
@media(max-width:1100px){.monitor-map-shell-v89{height:auto;min-height:620px}.monitor-side-v89{position:relative;right:auto;top:auto;width:auto;margin:12px;max-height:none}.monitor-offline-list-v89{max-height:260px}.monitor-settings-float-v89{position:relative;left:auto;top:auto;width:auto;margin-bottom:10px}.monitor-settings-grid-v89{grid-template-columns:1fr}.monitor-alert-v89{position:relative;left:auto;top:auto;margin-bottom:10px}.monitor-floating-legend-v89{left:12px;bottom:12px}.monitor-mobile-list-v89{display:block}.monitor-mobile-list-v89 a{display:block;background:#fff;border:1px solid #dbeafe;border-radius:14px;padding:10px;margin:8px 0}.monitor-mobile-list-v89 b{display:block}.monitor-mobile-list-v89 span{display:block;color:#64748b;font-size:12px;margin-top:3px}}


/* V90 - Fix map blank hitam monitoring */
.monitor-map-error-v90{
  position:absolute;
  inset:72px 380px 72px 32px;
  z-index:4;
  place-items:center;
  text-align:center;
  padding:22px;
  color:#e5f0ff;
  border:1px dashed rgba(148,163,184,.42);
  border-radius:22px;
  background:rgba(15,23,42,.62);
  backdrop-filter:blur(10px);
}
.monitor-map-error-v90 b{font-size:20px;color:#fff;margin-bottom:8px;display:block}
.monitor-map-error-v90 span{color:#cbd5e1;line-height:1.6}
.monitor-map-v89.leaflet-container{background:#0b1220!important}
.monitor-map-v89 .leaflet-tile{filter:saturate(1.08) contrast(1.03)}
@media(max-width:900px){
  .monitor-map-error-v90{inset:80px 16px 220px 16px}
}


/* V91 - Perkecil icon/marker monitoring map */
.monitor-marker-wrap-v89{
  width:18px!important;
  height:18px!important;
  margin-left:0!important;
  margin-top:0!important;
}
.monitor-marker-v89{
  width:18px!important;
  height:18px!important;
  border-radius:50%!important;
  box-shadow:0 0 0 1px #030712,0 0 10px rgba(0,0,0,.32)!important;
}
.monitor-marker-v89 img{
  width:11px!important;
  height:11px!important;
}
.monitor-marker-v89.online,
.monitor-marker-v89.offline{
  border-width:1.5px!important;
}
.monitor-marker-v89:after{
  inset:3px!important;
}
.monitor-fakhira-line-v89{
  opacity:.76!important;
}
.fallback-marker-v88{
  padding:4px 7px!important;
  gap:5px!important;
  font-size:10px!important;
  box-shadow:0 10px 24px rgba(239,68,68,.18),0 0 0 4px rgba(239,68,68,.08)!important;
}
.fallback-marker-v88 i{
  width:11px!important;
  height:11px!important;
  border-width:2px!important;
  box-shadow:0 0 0 3px rgba(239,68,68,.15)!important;
}
@media(max-width:800px){
  .monitor-marker-wrap-v89{width:16px!important;height:16px!important}
  .monitor-marker-v89{width:16px!important;height:16px!important}
  .monitor-marker-v89 img{width:10px!important;height:10px!important}
}


/* V92 - Hilangkan daftar pelanggan offline di panel kanan monitoring */
.monitor-offline-list-v89,
.monitor-mobile-list-v89{
  display:none!important;
}
.monitor-side-v89{
  width:300px!important;
  max-height:none!important;
  height:auto!important;
  overflow:visible!important;
  padding:10px!important;
}
.monitor-counts-v89{
  margin:4px 0 0!important;
}
.monitor-counts-v89 time{
  display:none!important;
}
@media(max-width:1100px){
  .monitor-side-v89{
    position:absolute!important;
    right:12px!important;
    top:12px!important;
    width:min(300px,calc(100% - 24px))!important;
    margin:0!important;
  }
}


/* V93 - HP full map: hilangkan panel yang menghalangi layar */
@media(max-width:1100px){
  .monitor-side-v89,
  .monitor-mobile-list-v89,
  .monitor-offline-list-v89{
    display:none!important;
  }
  .monitor-map-shell-v89{
    height:calc(100vh - 92px)!important;
    min-height:calc(100vh - 92px)!important;
    margin:0!important;
    border-radius:0!important;
  }
  .monitor-fullmap-v89{
    margin:0!important;
    min-height:calc(100vh - 92px)!important;
  }
  .monitor-map-v89{
    inset:0!important;
  }
  .monitor-floating-legend-v89{
    display:none!important;
  }
  .monitor-settings-float-v89{
    position:absolute!important;
    left:10px!important;
    top:10px!important;
    width:calc(100% - 20px)!important;
    margin:0!important;
    z-index:8!important;
  }
  .monitor-settings-float-v89[open]{
    max-height:70vh!important;
    overflow:auto!important;
  }
}
@media(max-width:760px){
  .monitor-fullmap-v89{
    margin:-12px!important;
  }
  .monitor-map-shell-v89{
    height:calc(100vh - 74px)!important;
    min-height:calc(100vh - 74px)!important;
  }
  .monitor-map-error-v90{
    inset:72px 12px 16px 12px!important;
  }
  .monitor-empty-v89{
    padding:16px!important;
  }
}


/* V94 - Tampilkan nama pelanggan di marker monitoring */
.monitor-marker-wrap-v94{
  width:118px!important;
  height:38px!important;
  pointer-events:auto!important;
  overflow:visible!important;
}
.monitor-marker-stack-v94{
  width:118px;
  height:38px;
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:flex-start;
  gap:2px;
  transform:translateY(-2px);
}
.monitor-marker-stack-v94 .monitor-marker-v89{
  flex:0 0 auto;
}
.monitor-marker-stack-v94 span{
  max-width:112px;
  display:block;
  padding:1px 5px;
  border-radius:999px;
  background:rgba(2,6,23,.76);
  border:1px solid rgba(255,255,255,.20);
  color:#ffffff;
  font-size:9px;
  line-height:1.2;
  font-weight:900;
  text-align:center;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  text-shadow:0 1px 4px rgba(0,0,0,.9);
  box-shadow:0 2px 8px rgba(0,0,0,.28);
}
.monitor-marker-stack-v94.offline span{
  background:rgba(127,29,29,.88);
  border-color:rgba(248,113,113,.45);
}
@media(max-width:760px){
  .monitor-marker-wrap-v94{width:92px!important;height:32px!important}
  .monitor-marker-stack-v94{width:92px;height:32px;gap:1px}
  .monitor-marker-stack-v94 span{max-width:88px;font-size:8px;padding:1px 4px}
}


/* V95 - Label nama pelanggan dibuat rapi agar map tidak penuh */
.monitor-marker-wrap-v94{
  width:26px!important;
  height:26px!important;
  overflow:visible!important;
  pointer-events:auto!important;
}
.monitor-marker-stack-v94{
  width:26px!important;
  height:26px!important;
  display:flex!important;
  flex-direction:column!important;
  align-items:center!important;
  justify-content:center!important;
  gap:0!important;
  transform:none!important;
}
.monitor-marker-stack-v94 .monitor-marker-v89{
  width:18px!important;
  height:18px!important;
  flex:0 0 18px!important;
  box-shadow:0 0 0 2px #020617,0 0 8px rgba(0,0,0,.45)!important;
}
.monitor-marker-stack-v94 .monitor-marker-v89 img{
  width:11px!important;
  height:11px!important;
}
.monitor-marker-stack-v94 span{
  position:absolute!important;
  left:50%!important;
  top:20px!important;
  transform:translateX(-50%)!important;
  z-index:5!important;
  display:none!important;
  max-width:96px!important;
  padding:1px 5px!important;
  border-radius:999px!important;
  background:rgba(2,6,23,.82)!important;
  border:1px solid rgba(255,255,255,.18)!important;
  color:#fff!important;
  font-size:8px!important;
  line-height:1.15!important;
  font-weight:900!important;
  text-align:center!important;
  white-space:nowrap!important;
  overflow:hidden!important;
  text-overflow:ellipsis!important;
  text-shadow:0 1px 4px rgba(0,0,0,.9)!important;
  box-shadow:0 2px 8px rgba(0,0,0,.35)!important;
  pointer-events:none!important;
}
.monitor-marker-stack-v94.offline span{
  background:rgba(127,29,29,.88)!important;
  border-color:rgba(248,113,113,.45)!important;
}
.monitor-map-v89.labels-offline .monitor-marker-stack-v94.offline span{
  display:block!important;
}
.monitor-map-v89.labels-near .monitor-marker-stack-v94.online span,
.monitor-map-v89.labels-near .monitor-marker-stack-v94.offline span{
  display:block!important;
}
.monitor-marker-wrap-v94:hover .monitor-marker-stack-v94 span,
.monitor-marker-stack-v94:hover span{
  display:block!important;
  max-width:140px!important;
  font-size:9px!important;
  z-index:9999!important;
}
.monitor-map-v89:not(.labels-near):not(.labels-offline)::after{
  content:'Zoom dekat untuk menampilkan nama pelanggan';
  position:absolute;
  left:14px;
  bottom:14px;
  z-index:600;
  padding:7px 10px;
  border-radius:999px;
  background:rgba(2,6,23,.72);
  color:#e5e7eb;
  font-size:11px;
  font-weight:800;
  pointer-events:none;
  border:1px solid rgba(255,255,255,.14);
}
@media(max-width:760px){
  .monitor-marker-wrap-v94{width:22px!important;height:22px!important}
  .monitor-marker-stack-v94{width:22px!important;height:22px!important}
  .monitor-marker-stack-v94 .monitor-marker-v89{width:16px!important;height:16px!important;flex-basis:16px!important}
  .monitor-marker-stack-v94 .monitor-marker-v89 img{width:10px!important;height:10px!important}
  .monitor-marker-stack-v94 span{top:18px!important;max-width:76px!important;font-size:7.5px!important;padding:1px 4px!important}
  .monitor-map-v89.labels-near .monitor-marker-stack-v94.online span{display:none!important}
  .monitor-map-v89.labels-near .monitor-marker-stack-v94.offline span{display:block!important}
}


/* V96 - Monitoring HP bersih: hilangkan nama dan bayangan hitam icon */
.monitor-marker-stack-v94 .monitor-marker-v89,
.monitor-marker-v89{
  box-shadow:none!important;
  filter:none!important;
  border-width:1px!important;
}
.monitor-marker-stack-v94 .monitor-marker-v89:after,
.monitor-marker-v89:after{
  display:none!important;
  content:none!important;
}
.monitor-marker-stack-v94 .monitor-marker-v89 img,
.monitor-marker-v89 img{
  filter:none!important;
  box-shadow:none!important;
}
.monitor-marker-v89.online,
.monitor-marker-stack-v94 .monitor-marker-v89.online{
  border-color:rgba(0,40,14,.85)!important;
}
.monitor-marker-v89.offline,
.monitor-marker-stack-v94 .monitor-marker-v89.offline{
  border-color:rgba(80,0,0,.85)!important;
}
@media(max-width:760px){
  .monitor-marker-wrap-v94,
  .monitor-marker-stack-v94,
  .monitor-marker-wrap-v89{
    width:17px!important;
    height:17px!important;
    overflow:visible!important;
  }
  .monitor-marker-stack-v94 .monitor-marker-v89,
  .monitor-marker-v89{
    width:15px!important;
    height:15px!important;
    flex-basis:15px!important;
    box-shadow:none!important;
    filter:none!important;
    border-width:1px!important;
  }
  .monitor-marker-stack-v94 .monitor-marker-v89 img,
  .monitor-marker-v89 img{
    width:10px!important;
    height:10px!important;
    filter:none!important;
  }
  .monitor-marker-stack-v94 span,
  .monitor-map-v89.labels-offline .monitor-marker-stack-v94.offline span,
  .monitor-map-v89.labels-near .monitor-marker-stack-v94.online span,
  .monitor-map-v89.labels-near .monitor-marker-stack-v94.offline span,
  .monitor-marker-wrap-v94:hover .monitor-marker-stack-v94 span,
  .monitor-marker-stack-v94:hover span{
    display:none!important;
    opacity:0!important;
    visibility:hidden!important;
    width:0!important;
    height:0!important;
    padding:0!important;
    border:0!important;
    box-shadow:none!important;
    background:transparent!important;
  }
  .monitor-map-v89:not(.labels-near):not(.labels-offline)::after{
    display:none!important;
    content:none!important;
  }
  .monitor-map-v89 .leaflet-marker-icon{
    filter:none!important;
  }
}


/* V97 - Monitoring HP benar-benar bersih: tanpa label, tanpa bayangan */
@media(max-width:900px){
  .monitor-map-v89,
  #monitorMapV89{
    overflow:hidden!important;
  }
  .monitor-map-v89 .leaflet-marker-icon,
  #monitorMapV89 .leaflet-marker-icon,
  .monitor-marker-wrap-v89,
  .monitor-marker-wrap-v94{
    width:16px!important;
    height:16px!important;
    margin-left:-8px!important;
    margin-top:-8px!important;
    background:transparent!important;
    border:0!important;
    box-shadow:none!important;
    filter:none!important;
    text-shadow:none!important;
    overflow:visible!important;
  }
  .monitor-marker-stack-v94,
  .monitor-marker-stack-v94.mobile-clean{
    width:16px!important;
    height:16px!important;
    display:grid!important;
    place-items:center!important;
    transform:none!important;
    gap:0!important;
    overflow:visible!important;
  }
  .monitor-marker-stack-v94 span,
  .monitor-marker-stack-v94.mobile-clean span,
  #monitorMapV89 .monitor-marker-stack-v94 span,
  #monitorMapV89.labels-offline .monitor-marker-stack-v94.offline span,
  #monitorMapV89.labels-near .monitor-marker-stack-v94.online span,
  #monitorMapV89.labels-near .monitor-marker-stack-v94.offline span,
  .monitor-marker-wrap-v94:hover .monitor-marker-stack-v94 span,
  .monitor-marker-stack-v94:hover span{
    display:none!important;
    visibility:hidden!important;
    opacity:0!important;
    width:0!important;
    height:0!important;
    max-width:0!important;
    max-height:0!important;
    padding:0!important;
    margin:0!important;
    border:0!important;
    box-shadow:none!important;
    text-shadow:none!important;
    background:transparent!important;
    font-size:0!important;
    line-height:0!important;
  }
  .monitor-marker-v89,
  .monitor-marker-stack-v94 .monitor-marker-v89{
    width:14px!important;
    height:14px!important;
    min-width:14px!important;
    min-height:14px!important;
    max-width:14px!important;
    max-height:14px!important;
    display:grid!important;
    place-items:center!important;
    border-radius:50%!important;
    border:1px solid #001b08!important;
    box-shadow:none!important;
    filter:none!important;
    outline:0!important;
  }
  .monitor-marker-v89.offline,
  .monitor-marker-stack-v94 .monitor-marker-v89.offline{
    border-color:#2a0000!important;
    animation:none!important;
  }
  .monitor-marker-v89:before,
  .monitor-marker-v89:after,
  .monitor-marker-stack-v94 .monitor-marker-v89:before,
  .monitor-marker-stack-v94 .monitor-marker-v89:after{
    display:none!important;
    content:none!important;
    box-shadow:none!important;
    background:transparent!important;
  }
  .monitor-marker-v89 img,
  .monitor-marker-stack-v94 .monitor-marker-v89 img{
    width:9px!important;
    height:9px!important;
    display:block!important;
    object-fit:contain!important;
    box-shadow:none!important;
    filter:none!important;
    text-shadow:none!important;
  }
  .monitor-map-v89:not(.labels-near):not(.labels-offline)::after,
  #monitorMapV89:not(.labels-near):not(.labels-offline)::after{
    display:none!important;
    content:none!important;
  }
  .leaflet-tooltip,
  .leaflet-tooltip-pane,
  .leaflet-shadow-pane{
    display:none!important;
  }
}


/* PATCH PORTAL KARYAWAN MODERN V98 */
.employee-dashboard-v98{display:grid;gap:18px}
.employee-hero-v98{grid-template-columns:minmax(0,1.16fr) minmax(320px,.84fr);align-items:stretch;padding:24px;border-radius:30px;background:linear-gradient(135deg,#0f172a 0%,#16306f 38%,#2563eb 66%,#7c3aed 100%);box-shadow:0 26px 58px rgba(15,23,42,.24)}
.hero-main-v98{display:flex;flex-direction:column;justify-content:center}
.hero-main-v98 h1{margin-top:16px;margin-bottom:10px;font-size:42px;line-height:1.02;letter-spacing:-.05em}
.hero-main-v98 p{max-width:720px;font-size:15px;line-height:1.75;color:#eef2ff}
.hero-feature-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.hero-feature-tags span{display:inline-flex;align-items:center;gap:8px;padding:9px 12px;border-radius:999px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.16);color:#fff;font-size:12px;font-weight:800;box-shadow:inset 0 1px 0 rgba(255,255,255,.15)}
.hero-action-row-v98{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);gap:12px;margin-top:20px}
.hero-action-row-v98 .btn{width:100%;min-height:74px;border-radius:22px;padding:14px 18px;display:flex;align-items:center;gap:14px;text-align:left;box-shadow:0 18px 34px rgba(2,6,23,.24);border:1px solid rgba(255,255,255,.16)}
.hero-absen-btn{background:linear-gradient(135deg,#3b82f6 0%,#7c3aed 52%,#db2777 100%)!important;color:#fff!important;position:relative;overflow:hidden}
.hero-absen-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(255,255,255,.18),transparent 45%,transparent);pointer-events:none}
.hero-secondary-btn{background:rgba(255,255,255,.14)!important;color:#fff!important;backdrop-filter:blur(12px)}
.hero-action-row-v98 .cta-icon{width:46px;height:46px;min-width:46px;border-radius:16px;display:grid;place-items:center;background:rgba(255,255,255,.18);font-size:22px;box-shadow:inset 0 1px 0 rgba(255,255,255,.18)}
.hero-action-row-v98 .cta-copy{display:flex;flex-direction:column;gap:3px;flex:1;min-width:0}
.hero-action-row-v98 .cta-copy strong{font-size:18px;line-height:1.1;letter-spacing:-.02em;color:#fff}
.hero-action-row-v98 .cta-copy small{font-size:12px;color:rgba(255,255,255,.86);font-weight:700;line-height:1.4}
.hero-action-row-v98 .cta-pill{display:inline-flex;align-items:center;justify-content:center;padding:7px 11px;border-radius:999px;background:rgba(255,255,255,.18);font-size:11px;font-weight:900;letter-spacing:.12em}
.hero-side-v98{display:grid;gap:14px;align-content:start}
.hero-profile-v98{background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.10));border-radius:26px;padding:18px;display:grid;grid-template-columns:auto 1fr;gap:14px;align-items:center;text-align:left;justify-items:start;border:1px solid rgba(255,255,255,.18)}
.hero-profile-copy b{font-size:19px;line-height:1.15;color:#fff}
.hero-profile-copy span{font-size:13px;color:#dbeafe;font-weight:800;margin-top:5px}
.hero-profile-copy small{display:block;margin-top:4px;color:#cbd5e1;font-weight:700;font-size:12px}
.hero-profile-v98 .status-dot{grid-column:1 / -1;justify-self:start;margin-top:4px}
.hero-metric-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
.hero-metric-card{border-radius:22px;padding:16px;background:linear-gradient(180deg,rgba(255,255,255,.18),rgba(255,255,255,.10));border:1px solid rgba(255,255,255,.18);box-shadow:inset 0 1px 0 rgba(255,255,255,.12)}
.hero-metric-card span{display:block;font-size:11px;text-transform:uppercase;letter-spacing:.08em;color:#dbeafe;font-weight:900}
.hero-metric-card b{display:block;margin-top:6px;font-size:28px;line-height:1;color:#fff;letter-spacing:-.04em}
.hero-metric-card small{display:block;margin-top:5px;color:#e0e7ff;font-weight:700;font-size:12px}
.hero-metric-card.accent{background:linear-gradient(135deg,rgba(249,115,22,.22),rgba(236,72,153,.18),rgba(124,58,237,.16))}
.quick-menu-employee-v98{grid-template-columns:repeat(3,minmax(0,1fr))!important;gap:14px}
.quick-menu-employee-v98 a{position:relative;overflow:hidden;padding:16px 16px 14px;border-radius:22px;background:linear-gradient(145deg,#ffffff,#f8fbff);border:1px solid #dbeafe;box-shadow:0 14px 28px rgba(15,23,42,.08)}
.quick-menu-employee-v98 a:before{content:"";position:absolute;left:14px;right:14px;top:0;height:4px;border-radius:999px;background:linear-gradient(90deg,#22c55e,#3b82f6,#a855f7,#ec4899)}
.quick-menu-employee-v98 a:hover{transform:translateY(-3px);box-shadow:0 20px 34px rgba(15,23,42,.12)}
.quick-menu-employee-v98 i{width:48px;height:48px;border-radius:17px;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;box-shadow:0 14px 24px rgba(37,99,235,.18)}
.quick-menu-employee-v98 b{font-size:15px;line-height:1.25;color:#0f172a}
.quick-menu-employee-v98 span{font-size:12px;line-height:1.45;color:#64748b;font-weight:800}
.dashboard-grid-employee-v98{grid-template-columns:1.1fr .9fr;gap:16px}
.attendance-today-v98,.modern-card-employee-v98,.announcement-v98{border-radius:28px}
.section-badge-live{display:inline-flex;align-items:center;justify-content:center;padding:9px 12px;border-radius:999px;background:#eff6ff;color:#1d4ed8;font-weight:900;font-size:12px;box-shadow:0 8px 16px rgba(37,99,235,.10)}
.mini-stats-employee-v98{margin-bottom:14px}
.employee-service-list{display:grid;gap:10px;margin-top:8px}
.employee-service-list div{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:18px;background:linear-gradient(145deg,#ffffff,#f8fbff);border:1px solid #dbeafe}
.employee-service-list label{font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#64748b}
.employee-service-list strong{font-size:14px;color:#0f172a}
.announcement-v98 .announcement-item-pro{align-items:flex-start}
.announcement-v98 .announcement-item-pro img{width:74px;height:74px;object-fit:cover;border-radius:16px;border:1px solid #dbeafe}
@media (max-width:1100px){.employee-hero-v98{grid-template-columns:1fr}.hero-metric-grid{grid-template-columns:repeat(3,1fr)}.dashboard-grid-employee-v98{grid-template-columns:1fr}}
@media (max-width:800px){.employee-dashboard-v98{gap:14px}.employee-hero-v98{padding:18px;border-radius:24px}.hero-main-v98 h1{font-size:31px}.hero-feature-tags{gap:8px}.hero-feature-tags span{font-size:11px;padding:8px 10px}.hero-action-row-v98{grid-template-columns:1fr;gap:10px}.hero-action-row-v98 .btn{min-height:68px;border-radius:20px;padding:13px 15px}.hero-profile-v98{grid-template-columns:auto 1fr}.hero-metric-grid{grid-template-columns:1fr 1fr}.hero-metric-card:last-child{grid-column:1 / -1}.quick-menu-employee-v98{grid-template-columns:repeat(2,1fr)!important;gap:10px}.quick-menu-employee-v98 a{padding:14px;min-height:120px}.quick-menu-employee-v98 i{width:42px;height:42px;border-radius:15px}.quick-menu-employee-v98 b{font-size:13px}.quick-menu-employee-v98 span{font-size:11px}.dashboard-grid-employee-v98{gap:14px}}
@media (max-width:480px){.hero-main-v98 h1{font-size:27px}.hero-main-v98 p{font-size:13px;line-height:1.65}.hero-action-row-v98 .cta-copy strong{font-size:16px}.hero-action-row-v98 .cta-copy small{font-size:11px}.hero-action-row-v98 .cta-pill{font-size:10px;padding:6px 9px}.hero-profile-copy b{font-size:17px}.hero-metric-grid{grid-template-columns:1fr}.hero-metric-card:last-child{grid-column:auto}.quick-menu-employee-v98{grid-template-columns:1fr 1fr!important}.section-badge-live{width:100%;justify-content:center}}
html[data-theme="dark"] .quick-menu-employee-v98 a{background:linear-gradient(145deg,#0f172a,#111c35)!important;border-color:#334155!important;box-shadow:0 16px 34px rgba(0,0,0,.32)!important}
html[data-theme="dark"] .quick-menu-employee-v98 b,html[data-theme="dark"] .quick-menu-employee-v98 span,html[data-theme="dark"] .employee-service-list strong,html[data-theme="dark"] .employee-service-list label{color:#f8fafc!important}
html[data-theme="dark"] .employee-service-list div{background:linear-gradient(145deg,#0f172a,#111c35)!important;border-color:#334155!important}
html[data-theme="dark"] .section-badge-live{background:#1e293b!important;color:#f8fafc!important}


/* PATCH PORTAL PRESENSI + ABSEN UI V99 */
.employee-home-mobile-v99{display:block}
.presence-app-card-v99{max-width:820px;margin:0 auto;padding:18px;border-radius:34px;background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid #dbeafe;box-shadow:0 24px 60px rgba(15,23,42,.08);display:grid;gap:18px}
.presence-topbar-v99{display:flex;align-items:center;justify-content:space-between;gap:12px}
.presence-user-v99{display:flex;align-items:center;gap:14px}.presence-user-v99 .avatar{width:58px;height:58px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,#dbeafe,#eff6ff);display:grid;place-items:center;font-weight:900;color:#1d4ed8;border:3px solid #fff;box-shadow:0 8px 20px rgba(59,130,246,.18)}.presence-user-v99 .avatar img{width:100%;height:100%;object-fit:cover}.presence-user-v99 span{display:block;font-size:12px;color:#64748b;font-weight:800}.presence-user-v99 strong{display:block;font-size:28px;line-height:1.05;color:#0f172a;letter-spacing:-.04em}.presence-user-v99 small{display:block;font-size:13px;color:#334155;font-weight:800}
.presence-icons-v99{display:flex;gap:10px}.presence-icons-v99 a{width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:#fff;border:1px solid #dbeafe;box-shadow:0 12px 24px rgba(15,23,42,.08);font-size:20px}
.presence-clock-card-v99{padding:16px 18px;border-radius:24px;background:linear-gradient(135deg,#1d4ed8 0%,#2563eb 45%,#06b6d4 100%);color:#fff;box-shadow:0 18px 34px rgba(37,99,235,.24)}.presence-clock-card-v99 small{display:block;font-size:13px;font-weight:800;opacity:.95}.presence-date-v99{margin-top:10px;font-size:20px;font-weight:900;letter-spacing:-.03em}.presence-clock-actions-v99{margin-top:14px;display:grid;grid-template-columns:1fr 1fr;gap:10px}.clock-chip{display:flex;align-items:center;justify-content:center;gap:10px;padding:14px 12px;border-radius:999px;background:#fff;color:#0f172a;font-weight:900;box-shadow:inset 0 1px 0 rgba(255,255,255,.5)}.clock-chip span{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;background:#eff6ff;color:#1d4ed8}.clock-chip.out span{background:#fef2f2;color:#dc2626}
.section-head-inline{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.section-head-inline b{display:block;color:#0f172a;font-size:19px;letter-spacing:-.03em}.section-head-inline span{display:block;color:#64748b;font-size:13px;font-weight:700;max-width:240px;text-align:right}
.presence-top5-v99,.presence-stat-box-v99,.presence-menu-v99{padding:0 4px}.top5-row-v99{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.top5-card-v99{display:flex;align-items:center;gap:12px;padding:12px;border-radius:20px;background:linear-gradient(135deg,#ffffff,#e0f2fe);border:1px solid #dbeafe;box-shadow:0 10px 24px rgba(15,23,42,.06)}.top5-card-v99.leader{grid-column:1 / -1;background:linear-gradient(135deg,#fff7ed,#e0f2fe)}.top5-card-v99 em{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-style:normal;background:#0ea5e9;color:#fff;font-weight:900}.top5-avatar{width:44px;height:44px;border-radius:50%;overflow:hidden;display:grid;place-items:center;background:#fff;color:#1d4ed8;font-weight:900;border:2px solid #fff;box-shadow:0 6px 16px rgba(14,165,233,.15)}.top5-avatar img{width:100%;height:100%;object-fit:cover}.top5-card-v99 b{display:block;font-size:14px;color:#0f172a}.top5-card-v99 span{display:block;font-size:12px;color:#475569;font-weight:800}
.mini-colored-stats-v99{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}.stat-chip{padding:12px;border-radius:16px;color:#fff;text-align:center;box-shadow:0 10px 20px rgba(15,23,42,.08)}.stat-chip span{display:block;font-size:12px;font-weight:800}.stat-chip b{display:block;margin-top:4px;font-size:22px;line-height:1}.stat-chip.green{background:#22c55e}.stat-chip.yellow{background:#f59e0b}.stat-chip.blue{background:#3b82f6}.stat-chip.red{background:#ef4444}
.presence-menu-grid-v99{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}.presence-menu-grid-v99 a{padding:14px 10px;border-radius:24px;background:linear-gradient(180deg,#ffffff,#f8fbff);border:1px solid #dbeafe;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:8px;box-shadow:0 12px 28px rgba(15,23,42,.06)}.presence-menu-grid-v99 i{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;color:#fff;font-style:normal;font-size:24px;box-shadow:0 12px 22px rgba(15,23,42,.12)}.presence-menu-grid-v99 i.bg1{background:linear-gradient(135deg,#38bdf8,#2563eb)}.presence-menu-grid-v99 i.bg2{background:linear-gradient(135deg,#fb7185,#f97316)}.presence-menu-grid-v99 i.bg3{background:linear-gradient(135deg,#86efac,#22c55e)}.presence-menu-grid-v99 i.bg4{background:linear-gradient(135deg,#f59e0b,#f97316)}.presence-menu-grid-v99 i.bg5{background:linear-gradient(135deg,#1d4ed8,#7c3aed)}.presence-menu-grid-v99 i.bg6{background:linear-gradient(135deg,#ec4899,#7c3aed)}.presence-menu-grid-v99 b{font-size:15px;color:#0f172a}.presence-menu-grid-v99 span{font-size:12px;color:#64748b;font-weight:800;line-height:1.35}
.attendance-shell-v99{display:flex;justify-content:center}.attendance-phone-ui-v99{width:min(460px,100%);padding:16px;border-radius:30px;background:linear-gradient(180deg,#f8fafc,#ffffff);border:1px solid #dbeafe;box-shadow:0 26px 60px rgba(15,23,42,.10);display:grid;gap:14px}.attendance-page-head-v99{display:flex;align-items:center;justify-content:space-between;gap:12px}.attendance-page-head-v99 span{display:block;font-size:13px;font-weight:800;color:#22c55e}.attendance-page-head-v99 h2{margin:2px 0 0;font-size:28px;line-height:1.05;letter-spacing:-.04em;color:#0f172a}.face-warning-v99{padding:12px 14px;border-radius:18px;background:#fff7ed;border:1px solid #fdba74;color:#9a3412;font-weight:700;font-size:13px}.face-warning-v99 a{color:#c2410c;font-weight:900}
.attendance-camera-stage-v99{position:relative;overflow:hidden;border-radius:28px;background:linear-gradient(180deg,#0f172a,#020617);aspect-ratio:9/16;min-height:640px;border:1px solid rgba(255,255,255,.08);box-shadow:inset 0 1px 0 rgba(255,255,255,.04),0 18px 40px rgba(2,6,23,.24)}.attendance-camera-stage-v99 video,.attendance-camera-stage-v99 img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;background:#0f172a}.attendance-camera-stage-v99:after{content:"";position:absolute;left:0;right:0;bottom:0;height:42%;background:linear-gradient(180deg,transparent,rgba(2,6,23,.72));pointer-events:none}
.attendance-camera-stage-v99 .selfie-placeholder{position:absolute;inset:auto 22px 126px 22px;display:grid;place-items:center;padding:12px 16px;border-radius:18px;background:rgba(15,23,42,.48);backdrop-filter:blur(8px);color:#fff;font-weight:800;font-size:13px;line-height:1.5;text-align:center;z-index:2;border:1px solid rgba(255,255,255,.1)}
.camera-overlay-left-v99,.camera-overlay-right-v99,.camera-overlay-bottom-v99{position:absolute;z-index:3}.camera-overlay-left-v99{left:16px;top:16px;display:flex;align-items:center;gap:10px;max-width:52%;padding:10px 12px;border-radius:18px;background:rgba(255,255,255,.90);box-shadow:0 12px 24px rgba(2,6,23,.16)}.mini-map-badge-v99{width:36px;height:36px;border-radius:12px;display:grid;place-items:center;background:linear-gradient(135deg,#60a5fa,#2563eb);color:#fff;font-size:18px}.camera-overlay-left-v99 b{display:block;font-size:13px;color:#0f172a}.camera-overlay-left-v99 span{display:block;font-size:11px;color:#475569;font-weight:700;line-height:1.3}
.camera-overlay-right-v99{right:16px;top:16px;padding:12px 12px 10px;border-radius:18px;background:rgba(15,23,42,.74);border:1px solid rgba(255,255,255,.12);backdrop-filter:blur(10px);color:#fff;min-width:145px}.camera-overlay-right-v99 .ov-date{font-size:12px;font-weight:900}.camera-overlay-right-v99 .ov-time{font-size:22px;font-weight:900;line-height:1.1;margin-top:2px}.camera-overlay-right-v99 .ov-meta{margin-top:8px}.camera-overlay-right-v99 label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:#93c5fd;font-weight:900}.camera-overlay-right-v99 b{display:block;font-size:12px;line-height:1.35}
.camera-overlay-bottom-v99{left:16px;right:16px;bottom:78px;display:grid;gap:10px}.camera-overlay-bottom-v99 select{width:100%;appearance:none;border:none;border-radius:16px;padding:12px 14px;background:rgba(15,23,42,.80);color:#fff;font-weight:800;box-shadow:0 12px 24px rgba(2,6,23,.2);backdrop-filter:blur(8px)}.camera-overlay-bottom-v99 select option{color:#111827}
.face-match-box.v99{width:165px;height:250px;left:50%;top:51%;transform:translate(-50%,-50%);border-width:4px;border-radius:26px;background:rgba(255,255,255,.06);box-shadow:0 0 0 9999px rgba(2,6,23,.10) inset,0 16px 38px rgba(2,6,23,.20)}.face-match-box.v99 span{left:50%;bottom:-34px;top:auto;transform:translateX(-50%);padding:7px 14px;border-radius:999px;background:rgba(15,23,42,.68);color:#fff;font-size:11px;letter-spacing:.08em}
.attendance-helper-v99{display:grid;gap:10px}.attendance-helper-v99 .selfie-status,.attendance-helper-v99 .radius-status{margin:0;padding:12px 14px;border-radius:16px;background:#eff6ff;border:1px solid #bfdbfe;color:#1d4ed8;font-weight:800;font-size:12px;line-height:1.55}.attendance-helper-v99 .radius-status{background:#f8fafc;border-color:#e2e8f0;color:#334155}
.attendance-control-row-v99{display:grid;grid-template-columns:1fr 1fr;gap:10px}.control-btn-v99{height:48px;border:none;border-radius:16px;font-weight:900;box-shadow:0 10px 20px rgba(15,23,42,.08)}.control-btn-v99.reload{background:#e0f2fe;color:#0369a1}.control-btn-v99.retake{background:#fff7ed;color:#c2410c}
.attendance-type-hidden-v99,.attendance-hidden-submit-v99{display:none!important}
.attendance-action-buttons-v99{display:grid;grid-template-columns:1fr 1fr;gap:12px}.attendance-main-btn-v99{height:56px;border:none;border-radius:999px;color:#fff;font-size:18px;font-weight:900;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 16px 30px rgba(15,23,42,.12)}.attendance-main-btn-v99 span{font-size:20px}.attendance-main-btn-v99.masuk{background:linear-gradient(135deg,#16a34a,#22c55e)}.attendance-main-btn-v99.pulang{background:linear-gradient(135deg,#f97316,#ef4444)}.attendance-main-btn-v99:disabled{opacity:.45;filter:grayscale(1)}
.attendance-note-v99 textarea{min-height:80px;border-radius:18px}.attendance-mini-stats-v99{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.attendance-mini-stats-v99 div{padding:12px;border-radius:18px;background:#fff;border:1px solid #dbeafe;text-align:center;box-shadow:0 10px 22px rgba(15,23,42,.05)}.attendance-mini-stats-v99 span{display:block;font-size:12px;font-weight:800;color:#64748b}.attendance-mini-stats-v99 b{display:block;margin-top:4px;font-size:17px;color:#0f172a}.attendance-map-panel-v99{padding:14px;border-radius:24px;background:#fff;border:1px solid #dbeafe;box-shadow:0 12px 24px rgba(15,23,42,.06)}.gps-map.v99{height:240px;border-radius:18px}.coord-grid.compact-v99{grid-template-columns:repeat(2,minmax(0,1fr));margin-top:10px}
@media (max-width:768px){.presence-app-card-v99{padding:14px;border-radius:26px}.presence-user-v99 strong{font-size:24px}.top5-row-v99{grid-template-columns:1fr}.mini-colored-stats-v99{grid-template-columns:repeat(2,minmax(0,1fr))}.presence-menu-grid-v99{grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.presence-menu-grid-v99 a{padding:12px 8px;border-radius:20px}.presence-menu-grid-v99 i{width:48px;height:48px;border-radius:16px;font-size:21px}.presence-menu-grid-v99 b{font-size:13px}.presence-menu-grid-v99 span{font-size:11px}.attendance-phone-ui-v99{padding:12px;border-radius:24px}.attendance-page-head-v99 h2{font-size:24px}.attendance-camera-stage-v99{min-height:560px}}
@media (max-width:480px){.presence-topbar-v99{align-items:flex-start}.presence-icons-v99 a{width:42px;height:42px}.presence-user-v99 strong{font-size:22px}.presence-clock-actions-v99{grid-template-columns:1fr 1fr}.section-head-inline{align-items:center}.section-head-inline span{font-size:11px;max-width:140px}.presence-menu-grid-v99{grid-template-columns:repeat(3,minmax(0,1fr))}.attendance-phone-ui-v99{width:100%}.attendance-camera-stage-v99{min-height:500px}.camera-overlay-left-v99{max-width:62%;padding:8px 10px}.camera-overlay-right-v99{min-width:128px;padding:10px}.face-match-box.v99{width:148px;height:228px}.camera-overlay-bottom-v99{bottom:72px}}
html[data-theme="dark"] .presence-app-card-v99,html[data-theme="dark"] .attendance-phone-ui-v99,html[data-theme="dark"] .attendance-map-panel-v99,html[data-theme="dark"] .attendance-mini-stats-v99 div{background:linear-gradient(180deg,#0f172a,#111827)!important;border-color:#334155!important;box-shadow:0 24px 60px rgba(0,0,0,.30)!important}
html[data-theme="dark"] .presence-user-v99 strong,html[data-theme="dark"] .section-head-inline b,html[data-theme="dark"] .presence-menu-grid-v99 b,html[data-theme="dark"] .top5-card-v99 b,html[data-theme="dark"] .attendance-page-head-v99 h2,html[data-theme="dark"] .attendance-mini-stats-v99 b{color:#f8fafc!important}
html[data-theme="dark"] .presence-user-v99 small,html[data-theme="dark"] .presence-user-v99 span,html[data-theme="dark"] .presence-menu-grid-v99 span,html[data-theme="dark"] .section-head-inline span,html[data-theme="dark"] .top5-card-v99 span,html[data-theme="dark"] .attendance-mini-stats-v99 span{color:#cbd5e1!important}
html[data-theme="dark"] .top5-card-v99,html[data-theme="dark"] .presence-menu-grid-v99 a,html[data-theme="dark"] .attendance-mini-stats-v99 div{background:linear-gradient(180deg,#111827,#0f172a)!important;border-color:#334155!important}
html[data-theme="dark"] .attendance-helper-v99 .selfie-status{background:#172554!important;border-color:#1d4ed8!important;color:#dbeafe!important}
html[data-theme="dark"] .attendance-helper-v99 .radius-status{background:#111827!important;border-color:#334155!important;color:#cbd5e1!important}


/* V100 - Hilangkan menu garis 3 khusus Portal Karyawan */
body.employee-mode .hamburger,
body.employee-mode.premium-global-theme .hamburger,
.employee-mode .topbar .hamburger{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
  width:0!important;
  min-width:0!important;
  height:0!important;
  min-height:0!important;
  padding:0!important;
  margin:0!important;
  border:0!important;
  overflow:hidden!important;
}
body.employee-mode .topbar{
  justify-content:space-between!important;
  gap:10px!important;
}
body.employee-mode .top-title{
  flex:1 1 auto!important;
  min-width:0!important;
}
@media(max-width:800px){
  body.employee-mode .topbar{
    padding-left:16px!important;
    padding-right:10px!important;
  }
  body.employee-mode .top-title b{
    font-size:18px!important;
    line-height:1.15!important;
  }
  body.employee-mode .top-title span{
    display:none!important;
  }
}


/* PATCH V101 - auto open camera polish */
.attendance-camera-stage-v99.auto-starting{box-shadow:0 0 0 4px rgba(34,197,94,.18),0 18px 40px rgba(2,6,23,.24)!important}
.clock-chip.in,.clock-chip.out{position:relative;overflow:hidden}
.clock-chip.in:after,.clock-chip.out:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.22),transparent);transform:translateX(-120%);animation:v101ClockShine 2.4s ease-in-out infinite}
@keyframes v101ClockShine{60%,100%{transform:translateX(120%)}}


/* PATCH V103 - dark mode clock text contrast */
html[data-theme="dark"] .presence-clock-card-v99{background:linear-gradient(135deg,#1d4ed8 0%,#2563eb 45%,#06b6d4 100%)!important;box-shadow:0 18px 34px rgba(37,99,235,.30)!important}
html[data-theme="dark"] .presence-clock-card-v99 small,
html[data-theme="dark"] .presence-date-v99{color:#ffffff!important;text-shadow:0 2px 8px rgba(15,23,42,.24)!important}
html[data-theme="dark"] .clock-chip{background:#ffffff!important;color:#0f172a!important;border:1px solid rgba(255,255,255,.55)!important;opacity:1!important;filter:none!important;box-shadow:inset 0 1px 0 rgba(255,255,255,.8),0 10px 24px rgba(2,6,23,.20)!important}
html[data-theme="dark"] .clock-chip *,
html[data-theme="dark"] .clock-chip.in,
html[data-theme="dark"] .clock-chip.out{color:#0f172a!important;opacity:1!important}
html[data-theme="dark"] .clock-chip span{background:#eff6ff!important;color:#1d4ed8!important;border:1px solid #bfdbfe!important}
html[data-theme="dark"] .clock-chip.out span{background:#fee2e2!important;color:#dc2626!important;border-color:#fecaca!important}
html[data-theme="dark"] .clock-chip.in:hover,
html[data-theme="dark"] .clock-chip.out:hover{transform:translateY(-1px);box-shadow:inset 0 1px 0 rgba(255,255,255,.9),0 14px 28px rgba(2,6,23,.24)!important}


/* PATCH V104 - Tombol kembali dan home di semua halaman portal karyawan */
.employee-floating-nav-v104{position:fixed;right:18px;bottom:18px;z-index:120;display:flex;gap:10px;align-items:center;padding:8px;border-radius:999px;background:rgba(255,255,255,.88);border:1px solid rgba(191,219,254,.95);box-shadow:0 18px 42px rgba(15,23,42,.18);backdrop-filter:blur(14px)}
.employee-floating-nav-v104 a,.employee-floating-nav-v104 button{height:48px;border:0;border-radius:999px;padding:0 16px;display:flex;align-items:center;gap:8px;font-weight:900;font-size:13px;cursor:pointer;text-decoration:none;color:#0f172a;background:#ffffff;box-shadow:0 8px 18px rgba(15,23,42,.08)}
.employee-floating-nav-v104 .nav-home-v104{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff}
.employee-floating-nav-v104 .nav-back-v104{background:#f8fbff;color:#1d4ed8;border:1px solid #dbeafe}
.employee-floating-nav-v104 span{font-size:17px;line-height:1}
.employee-top-return-v104{display:flex;align-items:center;justify-content:space-between;gap:10px;margin:0 0 14px;padding:10px;border-radius:20px;background:linear-gradient(135deg,#ffffff,#f8fbff);border:1px solid #dbeafe;box-shadow:0 12px 28px rgba(15,23,42,.06)}
.employee-top-return-v104 a,.employee-top-return-v104 button{border:0;border-radius:999px;padding:10px 14px;font-weight:900;font-size:13px;text-decoration:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}
.employee-top-return-v104 button{background:#eef2ff;color:#4338ca}
.employee-top-return-v104 a{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff}
@media(max-width:800px){
  .employee-floating-nav-v104{left:50%;right:auto;bottom:14px;transform:translateX(-50%);padding:7px;gap:8px;max-width:calc(100vw - 28px)}
  .employee-floating-nav-v104 a,.employee-floating-nav-v104 button{height:44px;padding:0 13px;font-size:12px;white-space:nowrap}
  .employee-top-return-v104{margin-top:-2px;border-radius:18px;padding:8px}
  .employee-top-return-v104 a,.employee-top-return-v104 button{flex:1;padding:10px 8px;font-size:12px}
  body.employee-mode .content-wrap{padding-bottom:82px!important}
}
html[data-theme="dark"] .employee-floating-nav-v104{background:rgba(15,23,42,.82);border-color:#334155;box-shadow:0 18px 42px rgba(0,0,0,.38)}
html[data-theme="dark"] .employee-floating-nav-v104 a,html[data-theme="dark"] .employee-floating-nav-v104 button{color:#f8fafc!important;background:#111827!important;border-color:#334155!important}
html[data-theme="dark"] .employee-floating-nav-v104 .nav-home-v104{background:linear-gradient(135deg,#2563eb,#7c3aed)!important;color:#fff!important}
html[data-theme="dark"] .employee-floating-nav-v104 .nav-back-v104{background:#0f172a!important;color:#dbeafe!important;border:1px solid #334155!important}
html[data-theme="dark"] .employee-top-return-v104{background:linear-gradient(135deg,#0f172a,#111827)!important;border-color:#334155!important;box-shadow:0 12px 28px rgba(0,0,0,.24)!important}
html[data-theme="dark"] .employee-top-return-v104 button{background:#111827!important;color:#dbeafe!important;border:1px solid #334155!important}
html[data-theme="dark"] .employee-top-return-v104 a{background:linear-gradient(135deg,#2563eb,#7c3aed)!important;color:#fff!important}


/* PATCH V105 - tombol kembali tunggal */
.employee-floating-nav-v104,
.employee-top-return-v104{display:none!important}
.employee-request-hero>.btn.small[href$="employee.php"],
.attendance-page-head-v99>.btn.small.soft[href$="employee.php"]{display:none!important}
.monitor-return-v105{
  display:flex;gap:12px;align-items:center;justify-content:flex-start;margin:0 0 12px;position:relative;z-index:30
}
.monitor-return-v105 button,.monitor-return-v105 a{
  flex:0 0 auto;min-height:44px;padding:0 18px;border-radius:999px;border:1px solid rgba(191,219,254,.9);
  background:linear-gradient(135deg,#ffffff,#eff6ff);color:#0f172a;font-weight:900;display:inline-flex;align-items:center;justify-content:center;
  box-shadow:0 12px 24px rgba(15,23,42,.08);text-decoration:none;cursor:pointer
}
.monitor-return-v105 a{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border-color:rgba(255,255,255,.2)}
.monitor-return-v105 button:hover,.monitor-return-v105 a:hover{transform:translateY(-1px);box-shadow:0 16px 28px rgba(15,23,42,.12)}
html[data-theme="dark"] .monitor-return-v105 button{background:linear-gradient(135deg,#0f172a,#111827)!important;color:#f8fafc!important;border-color:#334155!important}
html[data-theme="dark"] .monitor-return-v105 a{background:linear-gradient(135deg,#1d4ed8,#7c3aed)!important;color:#fff!important}
@media(max-width:800px){
  .monitor-return-v105{position:fixed;left:12px;right:12px;top:92px;margin:0;z-index:9999;justify-content:center}
  .monitor-return-v105 button,.monitor-return-v105 a{flex:1 1 0;min-height:42px;padding:0 12px;font-size:13px}
  .monitor-fullmap-v89{padding-top:54px!important}
}


/* PATCH V106 - Tombol Home di header portal karyawan */
.portal-header-home-v106{
  height:40px;min-width:40px;padding:0 14px;border-radius:15px;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,#22c55e,#2563eb 55%,#7c3aed)!important;color:#fff!important;border:1px solid rgba(255,255,255,.28)!important;
  box-shadow:0 12px 24px rgba(37,99,235,.18)!important;font-weight:900;text-decoration:none!important;white-space:nowrap
}
.portal-header-home-v106 i,.portal-header-home-v106 span{color:#fff!important;opacity:1!important}
.portal-header-home-v106 span{font-size:12px;line-height:1}
.portal-header-home-v106:hover{transform:translateY(-1px);box-shadow:0 16px 30px rgba(37,99,235,.24)!important}
body.employee-mode .top-actions{gap:8px!important}
.monitor-return-single-v106{justify-content:flex-start!important}
.monitor-return-single-v106 a{display:none!important}
.monitor-return-single-v106 button{min-width:150px}
html[data-theme="dark"] .portal-header-home-v106{background:linear-gradient(135deg,#16a34a,#1d4ed8 55%,#7c3aed)!important;color:#fff!important;border-color:rgba(148,163,184,.25)!important;box-shadow:0 12px 28px rgba(0,0,0,.28)!important}
html[data-theme="dark"] .portal-header-home-v106 *{color:#fff!important}
@media(max-width:800px){
  .portal-header-home-v106{height:40px;min-width:40px;width:40px;padding:0;border-radius:14px}
  .portal-header-home-v106 span{display:none!important}
  body.employee-mode .top-actions{gap:6px!important}
  body.employee-mode .theme-toggle,body.employee-mode .notif{width:40px!important;height:40px!important;min-width:40px!important;padding:0!important}
  body.employee-mode .theme-toggle span{display:none!important}
  body.employee-mode .user-chip{max-width:86px!important;min-width:auto!important}
  .monitor-return-single-v106{left:12px!important;right:auto!important;width:auto!important;justify-content:flex-start!important}
  .monitor-return-single-v106 button{flex:0 0 auto!important;min-width:120px!important}
}
@media(max-width:430px){
  body.employee-mode .top-title b{font-size:15px!important}
  body.employee-mode .top-actions{gap:5px!important}
  body.employee-mode .notif,body.employee-mode .theme-toggle,.portal-header-home-v106{width:38px!important;height:38px!important;min-width:38px!important;border-radius:13px!important}
  body.employee-mode .user-chip{max-width:74px!important;padding:5px!important}
}


/* PATCH V108 - Pengumuman tampil di Portal Karyawan */
.presence-announcement-v108{padding:0 4px}
.announcement-list-v108{display:grid;gap:10px}
.announcement-card-v108{display:grid;grid-template-columns:56px 1fr;gap:12px;align-items:start;padding:12px;border-radius:20px;background:linear-gradient(135deg,#ffffff,#eff6ff);border:1px solid #dbeafe;box-shadow:0 12px 26px rgba(15,23,42,.07)}
.announcement-card-v108 img{width:56px;height:56px;border-radius:17px;object-fit:cover;border:2px solid #fff;box-shadow:0 10px 20px rgba(37,99,235,.12)}
.announcement-card-v108 i{width:56px;height:56px;border-radius:17px;display:grid;place-items:center;font-style:normal;font-size:26px;background:linear-gradient(135deg,#22c55e,#2563eb);color:#fff;box-shadow:0 10px 20px rgba(37,99,235,.14)}
.announcement-card-v108 b{display:block;color:#0f172a;font-size:15px;line-height:1.25;letter-spacing:-.02em}
.announcement-card-v108 p{margin:5px 0 0;color:#475569;font-size:13px;line-height:1.45;font-weight:700;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}
.announcement-card-v108 small{display:inline-flex;margin-top:8px;padding:5px 8px;border-radius:999px;background:#dbeafe;color:#1d4ed8;font-size:11px;font-weight:900}
.announcement-empty-v108{padding:14px;border-radius:18px;background:#f8fafc;border:1px dashed #bfdbfe;color:#64748b;font-weight:800;text-align:center}
html[data-theme="dark"] .announcement-card-v108{background:linear-gradient(180deg,#111827,#0f172a)!important;border-color:#334155!important;box-shadow:0 14px 28px rgba(0,0,0,.28)!important}
html[data-theme="dark"] .announcement-card-v108 b{color:#f8fafc!important}
html[data-theme="dark"] .announcement-card-v108 p{color:#cbd5e1!important}
html[data-theme="dark"] .announcement-card-v108 small{background:#172554!important;color:#dbeafe!important}
html[data-theme="dark"] .announcement-empty-v108{background:#111827!important;border-color:#334155!important;color:#cbd5e1!important}
@media(max-width:480px){.announcement-card-v108{grid-template-columns:48px 1fr;padding:10px;border-radius:18px}.announcement-card-v108 img,.announcement-card-v108 i{width:48px;height:48px;border-radius:15px}.announcement-card-v108 b{font-size:14px}.announcement-card-v108 p{font-size:12px;-webkit-line-clamp:2}}


/* PATCH V109 - Kamera Face ID 4:5 dan kotak wajah persegi */
.attendance-camera-stage-v99{
  aspect-ratio:4/5!important;
  min-height:0!important;
  height:auto!important;
  max-height:calc(100vh - 260px)!important;
  width:100%!important;
}
.attendance-camera-stage-v99 video,
.attendance-camera-stage-v99 img{
  object-fit:cover!important;
  object-position:center center!important;
}
.face-match-box.v99{
  width:210px!important;
  height:210px!important;
  aspect-ratio:1/1!important;
  border-radius:24px!important;
  left:50%!important;
  top:48%!important;
  transform:translate(-50%,-50%)!important;
  box-shadow:0 0 0 2px rgba(255,255,255,.18),0 12px 30px rgba(2,6,23,.20)!important;
}
.face-match-box.v99.ok{box-shadow:0 0 0 3px rgba(34,197,94,.30),0 12px 30px rgba(2,6,23,.20)!important}
.face-match-box.v99.danger{box-shadow:0 0 0 3px rgba(239,68,68,.30),0 12px 30px rgba(2,6,23,.20)!important}
.face-match-box.v99 span{
  bottom:-32px!important;
  white-space:nowrap!important;
}
@media(max-width:768px){
  .attendance-camera-stage-v99{
    aspect-ratio:4/5!important;
    max-height:none!important;
  }
  .face-match-box.v99{
    width:190px!important;
    height:190px!important;
    border-radius:22px!important;
  }
}
@media(max-width:420px){
  .face-match-box.v99{
    width:168px!important;
    height:168px!important;
    border-radius:20px!important;
  }
  .camera-overlay-bottom-v99{bottom:66px!important}
}


/* V110 - Face ID hanya membaca wajah inti: mata, hidung, mulut */

.face-match-box.v99:after,
.face-match-box.show:after{
  content:"AREA WAJAH";
  position:absolute;
  left:50%;
  top:-34px;
  transform:translateX(-50%);
  white-space:nowrap;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(15,23,42,.88);
  color:#fff;
  font-weight:800;
  font-size:12px;
  letter-spacing:.04em;
}

.faceid-enroll-panel .selfie-stage:after{
  content:"Face ID hanya merekam wajah inti, bukan objek sekitar";
  position:absolute;
  left:14px;
  right:14px;
  bottom:14px;
  z-index:4;
  padding:10px 12px;
  border-radius:16px;
  background:rgba(15,23,42,.72);
  color:#fff;
  font-weight:900;
  font-size:12px;
  text-align:center;
  pointer-events:none;
}


/* PATCH V111 - Hilangkan gambar/maps overlay pada foto absen */
.attendance-camera-stage-v99 .camera-overlay-left-v99,
.attendance-camera-stage-v99 .mini-map-badge-v99,
.camera-overlay-left-v99,
.mini-map-badge-v99{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
.gps-status-hidden-v111{
  position:absolute!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
  clip:rect(0 0 0 0)!important;
  white-space:nowrap!important;
  opacity:0!important;
  pointer-events:none!important;
}
.attendance-camera-stage-v99{
  background:linear-gradient(180deg,#0f172a,#020617)!important;
}
.attendance-camera-stage-v99 video,
.attendance-camera-stage-v99 img{
  z-index:1!important;
}
.attendance-camera-stage-v99 .face-match-box,
.attendance-camera-stage-v99 .selfie-placeholder,
.attendance-camera-stage-v99 .camera-overlay-right-v99,
.attendance-camera-stage-v99 .camera-overlay-bottom-v99{
  z-index:3!important;
}


/* PATCH V112 - Hapus keterangan besar di atas kamera absen */
.attendance-camera-stage-v99 .camera-overlay-right-v99,
.camera-overlay-right-v99{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
.attendance-camera-stage-v99{
  padding-top:0!important;
}
.face-match-box.v99{
  top:48%!important;
}
@media(max-width:480px){
  .face-match-box.v99{
    top:47%!important;
  }
}

/* PATCH V113 - Bersihkan text overlay kamera Face ID */
.attendance-camera-stage-v99 .face-match-box.v99 span,
.face-match-box.v99 span,
.face-match-box span{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
.attendance-camera-stage-v99 .camera-overlay-bottom-v99,
.camera-overlay-bottom-v99{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
  height:0!important;
  overflow:hidden!important;
}
.attendance-camera-stage-v99 .camera-overlay-left-v99,
.camera-overlay-left-v99{
  display:none!important;
  visibility:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
.attendance-camera-stage-v99 .face-match-box.v99,
.face-match-box.v99{
  background:transparent!important;
}

/* PATCH V115 - Statistik HP 1 baris 4 kotak */
@media (max-width:768px){
  .presence-stat-box-v99{
    padding:0 2px!important;
    margin-top:4px!important;
  }
  .presence-stat-box-v99 .section-head-inline{
    margin-bottom:8px!important;
    align-items:center!important;
  }
  .presence-stat-box-v99 .section-head-inline b{
    font-size:18px!important;
    line-height:1.1!important;
  }
  .presence-stat-box-v99 .section-head-inline span{
    font-size:12px!important;
    max-width:110px!important;
    text-align:right!important;
  }
  .mini-colored-stats-v99{
    grid-template-columns:repeat(4,minmax(0,1fr))!important;
    gap:6px!important;
  }
  .mini-colored-stats-v99 .stat-chip,
  .stat-chip{
    min-height:58px!important;
    padding:8px 4px!important;
    border-radius:14px!important;
    display:flex!important;
    flex-direction:column!important;
    align-items:center!important;
    justify-content:center!important;
    box-shadow:0 8px 16px rgba(15,23,42,.10)!important;
  }
  .mini-colored-stats-v99 .stat-chip span,
  .stat-chip span{
    font-size:10px!important;
    line-height:1.05!important;
    white-space:nowrap!important;
    font-weight:900!important;
  }
  .mini-colored-stats-v99 .stat-chip b,
  .stat-chip b{
    margin-top:3px!important;
    font-size:19px!important;
    line-height:1!important;
    font-weight:1000!important;
  }
}
@media (max-width:380px){
  .mini-colored-stats-v99{gap:5px!important}
  .mini-colored-stats-v99 .stat-chip,
  .stat-chip{min-height:52px!important;padding:7px 2px!important;border-radius:12px!important}
  .mini-colored-stats-v99 .stat-chip span,
  .stat-chip span{font-size:9px!important}
  .mini-colored-stats-v99 .stat-chip b,
  .stat-chip b{font-size:17px!important}
}


/* PATCH V116 - Animasi Notifikasi Premium */
.toast-zone-v116{
  position:fixed;
  right:18px;
  top:86px;
  z-index:9999;
  display:grid;
  gap:12px;
  width:min(420px,calc(100vw - 28px));
  pointer-events:none;
}
.app-flash-toast{
  position:relative!important;
  margin:0!important;
  padding:16px 48px 16px 58px!important;
  border-radius:22px!important;
  overflow:hidden!important;
  background:linear-gradient(145deg,rgba(255,255,255,.96),rgba(248,251,255,.92))!important;
  color:#0f172a!important;
  border:1px solid rgba(191,219,254,.95)!important;
  box-shadow:0 22px 52px rgba(15,23,42,.16),inset 0 1px 0 rgba(255,255,255,.88)!important;
  backdrop-filter:blur(18px)!important;
  font-weight:900!important;
  line-height:1.48!important;
  pointer-events:auto;
  transform:translateX(38px) scale(.96);
  opacity:0;
  animation:toastEnterV116 .58s cubic-bezier(.2,1,.22,1) forwards;
}
.app-flash-toast:before{
  content:"";
  position:absolute;
  left:0;top:0;bottom:0;width:7px;
  background:linear-gradient(180deg,#2563eb,#7c3aed,#ec4899);
}
.app-flash-toast:after{
  content:"";
  position:absolute;
  inset:-45% auto auto -20%;
  width:180px;height:180px;
  border-radius:999px;
  background:rgba(59,130,246,.14);
  filter:blur(10px);
  pointer-events:none;
}
.app-flash-toast.success:before{background:linear-gradient(180deg,#22c55e,#16a34a,#0f766e)}
.app-flash-toast.danger:before{background:linear-gradient(180deg,#ef4444,#dc2626,#991b1b)}
.app-flash-toast.warning:before,.app-flash-toast.warn:before{background:linear-gradient(180deg,#f59e0b,#f97316,#c2410c)}
.app-flash-toast.info:before{background:linear-gradient(180deg,#38bdf8,#2563eb,#4f46e5)}
.toast-icon-v116{
  position:absolute;
  left:17px;
  top:50%;
  transform:translateY(-50%);
  width:32px;height:32px;
  border-radius:14px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,#2563eb,#7c3aed);
  color:#fff;
  font-size:16px;
  box-shadow:0 12px 24px rgba(37,99,235,.24);
  z-index:2;
}
.app-flash-toast.success .toast-icon-v116{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 12px 24px rgba(34,197,94,.24)}
.app-flash-toast.danger .toast-icon-v116{background:linear-gradient(135deg,#ef4444,#dc2626);box-shadow:0 12px 24px rgba(239,68,68,.24)}
.app-flash-toast.warning .toast-icon-v116,.app-flash-toast.warn .toast-icon-v116{background:linear-gradient(135deg,#f59e0b,#f97316);box-shadow:0 12px 24px rgba(245,158,11,.24)}
.toast-close-v116{
  position:absolute;
  right:12px;
  top:12px;
  width:30px;height:30px;
  border:0;
  border-radius:12px;
  background:rgba(15,23,42,.08);
  color:#0f172a;
  display:grid;
  place-items:center;
  cursor:pointer;
  font-weight:1000;
  z-index:3;
}
.toast-close-v116:hover{background:rgba(15,23,42,.14)}
.toast-progress-v116{
  position:absolute;
  left:0;right:0;bottom:0;
  height:4px;
  transform-origin:left;
  background:linear-gradient(90deg,#2563eb,#7c3aed,#ec4899);
  animation:toastProgressV116 5.6s linear forwards;
  z-index:3;
}
.app-flash-toast.success .toast-progress-v116{background:linear-gradient(90deg,#22c55e,#16a34a,#0f766e)}
.app-flash-toast.danger .toast-progress-v116{background:linear-gradient(90deg,#ef4444,#dc2626,#991b1b)}
.app-flash-toast.warning .toast-progress-v116,.app-flash-toast.warn .toast-progress-v116{background:linear-gradient(90deg,#f59e0b,#f97316,#c2410c)}
.app-flash-toast.toast-hide-v116{animation:toastExitV116 .34s ease forwards!important}
.app-flash-toast.danger{animation:toastEnterV116 .58s cubic-bezier(.2,1,.22,1) forwards, toastShakeV116 .48s ease .18s}
@keyframes toastEnterV116{0%{opacity:0;transform:translateX(48px) translateY(-8px) scale(.94)}70%{opacity:1;transform:translateX(-4px) translateY(0) scale(1.015)}100%{opacity:1;transform:translateX(0) translateY(0) scale(1)}}
@keyframes toastExitV116{to{opacity:0;transform:translateX(46px) scale(.96)}}
@keyframes toastProgressV116{to{transform:scaleX(0)}}
@keyframes toastShakeV116{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}
html[data-theme="dark"] .app-flash-toast{
  background:linear-gradient(145deg,rgba(15,23,42,.96),rgba(17,24,39,.92))!important;
  color:#f8fafc!important;
  border-color:rgba(96,165,250,.28)!important;
  box-shadow:0 24px 60px rgba(0,0,0,.42),inset 0 1px 0 rgba(255,255,255,.07)!important;
}
html[data-theme="dark"] .toast-close-v116{background:rgba(255,255,255,.10);color:#f8fafc}
html[data-theme="dark"] .toast-close-v116:hover{background:rgba(255,255,255,.16)}
@media(max-width:800px){
  .toast-zone-v116{left:12px;right:12px;top:auto;bottom:16px;width:auto;gap:10px}
  .app-flash-toast{border-radius:20px!important;padding:15px 44px 15px 54px!important;font-size:13px!important;box-shadow:0 18px 42px rgba(15,23,42,.22)!important}
  .toast-icon-v116{left:15px;width:30px;height:30px;border-radius:12px}
  .toast-close-v116{right:10px;top:10px}
}


/* PATCH V119 - Perbaiki menu pengumuman admin */
.admin-announcement-page-v119{display:grid;gap:18px}
.admin-ann-hero-v119{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:24px;border-radius:30px;background:linear-gradient(135deg,#0f172a,#2563eb 55%,#7c3aed);color:#fff;box-shadow:0 26px 58px rgba(37,99,235,.18);border:1px solid rgba(255,255,255,.12)}
.admin-ann-hero-v119 span{display:inline-flex;gap:9px;align-items:center;padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.14);font-size:12px;font-weight:900;text-transform:uppercase;letter-spacing:.08em;color:#dbeafe}
.admin-ann-hero-v119 h1{margin:12px 0 8px;font-size:34px;line-height:1.05;letter-spacing:-.04em;color:#fff}
.admin-ann-hero-v119 p{margin:0;max-width:760px;color:#dbeafe;font-weight:700;line-height:1.6}
.admin-ann-count-v119{min-width:150px;text-align:center;padding:18px;border-radius:24px;background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.16)}
.admin-ann-count-v119 b{display:block;font-size:40px;line-height:1;color:#fff}.admin-ann-count-v119 small{display:block;margin-top:6px;color:#dbeafe;font-weight:900}
.admin-ann-grid-v119{align-items:start}.admin-ann-form-card-v119,.admin-ann-preview-card-v119,.admin-ann-list-card-v119{border-radius:28px}
.admin-ann-preview-v119{display:flex;gap:14px;align-items:flex-start;padding:18px;border-radius:22px;background:linear-gradient(135deg,#eff6ff,#f5f3ff);border:1px solid #dbeafe;margin-bottom:12px}
.admin-ann-preview-v119 .preview-icon{width:56px;height:56px;border-radius:18px;background:linear-gradient(135deg,#2563eb,#7c3aed);display:grid;place-items:center;color:#fff;font-size:24px;box-shadow:0 14px 28px rgba(37,99,235,.18)}
.admin-ann-preview-v119 b{display:block;font-size:18px;color:#0f172a}.admin-ann-preview-v119 p{margin:6px 0 0;color:#475569;line-height:1.55;font-weight:700}
.admin-ann-list-v119{display:grid;gap:12px}.admin-ann-item-v119{display:grid;grid-template-columns:92px 1fr auto;gap:14px;align-items:start;padding:14px;border:1px solid #dbeafe;border-radius:22px;background:linear-gradient(135deg,#ffffff,#f8fbff);box-shadow:0 12px 26px rgba(15,23,42,.05)}
.admin-ann-thumb-v119{width:92px;height:92px;border-radius:20px;overflow:hidden;background:linear-gradient(135deg,#dbeafe,#f5f3ff);display:grid;place-items:center;font-size:30px;border:1px solid #dbeafe}.admin-ann-thumb-v119 img{width:100%;height:100%;object-fit:cover}
.admin-ann-body-v119 b{display:block;font-size:17px;color:#0f172a}.admin-ann-body-v119 p{margin:6px 0 8px;color:#334155;line-height:1.55;font-weight:700}.admin-ann-body-v119 small{color:#64748b;font-weight:800}
.admin-ann-actions-v119{display:flex;gap:8px;flex-wrap:wrap;justify-content:flex-end}
html[data-theme="dark"] .admin-ann-preview-v119,html[data-theme="dark"] .admin-ann-item-v119{background:linear-gradient(180deg,#111827,#0f172a)!important;border-color:#334155!important;color:#f8fafc!important}
html[data-theme="dark"] .admin-ann-preview-v119 b,html[data-theme="dark"] .admin-ann-body-v119 b{color:#f8fafc!important}html[data-theme="dark"] .admin-ann-preview-v119 p,html[data-theme="dark"] .admin-ann-body-v119 p,html[data-theme="dark"] .admin-ann-body-v119 small{color:#cbd5e1!important}
@media(max-width:900px){.admin-ann-hero-v119{display:block}.admin-ann-count-v119{margin-top:16px}.admin-ann-item-v119{grid-template-columns:72px 1fr}.admin-ann-thumb-v119{width:72px;height:72px;border-radius:16px}.admin-ann-actions-v119{grid-column:1 / -1;justify-content:flex-start}.admin-ann-hero-v119 h1{font-size:28px}}

/* PATCH V122 - pilihan shift di portal karyawan */
.presence-shift-box-v122{margin-top:12px;display:grid;gap:6px}
.presence-shift-box-v122 label{font-size:12px;font-weight:800;opacity:.95;color:#e0ecff}
.presence-shift-select-v122{width:100%;appearance:none;-webkit-appearance:none;border:1px solid rgba(255,255,255,.26);border-radius:16px;padding:12px 14px;background:rgba(255,255,255,.16);color:#fff;font-weight:800;outline:none;box-shadow:inset 0 1px 0 rgba(255,255,255,.08)}
.presence-shift-select-v122 option{color:#0f172a}
.presence-shift-select-v122:focus{border-color:rgba(255,255,255,.55);background:rgba(255,255,255,.20)}
html[data-theme="dark"] .presence-shift-select-v122{background:rgba(255,255,255,.12)!important;color:#fff!important;border-color:rgba(255,255,255,.24)!important}
html[data-theme="dark"] .presence-shift-box-v122 label{color:#e6f0ff!important}
@media (max-width:480px){.presence-shift-select-v122{padding:11px 12px;font-size:13px}}

/* PATCH V123 - pengaturan absen sebelum jam masuk */
.shift-early-input-v123{display:grid;grid-template-columns:minmax(0,1fr) 118px;gap:8px;align-items:center}
.shift-early-input-v123 input,.shift-early-input-v123 select{height:44px}
.shift-early-input-v123 select{font-weight:800;background:#f8fbff}
html[data-theme="dark"] .shift-early-input-v123 select{background:#0f172a!important;color:#f8fafc!important;border-color:#334155!important}
@media(max-width:640px){.shift-early-input-v123{grid-template-columns:1fr}.shift-early-input-v123 select{width:100%}}

/* PATCH V126 - Kamera absen Face ID tampil seperti selfie (tidak terbalik bagi pengguna) */
.attendance-camera-stage-v99 video#selfieVideo,
.attendance-camera-stage-v99 #selfieVideo,
#selfieVideo{
  transform:scaleX(-1)!important;
  -webkit-transform:scaleX(-1)!important;
  transform-origin:center center!important;
}
.attendance-camera-stage-v99 img#selfiePreview,
.attendance-camera-stage-v99 #selfiePreview{
  transform:scaleX(-1)!important;
  -webkit-transform:scaleX(-1)!important;
  transform-origin:center center!important;
}
.faceid-register-page #faceIdVideo,
.faceid-register-page video#faceIdVideo{
  transform:scaleX(-1)!important;
  -webkit-transform:scaleX(-1)!important;
  transform-origin:center center!important;
}


/* PATCH V127 - Batas waktu absen masuk per shift */
.shift-window-box-v127{padding:14px;border-radius:18px;background:linear-gradient(135deg,#eff6ff,#f8fbff);border:1px dashed #93c5fd}
.shift-window-box-v127>.hint{margin-top:8px}
html[data-theme="dark"] .shift-window-box-v127{background:linear-gradient(135deg,#0f1e3a,#111827)!important;border-color:#334155!important}
html[data-theme="dark"] .shift-window-box-v127 .hint{color:#cbd5e1!important}


/* PATCH V128 - Menu Logout Portal Karyawan */
.presence-menu-grid-v99 i.bg7{
  background:linear-gradient(135deg,#ef4444,#f97316)!important;
  color:#fff!important;
  box-shadow:0 12px 22px rgba(239,68,68,.20)!important;
}
.presence-menu-grid-v99 a.logout-menu-v128{
  border-color:#fecaca!important;
  background:linear-gradient(180deg,#fff7ed,#fff1f2)!important;
}
.presence-menu-grid-v99 a.logout-menu-v128 b{color:#7f1d1d!important}
.presence-menu-grid-v99 a.logout-menu-v128 span{color:#991b1b!important}
.presence-menu-grid-v99 a.logout-menu-v128:hover{
  transform:translateY(-3px);
  box-shadow:0 18px 34px rgba(239,68,68,.14)!important;
}
html[data-theme="dark"] .presence-menu-grid-v99 a.logout-menu-v128{
  background:linear-gradient(180deg,#3a0a0a,#431407)!important;
  border-color:#7f1d1d!important;
}
html[data-theme="dark"] .presence-menu-grid-v99 a.logout-menu-v128 b,
html[data-theme="dark"] .presence-menu-grid-v99 a.logout-menu-v128 span{color:#fee2e2!important}
@media(max-width:480px){
  .presence-menu-grid-v99 a.logout-menu-v128{min-height:112px!important}
}


/* PATCH V130 - Menu Face ID Admin */
.admin-faceid-page-v130{display:grid;gap:16px}
.faceid-hero-v130{display:flex;align-items:center;justify-content:space-between;gap:18px;background:linear-gradient(135deg,#0f172a,#1d4ed8 52%,#7c3aed);color:#fff;border-radius:28px;overflow:hidden;position:relative}
.faceid-hero-v130:before{content:"";position:absolute;right:-80px;top:-100px;width:260px;height:260px;border-radius:50%;background:rgba(255,255,255,.14)}
.faceid-hero-v130>*{position:relative;z-index:1}.faceid-kicker-v130{display:inline-flex;gap:8px;align-items:center;text-transform:uppercase;letter-spacing:.12em;font-size:11px;font-weight:1000;color:#bfdbfe}.faceid-hero-v130 h2{margin:8px 0 8px;font-size:30px;color:#fff}.faceid-hero-v130 p{margin:0;color:#e0f2fe;max-width:760px;font-weight:700;line-height:1.65}.faceid-status-pill-v130{min-width:170px;border-radius:22px;padding:16px;text-align:center;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.12);backdrop-filter:blur(10px)}.faceid-status-pill-v130 b{display:block;font-size:22px}.faceid-status-pill-v130 span{display:block;margin-top:4px;font-size:12px;color:#dbeafe;font-weight:900}.faceid-status-pill-v130.off{background:rgba(239,68,68,.18)}
.faceid-stat-grid-v130{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.faceid-stat-v130{border-radius:24px;padding:18px;background:#fff;border:1px solid #dbeafe;box-shadow:0 18px 40px rgba(37,99,235,.09);position:relative;overflow:hidden}.faceid-stat-v130:after{content:"";position:absolute;right:-45px;top:-45px;width:120px;height:120px;border-radius:50%;background:var(--faceid-glow,rgba(59,130,246,.12))}.faceid-stat-v130 i{position:relative;z-index:1;width:46px;height:46px;border-radius:16px;display:grid;place-items:center;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;font-size:20px;margin-bottom:10px}.faceid-stat-v130 span{position:relative;z-index:1;display:block;color:#64748b;font-size:12px;font-weight:1000;text-transform:uppercase}.faceid-stat-v130 b{position:relative;z-index:1;display:block;margin-top:4px;font-size:28px;color:#0f172a}.faceid-stat-v130.green{--faceid-glow:rgba(34,197,94,.18)}.faceid-stat-v130.red{--faceid-glow:rgba(239,68,68,.16)}.faceid-stat-v130.purple{--faceid-glow:rgba(124,58,237,.16)}
.faceid-table-v130 table{min-width:980px}.faceid-thumb-v130{width:72px;height:72px;border-radius:20px;object-fit:cover;border:3px solid #fff;box-shadow:0 12px 24px rgba(15,23,42,.12)}.faceid-empty-v130{width:72px;height:72px;border-radius:20px;display:grid;place-items:center;background:#eef2ff;color:#64748b;font-size:28px;border:1px dashed #bfdbfe}.inline-actions{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
html[data-theme="dark"] .faceid-stat-v130{background:linear-gradient(180deg,#0f172a,#111827)!important;border-color:#334155!important;box-shadow:0 18px 40px rgba(0,0,0,.28)!important}html[data-theme="dark"] .faceid-stat-v130 b{color:#f8fafc!important}html[data-theme="dark"] .faceid-stat-v130 span{color:#cbd5e1!important}html[data-theme="dark"] .faceid-empty-v130{background:#111827!important;border-color:#334155!important;color:#94a3b8!important}
@media(max-width:900px){.faceid-hero-v130{display:grid}.faceid-stat-grid-v130{grid-template-columns:repeat(2,1fr)}}@media(max-width:520px){.faceid-stat-grid-v130{grid-template-columns:1fr}.faceid-hero-v130 h2{font-size:24px}.faceid-status-pill-v130{min-width:0;width:100%}}
