:root{
  --bg:#0b1020;--bg2:#121933;--card:#ffffff;--soft:#eef3ff;--line:#d9e2f3;--text:#172033;--muted:#6c7892;--primary:#2f6cf6;--primary2:#6a8dff;--danger:#d34a4a;--success:#18a36c;
}
*{box-sizing:border-box} body{margin:0;font-family:Inter,Arial,sans-serif;background:linear-gradient(135deg,#0b1020,#17213f);color:var(--text)}
a{text-decoration:none;color:inherit}
.app-shell{display:grid;grid-template-columns:280px 1fr;min-height:100vh}
.sidebar{background:rgba(6,10,25,.9);padding:24px;border-right:1px solid rgba(255,255,255,.08);color:#fff}
.brand-card{display:flex;align-items:center;gap:14px;padding:16px;border-radius:22px;background:rgba(255,255,255,.08);backdrop-filter:blur(10px);margin-bottom:20px}
.brand-logo{width:54px;height:54px;border-radius:18px;background:linear-gradient(135deg,var(--primary),#8db0ff);display:grid;place-items:center;font-weight:700;overflow:hidden}
.brand-logo img{width:100%;height:100%;object-fit:cover}
.brand-title{font-weight:700}.brand-sub{font-size:12px;opacity:.8}
.nav-links{display:flex;flex-direction:column;gap:8px}
.nav-links a{padding:12px 14px;border-radius:14px;color:#dfe8ff}
.nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.12);color:#fff}
.main-content{padding:28px}
.topbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;color:#fff}
.topbar h1{margin:0 0 4px;font-size:28px}
.topbar p{margin:0;color:#c8d2ef}
.topbar-tag,.pill{padding:8px 12px;border-radius:999px;background:rgba(255,255,255,.12);color:#fff;font-size:13px}
.grid{display:grid;gap:18px}.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.span-1{grid-column:span 1}.span-2{grid-column:span 2}.span-3{grid-column:span 3}
.card{background:var(--card);border-radius:24px;padding:20px;box-shadow:0 22px 60px rgba(0,0,0,.16)}
.metric{display:flex;flex-direction:column;gap:8px}
.metric span{color:var(--muted);font-size:14px}.metric strong{font-size:30px}
.section-head{display:flex;justify-content:space-between;align-items:center;gap:14px;margin-bottom:14px}
.section-head h2{margin:0;font-size:20px}
.stack{display:flex;flex-direction:column}.gap-12{gap:12px}
label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
input,select,textarea{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--line);background:#fff;color:var(--text);outline:none}
input:focus,select:focus,textarea:focus{border-color:var(--primary);box-shadow:0 0 0 4px rgba(47,108,246,.12)}
.btn{display:inline-flex;align-items:center;justify-content:center;padding:11px 14px;border-radius:14px;border:none;cursor:pointer;font-weight:600}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary2));color:#fff}
.btn-soft{background:var(--soft);color:var(--primary)}
.btn-danger{background:#fff0f0;color:var(--danger)}
.actions{display:flex;gap:8px;flex-wrap:wrap}
.table-wrap{overflow:auto}
table{width:100%;border-collapse:collapse}
th,td{padding:12px;border-bottom:1px solid #edf1f8;text-align:left;vertical-align:top}
th{font-size:13px;color:var(--muted);white-space:nowrap}
.muted{color:var(--muted)}
.flash,.error-box,.helper-box{padding:14px 16px;border-radius:16px;margin-bottom:16px}
.flash{background:#eaf6ef;color:#10794d}.error-box{background:#fff0f0;color:#9a2c2c}.helper-box{background:#eff5ff;color:#31559b}
.login-body,.portal-body{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#0b1020,#18254d)}
.login-wrap{width:min(100%,440px);padding:24px}
.login-card{background:rgba(255,255,255,.96);padding:28px;border-radius:28px;box-shadow:0 30px 80px rgba(0,0,0,.25)}
.glass{backdrop-filter:blur(10px)}
.link-muted{color:var(--muted);text-align:center}
.brand-preview{min-height:240px;display:grid;place-items:center;border-radius:24px;background:linear-gradient(135deg,#eaf1ff,#ffffff);gap:10px;padding:20px;text-align:center}
.brand-preview img{max-width:120px;max-height:120px;border-radius:20px}
.payslip{display:flex;flex-direction:column;gap:16px}
.payslip-head{display:flex;justify-content:space-between;gap:14px;align-items:center}
.brand-mini{display:flex;gap:12px;align-items:center}
.brand-mini img{width:56px;height:56px;border-radius:16px;object-fit:cover}
.mini-card{border:1px solid #ebeff8;border-radius:20px;padding:16px}
.mini-card h4{margin:0 0 12px}
.line{display:flex;justify-content:space-between;gap:12px;padding:8px 0;border-bottom:1px dashed #e8ecf6}
.line.total{font-weight:700}
.netpay-box{background:linear-gradient(135deg,#102857,#1d4fd7);border-radius:24px;padding:22px;color:#fff;display:flex;justify-content:space-between;align-items:center}
.netpay-box strong{font-size:28px}
.portal-shell{width:min(1150px,100%);padding:24px}
.portal-top{display:flex;justify-content:space-between;align-items:center;color:#fff;margin-bottom:18px}
.portal-actions{display:flex;gap:10px;align-items:center}
.compact{gap:14px}
@media print{
  .sidebar,.topbar,.section-head .btn,.section-head .actions,.portal-top .btn{display:none !important}
  body{background:#fff}
  .app-shell{display:block}
  .main-content,.portal-shell{padding:0}
  .card{box-shadow:none;border-radius:0}
}
@media (max-width:1100px){
  .app-shell{grid-template-columns:1fr}
  .sidebar{display:none}
  .cols-4{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width:760px){
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .span-2,.span-3{grid-column:span 1}
  .topbar,.portal-top,.payslip-head{flex-direction:column;align-items:flex-start}
}

textarea{min-height:110px;resize:vertical}
.actions form{display:flex;gap:8px;flex-wrap:wrap;align-items:center}

.badge{display:inline-flex;padding:6px 10px;border-radius:999px;background:#eff5ff;color:#31559b;font-size:12px;font-weight:600}.code-box{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;background:#0f172a;color:#e2e8f0;padding:14px 16px;border-radius:16px;overflow:auto}.list-clean{margin:0;padding-left:18px}.split{display:flex;justify-content:space-between;gap:16px;align-items:center}.hint-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.text-right{text-align:right}.nowrap{white-space:nowrap}@media (max-width:760px){.hint-grid{grid-template-columns:1fr}}


.mobile-hero{background:linear-gradient(135deg,#ffffff,#edf4ff);border-radius:26px;padding:22px;box-shadow:0 22px 60px rgba(0,0,0,.14)}
.mobile-hero h1{margin:4px 0 10px;font-size:32px}
.mobile-hero p{margin:0;color:var(--muted)}
.hero-kicker{font-size:12px;letter-spacing:.08em;text-transform:uppercase;color:var(--primary);font-weight:700}
.hero-badges{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}
.tracker-card{display:flex;flex-direction:column;gap:10px}
.btn-xl{width:100%;min-height:58px;font-size:18px;border-radius:18px}
.tracker-status{margin-top:10px;font-size:13px;color:var(--muted)}
.compact-stack{align-items:stretch}
input[disabled],button[disabled]{opacity:.6;cursor:not-allowed}
@media (max-width:1100px){.main-content{padding:18px}.portal-shell{padding:18px}}
@media (max-width:760px){
  body{font-size:15px}
  .login-wrap,.portal-shell,.main-content{padding:14px}
  .login-card,.card,.mobile-hero{border-radius:22px;padding:16px}
  .topbar h1,.mobile-hero h1{font-size:24px}
  .metric strong{font-size:24px}
  .portal-actions,.actions{width:100%}
  .portal-actions .btn,.actions .btn{flex:1 1 calc(50% - 8px)}
  .btn{min-height:48px}
  .table-wrap table{min-width:680px}
}

.camera-wrap{display:flex;flex-direction:column;gap:10px}
.camera-preview,.camera-canvas{width:100%;max-height:320px;border-radius:20px;background:#0f172a;object-fit:cover}
.camera-canvas{display:none}
.alert-item{display:flex;justify-content:space-between;gap:14px;padding:14px 16px;border-radius:18px;margin-bottom:10px;background:#f6f8fc;border:1px solid #e7edf7}
.alert-item.warning{background:#fff4e8;border-color:#ffd8a8}
.alert-item.info{background:#eef5ff;border-color:#d5e4ff}
@media (max-width:760px){.alert-item{flex-direction:column}.camera-actions .btn{flex:1 1 100%}}
