:root{
    --bg:#f4f7fb;
    --ink:#172033;
    --muted:#718096;
    --primary:#00AEEF;
    --monik-pink:#EC008C;
    --monik-blue:#00AEEF;
    --sidebar:#111111;
    --panel:#ffffff;
    --line:#e6edf5;
    --radius:22px;
}
*{box-sizing:border-box}
body{background:var(--bg);color:var(--ink);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif}
a{text-decoration:none}
.app-shell{display:flex;min-height:100vh}
.sidebar{width:270px;background:linear-gradient(180deg,#111111,#1f1f1f);color:#fff;padding:22px 16px;position:fixed;left:0;top:0;bottom:0;overflow-y:auto}
.brand-box{display:flex;align-items:center;gap:12px;margin-bottom:24px;padding:12px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);border-radius:18px}
.brand-logo{width:46px;height:46px;display:grid;place-items:center;border-radius:16px;background:var(--monik-blue);font-size:24px;box-shadow:0 16px 40px rgba(0,174,239,.28)}
.brand-logo-img{width:52px;height:52px;object-fit:contain;border-radius:16px;background:#fff;padding:3px;box-shadow:0 14px 34px rgba(236,0,140,.18)}
.brand-title{font-size:21px;font-weight:900;letter-spacing:.4px}
.brand-subtitle{font-size:12px;color:#b9c3d5}
.sidebar-nav{gap:4px}
.sidebar-nav .nav-link{display:flex;align-items:center;gap:12px;color:#cbd5e1;border-radius:14px;padding:11px 12px;font-weight:650}
.sidebar-nav .nav-link:hover{background:rgba(255,255,255,.08);color:#fff}
.sidebar-nav .nav-link.active{background:#fff;color:#111827;box-shadow:0 14px 34px rgba(236,0,140,.22)}
.sidebar-nav .nav-link.active i{color:var(--monik-pink)}
.sidebar-nav .nav-link i{font-size:18px;width:22px;text-align:center}
.main-content{margin-left:270px;min-height:100vh;width:calc(100% - 270px)}
.topbar{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:24px 30px;background:rgba(244,247,251,.88);backdrop-filter:blur(16px);position:sticky;top:0;z-index:10;border-bottom:1px solid rgba(226,232,240,.8)}
.topbar h1{font-weight:900;font-size:28px;margin:0}
.topbar p{margin:3px 0 0;color:var(--muted)}
.user-pill{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;background:#fff;border:1px solid var(--line);box-shadow:0 8px 22px rgba(15,23,42,.06)}
.content-wrap{padding:24px 30px 40px}
.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:0 18px 50px rgba(15,23,42,.06);padding:22px}
.panel-title{font-size:18px;font-weight:900;margin-bottom:16px;display:flex;align-items:center;gap:8px}
.stat-card{border-radius:22px;padding:18px;color:#fff;min-height:150px;position:relative;overflow:hidden;box-shadow:0 18px 42px rgba(15,23,42,.12)}
.stat-card:after{content:"";position:absolute;width:120px;height:120px;right:-32px;bottom:-36px;border-radius:999px;background:rgba(255,255,255,.16)}
.stat-card i{font-size:28px;opacity:.9}
.stat-number{font-size:34px;font-weight:950;margin-top:16px;line-height:1}
.stat-label{font-weight:700;margin-top:7px;opacity:.94}
.stat-primary{background:linear-gradient(135deg,var(--monik-blue),#0077c8)}
.stat-info{background:linear-gradient(135deg,var(--monik-pink),#b4006c)}
.stat-success{background:linear-gradient(135deg,#16a34a,#15803d)}
.stat-warning{background:linear-gradient(135deg,#f59e0b,#d97706)}
.stat-danger{background:linear-gradient(135deg,#dc2626,#b91c1c)}
.stat-dark{background:linear-gradient(135deg,#334155,#0f172a)}
.table{--bs-table-bg:transparent}.table th{font-size:12px;text-transform:uppercase;color:#64748b;letter-spacing:.06em}.table td{vertical-align:middle}
.action-buttons .btn{margin-left:3px;margin-bottom:3px}.form-label{font-weight:750;color:#334155}.form-control,.form-select{border-radius:14px;border-color:#d8e1ee;padding:.68rem .85rem}.btn{border-radius:14px;font-weight:750}.btn-lg{border-radius:17px}.badge{border-radius:999px;padding:.48rem .72rem}.mini-bar{display:flex;justify-content:space-between;align-items:center;padding:11px 0;border-bottom:1px dashed #d9e3ef}.mini-bar:last-child{border-bottom:0}.mini-bar span{font-weight:700}.mini-bar strong{background:#e9f8ff;padding:4px 12px;border-radius:999px;color:#0077c8}.master-tile{display:block;height:100%;background:#fff;border:1px solid var(--line);border-radius:22px;padding:22px;box-shadow:0 18px 50px rgba(15,23,42,.06);color:var(--ink);transition:.2s}.master-tile:hover{transform:translateY(-3px);box-shadow:0 24px 60px rgba(15,23,42,.12)}.master-tile i{font-size:34px;color:var(--monik-pink)}.master-tile strong{display:block;font-size:19px;margin-top:14px}.master-tile span{display:block;color:var(--muted);margin-top:8px}.qr-reader{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:22px;padding:16px;min-height:320px}.batch-passport h2{font-weight:950;margin:0}.eyebrow{text-transform:uppercase;font-size:12px;letter-spacing:.12em;color:#64748b;font-weight:900}.info-box{background:#f8fafc;border:1px solid #e2e8f0;border-radius:18px;padding:15px}.info-box span{display:block;color:#64748b;font-size:13px;font-weight:800}.info-box strong{display:block;font-size:18px;margin-top:3px}.action-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.login-body{min-height:100vh;display:grid;place-items:center;background:radial-gradient(circle at 10% 10%,rgba(236,0,140,.16),transparent 32%),radial-gradient(circle at 90% 20%,rgba(0,174,239,.16),transparent 30%),linear-gradient(135deg,#fff,#f8fafc)}.login-card{width:min(440px,calc(100vw - 32px));background:#fff;border-radius:30px;padding:34px;box-shadow:0 30px 80px rgba(15,23,42,.16);border:1px solid #e8eef6}.login-logo{width:72px;height:72px;display:grid;place-items:center;border-radius:24px;background:var(--monik-blue);color:#fff;font-size:36px;margin-bottom:16px}
.login-logo-full{display:block;width:min(330px,100%);height:auto;margin:0 auto 20px;border-radius:18px}.login-card h1{font-weight:950;margin:0}.login-card p{color:#64748b}.login-hint{margin-top:16px;text-align:center;color:#64748b}.label-body{background:#eef2f7;padding:30px}.label-toolbar{display:flex;gap:8px;justify-content:center;margin-bottom:18px}.qr-label-card{width:330px;min-height:500px;margin:0 auto;background:#fff;border:2px solid #111827;border-radius:18px;padding:20px;text-align:center;box-shadow:0 20px 50px rgba(15,23,42,.15)}.label-brand{font-weight:950;letter-spacing:.12em;border-bottom:2px solid #111827;padding-bottom:8px;margin-bottom:5px;display:flex;align-items:center;justify-content:center;gap:8px}.label-brand img{width:38px;height:38px;object-fit:contain}.label-subbrand{font-size:12px;font-weight:800;margin-bottom:12px;color:#334155}.qr-label-card h1{font-size:23px;font-weight:950;margin:8px 0 12px}.label-meta{font-size:15px;margin:5px 0}.qrcode-box{display:inline-block;margin:18px auto 10px;padding:10px;border:1px solid #111827}
@media(max-width:992px){.sidebar{position:static;width:100%;height:auto}.app-shell{display:block}.main-content{margin-left:0;width:100%}.topbar{position:static;display:block}.user-pill{margin-top:12px;display:inline-flex}.content-wrap{padding:18px}.action-grid{grid-template-columns:1fr}}
@media print{body{background:#fff}.main-content{margin:0;width:100%}.content-wrap{padding:0}.panel{box-shadow:none;border:0;padding:0}.topbar,.sidebar,.d-print-none{display:none!important}.table{font-size:12px}.label-body{padding:0}.qr-label-card{box-shadow:none;margin:0;border-radius:0}}

.btn-primary{--bs-btn-bg:var(--monik-pink);--bs-btn-border-color:var(--monik-pink);--bs-btn-hover-bg:#c70078;--bs-btn-hover-border-color:#c70078;--bs-btn-active-bg:#b4006c;--bs-btn-active-border-color:#b4006c}
.text-primary{color:var(--monik-blue)!important}

/* MONIK Footer v2 - compact premium */
.app-footer{
    margin-top:30px;
}
.app-footer-inner{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:16px;
    padding:14px 18px;
    border:1px solid rgba(226,232,240,.95);
    border-radius:20px;
    background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(248,250,252,.96));
    box-shadow:0 14px 34px rgba(15,23,42,.055);
    position:relative;
    overflow:hidden;
}
.app-footer-inner:before{
    content:"";
    position:absolute;
    left:0;top:0;bottom:0;
    width:5px;
    background:linear-gradient(180deg,var(--monik-pink),var(--monik-blue));
}
.footer-brand-mini{
    display:flex;
    align-items:center;
    gap:11px;
    min-width:0;
}
.footer-mark{
    width:36px;
    height:36px;
    flex:0 0 36px;
    display:grid;
    place-items:center;
    border-radius:13px;
    color:#fff;
    background:linear-gradient(135deg,var(--monik-pink),var(--monik-blue));
    box-shadow:0 10px 24px rgba(236,0,140,.20);
}
.footer-brand-mini strong{
    display:block;
    color:var(--ink);
    font-size:13px;
    font-weight:950;
    letter-spacing:.02em;
    line-height:1.1;
}
.footer-brand-mini span{
    display:block;
    color:#64748b;
    font-size:12.5px;
    font-weight:700;
    margin-top:2px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
}
.footer-year{
    flex:0 0 auto;
    font-size:12.5px;
    font-weight:900;
    color:#475569;
    background:#f1f5f9;
    border:1px solid #e2e8f0;
    border-radius:999px;
    padding:7px 12px;
}
.login-body{
    align-content:center;
    gap:14px;
}
.login-footer-pro{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    gap:10px;
    width:min(440px,calc(100vw - 32px));
    padding:11px 14px;
    border-radius:999px;
    background:rgba(255,255,255,.76);
    border:1px solid rgba(226,232,240,.9);
    box-shadow:0 18px 40px rgba(15,23,42,.09);
    color:#64748b;
    font-size:12.5px;
    font-weight:750;
    backdrop-filter:blur(14px);
}
.login-footer-pro .footer-mark{
    width:30px;
    height:30px;
    flex-basis:30px;
    border-radius:11px;
}
.login-footer-pro strong{
    color:var(--ink);
    font-weight:950;
}
@media(max-width:576px){
    .app-footer-inner{align-items:flex-start;flex-direction:column;padding:14px 16px 14px 18px}
    .footer-year{align-self:flex-start}
    .footer-brand-mini span{white-space:normal}
    .login-footer-pro{border-radius:18px;text-align:center;line-height:1.35}
}


/* MONIK v1.1 Simple QR Flow */
.scan-box{border:1px dashed #cbd5e1;background:#f8fafc;border-radius:18px;padding:14px}
.qr-reader-compact{min-height:280px;border-radius:18px;background:#fff}
.form-text{font-size:12.5px;color:#64748b;font-weight:650}
