@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+TC:wght@300;400;500;700;900&family=JetBrains+Mono:wght@400;700&display=swap');
:root {
  --bg:#f0f4f8;
  --surface:#ffffff;
  --surface2:#f4f7fb;
  --border:#dde3ec;
  --accent:#2563eb;
  --accent-light:#eff4ff;
  --accent2:#0ea5e9;
  --teal:#0d9488;
  --text:#1a2335;
  --text2:#64748b;
  --danger:#ef4444;
  --warn:#f59e0b;
  --success:#10b981;
  --purple:#7c3aed;
  --r:12px;
}
*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent;}
body{background:var(--bg);color:var(--text);font-family:'Noto Sans TC',sans-serif;min-height:100vh;overflow-x:hidden;}

/* LOGIN */
#login-screen{
  min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px;
  background:radial-gradient(ellipse at 20% 10%,rgba(37,99,235,.06) 0%,transparent 50%),
             radial-gradient(ellipse at 85% 90%,rgba(14,165,233,.05) 0%,transparent 50%),
             var(--bg);
}
.login-brand{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.brand-icon{width:42px;height:42px;background:var(--accent);border-radius:11px;display:flex;align-items:center;justify-content:center;font-size:21px;color:#fff;}
.brand-name{font-size:24px;font-weight:900;letter-spacing:-.02em;color:var(--text);}
.brand-name span{color:var(--accent);}
.login-tagline{font-size:12px;color:var(--text2);margin-bottom:34px;letter-spacing:.06em;}
.login-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:28px 22px;width:100%;max-width:360px;box-shadow:0 4px 24px rgba(37,99,235,.07);}
.sec-title{font-size:11px;font-weight:700;letter-spacing:.15em;color:var(--text2);text-transform:uppercase;margin-bottom:12px;}
.inp-group{margin-bottom:14px;}
.inp-label{font-size:11px;color:var(--text2);margin-bottom:5px;display:block;letter-spacing:.05em;font-weight:600;}
.inp{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px 14px;font-size:15px;color:var(--text);font-family:inherit;outline:none;transition:border-color .2s,box-shadow .2s;}
.inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.btn-primary{width:100%;background:var(--accent);color:#fff;border:none;border-radius:12px;padding:14px;font-size:15px;font-weight:700;font-family:inherit;cursor:pointer;transition:opacity .2s,transform .1s;letter-spacing:.03em;}
.btn-primary:active{transform:scale(.98);opacity:.9;}
.demo-hint{text-align:center;margin-top:14px;font-size:11px;color:var(--text2);line-height:1.7;}
.demo-hint code{background:var(--accent-light);border:1px solid rgba(37,99,235,.2);border-radius:4px;padding:1px 6px;font-family:'JetBrains Mono',monospace;font-size:10px;color:var(--accent);font-weight:700;}

/* APP */
#app{display:none;flex-direction:column;min-height:100vh;}
.topbar{background:var(--surface);border-bottom:1px solid var(--border);padding:11px 16px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:100;box-shadow:0 1px 8px rgba(0,0,0,.06);}
.topbar-left{display:flex;align-items:center;gap:10px;}
.t-avatar{width:34px;height:34px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:17px;flex-shrink:0;}
.t-info{display:flex;flex-direction:column;}
.t-role{font-size:10px;color:var(--accent);font-weight:700;letter-spacing:.1em;text-transform:uppercase;}
.t-user{font-size:14px;font-weight:700;color:var(--text);}
.logout-btn{background:none;border:1px solid var(--border);color:var(--text2);font-size:11px;padding:6px 12px;border-radius:8px;cursor:pointer;font-family:inherit;transition:background .15s;}
.logout-btn:hover{background:var(--surface2);}
.main{flex:1;padding:16px;max-width:600px;margin:0 auto;width:100%;}

/* TABS */
.tabs{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none;}
.tabs::-webkit-scrollbar{display:none;}
.tab{background:var(--surface);border:1px solid var(--border);color:var(--text2);padding:8px 14px;border-radius:20px;font-size:13px;font-weight:500;cursor:pointer;white-space:nowrap;font-family:inherit;transition:all .18s;position:relative;}
.tab.active{background:var(--accent);color:#fff;border-color:var(--accent);font-weight:700;}
.tab .cnt{position:absolute;top:-4px;right:-4px;background:var(--danger);color:#fff;border-radius:10px;font-size:9px;font-weight:800;padding:1px 5px;min-width:16px;text-align:center;}

/* CASHBOX */
.cashbox-card{background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);border-radius:16px;padding:20px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 4px 20px rgba(37,99,235,.25);}
.cb-label{font-size:10px;color:rgba(255,255,255,.8);font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:3px;}
.cb-amount{font-size:30px;font-weight:900;font-family:'JetBrains Mono',monospace;color:#fff;}
.cb-sub{font-size:10px;color:rgba(255,255,255,.65);margin-top:2px;}
.cb-icon{font-size:32px;opacity:.7;}

/* STATS */
.stats-row{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;margin-bottom:16px;}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;box-shadow:0 1px 4px rgba(0,0,0,.04);}
.stat-label{font-size:10px;color:var(--text2);margin-bottom:3px;font-weight:600;}
.stat-val{font-size:20px;font-weight:900;font-family:'JetBrains Mono',monospace;}
.c-green{color:var(--success);} .c-orange{color:var(--warn);} .c-blue{color:var(--accent);} .c-red{color:var(--danger);}

/* CARD */
.req-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:16px;margin-bottom:10px;position:relative;overflow:hidden;box-shadow:0 1px 4px rgba(0,0,0,.04);}
.req-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;border-radius:3px 0 0 3px;}
.req-card.s-pending::before{background:var(--warn);}
.req-card.s-approved::before{background:var(--accent);}
.req-card.s-in-transit::before{background:var(--purple);}
.req-card.s-delivered::before{background:var(--teal);}
.req-card.s-store-signed::before{background:var(--purple);}
.req-card.s-completed::before{background:var(--border);}
.req-card.s-rejected::before{background:var(--danger);}
.card-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:8px;}
.card-id{font-size:10px;color:var(--text2);font-family:'JetBrains Mono',monospace;margin-bottom:1px;}
.card-store{font-size:16px;font-weight:700;color:var(--text);}
.card-amt{font-size:22px;font-weight:900;font-family:'JetBrains Mono',monospace;color:var(--accent);text-align:right;}
.s-pill{display:inline-flex;align-items:center;gap:4px;font-size:10px;font-weight:700;padding:3px 9px;border-radius:20px;letter-spacing:.04em;margin-top:2px;}
.s-pill.pending{background:#fef3c7;color:#d97706;}
.s-pill.approved{background:var(--accent-light);color:var(--accent);}
.s-pill.in-transit{background:#f5f3ff;color:var(--purple);}
.s-pill.delivered{background:#f0fdf4;color:var(--teal);}
.s-pill.completed{background:#f1f5f9;color:var(--text2);}
.s-pill.rejected{background:#fef2f2;color:var(--danger);}
.dot{width:5px;height:5px;border-radius:50%;background:currentColor;display:inline-block;}
.card-meta{display:flex;gap:12px;margin-bottom:10px;flex-wrap:wrap;}
.meta-i{font-size:11px;color:var(--text2);}
.meta-i span{color:var(--text);font-weight:500;}

/* TIMELINE */
.tl{margin-top:10px;padding-top:10px;border-top:1px solid var(--border);}
.tl-item{display:flex;gap:8px;margin-bottom:7px;align-items:flex-start;}
.tl-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0;margin-top:4px;}
.tl-dot.done{background:var(--success);}
.tl-dot.waiting{background:var(--border);}
.tl-txt{font-size:12px;color:var(--text2);}
.tl-who{color:var(--text);font-weight:600;}
.tl-time{font-size:10px;color:var(--text2);margin-top:1px;font-family:'JetBrains Mono',monospace;}

/* ACTIONS */
.divider{height:1px;background:var(--border);margin:12px 0;}
.card-actions{display:flex;gap:8px;flex-wrap:wrap;}
.btn-act{flex:1;min-width:90px;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:10px;border-radius:10px;font-size:12px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s;text-align:center;}
.btn-act:active{transform:scale(.97);}
.btn-act.green{background:#f0fdf4;border-color:#86efac;color:#16a34a;}
.btn-act.orange{background:#eff6ff;border-color:#93c5fd;color:var(--accent);}
.btn-act.pink{background:#f5f3ff;border-color:#c4b5fd;color:var(--purple);}
.btn-act.red{background:#fef2f2;border-color:#fca5a5;color:var(--danger);}

/* FORM */
.form-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:20px;margin-bottom:16px;box-shadow:0 1px 4px rgba(0,0,0,.04);}
.form-title{font-size:17px;font-weight:800;margin-bottom:18px;color:var(--text);}
select.inp{-webkit-appearance:none;appearance:none;}
.note-ta{width:100%;background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px;font-size:14px;color:var(--text);font-family:inherit;outline:none;resize:none;transition:border-color .2s,box-shadow .2s;min-height:68px;}
.note-ta:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);}

/* CASH BREAKDOWN */
.cash-section{background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:16px;}
.cash-section-hdr{display:flex;align-items:center;gap:8px;margin-bottom:12px;}
.cash-section-icon{font-size:18px;}
.cash-section-title{font-size:13px;font-weight:700;color:var(--text);}
.cash-section-sub{font-size:11px;color:var(--accent);font-weight:700;margin-left:auto;}
.denom-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;margin-bottom:10px;}
.denom-row:last-child{margin-bottom:0;}
.denom-label{display:flex;align-items:center;gap:6px;min-width:72px;}
.denom-coin{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;font-family:'JetBrains Mono',monospace;flex-shrink:0;}
.denom-coin.bills{border-radius:8px;width:42px;height:28px;font-size:10px;}
.denom-coin.c1{background:#e2e8f0;color:#64748b;}
.denom-coin.c5{background:#ede9fe;color:#7c3aed;}
.denom-coin.c10{background:#fef9c3;color:#ca8a04;}
.denom-coin.c50{background:#d1fae5;color:#059669;}
.denom-coin.bill{background:#dbeafe;color:var(--accent);}
.denom-val{font-size:11px;color:var(--text2);font-weight:600;}
.denom-inp-wrap{display:flex;align-items:center;}
.denom-stepper{background:var(--surface);border:1px solid var(--border);color:var(--text);width:34px;height:38px;font-size:18px;font-weight:700;font-family:inherit;cursor:pointer;transition:all .15s;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.denom-stepper:first-child{border-radius:8px 0 0 8px;}
.denom-stepper:last-child{border-radius:0 8px 8px 0;}
.denom-stepper:active{background:var(--surface2);}
.denom-num{width:52px;background:var(--surface);border:1px solid var(--border);border-left:none;border-right:none;color:var(--text);font-size:15px;font-weight:700;font-family:'JetBrains Mono',monospace;text-align:center;padding:8px 4px;outline:none;height:38px;}
.denom-num::-webkit-inner-spin-button,.denom-num::-webkit-outer-spin-button{-webkit-appearance:none;}
.denom-subtotal{font-size:12px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--text2);min-width:60px;text-align:right;}
.denom-subtotal.has-val{color:var(--accent);}

/* TOTAL BAR */
.total-bar{background:linear-gradient(135deg,var(--accent-light),#e0f2fe);border:1px solid #bfdbfe;border-radius:var(--r);padding:14px 16px;display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.total-bar-left{display:flex;flex-direction:column;}
.total-bar-label{font-size:10px;color:var(--accent);font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin-bottom:2px;}
.total-bar-detail{font-size:11px;color:var(--text2);}
.total-bar-amt{font-size:28px;font-weight:900;font-family:'JetBrains Mono',monospace;color:var(--accent);}

/* BREAKDOWN IN CARD */
.breakdown-list{display:flex;flex-direction:column;gap:4px;margin-top:8px;}
.bd-item{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:8px 10px;display:flex;justify-content:space-between;align-items:center;}
.bd-item .bd-k{font-size:11px;color:var(--text2);}
.bd-item .bd-v{font-size:12px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--text);}
.bd-item .bd-v.highlight{color:var(--accent);}
.bd-edit-qty{width:56px;padding:4px 6px;border:1px solid var(--border);border-radius:6px;text-align:center;font-size:13px;font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--text);background:var(--bg);-moz-appearance:textfield;}
.bd-edit-qty::-webkit-outer-spin-button,.bd-edit-qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.bd-edit-qty:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 2px rgba(59,130,246,.15);}

/* MODALS */
.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.5);backdrop-filter:blur(6px);z-index:200;display:none;align-items:center;justify-content:center;padding:20px;}
.modal-overlay.show{display:flex;}
.modal-card{background:var(--surface);border:1px solid var(--border);border-radius:20px;padding:26px;width:100%;max-width:340px;text-align:center;animation:mIn .28s cubic-bezier(.34,1.56,.64,1);box-shadow:0 20px 60px rgba(0,0,0,.15);max-height:90vh;display:flex;flex-direction:column;}
.modal-card .m-info{overflow-y:auto;flex:1;min-height:0;}
.modal-card .btn-row{flex-shrink:0;margin-top:16px;}
@keyframes mIn{from{transform:scale(.82);opacity:0;}to{transform:scale(1);opacity:1;}}
.m-title{font-size:18px;font-weight:800;margin-bottom:3px;color:var(--text);}
.m-sub{font-size:12px;color:var(--text2);margin-bottom:18px;}
.qr-wrap{background:#fff;border:2px solid var(--border);border-radius:14px;padding:14px;display:inline-block;margin-bottom:18px;}
.m-info{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:14px;text-align:left;}
.mi-row{display:flex;justify-content:space-between;font-size:13px;margin-bottom:4px;}
.mi-row:last-child{margin-bottom:0;}
.mi-row .k{color:var(--text2);} .mi-row .v{font-weight:600;color:var(--text);}
.btn-close{width:100%;background:var(--surface2);border:1px solid var(--border);color:var(--text);padding:12px;border-radius:10px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;}
.scan-hint-box{background:var(--surface2);border:2px dashed var(--border);border-radius:12px;padding:26px 16px;text-align:center;margin-bottom:14px;}
.sh-icon{font-size:36px;margin-bottom:6px;}
.sh-text{font-size:12px;color:var(--text2);}
.code-inp{width:100%;background:var(--surface2);border:2px solid var(--border);border-radius:10px;padding:13px;font-size:17px;font-weight:700;color:var(--accent);font-family:'JetBrains Mono',monospace;text-align:center;outline:none;letter-spacing:.08em;margin-bottom:12px;transition:border-color .2s;}
.code-inp:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(37,99,235,.1);}
.scan-preview{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:12px;text-align:left;display:none;}
.btn-row{display:flex;gap:8px;}

/* TOAST */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:11px 18px;font-size:13px;font-weight:600;z-index:999;transition:transform .3s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;display:flex;align-items:center;gap:8px;box-shadow:0 8px 32px rgba(0,0,0,.12);}
.toast.show{transform:translateX(-50%) translateY(0);}
.toast.success{border-color:#86efac;color:#16a34a;background:#f0fdf4;}
.toast.error{border-color:#fca5a5;color:var(--danger);background:#fef2f2;}
.empty{text-align:center;padding:50px 20px;color:var(--text2);}
.empty .e-icon{font-size:44px;margin-bottom:10px;opacity:.4;}
.empty .e-text{font-size:13px;}

/* ACCOUNTS */
.acc-form{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:18px;margin-bottom:14px;box-shadow:0 1px 4px rgba(0,0,0,.04);}
.acc-form-title{font-size:14px;font-weight:700;margin-bottom:14px;color:var(--text);}
.inp-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:10px;}
.acc-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin-bottom:8px;display:flex;align-items:center;gap:12px;box-shadow:0 1px 3px rgba(0,0,0,.03);}
.acc-avatar{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0;}
.acc-info{flex:1;min-width:0;}
.acc-name{font-size:15px;font-weight:700;color:var(--text);}
.acc-detail{font-size:11px;color:var(--text2);margin-top:2px;}
.acc-role-pill{font-size:10px;font-weight:700;padding:3px 8px;border-radius:20px;white-space:nowrap;}
.acc-role-pill.admin{background:#d1fae5;color:#065f46;}
.acc-role-pill.staff{background:#fef3c7;color:#92400e;}
.acc-role-pill.store{background:var(--accent-light);color:#1d4ed8;}
.acc-actions{display:flex;gap:6px;flex-shrink:0;}
.icon-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text2);width:32px;height:32px;border-radius:8px;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;}
.icon-btn:active{opacity:.7;}
.icon-btn.del{border-color:#fca5a5;color:var(--danger);background:#fef2f2;}
.acc-group-label{font-size:11px;font-weight:700;letter-spacing:.12em;color:var(--text2);text-transform:uppercase;margin:14px 0 8px;}

/* VAULT */
.vault-card{background:linear-gradient(135deg,var(--accent) 0%,var(--accent2) 100%);border-radius:16px;padding:20px;margin-bottom:14px;box-shadow:0 4px 20px rgba(37,99,235,.2);}
.vault-title{font-size:11px;color:rgba(255,255,255,.8);font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:4px;}
.vault-total{font-size:36px;font-weight:900;font-family:'JetBrains Mono',monospace;color:#fff;margin-bottom:2px;}
.vault-sub{font-size:11px;color:rgba(255,255,255,.65);}
.vault-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px;}
.vault-item{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;display:flex;align-items:center;gap:10px;}
.vault-item-coin{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:800;font-family:'JetBrains Mono',monospace;flex-shrink:0;}
.vault-item-coin.bill{border-radius:8px;background:#dbeafe;color:var(--accent);}
.vault-item-coin.c500{background:#f0fdf4;color:#16a34a;}
.vault-item-coin.c100{background:#fef9c3;color:#ca8a04;}
.vault-item-coin.c50{background:#d1fae5;color:#059669;}
.vault-item-coin.c10{background:#ede9fe;color:#7c3aed;}
.vault-item-coin.c5{background:#fce7f3;color:#db2777;}
.vault-item-coin.c1{background:#f1f5f9;color:#64748b;}
.vault-item-info{flex:1;min-width:0;}
.vault-item-label{font-size:11px;color:var(--text2);font-weight:600;}
.vault-item-qty{font-size:13px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--text);}
.vault-item-amt{font-size:11px;color:var(--accent);font-weight:700;font-family:'JetBrains Mono',monospace;}
.stocktake-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border);}
.stocktake-row:last-child{border-bottom:none;}
.st-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;}
.st-dot.ok{background:var(--success);}
.st-dot.diff{background:var(--danger);}
.topup-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:14px;}
.topup-item{background:var(--surface2);border:1px solid var(--border);border-radius:10px;padding:12px;}
.topup-item-label{font-size:11px;color:var(--text2);font-weight:600;margin-bottom:6px;}
.topup-inp{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:8px;padding:8px;font-size:16px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--text);text-align:center;outline:none;}
.topup-inp:focus{border-color:var(--accent);}
.log-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;}
.log-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px;}
.log-who{font-size:12px;font-weight:700;color:var(--text);}
.log-time{font-size:10px;color:var(--text2);font-family:'JetBrains Mono',monospace;}
.log-detail{font-size:11px;color:var(--text2);}
.log-amt{font-size:14px;font-weight:900;font-family:'JetBrains Mono',monospace;color:var(--success);}

/* PRINT */
@media print {
  body * { visibility: hidden !important; }
  #print-area, #print-area * { visibility: visible !important; }
  #print-area {
    position: fixed !important;
    inset: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    background: #fff !important;
    padding: 40px !important;
  }
}
#print-area { display: none; }
.print-store { font-size: 36px; font-weight: 900; color: #1a2335; margin-bottom: 6px; text-align: center; letter-spacing: -.01em; }
.print-id    { font-size: 14px; color: #64748b; margin-bottom: 24px; text-align: center; font-family: 'JetBrains Mono', monospace; letter-spacing: .08em; }
.print-qr    { background: #fff; border: 2px solid #dde3ec; border-radius: 14px; padding: 18px; }
.print-footer { font-size: 11px; color: #94a3b8; margin-top: 20px; text-align: center; }

/* ── Vault tabs (vault page + topup page switcher) ── */
.vault-tabs{display:flex;gap:8px;margin-bottom:16px;}
.vault-tab{flex:1;padding:10px 0;text-align:center;border-radius:10px;font-size:14px;font-weight:700;cursor:pointer;border:2px solid var(--border);background:var(--surface);color:var(--text2);transition:all .18s;}
.vault-tab.active{background:var(--accent);color:#fff;border-color:var(--accent);}

/* ── Vault selector on request cards ── */
.vault-selector{display:inline-flex;gap:3px;background:var(--surface2);border-radius:6px;padding:2px;margin-left:4px;}
.vault-opt{padding:2px 9px;border-radius:4px;font-size:11px;font-weight:700;cursor:pointer;color:var(--text2);transition:all .15s;}
.vault-opt.active{background:var(--accent);color:#fff;}
