/* Asaan Pay portal theme — matches the landing design (Sora/Manrope, green #0E7A46) */
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:#F6FAF7;color:#0B1512;font-family:'Manrope',system-ui,sans-serif;-webkit-font-smoothing:antialiased}
a{text-decoration:none;color:inherit}
img{max-width:100%}
h1,h2,h3,h4{font-family:'Sora',sans-serif;letter-spacing:-0.02em;margin:0}
:focus-visible{outline:3px solid #E8A13A;outline-offset:2px;border-radius:8px}
::selection{background:#12995A;color:#fff}

/* ===== Shell ===== */
.shell{display:flex;min-height:100vh}
.sidebar{width:248px;flex-shrink:0;background:#08130E;color:#9DB6A9;display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow-y:auto}
.sidebar .brand{display:flex;align-items:center;gap:11px;padding:20px 20px 16px;border-bottom:1px solid #14231B}
.sidebar .brand .logo{width:38px;height:38px;border-radius:11px;background:linear-gradient(135deg,#16A55E,#0E7A46);display:flex;align-items:center;justify-content:center;flex-shrink:0}
.sidebar .brand b{font-family:'Sora',sans-serif;font-size:16px;color:#fff;display:block;line-height:1.1}
.sidebar .brand small{font-size:11px;color:#5A7267}
.sidebar nav{padding:14px 12px;display:flex;flex-direction:column;gap:3px;flex:1}
.sidebar nav .sec{font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:#4E6157;padding:14px 10px 6px;font-weight:700}
.sidebar nav a{display:flex;align-items:center;gap:11px;padding:10px 12px;border-radius:10px;font-size:14px;font-weight:500;color:#9DB6A9;transition:background .15s,color .15s}
.sidebar nav a:hover{background:#0E1F17;color:#fff}
.sidebar nav a.active{background:#0E7A46;color:#fff;font-weight:600}
.sidebar nav a svg{flex-shrink:0}
.sidebar .foot{padding:14px 16px;border-top:1px solid #14231B;font-size:12px;color:#4E6157}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{background:rgba(246,250,247,.9);backdrop-filter:blur(12px);border-bottom:1px solid #E2ECE6;padding:14px 28px;display:flex;align-items:center;gap:14px;position:sticky;top:0;z-index:20}
.topbar h1{font-size:19px;font-weight:700}
.topbar .spacer{flex:1}
.topbar .who{font-size:13px;color:#5A6B62;text-align:right;line-height:1.25}
.topbar .who b{color:#0B1512;font-size:13.5px}
.content{padding:26px 28px 60px;max-width:1200px;width:100%}

/* ===== Cards / grid ===== */
.card{background:#fff;border:1px solid #E2ECE6;border-radius:16px;padding:22px;margin-bottom:18px}
.card h3{font-size:16px;margin-bottom:4px}
.card .sub{color:#5A6B62;font-size:13px;margin:0 0 14px}
.grid{display:grid;gap:16px}
.grid.c2{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.grid.c3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr))}
.grid.c4{grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}
.stat{background:#fff;border:1px solid #E2ECE6;border-radius:16px;padding:18px 20px}
.stat .k{font-size:12.5px;color:#5A6B62;font-weight:600}
.stat .v{font-family:'Sora',sans-serif;font-weight:800;font-size:26px;margin-top:4px}
.stat .v small{font-size:14px;color:#5A6B62;font-weight:600}
.stat.dark{background:#08130E;border-color:#08130E;color:#fff}
.stat.dark .k{color:#8FD5AF}

/* ===== Tables ===== */
.table-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;padding:9px 12px;background:#E9F6EF;color:#0E7A46;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;border-bottom:1px solid #CDEBDA;white-space:nowrap}
.tbl td{padding:10px 12px;border-bottom:1px solid #EDF3EF;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl .r{text-align:right}
.tbl .mono{font-family:'JetBrains Mono',monospace;font-size:12px}

/* ===== Badges ===== */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;padding:4px 11px;border-radius:999px;white-space:nowrap}
.badge.green{background:#E9F6EF;color:#0E7A46;border:1px solid #CDEBDA}
.badge.amber{background:#FEF6E7;color:#96690D;border:1px solid #F3DFAE}
.badge.red{background:#FDECEA;color:#B3362A;border:1px solid #F5C9C3}
.badge.gray{background:#EFF3F0;color:#48564E;border:1px solid #DCE7E0}
.badge.dark{background:#08130E;color:#5FCB93;border:1px solid #08130E}

/* ===== Forms ===== */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;color:#39463F;margin-bottom:6px}
.input,select.input,textarea.input{width:100%;padding:10px 13px;border:1px solid #DCE7E0;border-radius:10px;font-family:inherit;font-size:14px;background:#fff;color:#0B1512}
.input:focus{border-color:#12995A;outline:none;box-shadow:0 0 0 3px rgba(18,153,90,.12)}
.hint{font-size:12px;color:#5A6B62;margin-top:5px}
.err{color:#B3362A;font-size:12.5px;margin-top:5px;font-weight:600}
.form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:12px}
.inline-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}
.inline-form .field{margin-bottom:0;flex:1;min-width:130px}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:10px;font-weight:600;font-size:14px;border:1px solid transparent;cursor:pointer;font-family:inherit;transition:background .15s,border-color .15s;white-space:nowrap}
.btn.primary{background:#0E7A46;color:#fff;box-shadow:0 6px 16px rgba(14,122,70,.22)}
.btn.primary:hover{background:#0B6339}
.btn.ghost{background:#fff;color:#0B1512;border-color:#DCE7E0}
.btn.ghost:hover{border-color:#12995A;color:#0E7A46}
.btn.danger{background:#fff;color:#B3362A;border-color:#F5C9C3}
.btn.danger:hover{background:#FDECEA}
.btn.dark{background:#08130E;color:#fff}
.btn.dark:hover{background:#031008}
.btn.sm{padding:6px 12px;font-size:12.5px;border-radius:8px}
.btn:disabled{opacity:.5;cursor:not-allowed}

/* ===== Flash ===== */
.flash{padding:13px 16px;border-radius:12px;font-size:14px;font-weight:600;margin-bottom:18px;display:flex;gap:10px;align-items:center}
.flash.success{background:#E9F6EF;color:#0E7A46;border:1px solid #CDEBDA}
.flash.error{background:#FDECEA;color:#B3362A;border:1px solid #F5C9C3}

/* ===== Tabs ===== */
.tabs{display:flex;gap:6px;border-bottom:1px solid #E2ECE6;margin-bottom:20px;flex-wrap:wrap}
.tabs a{padding:10px 16px;font-size:14px;font-weight:600;color:#5A6B62;border-bottom:2px solid transparent;margin-bottom:-1px}
.tabs a.active{color:#0E7A46;border-bottom-color:#0E7A46}

/* ===== Misc ===== */
.token-box{font-family:'JetBrains Mono',monospace;font-size:12.5px;background:#08130E;color:#8FD5AF;padding:13px 15px;border-radius:11px;word-break:break-all;line-height:1.55}
.muted{color:#5A6B62;font-size:13px}
.qr-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:14px}
.qr-card{border:1px solid #E6EEE9;border-radius:14px;padding:12px;text-align:center;background:#fff}
.qr-card img{width:100%;border-radius:9px;border:1px solid #EDF3EF}
.qr-card .amt{font-family:'Sora',sans-serif;font-weight:700;margin-top:8px}
.pagination{display:flex;gap:6px;flex-wrap:wrap;margin-top:16px;font-size:13.5px}
.pagination a,.pagination span{padding:7px 12px;border:1px solid #DCE7E0;border-radius:8px;background:#fff}
.pagination .active span,.pagination span[aria-current]{background:#0E7A46;color:#fff;border-color:#0E7A46}
.empty{padding:34px;text-align:center;color:#5A6B62;font-size:14px}
.divider{height:1px;background:#EDF3EF;margin:18px 0}
details.acc{border:1px solid #E6EEE9;border-radius:14px;margin-bottom:12px;background:#fff}
details.acc>summary{list-style:none;cursor:pointer;padding:15px 18px;display:flex;align-items:center;gap:12px;font-weight:600;font-size:14.5px}
details.acc>summary::-webkit-details-marker{display:none}
details.acc .body{padding:0 18px 18px;border-top:1px solid #EDF3EF;padding-top:14px}
code.k{font-family:'JetBrains Mono',monospace;font-size:12px;background:#E9F6EF;color:#0E7A46;padding:2px 7px;border-radius:6px}
pre.code{margin:0;padding:16px 18px;font-family:'JetBrains Mono',monospace;font-size:12.5px;line-height:1.65;color:#CFE6DA;background:#08130E;border-radius:12px;overflow-x:auto}
@media(max-width:900px){.sidebar{display:none}.content{padding:18px 14px 50px}}

/* ===== Auth pages ===== */
.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:radial-gradient(circle at 80% -10%,rgba(29,180,106,.14),rgba(29,180,106,0) 60%),#F6FAF7}
.auth-card{width:100%;max-width:430px;background:#fff;border:1px solid #E2ECE6;border-radius:20px;padding:34px;box-shadow:0 30px 70px rgba(11,21,18,.10)}
