/* ═══════════════════════════════════════════════════════
   ClariPay v5 — Unified Design System
   Fintech Dark · Glassmorphism · Premium Mobile
   ═══════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:ital,wght@0,400;0,500;0,600;0,700;0,800;1,400&family=Sora:wght@600;700;800&display=swap');

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
*{-webkit-tap-highlight-color:transparent;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}

/* ── TOKENS ── */
:root{
  --bg:   #04071A;
  --bg2:  #070D24;
  --bg3:  #0B1330;
  --bg4:  #0F1A3E;

  --g1:rgba(255,255,255,.03);
  --g2:rgba(255,255,255,.06);
  --g3:rgba(255,255,255,.10);
  --g4:rgba(255,255,255,.15);
  --gb: rgba(255,255,255,.07);
  --gb2:rgba(255,255,255,.04);

  --blue:  #1D4ED8;
  --blue2: #2563EB;
  --blue3: #3B82F6;
  --blue4: #60A5FA;
  --blue5: #93C5FD;
  --cyan:  #06B6D4;
  --cyan2: #22D3EE;
  --green: #10B981;
  --green2:#34D399;
  --red:   #EF4444;
  --red2:  #F87171;
  --gold:  #D97706;
  --gold2: #F59E0B;
  --gold3: #FCD34D;
  --violet:#6D28D9;
  --violet2:#8B5CF6;
  --teal:  #0D9488;
  --teal2: #14B8A6;

  --text:  #F0F6FF;
  --text2: #7A9CC5;
  --text3: #3E5A7A;
  --text4: #1E3050;

  --r-xs:8px;--r-sm:12px;--r-md:14px;--r-lg:18px;--r-xl:22px;--r-2xl:28px;--r-f:9999px;

  --tf:120ms cubic-bezier(.4,0,.2,1);
  --tb:220ms cubic-bezier(.4,0,.2,1);
  --ts:320ms cubic-bezier(.34,1.56,.64,1);
  --te:380ms cubic-bezier(.22,1,.36,1);
}

/* ── BASE ── */
html,body{height:100%;height:100dvh;overflow:hidden}
body{font-family:'Plus Jakarta Sans',sans-serif;background:var(--bg);color:var(--text);display:flex;justify-content:center}

/* ── APP SHELL ── */
#app{
  width:100%;max-width:430px;height:100%;background:var(--bg);
  display:flex;flex-direction:column;position:relative;overflow:hidden;
}

/* ── AMBIENT ORBS ── */
.amb{position:fixed;inset:0;pointer-events:none;z-index:0;overflow:hidden}
.amb::before{
  content:'';position:absolute;top:-20vh;left:-20vw;
  width:70vw;height:70vw;max-width:340px;max-height:340px;
  background:radial-gradient(ellipse,rgba(29,78,216,.16) 0%,transparent 65%);
  animation:ambA 16s ease-in-out infinite alternate;
}
.amb::after{
  content:'';position:absolute;bottom:-20vh;right:-20vw;
  width:60vw;height:60vw;max-width:300px;max-height:300px;
  background:radial-gradient(ellipse,rgba(6,182,212,.10) 0%,transparent 65%);
  animation:ambB 19s ease-in-out infinite alternate;
}
@keyframes ambA{from{transform:translate(0,0) scale(1)}to{transform:translate(32px,-24px) scale(1.1)}}
@keyframes ambB{from{transform:translate(0,0) scale(1)}to{transform:translate(-24px,32px) scale(1.08)}}

/* ── PAGE ENTER ── */
.page-enter{animation:pgIn .32s var(--te) both}
@keyframes pgIn{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}

/* ── SCROLL AREA ── */
.scroll-area{
  flex:1;overflow-y:auto;overflow-x:hidden;
  -webkit-overflow-scrolling:touch;scrollbar-width:none;
  padding-bottom:max(88px,calc(68px + env(safe-area-inset-bottom)));
}
.scroll-area::-webkit-scrollbar{display:none}

/* ── BOTTOM NAV ── */
.bnav{flex-shrink:0;display:flex;align-items:center;background:rgba(4,7,26,.97);backdrop-filter:blur(32px);-webkit-backdrop-filter:blur(32px);border-top:1px solid rgba(255,255,255,.08);padding:6px 0 max(16px,env(safe-area-inset-bottom));min-height:62px}
.ni{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;padding:5px 2px;text-decoration:none;color:rgba(255,255,255,.25);font-size:9.5px;font-weight:700;letter-spacing:.2px;transition:color .15s;position:relative}
.ni i{font-size:22px;display:block;line-height:1.1;margin-bottom:1px}
.ni:active i{transform:scale(.85)}
.ni.on{color:#60A5FA}
.ni.on i{filter:drop-shadow(0 0 7px rgba(96,165,250,.65))}
.ni-c{flex:0 0 66px;display:flex;justify-content:center;align-items:flex-start;padding-top:0}
.ni-fab{width:50px;height:50px;border-radius:15px;background:linear-gradient(145deg,#1D4ED8,#0891B2);display:flex;align-items:center;justify-content:center;margin-top:-14px;border:3px solid #04071A;box-shadow:0 6px 22px rgba(37,99,235,.55);transition:transform .2s,box-shadow .2s}
.ni-c:active .ni-fab{transform:scale(.88);box-shadow:0 2px 10px rgba(37,99,235,.3)}
.ni-fab i{font-size:20px;color:#fff}

/* ── PAGE HEADER (sub-pages) ── */
.phdr{
  flex-shrink:0;display:flex;align-items:center;gap:12px;
  padding:13px 17px;
  background:rgba(4,7,26,.92);
  backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
  border-bottom:1px solid rgba(255,255,255,.05);
  position:relative;z-index:10;
}
.phdr-back{
  width:36px;height:36px;flex-shrink:0;border-radius:11px;
  background:var(--g2);border:1px solid var(--gb2);
  display:flex;align-items:center;justify-content:center;
  color:var(--text2);font-size:14px;text-decoration:none;
  transition:all var(--tf);
}
.phdr-back:active{background:var(--g3);transform:scale(.9)}
.phdr-title{font-size:17px;font-weight:800;color:var(--text);font-family:'Sora',sans-serif;flex:1}
.phdr-sub{font-size:10px;color:var(--text3);margin-top:1px}
.phdr-action{
  width:34px;height:34px;border-radius:10px;
  background:var(--g1);border:1px solid var(--gb2);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);font-size:13px;text-decoration:none;
  transition:all var(--tf);cursor:pointer;
}
.phdr-action:active{background:var(--g2);transform:scale(.92)}

/* ── GLASS CARDS ── */
.card{background:var(--g2);border:1px solid var(--gb);border-radius:var(--r-xl);overflow:hidden}
.card-p{padding:14px 16px}

/* ── BUTTONS ── */
.btn{
  display:flex;align-items:center;justify-content:center;gap:7px;
  padding:13px 18px;border:none;border-radius:var(--r-md);
  font-family:'Plus Jakarta Sans',sans-serif;font-size:13px;font-weight:700;
  cursor:pointer;transition:all var(--tb);width:100%;
  position:relative;overflow:hidden;
}
.btn:active{transform:scale(.97)}
.btn:disabled{opacity:.4;cursor:not-allowed;transform:none!important}
.btn-primary{
  background:linear-gradient(135deg,var(--blue2) 0%,var(--blue3) 60%,var(--cyan) 100%);
  color:#fff;box-shadow:0 6px 22px rgba(37,99,235,.4);
}
.btn-primary:active{box-shadow:0 2px 10px rgba(37,99,235,.3)}
.btn-glass{background:var(--g2);border:1.5px solid var(--gb);color:var(--text2)}
.btn-glass:active{background:var(--g3)}
.btn-danger{background:rgba(239,68,68,.1);border:1.5px solid rgba(239,68,68,.2);color:var(--red2)}
.btn-sm{padding:8px 16px;font-size:12px;border-radius:var(--r-sm);width:auto}

/* ── INPUTS ── */
.field{margin-bottom:13px}
.field label{display:block;font-size:9.5px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1.1px;margin-bottom:6px}
.field input,.field textarea,.field select{
  width:100%;padding:12px 14px;
  background:var(--g1);border:1.5px solid var(--gb);border-radius:var(--r-sm);
  font-size:14px;font-weight:500;color:var(--text);
  font-family:'Plus Jakarta Sans',sans-serif;outline:none;
  transition:border-color var(--tf),background var(--tf);
}
.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--blue3);background:rgba(37,99,235,.05)}
.field input::placeholder,.field textarea::placeholder{color:var(--text3)}
.field textarea{resize:none;line-height:1.6}
.field select option{background:#0B1330;color:var(--text)}

/* ── CHIPS ── */
.chip{display:inline-flex;align-items:center;gap:4px;padding:6px 13px;border-radius:var(--r-f);font-size:11px;font-weight:700;background:var(--g2);border:1.5px solid var(--gb);color:var(--text3);cursor:pointer;transition:all var(--tf);white-space:nowrap}
.chip.on,.chip:active{background:rgba(37,99,235,.18);border-color:rgba(59,130,246,.45);color:var(--blue4)}

/* ── BADGES ── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--r-f);font-size:9px;font-weight:800;letter-spacing:.5px;text-transform:uppercase;line-height:1.4}
.bg-green{background:rgba(16,185,129,.12);color:var(--green2);border:1px solid rgba(16,185,129,.2)}
.bg-amber{background:rgba(245,158,11,.12);color:var(--gold2);border:1px solid rgba(245,158,11,.2)}
.bg-red{background:rgba(239,68,68,.12);color:var(--red2);border:1px solid rgba(239,68,68,.2)}
.bg-blue{background:rgba(96,165,250,.12);color:var(--blue4);border:1px solid rgba(96,165,250,.2)}
.bg-gold{background:rgba(217,119,6,.12);color:var(--gold3);border:1px solid rgba(217,119,6,.2)}
/* legacy aliases */
.badge-green{background:rgba(16,185,129,.12);color:var(--green2);border:1px solid rgba(16,185,129,.2)}
.badge-amber{background:rgba(245,158,11,.12);color:var(--gold2);border:1px solid rgba(245,158,11,.2)}
.badge-red{background:rgba(239,68,68,.12);color:var(--red2);border:1px solid rgba(239,68,68,.2)}
.badge-blue{background:rgba(96,165,250,.12);color:var(--blue4);border:1px solid rgba(96,165,250,.2)}
.badge-gold{background:rgba(217,119,6,.12);color:var(--gold3);border:1px solid rgba(217,119,6,.2)}

/* ── ALERTS ── */
.alert-err{background:rgba(239,68,68,.07);border:1.5px solid rgba(239,68,68,.2);border-radius:var(--r-sm);padding:10px 13px;font-size:12px;color:var(--red2);font-weight:500;display:none}
.alert-err.show{display:block}
.alert-ok{background:rgba(16,185,129,.07);border:1.5px solid rgba(16,185,129,.2);border-radius:var(--r-sm);padding:10px 13px;font-size:12px;color:var(--green2);font-weight:500;display:none}
.alert-ok.show{display:block}

/* ── SPINNERS ── */
.spin{display:inline-block;width:15px;height:15px;border:2px solid rgba(255,255,255,.18);border-top-color:#fff;border-radius:50%;animation:sp .6s linear infinite;vertical-align:middle;flex-shrink:0}
.spin-lg{display:block;width:32px;height:32px;border:2.5px solid var(--g2);border-top-color:var(--blue3);border-radius:50%;animation:sp .6s linear infinite;margin:40px auto}
@keyframes sp{to{transform:rotate(360deg)}}

/* ── SKELETON ── */
.skel{background:linear-gradient(90deg,var(--g1) 25%,var(--g3) 50%,var(--g1) 75%);background-size:200% 100%;animation:sk 1.5s infinite;border-radius:8px}
@keyframes sk{0%{background-position:200% 0}100%{background-position:-200% 0}}
.skel-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--gb2)}
.skel-row:last-child{border-bottom:none}
.skel-c{width:42px;height:42px;border-radius:13px;flex-shrink:0}
.skel-la{height:11px;border-radius:6px;width:55%;margin-bottom:6px}
.skel-lb{height:9px;border-radius:5px;width:35%}

/* ── EMPTY STATE ── */
.empty-state{display:flex;flex-direction:column;align-items:center;padding:44px 24px;text-align:center}
.empty-state-ico{font-size:44px;margin-bottom:12px;opacity:.65}
.empty-state-title{font-size:14px;font-weight:700;color:var(--text2);margin-bottom:4px}
.empty-state-sub{font-size:12px;color:var(--text3);line-height:1.6}

/* ── TOAST ── */
.toast{position:fixed;bottom:100px;left:50%;transform:translateX(-50%) translateY(12px);background:var(--bg3);border:1px solid var(--gb);backdrop-filter:blur(24px);border-radius:var(--r-md);padding:10px 20px;font-size:12px;font-weight:700;color:var(--text);white-space:nowrap;z-index:400;opacity:0;pointer-events:none;transition:all var(--tb)}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

/* ── MODAL ── */
.modal-overlay{position:fixed;inset:0;background:rgba(2,5,18,.82);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);z-index:250;display:none;align-items:flex-end;justify-content:center}
.modal-overlay.show{display:flex;animation:moIn .2s ease both}
@keyframes moIn{from{opacity:0}to{opacity:1}}
.modal-sheet{
  width:100%;max-width:430px;
  background:linear-gradient(180deg,var(--bg3),var(--bg4));
  border:1px solid var(--gb);
  border-radius:22px 22px 0 0;
  padding:8px 20px max(24px,env(safe-area-inset-bottom));
  transform:translateY(100%);
  transition:transform .4s var(--te);
}
.modal-overlay.show .modal-sheet{transform:translateY(0)}
.modal-handle{width:32px;height:3.5px;border-radius:2px;background:var(--g3);margin:0 auto 18px}
.modal-title{font-size:16px;font-weight:800;color:var(--text);margin-bottom:4px;font-family:'Sora',sans-serif}
.modal-sub{font-size:12px;color:var(--text3);line-height:1.6;margin-bottom:14px}

/* ── SECTION LABEL ── */
.slbl{display:flex;align-items:center;gap:10px;padding:16px 18px 8px;font-size:9.5px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:1.3px}
.slbl::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.05)}

/* ── PULL TO REFRESH ── */
.ptr{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px;font-size:12px;color:var(--text3);font-weight:600;overflow:hidden;max-height:0;transition:max-height var(--tb)}
.ptr.active{max-height:56px}

/* ── UTILITIES ── */
.mb-8{margin-bottom:8px}.mb-12{margin-bottom:12px}.mb-16{margin-bottom:16px}
.px-18{padding-left:18px;padding-right:18px}
.hidden{display:none!important}
.z1{position:relative;z-index:1}
