:root{--bg:#f6f8fc;--card:#fff;--line:#e5e7eb;--text:#101828;--muted:#667085;--primary:#0b5cff;--primary2:#14b8ff;--bank:linear-gradient(135deg,#17369e 0%,#0b5cff 58%,#08b2db 100%);--radius:24px;--shadow:0 18px 46px rgba(16,24,40,.12)}
*{box-sizing:border-box}body{margin:0;font-family:Inter,Arial,sans-serif;background:var(--bg);color:var(--text)}.hidden{display:none!important}h1,h2,h3,p{margin:0}.login-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:radial-gradient(circle at top right,#dbeafe 0,#f6f8fc 45%,#f6f8fc 100%)}.login-card{width:min(460px,100%);background:#fff;border-radius:32px;padding:32px;box-shadow:var(--shadow)}.brand-badge{width:68px;height:68px;border-radius:22px;display:grid;place-items:center;background:linear-gradient(135deg,#ff6b00,#ff9f0a);color:#fff;font-weight:900;font-size:28px;margin-bottom:16px}.brand-badge.mini{width:46px;height:46px;font-size:18px;border-radius:16px;margin:0}.login-card h1{font-size:32px}.login-card p{margin:6px 0 18px;color:var(--muted)}.form-stack,.form-grid{display:grid;gap:14px}.form-stack label,.form-grid label{display:grid;gap:8px;font-size:13px;font-weight:800;color:#344054}.form-stack input,.form-grid input,.form-grid select,.form-grid textarea,.search,select{width:100%;border:1px solid var(--line);border-radius:16px;padding:12px 14px;background:#fff;color:#101828}.form-grid textarea{min-height:90px;resize:vertical}.btn{border:0;cursor:pointer;padding:12px 16px;border-radius:16px;font-weight:900}.btn.primary{color:#fff;background:linear-gradient(135deg,#17369e,#0b5cff,#08b2db);box-shadow:0 10px 30px rgba(11,92,255,.25)}.btn.soft{background:#eff6ff;color:#0b5cff}.btn.danger{background:#fee2e2;color:#991b1b}.btn.danger:hover{background:#fecaca}.btn.light,.btn.ghost{background:#f3f4f6;color:#111827}.btn.full{width:100%}.app{min-height:100vh;display:grid;grid-template-columns:280px 1fr}.sidebar{background:#0f1020;color:#fff;padding:20px;position:sticky;top:0;height:100vh;display:flex;flex-direction:column;gap:18px}.logo-row{display:flex;align-items:center;gap:12px}.logo-row span{display:block;color:#a7a9bd;font-size:12px;margin-top:2px}.sidebar nav{display:grid;gap:8px}.nav-item{padding:13px 14px;border-radius:16px;color:#cfd2e6;text-decoration:none;display:flex;gap:10px;align-items:center;font-weight:800}.nav-item.active,.nav-item:hover{background:linear-gradient(135deg,rgba(37,99,235,.28),rgba(6,182,212,.20));color:#fff}.logout{margin-top:auto}.main{padding:24px 26px 110px}.topbar{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px}.topbar h2{font-size:30px}.topbar p{margin-top:5px;color:var(--muted)}.top-actions{display:flex;gap:10px;flex-wrap:wrap}.grid{display:grid;gap:16px}.grid.cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.grid.cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid.cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.card{background:var(--card);border:1px solid rgba(229,231,235,.9);border-radius:var(--radius);box-shadow:0 10px 28px rgba(17,24,39,.06);padding:18px}.dashboard-panels{display:grid;grid-template-columns:minmax(0,2fr) minmax(330px,1fr);gap:16px;margin-top:16px}.stat{position:relative;overflow:hidden;min-height:128px}.stat:after{content:"";position:absolute;right:-30px;top:-35px;width:110px;height:110px;border-radius:50%;background:linear-gradient(135deg,rgba(37,99,235,.12),rgba(6,182,212,.12))}.stat label{color:var(--muted);font-size:13px;font-weight:800;position:relative;z-index:1}.stat b{display:block;font-size:26px;margin-top:8px;position:relative;z-index:1}.stat small{color:var(--muted);position:relative;z-index:1}.bank-hero{position:relative;overflow:hidden;color:#fff;border:0;border-radius:30px;background:var(--bank);box-shadow:0 25px 60px rgba(37,99,235,.22);padding:24px;margin-bottom:18px}.bank-hero:before{content:"";position:absolute;right:-50px;top:-70px;width:210px;height:210px;border-radius:999px;background:rgba(255,255,255,.14)}.bank-hero:after{content:"";position:absolute;right:30px;bottom:-80px;width:180px;height:180px;border-radius:999px;background:rgba(255,255,255,.08)}.bank-hero>*{position:relative;z-index:1}.bank-hero-top{display:flex;align-items:center;justify-content:space-between;gap:14px}.bank-avatar{width:48px;height:48px;border-radius:18px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-weight:900}.bank-user{display:flex;align-items:center;gap:12px}.bank-user small{display:block;opacity:.78}.bank-hero h3{font-size:14px;margin:22px 0 8px;opacity:.82}.bank-amount{font-size:34px;font-weight:950;letter-spacing:-.03em}.bank-hero-row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px}.bank-mini{padding:12px;border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.12);border-radius:18px}.bank-mini span{display:block;font-size:11px;opacity:.78}.bank-mini b{display:block;margin-top:4px;font-size:15px}.quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin:0 0 16px}.quick-actions button{background:#fff;border:1px solid var(--line);border-radius:22px;padding:14px 8px;box-shadow:0 8px 20px rgba(16,24,40,.06);font-weight:850;color:#101828;cursor:pointer}.quick-actions i{display:grid;place-items:center;margin:0 auto 8px;width:42px;height:42px;border-radius:16px;background:#eff6ff;font-style:normal;font-size:20px}.quick-actions span{font-size:12px;display:block}.table-wrap{overflow:auto;border-radius:18px;border:1px solid var(--line);background:#fff}table{width:100%;border-collapse:collapse;background:#fff;min-width:860px}th,td{padding:12px 13px;border-bottom:1px solid var(--line);text-align:left;font-size:13px;vertical-align:top}th{background:#f9fafb;color:#4b5563;font-size:12px;text-transform:uppercase;letter-spacing:.04em}tr:hover td{background:#f8fbff}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 9px;font-size:12px;font-weight:800;background:#eef2ff;color:#3730a3}.pill.red{background:#fee2e2;color:#991b1b}.pill.amber{background:#fef3c7;color:#92400e}.pill.green{background:#d1fae5;color:#065f46}.toolbar{display:flex;gap:10px;align-items:center;justify-content:space-between;flex-wrap:wrap;margin-bottom:14px}.toolbar .left,.toolbar .right{display:flex;gap:10px;flex-wrap:wrap}.modal{position:fixed;inset:0;z-index:50;display:grid;place-items:center;padding:18px}.modal-backdrop{position:absolute;inset:0;background:rgba(15,16,32,.55);backdrop-filter:blur(8px)}.modal-box{position:relative;z-index:2;background:#fff;border-radius:28px;width:min(980px,96vw);max-height:92vh;overflow:auto;box-shadow:var(--shadow)}.modal-head{position:sticky;top:0;background:#fff;z-index:3;border-bottom:1px solid var(--line);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;border-radius:28px 28px 0 0}.modal-head h3{margin:0}.modal-head button{border:0;background:#f3f4f6;border-radius:12px;width:38px;height:38px;font-size:25px;cursor:pointer}.modal form{padding:18px 20px 22px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.form-grid .full{grid-column:1/-1}.calc-box{background:linear-gradient(135deg,#eff6ff,#ecfeff);border:1px solid #bfdbfe;border-radius:18px;padding:14px;display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.calc-box div{background:#fff;border-radius:14px;padding:12px}.calc-box span{display:block;color:var(--muted);font-size:12px;font-weight:800}.calc-box b{font-size:19px}.customer-detail{padding:18px 20px}.bottom-nav{display:none}.toast{position:fixed;top:18px;right:18px;background:#111827;color:#fff;padding:13px 16px;border-radius:16px;box-shadow:var(--shadow);z-index:100;max-width:340px}.toast.error{background:#991b1b}.toast.success{background:#065f46}.chart-card{height:330px}.empty{padding:28px;text-align:center;color:var(--muted)}small{color:var(--muted)}ul{padding-left:18px}li{margin-bottom:8px}
@media(max-width:980px){body{background:linear-gradient(180deg,#eaf2ff 0,#f6f8fc 210px,#f6f8fc 100%)}.app{display:block}.sidebar{display:none}.main{padding:0 14px 108px}.topbar{position:sticky;top:0;z-index:20;margin:0 -14px 14px;padding:14px 16px 10px;background:rgba(234,242,255,.88);backdrop-filter:blur(18px);display:flex;align-items:center}.topbar h2{font-size:22px}.topbar p{display:none}.top-actions{margin-left:auto}.top-actions .btn{font-size:0;width:42px;height:42px;border-radius:16px;padding:0}.top-actions .btn:before{font-size:20px}.top-actions .btn.soft:before{content:'＋'}.top-actions .btn.primary:before{content:'👤'}.bank-hero{margin-top:4px;border-radius:28px;padding:20px}.bank-amount{font-size:30px}.bank-hero-row{grid-template-columns:1fr 1fr 1fr;gap:8px}.bank-mini{padding:10px}.quick-actions{grid-template-columns:repeat(4,1fr);gap:9px}.quick-actions button{padding:12px 4px;border-radius:18px}.quick-actions i{width:38px;height:38px;border-radius:14px}.quick-actions span{font-size:11px}.grid.cols-4,.grid.cols-3,.grid.cols-2{grid-template-columns:1fr 1fr;gap:10px}.dashboard-panels{grid-template-columns:1fr;gap:12px}.card{border-radius:22px;padding:14px}.stat b{font-size:20px}.stat label{font-size:12px}.due-card-panel{width:100%;overflow:hidden}.bottom-nav{position:fixed;left:10px;right:10px;bottom:10px;background:rgba(255,255,255,.94);backdrop-filter:blur(22px);border:1px solid rgba(225,231,240,.88);box-shadow:0 18px 46px rgba(16,24,40,.16);display:grid;grid-template-columns:repeat(5,1fr);padding:7px 7px calc(7px + env(safe-area-inset-bottom));z-index:30;border-radius:24px}.bottom-nav a{display:grid;place-items:center;text-decoration:none;color:#7b8496;font-size:10px;font-weight:900;padding:7px 4px;border-radius:17px}.bottom-nav a span{font-size:20px;line-height:1}.bottom-nav a small{font-size:10px;margin-top:2px}.bottom-nav a.active{background:linear-gradient(135deg,#eff6ff,#ecfeff);color:#0b5cff}.form-grid{grid-template-columns:1fr}.calc-box{grid-template-columns:1fr}.modal{align-items:end;padding:0}.modal-box{width:100vw;max-height:92vh;border-radius:28px 28px 0 0}.modal-head{border-radius:28px 28px 0 0}.chart-card{height:300px}.table-wrap{border:0;overflow:visible;background:transparent}table{min-width:0;background:transparent}thead{display:none}tbody{display:grid;gap:12px}tr{display:block;background:#fff;border:1px solid var(--line);border-radius:22px;box-shadow:0 8px 22px rgba(16,24,40,.06);padding:12px}tr:hover td{background:transparent}td{display:flex;justify-content:space-between;gap:12px;border:0;padding:7px 4px;font-size:13px;text-align:right;align-items:flex-start}td:first-child{padding-top:0}td:last-child{padding-bottom:0;justify-content:flex-end;flex-wrap:wrap}td:before{content:'Thông tin';color:#667085;font-weight:850;text-align:left;min-width:86px}td:nth-child(1):before{content:'Mã/Ngày'}td:nth-child(2):before{content:'Khách'}td:nth-child(3):before{content:'Nội dung'}td:nth-child(4):before{content:'Chi tiết'}td:nth-child(5):before{content:'Giá trị'}td:nth-child(6):before{content:'Ngày/Phí'}td:nth-child(7):before{content:'Thao tác'}
}
@media(max-width:560px){.grid.cols-4,.grid.cols-3,.grid.cols-2{grid-template-columns:1fr 1fr}.toolbar{align-items:stretch}.toolbar .left,.toolbar .right{width:100%;display:grid;grid-template-columns:1fr auto}.toolbar input,.toolbar select{width:100%;min-width:0}.toolbar .right .btn{width:100%}.toolbar .right{grid-template-columns:1fr 1fr}.bank-hero-row{grid-template-columns:1fr}.quick-actions{grid-template-columns:repeat(4,1fr)}.chart-card{height:270px}.login-card{padding:26px;border-radius:28px}.modal form{padding-bottom:34px}.modal-submit .btn{width:100%}}
.logo-img{background:linear-gradient(135deg,#eaf6ff,#ffffff)!important;padding:6px;overflow:hidden}.logo-img img{width:100%;height:100%;object-fit:contain;display:block}.sidebar .logo-img{box-shadow:0 8px 20px rgba(0,0,0,.16)}
@media(max-width:980px){.bank-avatar{background:rgba(255,255,255,.22);background-image:url('logo.png');background-size:78%;background-repeat:no-repeat;background-position:center;color:transparent}.login-card .logo-img{width:86px;height:86px;margin-bottom:14px}}

/* Login center + replaceable background image */
.login-wrap{position:relative;isolation:isolate;min-height:100svh;padding:24px;display:grid;place-items:center;background:#edf6ff url('login-bg.jpg?v=1.2.0') center/cover no-repeat!important}.login-wrap:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(239,246,255,.78),rgba(255,255,255,.68),rgba(219,234,254,.78));z-index:-1}.login-card{margin:auto;text-align:center;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:500px}.login-card .logo-img{margin-left:auto;margin-right:auto;width:86px;height:86px;border-radius:28px}.login-card .form-stack{width:100%;max-width:410px;margin:0 auto;text-align:left}.login-card .form-stack .btn{text-align:center}.login-card small{display:block;text-align:center;line-height:1.25}.hp-field{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none!important}.security-note{font-size:12px;color:#667085;text-align:center;margin-top:10px}
@media(max-width:560px){.login-wrap{padding:16px;align-items:center}.login-card{min-height:auto;width:100%;padding:30px 22px;border-radius:32px}.login-card h1{font-size:30px}.login-card .logo-img{width:78px;height:78px}}

/* MPOS v9 - Due card notification bell */
.bell-btn{position:relative;width:48px;height:48px;border:0;border-radius:18px;background:#fff;color:#111827;box-shadow:0 10px 26px rgba(16,24,40,.10);display:grid;place-items:center;cursor:pointer;border:1px solid var(--line)}
.bell-icon{font-size:22px;display:block;transform-origin:50% 0%}.bell-btn.has-alert{background:linear-gradient(135deg,#fff7ed,#fff);border-color:#fed7aa}.bell-btn.has-alert .bell-icon{animation:bellRing 1.15s ease-in-out infinite;color:#f97316}.bell-count{position:absolute;right:-6px;top:-7px;min-width:23px;height:23px;padding:0 6px;border-radius:999px;background:#ef4444;color:#fff;font-size:12px;font-weight:950;display:grid;place-items:center;border:2px solid #fff;box-shadow:0 8px 16px rgba(239,68,68,.28)}
.nav-item{position:relative}.nav-badge{margin-left:auto;min-width:24px;height:24px;padding:0 7px;border-radius:999px;background:#ef4444;color:#fff;font-size:12px;font-weight:950;display:inline-grid;place-items:center}.bottom-nav a{position:relative}.bottom-badge{position:absolute;right:8px;top:2px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:#ef4444;color:#fff;font-size:10px;font-weight:950;display:grid;place-items:center;border:2px solid #fff}
@keyframes bellRing{0%,100%{transform:rotate(0)}10%{transform:rotate(16deg)}20%{transform:rotate(-14deg)}30%{transform:rotate(12deg)}40%{transform:rotate(-8deg)}50%{transform:rotate(5deg)}60%{transform:rotate(0)}}
@media(max-width:980px){.bell-btn{width:42px;height:42px;border-radius:16px}.bell-icon{font-size:20px}.bell-count{right:-5px;top:-6px;min-width:21px;height:21px;font-size:11px}.top-actions{align-items:center}}
