/* Lumera — cardholder cabinet (uses lumera-ui.css for tokens/buttons) */
body{background:#F4F5F7}
.cabtop{position:sticky;top:0;z-index:20;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.cabtop .in{max-width:960px;margin:0 auto;display:flex;align-items:center;gap:14px;height:64px;padding:0 24px}
.cabtop .logo{display:flex;align-items:center;gap:8px}
.cabtop .logo svg{height:26px;display:block}
.cabtop .logo .nm{font-weight:700;font-size:17px;letter-spacing:-.02em;color:var(--navy)}
.cabtop .who{margin-left:auto;display:flex;align-items:center;gap:12px;font-size:13.5px;color:#334155}
.av{width:34px;height:34px;border-radius:50%;background:var(--navy);color:#fff;display:grid;place-items:center;font-size:12.5px;font-weight:700}
.cab{max-width:960px;margin:0 auto;padding:28px 24px 70px}
.cab.narrow{max-width:600px}
.greet{font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:2px}
.greet+.sub{font-size:13.5px;color:var(--muted);margin-bottom:24px}
.back{display:inline-flex;align-items:center;gap:6px;font-size:13.5px;color:var(--muted);font-weight:500;margin-bottom:18px}
.back:hover{color:var(--navy)}
.ph{font-size:22px;font-weight:800;letter-spacing:-.02em;margin-bottom:4px}
.ph+.phsub{font-size:13.5px;color:var(--muted);margin-bottom:22px}

.row{display:grid;grid-template-columns:1.15fr 1fr;gap:22px;margin-bottom:22px}
.paycard{aspect-ratio:1.585;border-radius:18px;
  background:
    radial-gradient(120% 150% at 88% -15%, rgba(63,142,82,.30), transparent 46%),
    linear-gradient(135deg,#28344f 0%,#172139 46%,#0a1120 100%);
  color:#fff;padding:22px 24px;display:flex;flex-direction:column;justify-content:space-between;
  box-shadow:0 26px 52px -24px rgba(10,16,34,.78),inset 0 1px 0 rgba(255,255,255,.09);
  position:relative;overflow:hidden;font-variant-numeric:tabular-nums}
.paycard .pc-sheen{position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(105deg,transparent 32%,rgba(255,255,255,.10) 46%,transparent 60%)}
.pc-top{display:flex;align-items:flex-start;justify-content:space-between;position:relative;z-index:1}
.pc-brand{display:flex;align-items:center;gap:8px;font-weight:700;font-size:15px;letter-spacing:-.01em}
.pc-cl svg{width:22px;height:22px;display:block;stroke:rgba(255,255,255,.85);fill:none;stroke-width:2}
.pc-mid{position:relative;z-index:1}
.pc-chip{width:46px;height:35px;display:block}
.pc-num{font-size:20px;letter-spacing:.16em;position:relative;z-index:1;text-shadow:0 1px 2px rgba(0,0,0,.35)}
.pc-bot{display:flex;align-items:flex-end;justify-content:space-between;position:relative;z-index:1}
.pc-name{font-size:12.5px;letter-spacing:.08em;text-transform:uppercase;color:#dbe2ee}
.pc-exp{font-size:9.5px;letter-spacing:.1em;color:#9fb0c9;margin-top:3px}
.pc-net svg{height:30px;display:block}
.paycard.mini{aspect-ratio:auto;max-width:340px}

.balcard{border:1px solid var(--line);border-radius:18px;background:#fff;padding:22px;display:flex;flex-direction:column}
.balcard .lbl{font-size:12.5px;color:var(--muted)}
.balcard .amt{font-size:34px;font-weight:800;letter-spacing:-.02em;margin:4px 0 2px}
.balcard .cur{font-size:12.5px;color:var(--muted)}
.balcard .meta{margin-top:auto;display:flex;gap:8px;align-items:center;font-size:12px;color:var(--muted);padding-top:16px}
.pill-live{font-size:11px;font-weight:600;color:#2A5F38;background:var(--tint);padding:3px 9px;border-radius:999px}

.acts{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:26px}
.act{border:1px solid var(--line);border-radius:14px;background:#fff;padding:16px 12px;display:flex;flex-direction:column;align-items:center;gap:9px;text-align:center;cursor:pointer;transition:.16s;color:inherit}
.act:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:#D7DAE0}
.act .ico{width:42px;height:42px;border-radius:12px;background:var(--tint);display:grid;place-items:center;font-size:18px}
.act.primary .ico{background:var(--green);color:#fff}
.act .t{font-size:12.5px;font-weight:600;color:#334155}

.sec-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sec-h h3{font-size:16px;font-weight:700}
.sec-h a{font-size:12.5px;color:var(--green);font-weight:600}
.txbox{border:1px solid var(--line);border-radius:16px;background:#fff;overflow:hidden}
.tx{display:flex;align-items:center;gap:13px;padding:14px 18px;border-bottom:1px solid #F1F3F6}
.tx:last-child{border-bottom:0}
.tx .ic{width:36px;height:36px;border-radius:10px;background:#F1F5F9;display:grid;place-items:center;font-size:14px;color:#475569}
.tx .nm{font-size:14px;font-weight:500} .tx .sub{font-size:12px;color:var(--muted)}
.tx .amt{margin-left:auto;font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}
.amt.pos{color:#2A5F38} .amt.neg{color:#0F172A}

/* panels / sub-screens */
.panel-c{border:1px solid var(--line);border-radius:18px;background:#fff;padding:26px;margin-bottom:18px}
.panel-c h4{font-size:15px;font-weight:700;margin-bottom:4px}
.panel-c .hint{font-size:12.5px;color:var(--muted);margin-bottom:18px}
.pinbox{display:flex;align-items:center;justify-content:center;gap:14px;font-family:'JetBrains Mono',monospace;font-size:40px;font-weight:600;letter-spacing:.3em;color:var(--navy);background:var(--bg-soft);border:1px solid var(--line);border-radius:14px;padding:24px;margin-bottom:16px}
.seg{display:inline-flex;background:#EEF1F4;border-radius:10px;padding:3px;margin-bottom:18px}
.seg button{font-size:13px;font-weight:600;color:var(--muted);padding:7px 16px;border:0;background:transparent;border-radius:8px;cursor:pointer}
.seg button.on{background:#fff;color:var(--navy);box-shadow:0 1px 2px rgba(15,23,42,.1)}
.opts{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:20px}
.opt{border:1px solid var(--line);border-radius:14px;padding:20px;cursor:pointer;transition:.16s;background:#fff}
.opt:hover,.opt.sel{border-color:var(--green);box-shadow:var(--shadow)}
.opt .oi{font-size:24px;margin-bottom:10px}
.opt h5{font-size:14.5px;font-weight:700;margin-bottom:4px} .opt p{font-size:12.5px;color:var(--muted);line-height:1.5}
.ticket{display:flex;gap:12px;align-items:flex-start;padding:14px 0;border-bottom:1px solid #F1F3F6}
.ticket:last-child{border-bottom:0}
.ticket .st{margin-left:auto}
@media(max-width:760px){.row{grid-template-columns:1fr}.acts{grid-template-columns:repeat(3,1fr)}.opts{grid-template-columns:1fr}}

/* KYC banner + card controls */
.kyc{display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;font-size:13.5px;margin-bottom:22px}
.kyc.warn{background:#FEF3C7;border:1px solid #FDE68A;color:#92400E}
.kyc.ok{background:var(--tint);border:1px solid #D7E8CD;color:#2A5F38}
.kyc a{margin-left:auto;font-weight:600;color:inherit;text-decoration:underline;white-space:nowrap}
.cardctl{display:flex;gap:10px;margin:18px 0 8px;flex-wrap:wrap}
.cardctl button{font-size:13px;font-weight:600;padding:9px 14px;border-radius:10px;border:1px solid var(--line);background:#fff;color:#334155;cursor:pointer;display:inline-flex;gap:7px;align-items:center}
.cardctl button:hover{border-color:#CBD5E1;background:var(--bg-soft)}
.cardctl button.danger:hover{border-color:#FCA5A5;color:#B91C1C;background:#FEF2F2}

/* Lucide icons (replace emoji) */
.act .ico svg{width:22px;height:22px;stroke:var(--navy);stroke-width:1.85;fill:none}
.act.primary .ico svg{stroke:#fff}
.tx .ic svg{width:16px;height:16px;stroke:#475569;stroke-width:2;fill:none}
.cardctl button svg{width:16px;height:16px;stroke:currentColor;stroke-width:1.9;fill:none}
.opt .oi{line-height:0}
.opt .oi svg{width:26px;height:26px;stroke:var(--navy);stroke-width:1.7;fill:none}
.opt.sel .oi svg,.opt:hover .oi svg{stroke:var(--green)}

/* ── mobile polish (phones) ── */
@media(max-width:560px){
  .cabtop .in{padding:0 16px;gap:10px;height:58px}
  .cabtop .who{gap:9px;font-size:12.5px}
  .cab{padding:22px 16px 66px}
  .greet{font-size:20px} .greet+.sub{margin-bottom:20px}
  .ph{font-size:20px}
  .row{gap:16px;margin-bottom:18px}
  .paycard{padding:20px}
  .pc-num{font-size:18px;letter-spacing:.12em}
  .balcard{padding:20px} .balcard .amt{font-size:30px}
  .acts{gap:10px;margin-bottom:22px} .act{padding:14px 8px} .act .t{font-size:12px}
  .cardctl button{flex:1 1 auto;justify-content:center}
  .panel-c{padding:20px}
  .kyc{align-items:flex-start} .kyc a{white-space:normal}
}
@media(max-width:360px){
  .pc-num{font-size:16px;letter-spacing:.05em}
  .acts{grid-template-columns:repeat(2,1fr)}
}
