@import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@500;700&display=swap');

/* ═══════════════════════════════════════════════════════════════
   Electrik.NG — Authenticated Customer Layout
   (nav, page shell, dashboard, pay flows, transactions, profile)
   ═══════════════════════════════════════════════════════════════ */

/* ── Sticky nav ── */
.nav {
  position: sticky;
  top: 0;
  z-index: 50;
  height: 64px;
  background: #111827;
  border-bottom: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 1px 3px rgba(0,0,0,.25);
}
.nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 24px;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.nav-logo { display: flex; align-items: center; gap: 9px; }
.nav-logo-mark {
  width: 32px; height: 32px;
  background: var(--blue);
  border-radius: 8px;
  display: grid; place-items: center;
}
.nav-logo-mark svg { width: 16px; height: 16px; }
.nav-wordmark {
  font-family: var(--font-h);
  font-size: 1.05rem;
  font-weight: 800;
  color: #fff;
  letter-spacing: -.02em;
}

/* Nav links */
.nav-links { display: flex; gap: 2px; }
.nav-link {
  padding: 6px 14px;
  border-radius: 7px;
  font-size: .88rem;
  font-weight: 500;
  color: rgba(255,255,255,.65);
  transition: all var(--ease);
}
.nav-link:hover { color: #fff; background: rgba(255,255,255,.1); }
.nav-link.active { color: #fff; background: rgba(255,255,255,.15); font-weight: 600; }

/* Nav right */
.nav-right { display: flex; align-items: center; gap: 12px; }

/* Notification bell */
.notif-btn {
  position: relative;
  width: 38px; height: 38px;
  border-radius: 8px;
  background: transparent;
  display: grid; place-items: center;
  color: rgba(255,255,255,.65);
  transition: all var(--ease);
}
.notif-btn:hover { background: rgba(255,255,255,.1); color: #fff; }
.notif-badge {
  position: absolute;
  top: 6px; right: 6px;
  width: 16px; height: 16px;
  border-radius: 50%;
  background: var(--red);
  color: #fff;
  font-size: 9px;
  font-weight: 800;
  display: grid; place-items: center;
  border: 2px solid #111827;
}

/* Avatar dropdown */
.avatar-btn { position: relative; }
.avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: var(--blue);
  color: #fff;
  font-size: .82rem;
  font-weight: 800;
  display: grid; place-items: center;
  cursor: pointer;
  border: 2px solid var(--blue-m);
}
.avatar-dropdown {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: 220px;
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 12px;
  box-shadow: var(--shadow-md);
  padding: 6px;
  z-index: 200;
  transform-origin: top right;
}
/* Alpine x-transition helpers */
.dd-enter         { transition: opacity .15s ease, transform .15s ease; }
.dd-enter-start   { opacity: 0; transform: scale(.95) translateY(-4px); }
.dd-enter-end     { opacity: 1; transform: scale(1)   translateY(0); }
.dd-user {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 4px;
}
.dd-name { font-size: .86rem; font-weight: 700; color: var(--gray-900); }
.dd-email { font-size: .75rem; color: var(--gray-400); margin-top: 1px; }
.dd-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: .85rem;
  color: var(--gray-700);
  transition: background var(--ease);
}
.dd-item:hover { background: var(--gray-100); }
.dd-item.danger { color: var(--red); }
.dd-sep { height: 1px; background: var(--border); margin: 4px 0; }

/* Hamburger + mobile nav */
.hamburger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  padding: 6px;
  cursor: pointer;
}
.hamburger span {
  display: block;
  width: 22px; height: 2px;
  background: rgba(255,255,255,.8);
  border-radius: 1px;
  transition: .25s;
}
.mobile-nav {
  display: none;
  position: fixed;
  inset: 0;
  top: 64px;
  background: var(--white);
  z-index: 49;
  padding: 16px;
  flex-direction: column;
  gap: 4px;
  border-top: 1px solid var(--border);
}
.mobile-nav.open { display: flex; }
.mobile-nav a {
  padding: 12px 16px;
  border-radius: 8px;
  font-size: .95rem;
  font-weight: 500;
  color: var(--gray-700);
}
.mobile-nav a:hover { background: var(--gray-100); }

/* ── Page shell ── */
.page-wrap { max-width: 1200px; margin: 0 auto; padding: 32px 24px 64px; }

/* ── Page header ── */
.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px;
  flex-wrap: wrap;
  gap: 12px;
}
.greeting h1 {
  font-family: var(--font-h);
  font-size: 1.45rem;
  font-weight: 800;
  color: var(--gray-900);
  letter-spacing: -.02em;
}
.greeting p { font-size: .88rem; color: var(--gray-500); margin-top: 3px; }
.btn-pay {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 42px; padding: 0 20px;
  background: var(--blue);
  color: #fff;
  border-radius: 8px;
  font-size: .88rem;
  font-weight: 700;
  transition: all var(--ease);
}
.btn-pay:hover {
  background: var(--blue-d);
  box-shadow: 0 4px 14px rgba(26,86,160,.3);
  transform: translateY(-1px);
}

/* ── KPI row (customer) ── */
.kpi-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-bottom: 24px; }
.kpi-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 20px 22px;
  box-shadow: var(--shadow-sm);
  transition: box-shadow var(--ease);
}
.kpi-card:hover { box-shadow: var(--shadow-md); }
.kpi-label {
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  color: var(--gray-400);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}
.kpi-icon { width: 28px; height: 28px; border-radius: 7px; display: grid; place-items: center; font-size: .85rem; }
.kpi-value {
  font-family: var(--font-h);
  font-size: 1.8rem;
  font-weight: 800;
  color: var(--gray-900);
  line-height: 1;
  margin-bottom: 6px;
}
.kpi-delta {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: .76rem;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 100px;
}
.kpi-delta.up { background: var(--green-l); color: var(--green); }
.kpi-delta.neutral { background: var(--gray-100); color: var(--gray-500); }
.kpi-sub { font-size: .78rem; color: var(--gray-400); margin-top: 4px; }

/* ── Dashboard grid ── */
.main-grid { display: grid; grid-template-columns: 2fr 1fr; gap: 20px; margin-bottom: 20px; }

/* ── Transaction table ── */
.tx-table { width: 100%; border-collapse: collapse; }
.tx-table thead th {
  padding: 10px 20px;
  font-size: .72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--gray-400);
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.tx-table tbody tr {
  border-bottom: 1px solid var(--border);
  transition: background var(--ease);
  cursor: pointer;
}
.tx-table tbody tr:last-child { border-bottom: none; }
.tx-table tbody tr:hover { background: var(--surface); }
.tx-table td { padding: 13px 20px; font-size: .85rem; vertical-align: middle; }
.tx-cat-icon {
  width: 32px; height: 32px;
  border-radius: 8px;
  display: grid; place-items: center;
  font-size: .9rem;
  flex-shrink: 0;
}
.tx-cat-icon.prepaid { background: var(--blue-l); }
.tx-cat-icon.postpaid { background: var(--amber-l); }
.tx-cell-main { display: flex; align-items: center; gap: 10px; }
.tx-disco { font-weight: 600; color: var(--gray-900); }
.tx-ref { font-size: .74rem; color: var(--gray-400); margin-top: 1px; }
.tx-amount { font-weight: 700; color: var(--gray-900); }
.card-footer-link {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 14px;
  border-top: 1px solid var(--border);
  font-size: .84rem;
  font-weight: 600;
  color: var(--blue);
  transition: background var(--ease);
}
.card-footer-link:hover { background: var(--blue-l); }

/* ── Quick-pay ── */
.qp-list { display: flex; flex-direction: column; gap: 8px; padding: 16px 20px; }
.qp-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: 10px;
  border: 1px solid var(--border);
  transition: all var(--ease);
  cursor: pointer;
}
.qp-item:hover { border-color: var(--blue); background: var(--blue-l); }
.qp-icon {
  width: 36px; height: 36px;
  border-radius: 9px;
  display: grid; place-items: center;
  flex-shrink: 0;
}
.qp-label { font-size: .85rem; font-weight: 600; color: var(--gray-800); flex: 1; }
.qp-sub { font-size: .76rem; color: var(--gray-400); }
.qp-arrow { color: var(--gray-300); transition: color var(--ease); }
.qp-item:hover .qp-arrow { color: var(--blue); }

/* ── Token display ── */
.token-box {
  background: var(--gray-900);
  color: var(--green-m);
  font-family: 'Courier New', monospace;
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: .15em;
  padding: 18px 24px;
  border-radius: 12px;
  text-align: center;
  margin: 20px 0;
}

/* ── Pay flow cards ── */
.pay-shell { max-width: 680px; margin: 40px auto; padding: 0 20px 80px; }
.pay-card {
  background: var(--white);
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-md);
  overflow: hidden;
}
.pay-card-header { padding: 28px 32px 0; }
.pay-card-body { padding: 24px 32px 32px; }
.pay-step-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: .75rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--blue);
  background: var(--blue-l);
  padding: 4px 12px;
  border-radius: 100px;
  margin-bottom: 12px;
}
.pay-title {
  font-family: var(--font-h);
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--gray-900);
  letter-spacing: -.02em;
  margin-bottom: 4px;
}
.pay-sub { font-size: .88rem; color: var(--gray-500); margin-bottom: 24px; }
.verify-result {
  display: none;
  background: var(--green-l);
  border: 1px solid var(--green-m);
  border-radius: 10px;
  padding: 12px 16px;
  margin-bottom: 18px;
  gap: 10px;
  align-items: center;
}
.verify-result.show { display: flex; }
.verify-name { font-size: .88rem; font-weight: 700; color: #065F46; }
.verify-addr { font-size: .8rem; color: #047857; }

/* Summary row */
.summary-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  font-size: .88rem;
}
.summary-row:last-of-type { border-bottom: none; }
.summary-label { color: var(--gray-500); }
.summary-value { font-weight: 600; color: var(--gray-900); }
.summary-total { font-size: 1rem; font-weight: 800; color: var(--blue); }
.summary-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 16px 20px;
  margin-bottom: 20px;
}

/* Disco grid */
.disco-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: 12px;
}
.disco-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 20px 16px;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  background: var(--white);
  cursor: pointer;
  transition: all var(--ease);
  text-align: center;
}
.disco-card:hover { border-color: var(--blue); box-shadow: 0 4px 16px rgba(26,86,160,.12); transform: translateY(-2px); }
.disco-logo {
  width: 52px; height: 52px;
  border-radius: 12px;
  object-fit: contain;
  background: var(--gray-100);
  display: grid; place-items: center;
}
.disco-name { font-size: .82rem; font-weight: 700; color: var(--gray-800); }
.disco-code { font-size: .73rem; color: var(--gray-400); }

/* ── Transaction list (full page) ── */
.filter-bar {
  /*display: flex;*/
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-bottom: 20px;
}
.filter-bar .input { height: 38px; max-width: 200px; }
.filter-bar select.input { max-width: 160px; }

/* ── Profile page ── */
.profile-grid { display: grid; grid-template-columns: 280px 1fr; gap: 24px; }
.profile-card { border-radius: var(--radius-lg); }
.profile-avatar-wrap { display: flex; flex-direction: column; align-items: center; padding: 32px 24px 24px; border-bottom: 1px solid var(--border); }
.profile-avatar-lg {
  width: 80px; height: 80px;
  border-radius: 50%;
  background: var(--blue);
  color: #fff;
  font-family: var(--font-h);
  font-size: 1.6rem;
  font-weight: 800;
  display: grid; place-items: center;
  margin-bottom: 14px;
  border: 3px solid var(--blue-m);
}
.profile-name { font-size: 1rem; font-weight: 700; color: var(--gray-900); }
.profile-email { font-size: .82rem; color: var(--gray-400); margin-top: 2px; }

/* ── Responsive ── */
@media (max-width: 900px) {
  .nav-links { display: none; }
  .hamburger { display: flex; }
  .kpi-row { grid-template-columns: 1fr 1fr; }
  .main-grid { grid-template-columns: 1fr; }
  .profile-grid { grid-template-columns: 1fr; }
}
@media (max-width: 600px) {
  .kpi-row { grid-template-columns: 1fr; }
  .page-wrap { padding: 20px 16px 48px; }
  .pay-card-header, .pay-card-body { padding-left: 20px; padding-right: 20px; }
}


/* ---- Customer Dashboard ---- */
/* ── Page shell ── */


/* ── Page header ── */
.greeting h1{font-family:var(--font-h);font-size:1.45rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;}
.greeting p{font-size:.88rem;color:var(--gray-500);margin-top:3px;}
.btn-pay{display:inline-flex;align-items:center;gap:8px;height:42px;padding:0 20px;background:var(--blue);color:#fff;border-radius:8px;font-size:.88rem;font-weight:700;transition:all var(--ease);}
.btn-pay:hover{background:var(--blue-d);box-shadow:0 4px 14px rgba(26,86,160,.3);transform:translateY(-1px);}

/* ── KPI row ── */
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.kpi-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow-sm);transition:box-shadow var(--ease);}
.kpi-card:hover{box-shadow:var(--shadow-md);}
.kpi-label{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:10px;display:flex;align-items:center;gap:6px;}
.kpi-icon{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;font-size:.85rem;}
.kpi-value{font-family:var(--font-h);font-size:1.8rem;font-weight:800;color:var(--gray-900);line-height:1;margin-bottom:6px;}
.kpi-delta{display:inline-flex;align-items:center;gap:4px;font-size:.76rem;font-weight:600;padding:3px 8px;border-radius:100px;}
.kpi-delta.neutral{background:var(--gray-100);color:var(--gray-500);}
.kpi-sub{font-size:.78rem;color:var(--gray-400);margin-top:4px;}

/* ── Main grid ── */
.main-grid{display:grid;grid-template-columns:2fr 1fr;gap:20px;margin-bottom:20px;}

/* ── Card base ── */
.card{background:var(--white);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;}
.card-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 0;}
.card-title-sm{font-size:.9rem;font-weight:700;color:var(--gray-900);}
.card-link{font-size:.8rem;font-weight:600;color:var(--blue);display:flex;align-items:center;gap:4px;transition:opacity var(--ease);}
.card-link:hover{opacity:.7;}

/* ── Transaction table ── */
.tx-table{width:100%;border-collapse:collapse;}
.tx-table thead th{padding:10px 20px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);text-align:left;border-bottom:1px solid var(--border);}
.tx-table tbody tr{border-bottom:1px solid var(--border);transition:background var(--ease);cursor:pointer;}
.tx-table tbody tr:last-child{border-bottom:none;}
.tx-table tbody tr:hover{background:var(--surface);}
.tx-table td{padding:13px 20px;font-size:.85rem;vertical-align:middle;}
.tx-cat-icon{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;font-size:.9rem;flex-shrink:0;}
.tx-cat-icon.prepaid{background:var(--blue-l);}
.tx-cat-icon.postpaid{background:var(--amber-l);}
.tx-cell-main{display:flex;align-items:center;gap:10px;}
.tx-disco{font-weight:600;color:var(--gray-900);}
.tx-ref{font-size:.74rem;color:var(--gray-400);margin-top:1px;}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:.72rem;font-weight:700;}
.badge-success{background:var(--green-l);color:#065F46;}
.badge-pending{background:var(--amber-l);color:#92400E;}
.badge-failed{background:var(--red-l);color:#991B1B;}
.badge-reversed{background:var(--gray-100);color:var(--gray-600);}
.badge-prepaid{background:var(--blue-l);color:var(--blue);}
.badge-postpaid{background:var(--amber-l);color:#92400E;}
.tx-amount{font-weight:700;color:var(--gray-900);}
.tx-arrow{color:var(--gray-300);}

/* ── Card footer ── */
.card-footer-link{display:flex;align-items:center;justify-content:center;gap:6px;padding:14px;border-top:1px solid var(--border);font-size:.84rem;font-weight:600;color:var(--blue);transition:background var(--ease);}
.card-footer-link:hover{background:var(--blue-l);}

/* ── Quick Pay card ── */
.quick-pay-list{padding:12px 0;}
.qp-item{display:flex;align-items:center;gap:12px;padding:12px 20px;transition:background var(--ease);cursor:pointer;text-decoration:none;color:inherit;}
.qp-item:hover{background:var(--surface);}
.qp-item:hover .qp-btn{background:var(--blue);color:#fff;}
.qp-icon{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;font-size:1rem;flex-shrink:0;}
.qp-icon.prepaid{background:var(--blue-l);}
.qp-icon.postpaid{background:var(--amber-l);}
.qp-meta{flex:1;min-width:0;}
.qp-nick{font-size:.86rem;font-weight:700;color:var(--gray-900);}
.qp-detail{font-size:.75rem;color:var(--gray-400);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.qp-btn{padding:5px 12px;border-radius:7px;font-size:.77rem;font-weight:700;background:var(--blue-l);color:var(--blue);border:1px solid var(--blue-m);transition:all var(--ease);flex-shrink:0;white-space:nowrap;}
.qp-btn:hover{background:var(--blue);color:#fff;}

/* ── Notifications card ── */
.notif-list{padding:8px 0;}
.notif-item{display:flex;align-items:flex-start;gap:11px;padding:12px 20px;transition:background var(--ease);}
.notif-item:hover{background:var(--surface);}
.notif-item.unread{background:var(--blue-l);}
.notif-dot{width:8px;height:8px;border-radius:50%;background:var(--blue);flex-shrink:0;margin-top:5px;}
.notif-dot.read{background:transparent;}
.notif-text{flex:1;}
.notif-msg{font-size:.83rem;color:var(--gray-800);line-height:1.4;}
.notif-time{font-size:.72rem;color:var(--gray-400);margin-top:3px;}
.mark-all{font-size:.78rem;font-weight:600;color:var(--blue);background:none;border:none;cursor:pointer;padding:0;font-family:var(--font);}
.mark-all:hover{text-decoration:underline;}

/* ── PIN setup banner ── */
.pin-banner{display:flex;align-items:flex-start;gap:14px;background:linear-gradient(135deg,#FFFBEB 0%,#FEF3C7 100%);border:1px solid #FDE68A;border-left:4px solid #D97706;border-radius:14px;padding:16px 20px;margin-bottom:24px;}
.pin-banner-icon{width:38px;height:38px;background:#D97706;border-radius:10px;display:grid;place-items:center;flex-shrink:0;margin-top:1px;}
.pin-banner-body{flex:1;min-width:0;}
.pin-banner-title{font-family:var(--font-h);font-size:.88rem;font-weight:800;color:#92400E;margin-bottom:3px;}
.pin-banner-text{font-size:.78rem;color:#B45309;line-height:1.55;margin-bottom:12px;}
.pin-banner-actions{display:flex;flex-wrap:wrap;gap:8px;align-items:center;}
.btn-setup-pin{display:inline-flex;align-items:center;gap:6px;height:34px;padding:0 15px;background:#D97706;color:#fff;border-radius:8px;font-size:.8rem;font-weight:700;text-decoration:none;white-space:nowrap;transition:all var(--ease);}
.btn-setup-pin:hover{background:#B45309;}

/* ── WhatsApp CTA card (dashboard) ── */
.wa-cta-card{background:linear-gradient(135deg,#E9FDF0 0%,#F0FFF4 100%);border:1px solid #A7F3C8;border-radius:12px;padding:18px 16px 14px;margin-bottom:0;display:flex;flex-direction:column;gap:12px;}
.wa-cta-card--linked{background:linear-gradient(135deg,#F0FFF4 0%,#ECFDF5 100%);border-color:#6EE7B7;}
.wa-cta-top{display:flex;align-items:center;gap:10px;}
.wa-cta-icon{width:38px;height:38px;background:var(--wa);border-radius:50%;display:grid;place-items:center;flex-shrink:0;}
.wa-cta-titles{display:flex;flex-direction:column;gap:2px;flex:1;}
.wa-cta-name{font-family:var(--font-h);font-size:.9rem;font-weight:800;color:#065F46;line-height:1.2;}
.wa-cta-sub{font-size:.75rem;color:#059669;line-height:1.4;}
.wa-linked-badge{display:inline-flex;align-items:center;gap:4px;height:24px;padding:0 10px;background:#D1FAE5;border:1px solid #6EE7B7;border-radius:20px;font-size:.72rem;font-weight:700;color:#065F46;white-space:nowrap;flex-shrink:0;}
.wa-cta-bullets{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:5px;}
.wa-cta-bullets li{font-size:.78rem;color:#065F46;line-height:1.5;padding-left:16px;position:relative;}
.wa-cta-bullets li::before{content:"✓";position:absolute;left:0;color:var(--wa);font-weight:700;font-size:.7rem;}
.wa-cta-btn{display:inline-flex;align-items:center;justify-content:center;gap:7px;height:38px;padding:0 18px;background:var(--wa);color:#fff;border-radius:8px;font-size:.83rem;font-weight:700;text-decoration:none;transition:all var(--ease);align-self:flex-start;}
.wa-cta-btn:hover{background:var(--wa-d);color:#fff;}
.wa-cmd-list{display:flex;flex-direction:column;gap:6px;}
.wa-cmd{display:flex;align-items:baseline;gap:8px;background:rgba(255,255,255,.6);border:1px solid #A7F3C8;border-radius:7px;padding:7px 10px;}
.wa-cmd-kw{font-family:monospace;font-size:.8rem;font-weight:700;color:#065F46;white-space:nowrap;flex-shrink:0;}
.wa-cmd-desc{font-size:.75rem;color:#059669;line-height:1.4;}
.wa-cta-guide-link{font-size:.78rem;font-weight:700;color:var(--wa);text-decoration:none;align-self:flex-end;}
.wa-cta-guide-link:hover{text-decoration:underline;}
.btn-link-wa{display:inline-flex;align-items:center;gap:7px;height:36px;padding:0 16px;background:var(--wa);color:#fff;border-radius:8px;font-size:.82rem;font-weight:700;text-decoration:none;transition:all var(--ease);}
.btn-link-wa:hover{background:var(--wa-d);}

/* ── Empty state ── */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center;}
.empty-icon{font-size:2.5rem;margin-bottom:12px;opacity:.4;}
.empty-title{font-size:.95rem;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
.empty-sub{font-size:.83rem;color:var(--gray-400);line-height:1.6;max-width:220px;}
.empty-cta{margin-top:16px;display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 16px;background:var(--blue);color:#fff;border-radius:8px;font-size:.84rem;font-weight:700;transition:all var(--ease);}
.empty-cta:hover{background:var(--blue-d);}

@media(max-width:900px){
  .main-grid{grid-template-columns:1fr;}
  .kpi-row{grid-template-columns:1fr 1fr;}
}
@media(max-width:540px){
  .kpi-row{grid-template-columns:1fr;}
  .page-wrap{padding:20px 16px 48px;}
  .page-header{flex-direction:column;align-items:flex-start;}
}


/* ---- Transaction History ---- */
/* ── Page shell ── */


/* ── Page header ── */
.page-title{font-family:var(--font-h);font-size:1.5rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;}
.btn-export{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 16px;background:var(--white);border:1.5px solid var(--border);border-radius:8px;font-size:.84rem;font-weight:700;color:var(--gray-700);transition:all var(--ease);text-decoration:none;}
.btn-export:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l);}

/* ── Filter bar ── */
.filter-bar{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:18px 20px;margin-bottom:16px;box-shadow:var(--shadow-sm);}
.filter-row-1{display:grid;grid-template-columns:1fr 1fr auto auto;gap:12px;align-items:end;}
.filter-row-2{display:grid;grid-template-columns:1fr auto 1fr auto auto;gap:12px;align-items:end;margin-top:12px;}
.filter-group{display:flex;flex-direction:column;gap:5px;}
.filter-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);}
.filter-input,.filter-select{width:100%;height:38px;border:1.5px solid var(--border);border-radius:8px;padding:0 12px;font-size:.85rem;font-family:var(--font);color:var(--gray-700);background:var(--white);outline:none;transition:border-color var(--ease);}
.filter-input:focus,.filter-select:focus{border-color:var(--blue);}
.filter-input[type="date"]{font-size:.82rem;}
.btn-filter{height:38px;padding:0 18px;background:var(--blue);color:#fff;border-radius:8px;font-size:.84rem;font-weight:700;white-space:nowrap;border:none;cursor:pointer;transition:all var(--ease);align-self:flex-end;}
.btn-filter:hover{background:var(--blue-d);}
.btn-clear{height:38px;padding:0 14px;background:transparent;border:1.5px solid var(--border);border-radius:8px;font-size:.84rem;font-weight:600;color:var(--gray-500);transition:all var(--ease);text-decoration:none;display:inline-flex;align-items:center;align-self:flex-end;}
.btn-clear:hover{border-color:var(--gray-400);color:var(--gray-700);}
.search-group{display:flex;flex-direction:column;gap:5px;grid-column:1/3;}

/* Active filter chips */
.active-chips{display:flex;gap:7px;flex-wrap:wrap;margin-top:12px;}
.active-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;background:var(--blue-l);border:1px solid var(--blue-m);font-size:.75rem;font-weight:700;color:var(--blue);}

/* ── Summary strip ── */
.summary-strip{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;background:var(--blue-l);border:1px solid var(--blue-m);border-radius:10px;margin-bottom:14px;font-size:.83rem;}
.ss-left{color:var(--blue);font-weight:600;}
.ss-right{color:var(--blue);font-weight:700;}

/* ── Table card ── */
.table-card{background:var(--white);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;}
.tx-table{width:100%;border-collapse:collapse;}
.tx-table thead th{padding:11px 20px;font-size:.71rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);text-align:left;border-bottom:1px solid var(--border);white-space:nowrap;background:var(--surface);}
.tx-table tbody tr{border-bottom:1px solid var(--border);transition:background var(--ease);cursor:pointer;}
.tx-table tbody tr:last-child{border-bottom:none;}
.tx-table tbody tr:hover{background:#F8FBFF;}
.tx-table td{padding:13px 20px;font-size:.85rem;vertical-align:middle;}
.tx-cat-cell{display:flex;align-items:center;gap:10px;}
.cat-icon{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;font-size:.9rem;flex-shrink:0;}
.cat-icon.prepaid{background:var(--blue-l);}
.cat-icon.postpaid{background:var(--amber-l);}
.tx-disco{font-weight:700;color:var(--gray-900);}
.tx-meter{font-size:.74rem;font-family:'JetBrains Mono',monospace;color:var(--gray-400);margin-top:1px;}
.tx-date-main{font-weight:600;color:var(--gray-800);}
.tx-date-time{font-size:.73rem;color:var(--gray-400);margin-top:1px;}
.tx-amount{font-weight:700;color:var(--gray-900);}
.tx-fee{font-size:.73rem;color:var(--gray-400);margin-top:1px;}
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:100px;font-size:.72rem;font-weight:700;white-space:nowrap;}
.badge-success{background:var(--green-l);color:#065F46;}
.badge-pending{background:var(--amber-l);color:#92400E;}
.badge-failed{background:var(--red-l);color:#991B1B;}
.badge-reversed{background:var(--gray-100);color:var(--gray-600);}
.badge-prepaid{background:var(--blue-l);color:var(--blue);}
.badge-postpaid{background:var(--amber-l);color:#92400E;}
.tx-arrow{color:var(--gray-300);}
.tx-table tbody tr:hover .tx-arrow{color:var(--blue);}

/* ── Empty state ── */
.empty-state{display:flex;flex-direction:column;align-items:center;padding:64px 24px;text-align:center;}
.empty-icon{font-size:3rem;margin-bottom:14px;opacity:.3;}
.empty-title{font-size:1rem;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
.empty-sub{font-size:.85rem;color:var(--gray-400);line-height:1.65;max-width:280px;}
.btn-make-payment{margin-top:20px;display:inline-flex;align-items:center;gap:7px;height:40px;padding:0 20px;background:var(--blue);color:#fff;border-radius:8px;font-size:.86rem;font-weight:700;transition:all var(--ease);text-decoration:none;}
.btn-make-payment:hover{background:var(--blue-d);}

/* ── Pagination ── */
.pagination{display:flex;align-items:center;justify-content:center;gap:6px;padding:20px;border-top:1px solid var(--border);}
.page-btn{width:36px;height:36px;border-radius:8px;display:grid;place-items:center;font-size:.84rem;font-weight:600;color:var(--gray-500);background:var(--white);border:1.5px solid var(--border);transition:all var(--ease);text-decoration:none;}
.page-btn:hover{border-color:var(--blue);color:var(--blue);}
.page-btn.active{background:var(--blue);color:#fff;border-color:var(--blue);}
.page-btn.nav-pg{font-size:1rem;}
.page-btn.disabled{opacity:.35;pointer-events:none;}
.page-info{font-size:.82rem;color:var(--gray-400);padding:0 8px;}

/* ── Mobile card view ── */
.mobile-tx-list{display:none;}
.mobile-tx-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px;margin-bottom:10px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all var(--ease);text-decoration:none;color:inherit;}
.mobile-tx-card:hover{border-color:var(--blue-m);box-shadow:var(--shadow-sm);}
.mtx-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:1rem;flex-shrink:0;}
.mtx-icon.prepaid{background:var(--blue-l);}
.mtx-icon.postpaid{background:var(--amber-l);}
.mtx-body{flex:1;min-width:0;}
.mtx-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:3px;}
.mtx-disco{font-weight:700;color:var(--gray-900);font-size:.9rem;}
.mtx-amount{font-weight:700;color:var(--gray-900);font-size:.9rem;}
.mtx-bottom{display:flex;align-items:center;justify-content:space-between;}
.mtx-date{font-size:.75rem;color:var(--gray-400);}

@media(max-width:1024px){
  .filter-row-1{grid-template-columns:1fr 1fr auto auto;}
  .filter-row-2{grid-template-columns:1fr 1fr auto auto;}
  .search-group{grid-column:1/3;}
}
@media(max-width:700px){
  .filter-row-1{grid-template-columns:1fr 1fr;}
  .filter-row-2{grid-template-columns:1fr 1fr;}
  .search-group{grid-column:auto;}
}
@media(max-width:640px){
  .tx-table{display:none;}
  .mobile-tx-list{display:block;}
  .filter-row-1,.filter-row-2{grid-template-columns:1fr;}
  .search-group{grid-column:auto;}
  .page-wrap{padding:20px 16px 64px;}
}


/* ---- Transaction Details ---- */


.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:20px;font-size:.84rem;color:var(--gray-400);}
.breadcrumb a{color:var(--blue);font-weight:600;text-decoration:none;}
.breadcrumb a:hover{text-decoration:underline;}

.ph-left h1{font-family:var(--font-h);font-size:1.4rem;font-weight:800;color:var(--gray-900);margin-bottom:4px;}
.ph-left p{font-size:.86rem;color:var(--gray-400);}
.ph-left p span{font-family:var(--mono);font-size:.82rem;color:var(--blue);}
.status-badge-large{display:inline-flex;align-items:center;gap:6px;padding:7px 16px;border-radius:100px;font-size:.88rem;font-weight:700;}
.badge-success-lg{background:var(--green-l);color:#065F46;border:1px solid var(--green-m);}
.badge-failed-lg{background:var(--red-l);color:#991B1B;border:1px solid var(--red-m);}
.badge-pending-lg{background:var(--amber-l);color:#92400E;border:1px solid var(--amber-m);}
.badge-reversed-lg{background:var(--gray-100);color:var(--gray-600);border:1px solid var(--gray-200);}

.detail-grid{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start;}

/* Transaction detail cards need padding; the dashboard .card has none */
.detail-grid .card{padding:24px;margin-bottom:16px;overflow:visible;}
.detail-grid .card:last-child{margin-bottom:0;}
.card-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--gray-400);margin-bottom:16px;display:flex;align-items:center;gap:7px;}

.detail-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:9px 0;border-bottom:1px solid var(--border);}
.detail-row:last-child{border-bottom:none;}
.dr-label{font-size:.84rem;color:var(--gray-500);flex-shrink:0;}
.dr-value{font-size:.86rem;font-weight:600;color:var(--gray-900);text-align:right;}
.dr-value.mono{font-family:var(--mono);font-size:.8rem;color:var(--blue);}
.dr-value.large{font-family:var(--font-h);font-size:1.2rem;font-weight:800;color:var(--gray-900);}
.dr-value.green{color:var(--green);}
.cat-pill{display:inline-flex;align-items:center;gap:4px;padding:2px 9px;border-radius:100px;font-size:.78rem;font-weight:700;}
.cat-pill.prepaid{background:var(--blue-l);color:var(--blue);}
.cat-pill.postpaid{background:var(--amber-l);color:var(--amber);}

.token-card{background:var(--blue-l);border:2px solid var(--blue-m);border-radius:12px;padding:18px 20px;margin:14px 0;}
.token-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--blue);margin-bottom:10px;display:flex;align-items:center;gap:5px;}
.token-number{font-family:var(--mono);font-size:1.5rem;font-weight:800;color:var(--blue);letter-spacing:.12em;word-break:break-all;margin-bottom:12px;}
.copy-btn{display:flex;align-items:center;gap:6px;height:36px;padding:0 14px;background:var(--blue);color:#fff;border-radius:7px;font-size:.82rem;font-weight:700;transition:all var(--ease);cursor:pointer;border:none;}
.copy-btn:hover{background:var(--blue-d);}
.copy-btn.copied{background:var(--green);}

.receipt-card{background:var(--teal-l);border:2px solid var(--teal-m);border-radius:12px;padding:18px 20px;margin:14px 0;}
.receipt-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--teal);margin-bottom:8px;}
.receipt-ref{font-family:var(--mono);font-size:1.2rem;font-weight:800;color:var(--teal);letter-spacing:.06em;}

.failure-box{background:var(--red-l);border:1px solid var(--red-m);border-left:4px solid var(--red);border-radius:10px;padding:14px 16px;margin:14px 0;}
.failure-box-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--red);margin-bottom:5px;}
.failure-box-msg{font-size:.88rem;font-weight:600;color:var(--gray-800);}
.not-charged-box{background:var(--green-l);border:1px solid var(--green-m);border-radius:10px;padding:12px 14px;margin:0 0 14px;font-size:.83rem;color:var(--gray-700);}

.reversal-box{background:var(--gray-100);border:1px solid var(--gray-200);border-radius:10px;padding:13px 16px;margin:14px 0;}
.reversal-box-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:4px;}
.reversal-box-msg{font-size:.84rem;color:var(--gray-700);}

/* Notification delivery */
.delivery-item{display:flex;align-items:center;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);font-size:.84rem;}
.delivery-item:last-child{border-bottom:none;}
.delivery-icon{width:30px;height:30px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;font-size:.85rem;}
.delivery-icon.sms{background:#FEF3C7;}
.delivery-icon.email{background:var(--blue-l);}
.delivery-text{flex:1;}
.delivery-label{font-weight:600;color:var(--gray-800);}
.delivery-detail{font-size:.75rem;color:var(--gray-400);margin-top:1px;}
.delivery-time{font-size:.74rem;color:var(--gray-400);}

/* Timeline */
.timeline{display:flex;flex-direction:column;gap:0;}
.tl-item{display:flex;gap:12px;position:relative;}
.tl-item:not(:last-child) .tl-line{position:absolute;left:11px;top:24px;bottom:-4px;width:2px;background:var(--border);}
.tl-dot{width:24px;height:24px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;font-size:.7rem;z-index:1;}
.tl-dot.done{background:var(--green);color:#fff;}
.tl-dot.active{background:var(--blue);color:#fff;}
.tl-dot.failed{background:var(--red);color:#fff;}
.tl-dot.pending{background:var(--amber);color:#fff;}
.tl-body{padding-bottom:18px;flex:1;}
.tl-title{font-size:.86rem;font-weight:700;color:var(--gray-900);}
.tl-time{font-size:.74rem;color:var(--gray-400);margin-top:2px;}

.action-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow-sm);}
.action-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:14px;}
.action-stack{display:flex;flex-direction:column;gap:8px;}
.btn-action{width:100%;height:42px;border-radius:9px;font-size:.86rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:7px;transition:all var(--ease);cursor:pointer;text-decoration:none;}
.btn-action.primary{background:var(--blue);color:#fff;border:none;}
.btn-action.primary:hover{background:var(--blue-d);}
.btn-action.secondary{background:transparent;color:var(--blue);border:1.5px solid var(--blue-m);}
.btn-action.secondary:hover{background:var(--blue-l);border-color:var(--blue);}
.btn-action.ghost{background:transparent;color:var(--gray-700);border:1.5px solid var(--border);}
.btn-action.ghost:hover{border-color:var(--blue);color:var(--blue);}
.btn-action[disabled]{opacity:.5;cursor:default;pointer-events:none;}
.action-divider{height:1px;background:var(--border);margin:6px 0;}
.support-note{margin-top:12px;text-align:center;font-size:.8rem;color:var(--gray-400);}
.support-note a{color:var(--blue);font-weight:600;text-decoration:none;}
.support-note a:hover{text-decoration:underline;}
.support-ref{font-family:var(--mono);font-size:.76rem;}

@media(max-width:860px){.detail-grid{grid-template-columns:1fr;}}


/* ---- Account Profile ---- */
/* ── Page ── */

.page-title{font-family:var(--font-h);font-size:1.5rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;margin-bottom:28px;}

/* ── Tabs ── */
.tabs{display:flex;gap:4px;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:5px;margin-bottom:28px;box-shadow:var(--shadow-sm);flex-wrap:wrap;}
.tab-btn{flex:1;min-width:120px;height:38px;border-radius:8px;font-size:.86rem;font-weight:600;color:var(--gray-500);background:transparent;border:none;transition:all var(--ease);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;}
.tab-btn:hover{color:var(--gray-700);background:var(--gray-100);}
.tab-btn.active{background:var(--blue);color:#fff;box-shadow:0 2px 8px rgba(26,86,160,.25);}
.tab-panel{display:none;}
.tab-panel.active{display:block;animation:fadeIn .2s ease;}
@keyframes fadeIn{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}

/* ── Card ── */
.profile-page .card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:28px;box-shadow:var(--shadow-sm);margin-bottom:20px;}
.section-title{font-family:var(--font-h);font-size:1rem;font-weight:800;color:var(--gray-900);margin-bottom:18px;}
.section-divider{height:1px;background:var(--border);margin:24px 0;}

/* ── Avatar ── */
.avatar-section{display:flex;align-items:center;gap:20px;margin-bottom:28px;padding-bottom:24px;border-bottom:1px solid var(--border);}
.avatar-large{width:72px;height:72px;border-radius:50%;background:var(--blue);color:#fff;font-family:var(--font-h);font-size:1.4rem;font-weight:800;display:grid;place-items:center;border:3px solid var(--blue-m);flex-shrink:0;}
.avatar-info h3{font-size:1rem;font-weight:700;color:var(--gray-900);}
.avatar-info p{font-size:.84rem;color:var(--gray-400);margin-top:2px;}

/* ── Form ── */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.field{display:flex;flex-direction:column;gap:5px;}
.field.full{grid-column:1/-1;}
.field-label{font-size:.79rem;font-weight:600;color:var(--gray-700);}
.field-label .req{color:var(--red);}
.field-hint{font-size:.74rem;color:var(--gray-400);}
.input-wrap{position:relative;}
.input-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none;display:flex;}
.input{width:100%;height:42px;border:1.5px solid #D1D5DB;border-radius:8px;padding:0 14px 0 40px;font-size:.88rem;color:var(--gray-900);font-family:var(--font);background:var(--white);outline:none;transition:border-color var(--ease),box-shadow var(--ease);}
.input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,160,.1);}
.input.no-icon{padding-left:14px;}
.input:read-only{background:var(--gray-100);color:var(--gray-500);cursor:not-allowed;}
.field-error-msg{font-size:.75rem;color:var(--red);margin-top:4px;}

/* ── Password strength ── */
.strength-bar{display:flex;gap:3px;margin-top:6px;}
.strength-seg{height:3px;flex:1;border-radius:2px;background:var(--gray-200);}

/* ── Buttons ── */
.btn-primary{height:42px;padding:0 20px;background:var(--blue);color:#fff;border-radius:8px;font-size:.88rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:all var(--ease);cursor:pointer;border:none;}
.btn-primary:hover{background:var(--blue-d);box-shadow:0 4px 14px rgba(26,86,160,.25);}
.btn-secondary{height:42px;padding:0 18px;background:transparent;color:var(--blue);border:1.5px solid var(--blue-m);border-radius:8px;font-size:.88rem;font-weight:600;display:inline-flex;align-items:center;justify-content:center;gap:7px;transition:all var(--ease);cursor:pointer;}
.btn-secondary:hover{background:var(--blue-l);border-color:var(--blue);}
.btn-row{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap;}

/* ── Notification toggles ── */
.notif-section{display:flex;flex-direction:column;gap:0;}
.notif-row{display:flex;align-items:center;justify-content:space-between;padding:15px 0;border-bottom:1px solid var(--border);}
.notif-row:last-child{border-bottom:none;}
.notif-info{flex:1;}
.notif-label{font-size:.88rem;font-weight:600;color:var(--gray-900);}
.notif-sub{font-size:.76rem;color:var(--gray-400);margin-top:2px;}
.toggle-switch{position:relative;width:44px;height:24px;flex-shrink:0;}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute;}
.toggle-slider{position:absolute;inset:0;border-radius:24px;background:var(--gray-200);transition:.2s;cursor:pointer;}
.toggle-slider::before{content:'';position:absolute;width:18px;height:18px;border-radius:50%;left:3px;top:3px;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.toggle-switch input:checked+.toggle-slider{background:var(--blue);}
.toggle-switch input:checked+.toggle-slider::before{transform:translateX(20px);}

/* ── Toast ── */
.toast{position:fixed;bottom:24px;right:24px;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:14px 18px;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:12px;font-size:.86rem;max-width:300px;transform:translateX(120%);transition:transform .35s cubic-bezier(.22,1,.36,1);z-index:200;}
.toast.show{transform:translateX(0);}
.toast-icon{width:30px;height:30px;border-radius:7px;display:grid;place-items:center;flex-shrink:0;background:var(--green-l);color:var(--green);}
.toast-text strong{display:block;font-weight:700;color:var(--gray-900);font-size:.84rem;}
.toast-text span{font-size:.76rem;color:var(--gray-400);}

@media(max-width:640px){
  .form-grid{grid-template-columns:1fr;}
  .page-wrap{padding:20px 16px 64px;}
  .tabs{flex-wrap:wrap;}
  .tab-btn{min-width:0;font-size:.79rem;}
}


/* ---- Saved Accounts ---- */
/* Saved accounts list */
.saved-header{display:flex;align-items:center;justify-content:space-between;padding:22px 24px 18px;border-bottom:1px solid var(--border);}
.saved-count{font-size:.85rem;color:var(--gray-500);background:var(--surface);border:1px solid var(--border);border-radius:100px;padding:5px 14px;}
.saved-count .used{font-weight:700;color:var(--gray-900);}
.btn-add-saved{display:inline-flex;align-items:center;gap:6px;height:38px;padding:0 18px;background:var(--blue);color:#fff;border-radius:8px;font-size:.84rem;font-weight:700;transition:all var(--ease);cursor:pointer;border:none;}
.btn-add-saved:hover{background:var(--blue-d);}
.btn-add-saved:disabled{opacity:.45;cursor:not-allowed;}

.saved-list{display:flex;flex-direction:column;gap:0;}
.saved-item{background:var(--white);border-bottom:1px solid var(--border);padding:16px 24px;display:flex;align-items:center;gap:14px;transition:background var(--ease);}
.saved-item:last-of-type{border-bottom:none;}
.saved-item:hover{background:#F8FBFF;}
.si-icon{width:40px;height:40px;border-radius:10px;display:grid;place-items:center;font-size:1rem;flex-shrink:0;}
.si-icon.prepaid{background:var(--blue-l);}
.si-icon.postpaid{background:var(--amber-l);}
.si-body{flex:1;min-width:0;}
.si-nick{font-size:.92rem;font-weight:700;color:var(--gray-900);}
.si-detail{display:flex;align-items:center;gap:6px;font-size:.76rem;color:var(--gray-400);margin-top:3px;flex-wrap:wrap;}
.si-badge{display:inline-flex;align-items:center;gap:3px;padding:2px 7px;border-radius:100px;font-size:.68rem;font-weight:700;}
.si-badge.prepaid{background:var(--blue-l);color:var(--blue);}
.si-badge.postpaid{background:var(--amber-l);color:var(--amber);}
.si-meter{font-family:'JetBrains Mono',monospace;font-size:.76rem;}
.si-actions{display:flex;gap:6px;flex-shrink:0;}
.btn-si-pay{height:32px;padding:0 12px;background:var(--blue);color:#fff;border-radius:7px;font-size:.78rem;font-weight:700;border:none;cursor:pointer;transition:all var(--ease);text-decoration:none;display:inline-flex;align-items:center;}
.btn-si-pay:hover{background:var(--blue-d);}
.btn-si-del{width:32px;height:32px;border:1.5px solid var(--border);border-radius:7px;background:var(--white);display:grid;place-items:center;color:var(--gray-400);cursor:pointer;transition:all var(--ease);}
.btn-si-del:hover{border-color:#DC2626;color:#DC2626;}
.btn-si-edit{width:32px;height:32px;border:1.5px solid var(--border);border-radius:7px;background:var(--white);display:grid;place-items:center;color:var(--gray-400);cursor:pointer;transition:all var(--ease);}
.btn-si-edit:hover{border-color:var(--blue);color:var(--blue);}

/* Delete confirm inline */
.delete-confirm{display:none;align-items:center;gap:8px;padding:10px 24px;background:#FEF2F2;border-top:1px solid #FECACA;font-size:.82rem;}
.delete-confirm.show{display:flex;}
.btn-del-confirm{height:30px;padding:0 12px;background:#DC2626;color:#fff;border-radius:6px;font-size:.78rem;font-weight:700;border:none;cursor:pointer;}
.btn-del-cancel{height:30px;padding:0 10px;background:transparent;border:1.5px solid var(--border);color:var(--gray-600);border-radius:6px;font-size:.78rem;font-weight:600;cursor:pointer;}

/* Rename inline row */
.rename-row{display:none;flex-direction:column;gap:6px;padding:10px 24px;background:#EFF6FF;border-top:1px solid #BFDBFE;}
.rename-row.show{display:flex;}
.rename-row form{display:flex;align-items:center;gap:8px;}
.rename-input{flex:1;height:34px;border:1.5px solid #93C5FD;border-radius:7px;padding:0 10px;font-size:.88rem;font-family:inherit;color:var(--gray-900);outline:none;max-width:220px;}
.rename-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,160,.12);}
.btn-ren-save{height:34px;padding:0 14px;background:var(--blue);color:#fff;border-radius:7px;font-size:.8rem;font-weight:700;border:none;cursor:pointer;}
.btn-ren-save:hover{opacity:.9;}
.btn-ren-cancel{height:34px;padding:0 10px;background:transparent;border:1.5px solid var(--border);color:var(--gray-600);border-radius:7px;font-size:.8rem;font-weight:600;cursor:pointer;}
.rename-hint{font-size:.75rem;color:#1D4ED8;display:flex;align-items:center;gap:4px;}
.rename-hint svg{flex-shrink:0;}

/* Nickname hint in add form */
.nickname-hint{display:flex;align-items:center;gap:4px;font-size:.75rem;color:var(--gray-500);margin-top:5px;line-height:1.4;}
.nickname-hint svg{flex-shrink:0;color:var(--gray-400);}

/* Empty state */
.empty-saved{display:flex;flex-direction:column;align-items:center;padding:56px 24px;text-align:center;}
.empty-saved-icon{font-size:2.5rem;opacity:.3;margin-bottom:12px;}
.empty-saved-title{font-size:.95rem;font-weight:700;color:var(--gray-700);margin-bottom:5px;}
.empty-saved-sub{font-size:.83rem;color:var(--gray-400);line-height:1.6;max-width:240px;}

/* Add form card */
.add-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:24px;box-shadow:var(--shadow-sm);margin-top:24px;}
.add-card-title{font-size:.88rem;font-weight:700;color:var(--gray-700);margin-bottom:18px;}
.add-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.modal-field{display:flex;flex-direction:column;gap:5px;margin-bottom:0;}
.modal-label{font-size:.79rem;font-weight:600;color:var(--gray-700);}
.modal-input,.modal-select{width:100%;height:42px;border:1.5px solid var(--border);border-radius:8px;padding:0 12px;font-size:.88rem;font-family:var(--font);color:var(--gray-900);background:var(--white);outline:none;transition:border-color var(--ease);}
.modal-input:focus,.modal-select:focus{border-color:var(--blue);}
.add-form-footer{display:flex;align-items:center;justify-content:space-between;margin-top:18px;gap:12px;flex-wrap:wrap;}
.add-form-tip{font-size:.78rem;color:var(--gray-400);}
.btn-add-submit{height:40px;padding:0 22px;background:var(--blue);color:#fff;border-radius:8px;font-size:.86rem;font-weight:700;border:none;cursor:pointer;transition:background var(--ease);}
.btn-add-submit:hover:not(:disabled){background:var(--blue-d);}
.btn-add-submit:disabled{opacity:.45;cursor:not-allowed;}
.btn-verify{height:42px;padding:0 14px;background:var(--gray-100);color:var(--gray-700);border:1.5px solid var(--border);border-radius:8px;font-size:.84rem;font-weight:700;cursor:pointer;white-space:nowrap;transition:all var(--ease);flex-shrink:0;}
.btn-verify:hover:not(:disabled){background:var(--blue-l);border-color:var(--blue);color:var(--blue);}
.btn-verify:disabled{opacity:.45;cursor:not-allowed;}
.verify-ok{display:flex;align-items:center;gap:5px;margin-top:6px;font-size:.78rem;color:#065F46;background:#ECFDF5;border:1px solid #A7F3D0;border-radius:6px;padding:5px 10px;}
.verify-err{margin-top:6px;font-size:.78rem;color:#DC2626;background:#FEF2F2;border:1px solid #FECACA;border-radius:6px;padding:5px 10px;}

@media(max-width:640px){.add-form-grid{grid-template-columns:1fr;}}


/* ---- Pay shared wrapper ---- */
.pay-wrap{display:flex;flex-direction:column;align-items:center;padding:40px 24px 80px;min-height:calc(100vh - 64px);}

/* ---- Pay - Category Selection ---- */
/* ── Step indicator ── */
.step-indicator{display:flex;align-items:center;gap:0;margin-bottom:36px;width:100%;max-width:640px;}
.step{display:flex;align-items:center;gap:8px;flex:1;}
.step:last-child{flex:0;}
.step-circle{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:800;flex-shrink:0;border:2px solid var(--gray-200);background:var(--white);color:var(--gray-400);}
.step-circle.active{border-color:var(--blue);background:var(--blue);color:#fff;box-shadow:0 0 0 4px rgba(26,86,160,.15);}
.step-circle.done{border-color:var(--green);background:var(--green);color:#fff;}
.step-label{font-size:.75rem;font-weight:600;color:var(--gray-400);}
.step-label.active{color:var(--blue);}
.step-label.done{color:var(--green);}
.step-line{flex:1;height:2px;background:var(--gray-200);margin:0 8px;}
.step-line.done{background:var(--green);}
/* ── Category cards ── */
.category-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px;}
.cat-card{border-radius:18px;padding:36px 32px 32px;border:2px solid transparent;cursor:pointer;position:relative;overflow:hidden;transition:all .25s ease;display:flex;flex-direction:column;text-decoration:none;}
.cat-card:hover{transform:translateY(-4px) scale(1.01);}
    .cat-card.prepaid {
        background: linear-gradient(145deg,#EFF6FF 0%,#DBEAFE 60%,#EFF6FF 100%);
        border-color: var(--blue-m);
        padding: 36px 32px 32px;
    }
.cat-card.prepaid:hover{border-color:var(--blue);box-shadow:0 12px 32px rgba(26,86,160,.22);}
    .cat-card.postpaid {
        background: linear-gradient(145deg,#FFFBEB 0%,#FEF3C7 60%,#FFFBEB 100%);
        border-color: var(--amber-m);
        padding: 36px 32px 32px;
    }
.cat-card.postpaid:hover{border-color:var(--amber);box-shadow:0 12px 32px rgba(217,119,6,.22);}
.cat-blob{position:absolute;width:160px;height:160px;border-radius:50%;filter:blur(40px);top:-40px;right:-40px;pointer-events:none;}
.prepaid .cat-blob{background:rgba(26,86,160,.09);}
.postpaid .cat-blob{background:rgba(217,119,6,.09);}
.cat-icon-wrap{width:60px;height:60px;border-radius:16px;display:grid;place-items:center;font-size:1.6rem;margin-bottom:20px;}
.prepaid .cat-icon-wrap{background:rgba(26,86,160,.1);}
.postpaid .cat-icon-wrap{background:rgba(217,119,6,.1);}
.cat-name{font-family:var(--font-h);font-size:1.4rem;font-weight:800;margin-bottom:8px;}
.prepaid .cat-name{color:var(--blue);}
.postpaid .cat-name{color:var(--amber);}
.cat-desc{font-size:.88rem;color:var(--gray-600);line-height:1.6;margin-bottom:24px;flex:1;}
.cat-features{display:flex;flex-direction:column;gap:8px;margin-bottom:28px;}
.cat-feat{display:flex;align-items:center;gap:9px;font-size:.82rem;color:var(--gray-600);}
.feat-dot{width:18px;height:18px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;font-size:.6rem;font-weight:800;}
.prepaid .feat-dot{background:var(--blue-l);color:var(--blue);}
.postpaid .feat-dot{background:var(--amber-l);color:var(--amber);}
.cat-btn{width:100%;height:46px;border-radius:10px;font-size:.92rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;}
.prepaid .cat-btn{background:var(--blue);color:#fff;}
.postpaid .cat-btn{background:var(--amber);color:#fff;}
.cat-arrow{position:absolute;top:16px;right:16px;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;opacity:0;transform:translateX(-4px);transition:all .2s ease;}
.prepaid .cat-arrow{background:var(--blue);color:#fff;}
.postpaid .cat-arrow{background:var(--amber);color:#fff;}
.cat-card:hover .cat-arrow{opacity:1;transform:translateX(0);}
.trust-note{display:flex;align-items:center;justify-content:center;gap:8px;font-size:.82rem;color:var(--gray-400);padding:16px;}
.cat-content-wrap{width:100%;max-width:720px;}
.page-title-group{text-align:center;margin-bottom:36px;}
.page-title-lg{font-family:var(--font-h);font-size:1.7rem;font-weight:800;color:var(--gray-900);letter-spacing:-.025em;margin-bottom:8px;}
.page-sub{font-size:.93rem;color:var(--gray-500);line-height:1.65;}
@media(max-width:700px){
  .category-grid{grid-template-columns:1fr;}
  .step-label{display:none;}
}


/* ---- Pay - DISCO Selection ---- */
/* ── Step indicator ── */
.step-indicator{display:flex;align-items:center;gap:0;margin-bottom:36px;width:100%;max-width:640px;}
.step{display:flex;align-items:center;gap:8px;flex:1;}
.step:last-child{flex:0;}
.step-circle{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:800;flex-shrink:0;transition:all .25s;border:2px solid var(--gray-200);background:var(--white);color:var(--gray-400);}
.step-circle.active{border-color:var(--blue);background:var(--blue);color:#fff;box-shadow:0 0 0 4px rgba(26,86,160,.15);animation:stepPulse 2s ease infinite;}
.step-circle.done{border-color:var(--green);background:var(--green);color:#fff;}
@keyframes stepPulse{0%,100%{box-shadow:0 0 0 4px rgba(26,86,160,.15)}50%{box-shadow:0 0 0 6px rgba(26,86,160,.08)}}
.step-label{font-size:.75rem;font-weight:600;color:var(--gray-400);}
.step-label.active{color:var(--blue);}
.step-label.done{color:var(--green);}
.step-line{flex:1;height:2px;background:var(--gray-200);margin:0 8px;}
.step-line.done{background:var(--green);}
/* ── Content ── */
.content-wrap{width:100%;max-width:860px;}
.page-header-left h1{font-family:var(--font-h);font-size:1.45rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;margin-bottom:4px;}
.page-header-left p{font-size:.88rem;color:var(--gray-500);}
.back-btn{display:flex;align-items:center;gap:6px;font-size:.83rem;font-weight:600;color:var(--gray-500);transition:color var(--ease);background:none;border:1px solid var(--border);cursor:pointer;padding:6px 10px;border-radius:7px;}
.back-btn:hover{color:var(--gray-900);background:var(--white);}
/* ── Category banner ── */
.cat-banner{display:inline-flex;align-items:center;gap:7px;padding:6px 14px;border-radius:8px;font-size:.82rem;font-weight:700;margin-bottom:20px;}
.cat-banner.prepaid{background:var(--blue-l);border:1px solid var(--blue-m);color:var(--blue);}
.cat-banner.postpaid{background:var(--amber-l);border:1px solid var(--amber-m);color:var(--amber);}
/* ── Search bar ── */
.search-wrap{position:relative;margin-bottom:24px;}
.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none;}
.search-input{width:100%;height:46px;border:1.5px solid var(--border);border-radius:10px;padding:0 44px;font-size:.9rem;color:var(--gray-900);background:var(--white);outline:none;font-family:var(--font);transition:border-color var(--ease),box-shadow var(--ease);}
.search-input::placeholder{color:var(--gray-400);}
.search-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,160,.1);}
.search-clear{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--gray-400);display:none;padding:4px;border-radius:4px;}
.search-clear:hover{color:var(--gray-700);}
.search-clear.show{display:flex;}
/* ── Grid ── */
.disco-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}
.disco-card{background:var(--white);border:2px solid var(--border);border-radius:14px;padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:10px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;text-decoration:none;color:inherit;}
.disco-card:hover{border-color:var(--blue);box-shadow:var(--shadow-md);transform:translateY(-3px);}
.disco-card:active{transform:translateY(-1px);}
.disco-avatar{width:52px;height:52px;border-radius:12px;display:grid;place-items:center;font-size:1rem;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden;background:var(--blue);}
.disco-avatar img{width:100%;height:100%;object-fit:contain;}
.disco-name{font-size:.88rem;font-weight:700;color:var(--gray-900);text-align:center;}
.disco-region{font-size:.73rem;color:var(--gray-400);text-align:center;}
/* ── No results ── */
.no-results{display:none;flex-direction:column;align-items:center;padding:48px 24px;text-align:center;grid-column:1/-1;}
.no-results.show{display:flex;}
.no-results-icon{font-size:2.2rem;margin-bottom:10px;opacity:.4;}
.no-results-title{font-size:.95rem;font-weight:700;color:var(--gray-700);margin-bottom:4px;}
.no-results-sub{font-size:.83rem;color:var(--gray-400);}
/* ── Footer note ── */
.footer-note{text-align:center;font-size:.82rem;color:var(--gray-400);margin-top:28px;line-height:1.6;}
.footer-note a{color:var(--blue);font-weight:600;}
@media(max-width:860px){.disco-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:600px){.disco-grid{grid-template-columns:repeat(2,1fr);}.step-label{display:none;}}


/* ---- Pay - Prepaid Form ---- */
/* ── Step indicator ── */
.step-indicator{display:flex;align-items:center;margin-bottom:32px;width:100%;max-width:640px;}
.step{display:flex;align-items:center;gap:7px;flex:1;}.step:last-child{flex:0;}
.step-circle{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;font-size:.75rem;font-weight:800;flex-shrink:0;border:2px solid var(--gray-200);background:var(--white);color:var(--gray-400);transition:all .25s;}
.step-circle.active{border-color:var(--blue);background:var(--blue);color:#fff;box-shadow:0 0 0 4px rgba(26,86,160,.15);}
.step-circle.done{border-color:var(--green);background:var(--green);color:#fff;}
.step-lbl{font-size:.72rem;font-weight:600;color:var(--gray-400);}
.step-lbl.active{color:var(--blue);}.step-lbl.done{color:var(--green);}
.step-line{flex:1;height:2px;background:var(--gray-200);margin:0 8px;}.step-line.done{background:var(--green);}

/* ── Layout ── */
.content-grid{display:grid;grid-template-columns:1fr 360px;gap:24px;width:100%;max-width:900px;}

/* ── DISCO strip ── */
.disco-strip{display:flex;align-items:center;justify-content:space-between;background:var(--white);border:1px solid var(--border);border-radius:12px;padding:14px 18px;margin-bottom:20px;box-shadow:var(--shadow-sm);}
.disco-strip-left{display:flex;align-items:center;gap:12px;}
.disco-avatar{width:42px;height:42px;border-radius:10px;display:grid;place-items:center;font-size:.9rem;font-weight:800;color:#fff;flex-shrink:0;overflow:hidden;background:var(--blue);}
.disco-avatar img{width:100%;height:100%;object-fit:contain;}
.disco-info-name{font-size:.95rem;font-weight:700;color:var(--gray-900);}
.disco-info-cat{font-size:.75rem;color:var(--gray-400);margin-top:2px;display:flex;align-items:center;gap:5px;}
.badge-prepaid-sm{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:100px;background:var(--blue-l);color:var(--blue);font-size:.7rem;font-weight:700;border:1px solid var(--blue-m);}
.change-link{font-size:.8rem;font-weight:600;color:var(--blue);display:flex;align-items:center;gap:4px;transition:opacity var(--ease);}
.change-link:hover{opacity:.7;}

/* ── Card ── */
.pay-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:28px;box-shadow:var(--shadow-sm);}
.card-section-title{font-family:var(--font-h);font-size:1rem;font-weight:800;color:var(--gray-900);margin-bottom:6px;}
.card-section-sub{font-size:.84rem;color:var(--gray-500);margin-bottom:22px;}

/* ── Field ── */
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:18px;}
.field-label{font-size:.8rem;font-weight:600;color:var(--gray-700);}
.field-label .req{color:var(--red);}
.input-wrap{position:relative;}
.input-icon-l{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none;display:flex;}
.input{width:100%;height:44px;border:1.5px solid var(--border-in, #D1D5DB);border-radius:8px;padding:0 44px 0 40px;font-size:.9rem;color:var(--gray-900);font-family:var(--font);background:var(--white);outline:none;transition:border-color var(--ease),box-shadow var(--ease);}
.input::placeholder{color:var(--gray-400);}
.input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,160,.1);}
.input.error{border-color:var(--red);}
.input.valid{border-color:var(--green);}
.input.mono{font-family:monospace;letter-spacing:.05em;}
.status-icon{position:absolute;right:12px;top:50%;transform:translateY(-50%);display:none;}
.status-icon.visible{display:flex;}
.spin{animation:spin .7s linear infinite;}
@keyframes spin{to{transform:rotate(360deg)}}
.field-error{font-size:.75rem;color:var(--red);margin-top:4px;display:none;align-items:center;gap:4px;}
.field-error.show{display:flex;}
.field-hint{font-size:.75rem;color:var(--gray-400);margin-top:4px;}

/* ── Meter validation result ── */
.meter-result{border-radius:10px;padding:12px 16px;margin-top:8px;display:none;align-items:center;gap:12px;}
.meter-result.show{display:flex;}
.meter-result.success{background:var(--green-l);border:1px solid var(--green-m);}
.meter-result.error-state{background:var(--red-l);border:1px solid var(--red-m);}
.mr-icon{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;flex-shrink:0;}
.mr-icon.ok{background:rgba(5,150,105,.15);}
.mr-icon.err{background:rgba(220,38,38,.12);}
.mr-label{font-size:.73rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;}
.mr-label.ok{color:var(--green);}
.mr-label.err{color:var(--red);}
.mr-name{font-size:.9rem;font-weight:700;color:var(--gray-900);}
.mr-tariff{font-size:.75rem;color:var(--gray-500);margin-top:2px;}

/* ── Amount phase ── */
.phase-2{display:none;}
.phase-2.show{display:block;animation:fadeSlide .3s ease;}
@keyframes fadeSlide{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}
.amount-input-wrap{position:relative;}
.currency-prefix{position:absolute;left:14px;top:50%;transform:translateY(-50%);font-size:.95rem;font-weight:800;color:var(--gray-500);pointer-events:none;}
.amount-input{width:100%;height:52px;border:2px solid #D1D5DB;border-radius:10px;padding:0 30px 0 44px;font-size:1.2rem;font-weight:700;color:var(--gray-900);font-family:monospace;background:var(--white);outline:none;transition:border-color var(--ease),box-shadow var(--ease);}
.amount-input:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,160,.1);}
.amount-input.error{border-color:var(--red);}
.quick-amounts{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px;}
.qa-btn{-webkit-appearance:none;appearance:none;display:inline-flex;align-items:center;justify-content:center;padding:6px 14px;border-radius:8px;border:1.5px solid var(--border-in);background:var(--white);font-size:.82rem;font-weight:700;color:var(--gray-700);line-height:1;transition:all var(--ease);cursor:pointer;}
.qa-btn:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l);}
.qa-btn.active{border-color:var(--blue);color:var(--blue);background:var(--blue-l);}
.unit-estimate{display:flex;align-items:center;gap:7px;margin-top:10px;font-size:.83rem;color:var(--gray-500);min-height:24px;}

/* ── Saved meter dropdown ── */
.saved-row{margin-bottom:16px;}
.saved-label{font-size:.76rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:6px;}
.saved-select{width:100%;height:40px;border:1.5px solid var(--border-in,#D1D5DB);border-radius:8px;padding:0 12px;font-size:.86rem;font-family:inherit;color:var(--gray-700);background:var(--white);outline:none;cursor:pointer;transition:border-color var(--ease);}
.saved-select:focus{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,160,.1);}

/* ── Save meter ── */
.save-row{display:flex;align-items:center;gap:9px;margin-top:18px;padding-top:16px;border-top:1px solid var(--border);}
.save-cb{width:16px;height:16px;accent-color:var(--blue);cursor:pointer;}
.save-label{font-size:.83rem;color:var(--gray-600);cursor:pointer;}
.save-nickname-wrap{display:none;margin-top:10px;}
.save-nickname-wrap.show{display:block;animation:fadeSlide .2s ease;}
.save-nickname{width:100%;height:38px;border:1.5px solid #D1D5DB;border-radius:7px;padding:0 12px;font-size:.86rem;font-family:var(--font);outline:none;transition:border-color var(--ease);}
.save-nickname:focus{border-color:var(--blue);}

/* ── Guest contact section ── */
.guest-contact-section{margin-top:18px;padding:16px 18px;background:linear-gradient(135deg,#F0FDF4,#ECFDF5);border:1.5px solid var(--green-m);border-radius:12px;animation:fadeSlide .3s ease;}
.guest-contact-header{display:flex;align-items:flex-start;gap:10px;margin-bottom:16px;}
.guest-contact-icon{width:36px;height:36px;border-radius:9px;background:var(--green);display:grid;place-items:center;flex-shrink:0;}
.guest-contact-title{font-size:.88rem;font-weight:700;color:#065F46;margin-bottom:2px;}
.guest-contact-sub{font-size:.76rem;color:#047857;line-height:1.5;}
.guest-field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;}
.guest-input-wrap{position:relative;}
.guest-input-icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--gray-400);pointer-events:none;display:flex;}
.guest-input{width:100%;height:42px;border:1.5px solid var(--border-in);border-radius:8px;padding:0 12px 0 36px;font-size:.87rem;color:var(--gray-900);font-family:var(--font);background:var(--white);outline:none;transition:border-color var(--ease),box-shadow var(--ease);}
.guest-input::placeholder{color:var(--gray-400);}
.guest-input:focus{border-color:var(--green);box-shadow:0 0 0 3px rgba(5,150,105,.1);}
.guest-input.error{border-color:var(--red);}
.guest-field-error{font-size:.73rem;color:var(--red);margin-top:4px;display:none;align-items:center;gap:3px;}
.guest-field-error.show{display:flex;}
.phone-prefix-wrap{display:flex;gap:6px;}
.phone-flag{display:flex;align-items:center;gap:5px;height:42px;padding:0 10px;border:1.5px solid var(--border-in);border-radius:8px;font-size:.84rem;font-weight:600;background:var(--gray-100);color:var(--gray-600);white-space:nowrap;flex-shrink:0;}
@media(max-width:600px){.guest-field-row{grid-template-columns:1fr;}}

/* ── Order summary (right) ── */
.summary-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:24px;box-shadow:var(--shadow-sm);position:sticky;top:84px;}
.summary-title{font-family:var(--font-h);font-size:.95rem;font-weight:800;color:var(--gray-900);margin-bottom:18px;display:flex;align-items:center;gap:7px;}
.summary-row{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;font-size:.85rem;padding:9px 0;border-bottom:1px solid var(--border);}
.summary-row:last-of-type{border-bottom:none;}
.sr-label{color:var(--gray-500);}
.sr-value{font-weight:600;color:var(--gray-900);text-align:right;}
.summary-total{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--blue-l);border:1px solid var(--blue-m);border-radius:10px;margin-top:16px;}
.st-label{font-size:.85rem;font-weight:700;color:var(--blue);}
.st-value{font-family:var(--font-h);font-size:1.3rem;font-weight:800;color:var(--blue);}
.summary-placeholder{text-align:center;padding:24px 0;color:var(--gray-300);font-size:.84rem;}

/* ── Submit ── */
.btn-pay-now{width:100%;height:50px;background:var(--blue);color:#fff;border-radius:10px;font-size:.95rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--ease);cursor:pointer;margin-top:18px;position:relative;border:none;}
.btn-pay-now:hover:not(:disabled){background:var(--blue-d);box-shadow:0 6px 20px rgba(26,86,160,.3);transform:translateY(-1px);}
.btn-pay-now:disabled{opacity:.45;cursor:not-allowed;transform:none;}
.btn-spinner{position:absolute;display:none;}
.btn-pay-now.loading .btn-text{opacity:0;}
.btn-pay-now.loading .btn-spinner{display:flex;}
.security-note{display:flex;align-items:center;justify-content:center;gap:5px;font-size:.76rem;color:var(--gray-400);margin-top:10px;}

@media(max-width:760px){
  .content-grid{grid-template-columns:1fr;}
  .summary-card{position:static;}
  .step-lbl{display:none;}
}


/* ---- Pay - Postpaid Form ---- */
/* ── Amber theme overrides — scoped so they don't bleed into Prepaid/Category pages ── */
.postpaid-wrap .step-circle.active{border-color:var(--amber);background:var(--amber);color:#fff;box-shadow:0 0 0 4px rgba(217,119,6,.15);}
.postpaid-wrap .step-lbl.active{color:var(--amber);}
.postpaid-wrap .disco-avatar{background:var(--amber);}
.postpaid-wrap .summary-total{background:var(--amber-l);border:1px solid var(--amber-m);}
.postpaid-wrap .st-label{color:var(--amber);}
.postpaid-wrap .st-value{color:var(--amber);}
.postpaid-wrap .btn-pay-now{background:var(--amber);}
.postpaid-wrap .btn-pay-now:hover:not(:disabled){background:var(--amber-d);box-shadow:0 6px 20px rgba(217,119,6,.3);}

.badge-postpaid{display:inline-flex;align-items:center;gap:3px;padding:2px 8px;border-radius:100px;background:var(--amber-l);color:var(--amber);font-size:.7rem;font-weight:700;border:1px solid var(--amber-m);}

/* ── Account-number input row (flex field + inline Fetch Bill button) ── */
.input-row{display:flex;align-items:center;border:1.5px solid #D1D5DB;border-radius:8px;background:var(--white);transition:border-color var(--ease),box-shadow var(--ease);overflow:hidden;}
.input-row:focus-within{border-color:var(--blue);box-shadow:0 0 0 3px rgba(26,86,160,.1);}
.input-row.valid{border-color:var(--green);}
.input-row.error{border-color:var(--red);}
.input-row-icon{padding:0 10px 0 12px;color:var(--gray-400);flex-shrink:0;display:flex;align-items:center;}
.input-row-field{flex:1;height:44px;border:none;outline:none;font-size:.9rem;color:var(--gray-900);font-family:monospace;background:transparent;min-width:0;}
.input-row-field::placeholder{color:var(--gray-400);}
.input-row-btn{flex-shrink:0;padding:0 12px;}

.btn-fetch{height:36px;padding:0 16px;background:var(--amber);color:#fff;border-radius:6px;font-size:.82rem;font-weight:700;white-space:nowrap;transition:all var(--ease);display:flex;align-items:center;gap:6px;border:none;cursor:pointer;}
.btn-fetch:hover:not(:disabled){background:var(--amber-d);}
.btn-fetch:disabled{opacity:.5;cursor:not-allowed;}

/* ── Bill detail card ── */
.phase-2.show{animation:fadeSlide .35s ease;}
.bill-card{border-radius:12px;padding:18px;margin-bottom:18px;border-left:4px solid var(--amber);}
.bill-card.normal{background:var(--amber-l);border-color:var(--amber);}
.bill-card.overdue{background:var(--red-l);border-color:var(--red);}
.bill-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;}
.bill-title{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;}
.bill-card.normal .bill-title{color:var(--amber);}
.bill-card.overdue .bill-title{color:var(--red);}
.overdue-chip{display:inline-flex;align-items:center;gap:4px;background:var(--red-l);border:1px solid var(--red-m);border-radius:100px;padding:3px 9px;font-size:.7rem;font-weight:700;color:var(--red);}
.bill-amount{font-family:var(--font-h);font-size:2rem;font-weight:800;color:var(--gray-900);margin-bottom:14px;}
.bill-amount .currency{font-size:1.1rem;color:var(--gray-500);}
.bill-rows{display:flex;flex-direction:column;gap:8px;}
.bill-row{display:flex;justify-content:space-between;font-size:.84rem;}
.bill-row-label{color:var(--gray-500);}
.bill-row-value{font-weight:600;color:var(--gray-900);}
.bill-row-value.red{color:var(--red);}

/* ── Partial payment toggle ── */
.partial-toggle{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding:12px 14px;background:var(--gray-100);border-radius:10px;}
.toggle-switch{position:relative;width:36px;height:20px;flex-shrink:0;}
.toggle-switch input{opacity:0;width:0;height:0;position:absolute;}
.toggle-slider{position:absolute;inset:0;border-radius:20px;background:var(--gray-300);transition:.2s;cursor:pointer;}
.toggle-slider::before{content:'';position:absolute;width:14px;height:14px;border-radius:50%;left:3px;top:3px;background:#fff;transition:.2s;box-shadow:0 1px 3px rgba(0,0,0,.2);}
.toggle-switch input:checked + .toggle-slider{background:var(--amber);}
.toggle-switch input:checked + .toggle-slider::before{transform:translateX(16px);}
.toggle-label{font-size:.84rem;color:var(--gray-700);}
.partial-amount-field{margin-bottom:16px;}
.partial-amount{width:100%;height:48px;border:2px solid var(--amber-m);border-radius:9px;padding:0 14px 0 30px;font-size:1.1rem;font-weight:700;font-family:monospace;outline:none;background:var(--amber-l);transition:border-color var(--ease);}
.partial-amount:focus{border-color:var(--amber);box-shadow:0 0 0 3px rgba(217,119,6,.1);}
.partial-prefix{position:absolute;left:12px;top:50%;transform:translateY(-50%);font-size:.95rem;font-weight:700;color:var(--gray-500);pointer-events:none;}


/* ---- Pay - Success ---- */
.success-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 16px 80px;}

/* ── Guest notice ── */
.guest-notice{width:100%;max-width:580px;background:var(--green-l);border:1px solid var(--green-m);border-radius:12px;padding:14px 18px;margin-bottom:16px;display:flex;align-items:flex-start;gap:10px;font-size:.85rem;color:#065F46;}
.guest-notice svg{flex-shrink:0;margin-top:1px;}

/* ── Processing note ── */
.processing-note{width:100%;max-width:580px;background:var(--blue-l);border:1px solid var(--blue-m);border-radius:12px;padding:14px 18px;margin-bottom:16px;font-size:.84rem;color:var(--blue);}

/* ── Main card ── */
.success-card{width:100%;max-width:580px;background:var(--white);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-md);overflow:hidden;animation:slideUp .45s ease both;}
@keyframes slideUp{from{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}

/* ── Banner ── */
.card-banner{padding:28px 32px 24px;text-align:center;position:relative;overflow:hidden;}
.card-banner.prepaid{background:linear-gradient(145deg,#EFF6FF 0%,#DBEAFE 100%);border-bottom:1px solid var(--blue-m);}
.card-banner.postpaid{background:linear-gradient(145deg,#CCFBF1 0%,#99F6E4 100%);border-bottom:1px solid #99F6E4;}
.check-wrap{width:80px;height:80px;border-radius:50%;margin:0 auto 18px;display:grid;place-items:center;}
.check-wrap.prepaid{background:rgba(26,86,160,.12);}
.check-wrap.postpaid{background:rgba(14,124,123,.12);}
.check-circle-path{stroke-dasharray:166;stroke-dashoffset:166;stroke-width:3;fill:none;stroke:#DBEAFE;animation:draw .6s cubic-bezier(.65,0,.45,1) forwards;}
.check-tick-path{stroke-dasharray:48;stroke-dashoffset:48;stroke-width:3.5;fill:none;animation:draw .4s .6s cubic-bezier(.65,0,.45,1) forwards;}
.check-tick-path.blue{stroke:var(--blue);}
.check-tick-path.teal{stroke:#0E7C7B;}
@keyframes draw{100%{stroke-dashoffset:0}}
.banner-title{font-family:var(--font-h);font-size:1.5rem;font-weight:800;letter-spacing:-.025em;margin-bottom:6px;}
.banner-title.blue{color:var(--blue);}
.banner-title.teal{color:#0E7C7B;}
.banner-sub{font-size:.9rem;color:var(--gray-500);line-height:1.6;}
.step-done-row{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;flex-wrap:wrap;}
.step-done{display:flex;align-items:center;gap:4px;font-size:.72rem;font-weight:700;padding:3px 10px;border-radius:100px;}
.step-done.blue{background:var(--blue);color:#fff;}
.step-done.teal{background:#0E7C7B;color:#fff;}
.step-done-sep{font-size:.7rem;color:var(--gray-300);}

/* ── Token section ── */
.token-section{padding:24px 28px;}

/* Token card — scoped to payment success page */
.success-card .token-card{background:var(--blue-l);border:2px solid var(--blue-m);border-radius:14px;padding:20px 24px;margin-bottom:4px;}
.success-card .token-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:var(--blue);margin-bottom:10px;display:flex;align-items:center;gap:5px;}
.success-card .token-number{font-family:'JetBrains Mono',monospace;font-size:1.7rem;font-weight:800;color:var(--blue);letter-spacing:.14em;margin-bottom:14px;word-break:break-all;}
.success-card .copy-btn{display:flex;align-items:center;justify-content:center;gap:7px;height:40px;width:100%;background:var(--blue);color:#fff;border-radius:8px;font-size:.88rem;font-weight:700;transition:all var(--ease);cursor:pointer;border:none;}
.success-card .copy-btn:hover{background:var(--blue-d);}
.success-card .copy-btn.copied{background:var(--green);}
.token-delivery{font-size:.78rem;color:var(--gray-400);margin-top:10px;display:flex;align-items:center;gap:5px;}

/* Receipt card (postpaid) — scoped to payment success page */
.success-card .receipt-card{background:#CCFBF1;border:2px solid #99F6E4;border-radius:14px;padding:20px 24px;margin-bottom:4px;}
.success-card .receipt-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.09em;color:#0E7C7B;margin-bottom:10px;}
.success-card .receipt-ref{font-family:'JetBrains Mono',monospace;font-size:1.1rem;font-weight:800;color:#0E7C7B;letter-spacing:.06em;margin-bottom:12px;}
.receipt-rows{display:flex;flex-direction:column;gap:6px;}
.receipt-row{display:flex;justify-content:space-between;font-size:.84rem;}
.receipt-row-label{color:var(--gray-500);}
.receipt-row-value{font-weight:600;color:var(--gray-900);}

/* ── Tx summary ── */
.tx-summary{background:var(--gray-100);border-radius:12px;padding:16px 18px;margin-top:12px;}
.tx-summary-title{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:10px;}
.tx-rows{display:flex;flex-direction:column;gap:7px;}
.tx-row{display:flex;justify-content:space-between;font-size:.84rem;}
.tx-row-label{color:var(--gray-500);}
.tx-row-value{font-weight:600;color:var(--gray-900);}
.tx-row-value.mono{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--blue);}

/* ── Actions ── */
.action-row{display:flex;gap:10px;margin-top:16px;flex-wrap:wrap;}
.btn-download{flex:1;height:42px;border:1.5px solid var(--border);background:var(--white);color:var(--gray-700);border-radius:9px;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--ease);cursor:pointer;min-width:130px;text-decoration:none;}
.btn-download:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l);}
.btn-view{flex:1;height:42px;border:none;background:var(--blue-l);color:var(--blue);border-radius:9px;font-size:.85rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:6px;transition:all var(--ease);cursor:pointer;min-width:130px;text-decoration:none;}
.btn-view:hover{background:var(--blue-m);}

/* ── Bottom links ── */
.bottom-links{display:flex;align-items:center;justify-content:center;gap:20px;padding:18px 28px 24px;border-top:1px solid var(--border);flex-wrap:wrap;}
.bottom-link{font-size:.84rem;font-weight:600;color:var(--blue);display:flex;align-items:center;gap:4px;transition:opacity var(--ease);}
.bottom-link:hover{opacity:.7;}
.bottom-link.muted{color:var(--gray-400);font-weight:400;}

@media(max-width:540px){
  .token-section{padding:20px 18px;}
  .success-card{border-radius:16px;}
  .bottom-links{gap:14px;}
  .token-number{font-size:1.35rem;}
}


/* ---- Pay - Failed ---- */
/* Failed card */
.failed-card{width:100%;max-width:520px;background:var(--white);border:1px solid var(--border);border-radius:20px;box-shadow:var(--shadow-md);overflow:hidden;animation:slideUp .4s ease both;}
to{opacity:1;transform:translateY(0)}}

/* Header */
.fc-header{background:linear-gradient(145deg,#FEF2F2,#FFF1F2);border-bottom:1px solid #FECACA;padding:32px 32px 24px;text-align:center;}
.x-wrap{width:80px;height:80px;border-radius:50%;background:rgba(220,38,38,.1);display:grid;place-items:center;margin:0 auto 18px;position:relative;}
.x-wrap::before{content:'';position:absolute;inset:-8px;border-radius:50%;border:2px solid #FECACA;animation:ringPulse 2.4s ease-out infinite;}
@keyframes ringPulse{0%{opacity:.7;transform:scale(1)}60%{opacity:0;transform:scale(1.2)}100%{opacity:0;transform:scale(1.2)}}
.x-circle{fill:none;stroke:#DC2626;stroke-width:3;stroke-dasharray:166;stroke-dashoffset:166;animation:draw .6s cubic-bezier(.65,0,.45,1) forwards;}
.x-line1,.x-line2{stroke:#DC2626;stroke-width:3.5;stroke-linecap:round;}
.x-line1{stroke-dasharray:30;stroke-dashoffset:30;animation:draw .3s .65s ease forwards;}
.x-line2{stroke-dasharray:30;stroke-dashoffset:30;animation:draw .3s .82s ease forwards;}
@keyframes draw{100%{stroke-dashoffset:0}}
.fc-title{font-family:var(--font-h);font-size:1.5rem;font-weight:800;color:#B91C1C;letter-spacing:-.025em;margin-bottom:8px;}
.fc-sub{font-size:.9rem;color:var(--gray-500);line-height:1.65;}

/* Body */
.fc-body{padding:24px 28px;}

/* Reason box */
.reason-box{background:#FEF2F2;border:1px solid #FECACA;border-left:4px solid #DC2626;border-radius:10px;padding:14px 16px;margin-bottom:20px;}
.reason-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:#DC2626;margin-bottom:6px;}
.reason-text{font-size:.9rem;font-weight:600;color:var(--gray-800);}

/* Not-charged notice */
.not-charged{display:flex;align-items:flex-start;gap:10px;background:var(--green-l);border:1px solid #6EE7B7;border-radius:10px;padding:12px 14px;margin-bottom:22px;}
.nc-icon{width:28px;height:28px;border-radius:7px;background:rgba(5,150,105,.12);display:grid;place-items:center;flex-shrink:0;color:var(--green);}
.nc-text{font-size:.84rem;color:var(--gray-700);line-height:1.55;}
.nc-text strong{display:block;font-weight:700;color:var(--green);margin-bottom:2px;}

/* Buttons */
.fc-action-stack{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;}
.btn-retry{width:100%;height:48px;background:var(--blue);color:#fff;border-radius:10px;font-size:.95rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--ease);text-decoration:none;}
.btn-retry:hover{background:var(--blue-d);box-shadow:0 6px 20px rgba(26,86,160,.25);transform:translateY(-1px);}
.btn-alt{width:100%;height:44px;border:1.5px solid var(--border);background:var(--white);color:var(--gray-700);border-radius:10px;font-size:.88rem;font-weight:600;display:flex;align-items:center;justify-content:center;gap:7px;transition:all var(--ease);text-decoration:none;}
.btn-alt:hover{border-color:var(--blue);color:var(--blue);background:var(--blue-l);}

/* Reference row */
.ref-row{display:flex;align-items:center;justify-content:center;gap:8px;padding-top:16px;border-top:1px solid var(--border);}
.ref-label{font-size:.78rem;color:var(--gray-400);}
.ref-value{font-family:'JetBrains Mono',monospace;font-size:.78rem;color:var(--gray-500);font-weight:600;}
.ref-copy{background:none;border:none;cursor:pointer;color:var(--gray-400);display:flex;padding:2px;border-radius:4px;transition:color var(--ease);}
.ref-copy:hover{color:var(--blue);}

/* Support note */
.support-note{text-align:center;font-size:.82rem;color:var(--gray-400);margin-top:14px;}
.support-note a{color:var(--blue);font-weight:600;text-decoration:none;}
.support-note a:hover{text-decoration:underline;}

/* Page centering */
.failed-wrap{flex:1;display:flex;align-items:center;justify-content:center;padding:40px 16px 80px;}

@media(max-width:540px){.fc-body{padding:20px 18px;}.fc-header{padding:24px 20px 20px;}.failed-card{border-radius:16px;}}


/* ── Sos/Index (page-body pages use .page-body .card for scoping) ── */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes drawCheck{from{stroke-dashoffset:100}to{stroke-dashoffset:0}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.5}}
@keyframes fillProgress{to{stroke-dashoffset:0}}

.page-body{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;padding:40px 24px 80px;}
.page-body .card{background:var(--white);border:1px solid var(--border);border-radius:20px;width:100%;max-width:540px;box-shadow:var(--shadow-md);overflow:hidden;}

/* Header */
.modal-header{padding:24px 28px 20px;display:flex;align-items:flex-start;justify-content:space-between;transition:background .4s;}
.modal-header.state-default{background:var(--red-l);}
.modal-header.state-loading{background:var(--red-l);}
.modal-header.state-success{background:var(--green-l);}
.modal-header.state-fail{background:var(--red-l);}
.mh-left{display:flex;align-items:center;gap:12px;}
.mh-icon{width:40px;height:40px;border-radius:50%;display:grid;place-items:center;flex-shrink:0;}
.mh-icon.red{background:var(--red);color:#fff;}
.mh-icon.green{background:var(--green);color:#fff;}
.mh-icon svg{width:20px;height:20px;}
.modal-title{font-family:var(--font-h);font-size:1.2rem;font-weight:800;line-height:1.2;}
.modal-title.red{color:var(--red);}
.modal-title.green{color:var(--green);}
.modal-subtitle{font-size:.8rem;margin-top:2px;}
.modal-subtitle.red{color:#991B1B;}
.modal-subtitle.green{color:#065F46;}

/* Body */
.modal-body{padding:24px 28px 28px;}

/* Ineligible notice */
.ineligible-card{background:var(--gray-100);border:1px solid var(--gray-200);border-left:4px solid var(--gray-400);border-radius:12px;padding:18px 20px;margin-bottom:20px;text-align:center;}
.ineligible-title{font-weight:700;font-size:.95rem;color:var(--gray-700);margin-bottom:6px;}
.ineligible-text{font-size:.84rem;color:var(--gray-500);line-height:1.6;}

/* Eligibility card */
.elig-card{border:1px solid var(--red-m);border-left:4px solid var(--red);border-radius:12px;padding:14px 16px;margin-bottom:20px;background:var(--red-l);}
.elig-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;}
.elig-tier{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;background:var(--red);color:#fff;font-size:.71rem;font-weight:800;}
.elig-limit-label{font-size:.75rem;color:#991B1B;font-weight:600;margin-bottom:6px;}
.elig-bar-wrap{background:rgba(220,38,38,.15);border-radius:100px;height:8px;overflow:hidden;}
.elig-bar-fill{height:100%;background:var(--green);border-radius:100px;}
.elig-bar-text{font-size:.72rem;color:#991B1B;margin-top:4px;}

/* Meter picker */
.section-label{font-size:.70rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:10px;}
.sm-list{display:flex;flex-direction:column;gap:8px;margin-bottom:20px;}
.sm-card{display:flex;align-items:center;gap:12px;border:2px solid var(--border);border-radius:12px;padding:12px 14px;cursor:pointer;transition:all var(--ease);}
.sm-card:hover{border-color:var(--red-m);background:var(--red-l);}
.sm-card.selected{border-color:var(--red);background:var(--red-l);}
.sm-badge{flex-shrink:0;padding:3px 10px;border-radius:100px;font-size:.70rem;font-weight:800;color:#fff;}
.sm-body{flex:1;min-width:0;}
.sm-nick{font-size:.88rem;font-weight:700;color:var(--gray-900);}
.sm-card.selected .sm-nick{color:var(--red-d);}
.sm-meta{font-size:.76rem;color:var(--gray-500);margin-top:2px;}
.sm-meta .mono{font-family:var(--mono);font-size:.74rem;}
.sm-check{width:22px;height:22px;background:var(--red);border-radius:50%;display:grid;place-items:center;flex-shrink:0;opacity:0;transition:opacity var(--ease);}
.sm-check svg{width:11px;height:11px;}
.sm-card.selected .sm-check{opacity:1;}

/* Amount pills */
.amt-label{font-size:.78rem;font-weight:700;color:var(--gray-700);margin-bottom:12px;}
.amount-pills{display:flex;gap:10px;margin-bottom:20px;}
.amt-pill{flex:1;height:56px;min-width:80px;border-radius:12px;font-family:var(--font-h);font-size:.95rem;font-weight:800;color:var(--red);background:var(--white);border:2px solid var(--red-m);transition:all var(--ease);cursor:pointer;}
.amt-pill:hover{background:var(--red-l);}
.amt-pill.act{background:var(--red);color:#fff;border-color:var(--red);}

/* Repayment notice */
.repay-card{background:var(--amber-l);border:1px solid var(--amber-m);border-radius:12px;padding:16px;margin-bottom:20px;}
.repay-title{font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:#92400E;margin-bottom:10px;}
.repay-rows{display:flex;flex-direction:column;gap:6px;}
.repay-row{display:flex;justify-content:space-between;font-size:.84rem;color:var(--gray-700);}
.repay-row.total{font-weight:800;color:var(--gray-900);padding-top:8px;border-top:1px solid var(--amber-m);margin-top:4px;}
.repay-row span:last-child{font-weight:700;}
.repay-row.total span:last-child{font-size:1rem;color:var(--red);}

/* CTA */
.btn-sos{width:100%;height:52px;background:var(--red);color:#fff;border-radius:12px;font-family:var(--font-h);font-size:1rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:9px;transition:all var(--ease);letter-spacing:-.01em;border:none;cursor:pointer;}
.btn-sos:hover:not(:disabled){background:var(--red-d);}
.btn-sos:disabled{opacity:.55;cursor:not-allowed;}
.cancel-link{display:block;text-align:center;margin-top:14px;font-size:.82rem;color:var(--gray-400);font-weight:500;text-decoration:none;}
.cancel-link:hover{color:var(--gray-700);}

/* Loading */
.loading-wrap{text-align:center;padding:8px 0 16px;}
.progress-ring{position:relative;width:56px;height:56px;margin:0 auto 16px;}
.progress-ring svg{width:56px;height:56px;transform:rotate(-90deg);}
.progress-ring circle{fill:none;stroke-width:4;stroke-linecap:round;}
.pr-bg{stroke:var(--red-m);}
.pr-fill{stroke:var(--red);stroke-dasharray:151;stroke-dashoffset:151;animation:fillProgress 3.5s ease-out forwards;}
.loading-pulse{font-size:.84rem;color:var(--gray-500);animation:pulse 1.2s infinite;}

/* Success */
.success-wrap{text-align:center;padding:4px 0 8px;animation:fadeIn .4s;}
.check-ring{width:72px;height:72px;margin:0 auto 16px;}
.check-ring svg{width:72px;height:72px;}
.success-title{font-family:var(--font-h);font-size:1.15rem;font-weight:800;color:var(--green);margin-bottom:6px;}
.success-sub{font-size:.84rem;color:var(--gray-500);margin-bottom:20px;line-height:1.5;}
.token-box{background:var(--green-l);border:1px solid var(--green-m);border-radius:12px;padding:20px;margin-bottom:16px;text-align:center;}
.token-label{font-size:.70rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--green);margin-bottom:8px;}
.token-val{font-family:var(--mono);font-size:1.4rem;font-weight:700;color:var(--gray-900);letter-spacing:.12em;line-height:1.3;word-break:break-all;}
.btn-copy-tok{width:100%;height:42px;background:var(--white);border:2px solid var(--green-m);border-radius:9px;font-size:.84rem;font-weight:700;color:var(--green);display:flex;align-items:center;justify-content:center;gap:7px;margin-top:12px;transition:all var(--ease);cursor:pointer;}
.btn-copy-tok:hover{background:var(--green-l);}
.btn-copy-tok.ok{background:var(--green-l);border-color:var(--green);}
.btn-copy-tok svg{width:14px;height:14px;}
.btn-done{width:100%;height:48px;background:var(--green);color:#fff;border-radius:12px;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;transition:all var(--ease);margin-top:4px;text-decoration:none;}
.btn-done:hover{background:#047857;}

/* Fail */
.fail-banner{background:var(--red-l);border:1px solid var(--red-m);border-radius:10px;padding:14px 16px;margin-bottom:20px;text-align:center;}
.fail-title{font-weight:700;color:var(--red);margin-bottom:4px;font-size:.9rem;}
.fail-text{font-size:.82rem;color:var(--gray-500);}
.fail-btns{display:flex;gap:10px;}
.btn-try{flex:1;height:44px;background:var(--red);color:#fff;border-radius:10px;font-size:.875rem;font-weight:700;transition:all var(--ease);border:none;cursor:pointer;}
.btn-try:hover{background:var(--red-d);}
.btn-cancel-fail{flex:1;height:44px;background:var(--white);border:2px solid var(--border);border-radius:10px;font-size:.875rem;font-weight:600;color:var(--gray-600);transition:all var(--ease);cursor:pointer;}
.btn-cancel-fail:hover{border-color:var(--gray-400);}

.spinner-sm{width:18px;height:18px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0;}

@media(max-width:600px){.amount-pills{flex-direction:column;}.amt-pill{height:48px;}}


/* ── Account/SavedAccounts ─────────────────────────────────────── */
/* ── Wizard step indicator ── */
.wiz-steps{display:flex;align-items:flex-start;margin-bottom:24px;}
.wiz-s-wrap{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;}
.wiz-s-circle{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;font-size:.71rem;font-weight:800;transition:all .2s;}
.wiz-s-circle.done{background:var(--teal);color:#fff;}
.wiz-s-circle.active{background:var(--blue);color:#fff;box-shadow:0 0 0 3px var(--blue-m);}
.wiz-s-circle.todo{background:var(--gray-100);color:var(--gray-400);}
.wiz-s-label{font-size:.63rem;font-weight:700;white-space:nowrap;}
.wiz-s-label.active{color:var(--blue);}
.wiz-s-label.done{color:var(--teal);}
.wiz-s-label.todo{color:var(--gray-400);}
.wiz-s-line{flex:1;height:2px;margin:13px 4px 0;transition:background .2s;}
.wiz-s-line.done{background:var(--teal);}
.wiz-s-line.todo{background:var(--gray-200);}
/* ── DISCO grid ── */
.disco-grid-sm{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:6px;}
.disco-card-sm{border:2px solid var(--border);border-radius:10px;padding:10px 6px;text-align:center;cursor:pointer;transition:all var(--ease);}
.disco-card-sm:hover{border-color:var(--blue-m);background:var(--blue-l);}
.disco-card-sm.sel{border-color:var(--blue);background:var(--blue-l);}
.disco-av-sm{width:32px;height:32px;border-radius:8px;display:grid;place-items:center;margin:0 auto 5px;font-size:.6rem;font-weight:800;color:#fff;letter-spacing:.02em;}
.disco-code-sm{font-size:.68rem;font-weight:800;color:var(--gray-700);}
.disco-card-sm.sel .disco-code-sm{color:var(--blue);}
.disco-nm-sm{font-size:.60rem;color:var(--gray-500);margin-top:1px;line-height:1.3;}
/* ── Category cards ── */
.cat-cards{display:flex;gap:12px;margin-bottom:8px;}
.cat-card{flex:1;border:2px solid var(--border);border-radius:14px;padding:22px 16px;cursor:pointer;transition:all var(--ease);text-align:center;}
.cat-card:hover{border-color:var(--gray-200);transform:translateY(-1px);}
.cat-card.sel-prepaid{border-color:var(--amber);background:var(--amber-l);}
.cat-card.sel-postpaid{border-color:var(--teal);background:var(--teal-l);}
.cat-card-icon{font-size:2.2rem;margin-bottom:10px;}
.cat-card-title{font-family:var(--font-h);font-size:.95rem;font-weight:800;color:var(--gray-900);}
.cat-card-desc{font-size:.76rem;color:var(--gray-500);margin-top:5px;line-height:1.5;}
/* ── Shared wizard elements ── */
.wiz-step-q{font-family:var(--font-h);font-size:.98rem;font-weight:800;color:var(--gray-900);margin-bottom:16px;}
.wiz-summary{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:14px;}
.wiz-chip{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;font-size:.73rem;font-weight:700;background:var(--blue-l);color:var(--blue);border:1px solid var(--blue-m);}
.wiz-nav{display:flex;align-items:center;justify-content:space-between;margin-top:20px;padding-top:16px;border-top:1px solid var(--border);}
.btn-wiz-back{height:38px;padding:0 16px;background:#fff;border:1.5px solid var(--border);border-radius:9px;font-size:.83rem;font-weight:700;color:var(--gray-600);cursor:pointer;transition:all var(--ease);}
.btn-wiz-back:hover{border-color:var(--gray-400);}
.btn-wiz-next{height:38px;padding:0 18px;background:var(--blue);color:#fff;border:none;border-radius:9px;font-size:.83rem;font-weight:700;cursor:pointer;transition:all var(--ease);}
.btn-wiz-next:hover:not(:disabled){background:var(--blue-d);}
.btn-wiz-next:disabled,.btn-wiz-save:disabled{opacity:.4;cursor:not-allowed;}
.btn-wiz-save{height:38px;padding:0 20px;background:var(--teal);color:#fff;border:none;border-radius:9px;font-size:.83rem;font-weight:700;cursor:pointer;transition:all var(--ease);}
.btn-wiz-save:hover:not(:disabled){background:#0A5E5D;}
/* ── Nickname error ── */
.nick-error{font-size:.76rem;color:var(--red);font-weight:600;margin-top:4px;min-height:16px;}
@media(max-width:600px){
  .disco-grid-sm{grid-template-columns:repeat(3,1fr);}
  .cat-cards{flex-direction:column;}
  .wiz-s-label{display:none;}
}


/* ── Vault/Index ───────────────────────────────────────────────── */
/* TABS */
.tabs-wrap{background:#fff;border-bottom:1px solid var(--border);}
.tabs{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;}
.tab{display:inline-flex;align-items:center;gap:7px;height:48px;padding:0 18px;font-size:.875rem;font-weight:600;color:var(--gray-400);border-bottom:2px solid transparent;text-decoration:none;transition:all var(--ease);margin-bottom:-1px;}
.tab:hover{color:var(--gray-700);}
.tab.act{color:var(--blue);border-bottom-color:var(--blue);}
.tab svg{width:16px;height:16px;flex-shrink:0;}
/* PAGE HEADER */
.ph-wrap{background:#fff;border-bottom:1px solid var(--border);}
.ph{max-width:1280px;margin:0 auto;padding:22px 24px 18px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:16px;}
.ph-title-row{display:flex;align-items:center;gap:11px;}
.ph-icon{width:40px;height:40px;background:var(--teal-l);border-radius:10px;display:grid;place-items:center;color:var(--teal);}
.ph-title{font-family:var(--font-h);font-size:1.45rem;font-weight:800;color:var(--gray-900);letter-spacing:-.025em;}
.ph-sub{font-size:.84rem;color:var(--gray-400);margin-top:3px;margin-left:51px;}
.btn-ghost{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 16px;background:#fff;border:1.5px solid var(--border);border-radius:8px;font-size:.84rem;font-weight:700;color:var(--gray-700);text-decoration:none;transition:all var(--ease);}
.btn-ghost:hover{border-color:var(--teal);color:var(--teal);background:var(--teal-l);}
.btn-ghost svg{width:15px;height:15px;}
/* MAIN */
.main{max-width:1280px;margin:0 auto;padding:28px 24px 80px;}
/* FILTER BAR */
.fb{background:#fff;border:1px solid var(--border);border-radius:14px;padding:16px 20px;margin-bottom:14px;box-shadow:var(--shadow-sm);}
.fb-row{display:grid;grid-template-columns:1fr 160px 134px 134px auto auto;gap:12px;align-items:end;}
.fg{display:flex;flex-direction:column;gap:5px;}
.fl{font-size:.70rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);}
.fi,.fs{height:38px;border:1.5px solid var(--border);border-radius:8px;padding:0 12px;font-size:.84rem;font-family:var(--font);color:var(--gray-700);background:#fff;outline:none;width:100%;transition:border-color var(--ease);}
.fi:focus,.fs:focus{border-color:var(--blue);}
.fi-rel{position:relative;}
.fi-rel svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--gray-400);width:15px;height:15px;pointer-events:none;}
.fi.search-fi{padding-left:36px;}
.cat-wrap{display:flex;gap:4px;}
.cat-btn{height:38px;padding:0 12px;border-radius:8px;font-size:.82rem;font-weight:600;color:var(--gray-500);background:transparent;border:1.5px solid var(--border);cursor:pointer;transition:all var(--ease);}
.cat-btn.act{background:var(--blue-l);color:var(--blue);border-color:var(--blue-m);}
.cat-btn:hover:not(.act){background:var(--gray-100);color:var(--gray-800);}
.btn-filter{height:38px;padding:0 20px;background:var(--blue);color:#fff;border-radius:8px;font-weight:700;font-size:.84rem;border:none;cursor:pointer;white-space:nowrap;}
.btn-filter:hover{background:var(--blue-d);}
/* RESULTS ROW */
.res-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px;}
.res-text{font-size:.82rem;color:var(--gray-400);font-weight:500;}
.res-text strong{color:var(--gray-700);}
.res-total{font-size:.82rem;font-weight:700;color:var(--teal);}
/* TABLE CARD */
.tc{background:#fff;border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;}
.vt{width:100%;border-collapse:collapse;}
.vt thead th{padding:11px 16px;font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);text-align:left;border-bottom:1px solid var(--border);background:var(--surface);white-space:nowrap;}
.vt tbody tr{border-bottom:1px solid var(--border);transition:background var(--ease);}
.vt tbody tr:last-child{border-bottom:none;}
.vt tbody tr:hover{background:#F8FBFF;}
.vt td{padding:13px 16px;font-size:.84rem;vertical-align:middle;}
.d-main{font-weight:600;color:var(--gray-800);font-size:.83rem;}
.d-time{font-size:.71rem;color:var(--gray-400);margin-top:1px;font-family:var(--mono);}
.disco-cell{display:flex;align-items:center;gap:9px;}
.disco-av{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;font-size:.62rem;font-weight:800;color:#fff;flex-shrink:0;}
.disco-nm{font-weight:600;color:var(--gray-800);font-size:.83rem;white-space:nowrap;}
.meter-v{font-family:var(--mono);font-size:.77rem;color:var(--gray-500);letter-spacing:.02em;}
.amt-v{font-weight:700;color:var(--gray-900);}
.amt-f{font-size:.71rem;color:var(--gray-400);margin-top:1px;}
.bdg{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:.70rem;font-weight:700;white-space:nowrap;}
.bdg-pre{background:var(--amber-l);color:#92400E;}
.bdg-post{background:var(--blue-l);color:#1E40AF;}
.tok-wrap{display:flex;align-items:center;gap:10px;min-width:0;}
.tok-meta{min-width:0;flex:1;}
.tok-lbl{font-size:.67rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);margin-bottom:2px;}
.tok-val{font-family:var(--mono);font-size:.82rem;font-weight:600;color:var(--gray-900);letter-spacing:.04em;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.tok-val.ref{color:var(--gray-500);font-size:.78rem;}
.btn-copy{display:inline-flex;align-items:center;gap:5px;height:30px;padding:0 11px;background:var(--gray-100);border:1px solid var(--gray-200);border-radius:7px;font-size:.72rem;font-weight:700;color:var(--gray-600);cursor:pointer;transition:all var(--ease);flex-shrink:0;white-space:nowrap;}
.btn-copy:hover{background:var(--blue-l);border-color:var(--blue-m);color:var(--blue);}
.btn-copy.ok{background:var(--green-l);border-color:var(--green-m);color:var(--green);}
.btn-copy svg{width:12px;height:12px;}
/* PAGINATION */
.pag{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid var(--border);}
.pag-info{font-size:.82rem;color:var(--gray-400);}
.pag-btns{display:flex;gap:4px;}
.pag-btn{width:34px;height:34px;border-radius:8px;background:transparent;border:1.5px solid var(--border);font-size:.82rem;font-weight:600;color:var(--gray-600);display:grid;place-items:center;text-decoration:none;transition:all var(--ease);}
.pag-btn:hover{background:var(--blue-l);border-color:var(--blue-m);color:var(--blue);}
.pag-btn.act{background:var(--blue);border-color:var(--blue);color:#fff;}
/* EMPTY */
.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:72px 24px;text-align:center;}
.empty-ring{width:80px;height:80px;background:var(--teal-l);border-radius:50%;display:grid;place-items:center;margin-bottom:20px;color:var(--teal);}
.empty-h{font-family:var(--font-h);font-size:1.08rem;font-weight:800;color:var(--gray-800);margin-bottom:8px;}
.empty-p{font-size:.875rem;color:var(--gray-400);line-height:1.7;max-width:300px;margin-bottom:24px;}
.btn-prim{display:inline-flex;align-items:center;gap:7px;height:42px;padding:0 22px;background:var(--blue);color:#fff;border-radius:9px;font-size:.875rem;font-weight:700;text-decoration:none;transition:all var(--ease);}
.btn-prim:hover{background:var(--blue-d);}
/* TOAST */
.toast-c{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column;gap:8px;}
.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--gray-900);color:#fff;border-radius:10px;font-size:.84rem;font-weight:500;box-shadow:var(--shadow-md);animation:tin .3s ease-out;}
.toast svg{color:var(--green-m);width:16px;height:16px;flex-shrink:0;}
@keyframes tin{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
@media(max-width:900px){.fb-row{grid-template-columns:1fr 1fr;}.vt{display:none;}}
@media(max-width:640px){.fb-row{grid-template-columns:1fr;}}


/* ── Schedules/Index ───────────────────────────────────────────── */
/* PAGE HEADER */
.ph-wrap{background:var(--white);border-bottom:1px solid var(--border);}
.ph{max-width:1280px;margin:0 auto;padding:22px 24px 18px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:16px;}
.ph-title{font-family:var(--font-h);font-size:1.45rem;font-weight:800;color:var(--gray-900);letter-spacing:-.025em;}
.ph-sub{font-size:.84rem;color:var(--gray-400);margin-top:3px;}
.btn-create{display:inline-flex;align-items:center;gap:8px;height:44px;padding:0 22px;background:var(--blue);color:#fff;border-radius:10px;font-size:.875rem;font-weight:700;text-decoration:none;transition:all var(--ease);}
.btn-create:hover{background:var(--blue-d);}
.btn-create svg{width:16px;height:16px;}
/* MAIN */
.main{max-width:1280px;margin:0 auto;padding:24px 24px 80px;}
.layout{display:grid;grid-template-columns:1fr 280px;gap:24px;align-items:start;}
/* WALLET STRIP */
.wallet-strip{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:14px 18px;margin-bottom:16px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm);}
.ws-left{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--gray-600);}
.ws-left svg{width:16px;height:16px;color:var(--teal);flex-shrink:0;}
.ws-bal{font-weight:700;color:var(--gray-900);}
.ws-link{font-size:.84rem;font-weight:700;color:var(--teal);text-decoration:none;}
.ws-link:hover{text-decoration:underline;}
/* SCHEDULE CARDS */
.sched-list{display:flex;flex-direction:column;gap:14px;}
.scard{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:18px;box-shadow:var(--shadow-sm);transition:box-shadow var(--ease),transform var(--ease);position:relative;overflow:hidden;}
.scard::before{content:'';position:absolute;left:0;top:0;bottom:0;width:4px;border-radius:4px 0 0 4px;}
.scard:hover:not(.paused){box-shadow:var(--shadow-md);transform:translateY(-2px);}
.scard.paused{opacity:.8;}
.scard.paused::before{background:var(--gray-300)!important;}
.sc-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.sc-nick{font-family:var(--font-h);font-size:1rem;font-weight:800;color:var(--gray-900);}
.sc-top-right{display:flex;align-items:center;gap:8px;flex-wrap:wrap;}
.bdg{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:100px;font-size:.71rem;font-weight:700;}
.bdg-active{background:var(--green-l);color:#065F46;}
.bdg-paused{background:var(--gray-100);color:var(--gray-500);}
.bdg-soon{background:var(--teal-l);color:var(--teal);}
.bdg svg{width:10px;height:10px;}
.sc-mid{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:12px;gap:12px;flex-wrap:wrap;}
.sc-disco{display:flex;align-items:center;gap:9px;}
.disco-av{width:28px;height:28px;border-radius:7px;display:grid;place-items:center;font-size:.6rem;font-weight:800;color:#fff;flex-shrink:0;}
.disco-nm{font-weight:600;color:var(--gray-800);font-size:.875rem;}
.disco-meter{font-family:var(--mono);font-size:.73rem;color:var(--gray-400);margin-top:1px;}
.sc-amount{font-family:var(--font-h);font-size:1.3rem;font-weight:800;color:var(--blue);letter-spacing:-.02em;white-space:nowrap;}
.sc-freq{display:flex;align-items:center;gap:8px;margin-bottom:12px;font-size:.84rem;color:var(--gray-500);}
.sc-freq svg{width:15px;height:15px;color:var(--gray-400);flex-shrink:0;}
.sc-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;}
.sc-runs{display:flex;flex-direction:column;gap:3px;}
.sc-next{font-size:.8rem;color:var(--gray-500);}
.sc-next strong{color:var(--gray-700);}
.sc-last-ok{font-size:.78rem;color:var(--green);}
.sc-last-warn{font-size:.78rem;color:var(--amber);}
.sc-last-fail{font-size:.78rem;color:var(--red);}
.sc-last-none{font-size:.78rem;color:var(--gray-400);}
.sc-actions{display:flex;align-items:center;gap:6px;}
.btn-pause,.btn-resume,.btn-edit{height:32px;padding:0 14px;border-radius:8px;font-size:.78rem;font-weight:700;cursor:pointer;transition:all var(--ease);text-decoration:none;display:inline-flex;align-items:center;}
.btn-edit{background:var(--blue-l);border:1px solid var(--blue-m);color:var(--blue);}
.btn-edit:hover{background:var(--blue-m);}
.btn-pause{background:var(--gray-100);border:1px solid var(--gray-200);color:var(--gray-600);}
.btn-pause:hover{background:var(--amber-l);border-color:var(--amber-m);color:var(--amber);}
.btn-resume{background:var(--green-l);border:1px solid var(--green-m);color:var(--green);}
.btn-resume:hover{background:#BBF7D0;border-color:var(--green);}
.del-confirm{background:var(--red-l);border:1px solid var(--red-m);border-radius:8px;padding:12px 14px;margin-top:10px;display:none;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;}
.del-confirm.open{display:flex;}
.del-text{font-size:.82rem;font-weight:600;color:#991B1B;}
.del-btns{display:flex;gap:8px;}
.btn-del-confirm{height:30px;padding:0 14px;background:var(--red);color:#fff;border-radius:7px;font-size:.78rem;font-weight:700;cursor:pointer;border:none;transition:all var(--ease);}
.btn-del-cancel{height:30px;padding:0 14px;background:var(--white);border:1px solid var(--border);border-radius:7px;font-size:.78rem;font-weight:600;color:var(--gray-600);cursor:pointer;transition:all var(--ease);}
/* TIMELINE SIDEBAR — scoped to avoid overriding transaction detail timeline */
.timeline-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:20px;box-shadow:var(--shadow-sm);position:sticky;top:88px;}
.timeline-card .tl-title{font-family:var(--font-h);font-size:.9rem;font-weight:800;color:var(--gray-900);margin-bottom:4px;}
.timeline-card .tl-sub{font-size:.75rem;color:var(--gray-400);margin-bottom:20px;}
.timeline-card .tl-list{display:flex;flex-direction:column;}
.timeline-card .tl-item{display:flex;align-items:flex-start;gap:12px;padding-bottom:18px;position:relative;}
.timeline-card .tl-item:not(:last-child)::before{content:'';position:absolute;left:7px;top:16px;bottom:0;width:1px;background:var(--border);}
.timeline-card .tl-dot{width:15px;height:15px;border-radius:50%;flex-shrink:0;margin-top:2px;border:2.5px solid #fff;box-shadow:0 0 0 1.5px currentColor;}
.timeline-card .tl-when{font-size:.78rem;font-weight:700;color:var(--gray-800);}
.timeline-card .tl-desc{font-size:.75rem;color:var(--gray-400);margin-top:1px;}
/* EMPTY STATE */
.empty{display:flex;flex-direction:column;align-items:center;padding:64px 24px;text-align:center;background:var(--white);border:1px solid var(--border);border-radius:14px;}
.empty-ring{width:88px;height:88px;background:var(--blue-l);border-radius:50%;display:grid;place-items:center;margin-bottom:20px;color:var(--blue);}
.empty-h{font-family:var(--font-h);font-size:1.08rem;font-weight:800;color:var(--gray-800);margin-bottom:8px;}
.empty-p{font-size:.875rem;color:var(--gray-400);line-height:1.7;max-width:320px;margin-bottom:24px;}
.btn-prim{display:inline-flex;align-items:center;gap:7px;height:44px;padding:0 22px;background:var(--blue);color:#fff;border-radius:10px;font-size:.875rem;font-weight:700;text-decoration:none;transition:all var(--ease);}
.btn-prim:hover{background:var(--blue-d);}
/* TOAST */
.toast-c{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column;gap:8px;}
.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--gray-900);color:#fff;border-radius:10px;font-size:.84rem;font-weight:500;box-shadow:var(--shadow-md);animation:tin .3s ease-out;max-width:340px;}
.toast.out{animation:tout .25s forwards;}
.toast svg{width:16px;height:16px;color:var(--green-m);flex-shrink:0;}
@keyframes tin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes tout{to{opacity:0;transform:translateY(8px)}}
@media(max-width:1100px){.layout{grid-template-columns:1fr;}}
@media(max-width:640px){.main{padding:20px 16px 100px;}}


/* ── WhatsApp/SetPin ───────────────────────────────────────────── */
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.page-body{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px 80px;}
.page-body .card{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:40px 36px;width:100%;max-width:460px;box-shadow:var(--shadow-md);}
/* step indicator */
.steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:28px;}
.s-wrap{display:flex;flex-direction:column;align-items:center;gap:5px;}
.s-circle{width:28px;height:28px;border-radius:50%;display:grid;place-items:center;font-size:.72rem;font-weight:800;flex-shrink:0;}
.s-circle.done{background:var(--wa);color:#fff;}
.s-circle.active{background:var(--amber);color:#fff;box-shadow:0 0 0 3px var(--amber-m);}
.s-label{font-size:.65rem;font-weight:700;color:var(--gray-400);white-space:nowrap;}
.s-label.active{color:var(--amber);}
.s-label.done{color:var(--wa);}
.s-line{width:40px;height:2px;background:var(--wa);margin-bottom:16px;}
/* header */
.icon-wrap{width:64px;height:64px;border-radius:50%;background:var(--amber-l);border:2px solid var(--amber-m);display:grid;place-items:center;margin:0 auto 18px;}
.card-title{font-family:var(--font-h);font-size:1.25rem;font-weight:800;color:var(--gray-900);text-align:center;letter-spacing:-.025em;margin-bottom:6px;}
.card-sub{font-size:.84rem;color:var(--gray-500);text-align:center;line-height:1.6;margin-bottom:28px;}
/* pin boxes */
.pin-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-500);text-align:center;margin-bottom:10px;}
.pin-row{display:flex;gap:10px;justify-content:center;margin-bottom:6px;}
.pin-box{width:56px;height:64px;border:2px solid var(--border);border-radius:12px;text-align:center;font-size:1.5rem;font-weight:800;font-family:var(--font-h);color:var(--gray-900);outline:none;transition:all var(--ease);}
.pin-box:focus{border-color:var(--amber);box-shadow:0 0 0 3px var(--amber-m);}
.pin-box.filled{border-color:var(--amber);background:var(--amber-l);}
.pin-box.error{border-color:var(--red);animation:shake .3s;}
.pin-error{text-align:center;font-size:.8rem;font-weight:600;color:var(--red);min-height:18px;margin-bottom:16px;}
/* button */
.btn-finish{width:100%;height:52px;background:var(--wa);color:#fff;border-radius:12px;font-size:.95rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:pointer;transition:all var(--ease);font-family:var(--font-h);}
.btn-finish:hover{background:var(--wa-d);}
.skip-link{display:block;text-align:center;margin-top:14px;font-size:.82rem;color:var(--gray-400);text-decoration:none;}
.skip-link:hover{color:var(--gray-700);}
.text-danger{font-size:.82rem;color:var(--red);display:block;text-align:center;margin-bottom:12px;}
@media(max-width:400px){.pin-box{width:48px;height:56px;font-size:1.3rem;}}


/* ── WhatsApp/Guide ────────────────────────────────────────────── */
@keyframes tin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@keyframes tout{to{opacity:0;transform:translateY(8px)}}
.wa-guide-wrap .ph-wrap{background:var(--white);border-bottom:1px solid var(--border);}
.wa-guide-wrap .ph{max-width:720px;margin:0 auto;padding:26px 24px 20px;display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.ph-left{display:flex;align-items:center;gap:14px;}
.wa-badge{width:48px;height:48px;background:var(--wa);border-radius:14px;display:grid;place-items:center;flex-shrink:0;}
.wa-guide-wrap .ph-title{font-family:var(--font-h);font-size:1.4rem;font-weight:800;color:var(--gray-900);letter-spacing:-.025em;}
.wa-guide-wrap .ph-sub{font-size:.84rem;color:var(--gray-400);margin-top:3px;}
.wa-status{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:100px;font-size:.78rem;font-weight:700;}
.wa-status.active{background:var(--wa-l);border:1px solid var(--wa-m);color:var(--wa-d);}
.wa-status.inactive{background:var(--amber-l);border:1px solid var(--amber-m);color:#92400E;}
.wa-dot{width:7px;height:7px;background:var(--wa);border-radius:50%;}
.wa-guide-wrap .main{max-width:720px;margin:0 auto;padding:28px 24px 80px;}
.not-linked-banner{display:flex;align-items:center;justify-content:space-between;background:var(--amber-l);border:1px solid var(--amber-m);border-radius:12px;padding:14px 18px;margin-bottom:20px;flex-wrap:wrap;gap:10px;}
.nlb-left{display:flex;align-items:center;gap:9px;}
.nlb-left svg{width:16px;height:16px;color:var(--amber);}
.nlb-text{font-size:.875rem;font-weight:600;color:#92400E;}
.btn-link-now{height:36px;padding:0 16px;background:var(--wa);color:#fff;border-radius:8px;font-size:.82rem;font-weight:700;display:inline-flex;align-items:center;gap:6px;text-decoration:none;transition:all var(--ease);}
.btn-link-now:hover{background:var(--wa-d);}
.bot-card{background:var(--white);border:1px solid var(--border);border-radius:16px;padding:20px 24px;margin-bottom:24px;box-shadow:var(--shadow-sm);display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;}
.bc-label{font-size:.70rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--wa-d);margin-bottom:5px;}
.bc-number{font-family:var(--mono);font-size:1.35rem;font-weight:700;color:var(--gray-900);letter-spacing:.04em;}
.bc-hint{font-size:.75rem;color:var(--gray-400);margin-top:3px;}
.bc-actions{display:flex;gap:8px;flex-shrink:0;}
.btn-copy-num{height:38px;padding:0 16px;background:var(--wa-l);border:1.5px solid var(--wa-m);border-radius:9px;font-size:.82rem;font-weight:700;color:var(--wa-d);display:inline-flex;align-items:center;gap:7px;cursor:pointer;border:1.5px solid var(--wa-m);transition:all var(--ease);}
.btn-copy-num:hover,.btn-copy-num.ok{background:var(--wa);color:#fff;border-color:var(--wa);}
.btn-msg{height:38px;padding:0 16px;background:var(--wa);border-radius:9px;font-size:.82rem;font-weight:700;color:#fff;display:inline-flex;align-items:center;gap:7px;text-decoration:none;transition:all var(--ease);}
.btn-msg:hover{background:var(--wa-d);}
.sec-title{font-family:var(--font-h);font-size:.95rem;font-weight:800;color:var(--gray-900);margin-bottom:12px;display:flex;align-items:center;gap:8px;}
.sec-title svg{width:15px;height:15px;color:var(--gray-400);}
.cmds-card{background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:24px;box-shadow:var(--shadow-sm);}
.cmd-hdr{display:grid;grid-template-columns:220px 1fr 90px;padding:10px 18px;background:var(--surface);border-bottom:1px solid var(--border);}
.cmd-hdr span{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);}
.cmd-row{display:grid;grid-template-columns:220px 1fr 90px;align-items:center;padding:13px 18px;border-bottom:1px solid var(--border);transition:background var(--ease);}
.cmd-row:last-child{border-bottom:none;}
.cmd-row:hover{background:var(--surface);}
.cmd-pill{display:inline-flex;background:var(--teal-l);border:1px solid var(--teal-m);border-radius:7px;padding:5px 10px;font-family:var(--mono);font-size:.79rem;font-weight:700;color:var(--teal);}
.cmd-desc{font-size:.83rem;color:var(--gray-600);line-height:1.5;padding:0 14px;}
.btn-try{height:30px;padding:0 12px;background:var(--wa-l);border:1px solid var(--wa-m);border-radius:7px;font-size:.74rem;font-weight:700;color:var(--wa-d);display:inline-flex;align-items:center;gap:4px;text-decoration:none;transition:all var(--ease);white-space:nowrap;}
.btn-try:hover{background:var(--wa);color:#fff;border-color:var(--wa);}
.chat-card{background:var(--white);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:24px;box-shadow:var(--shadow-sm);}
.chat-hdr{background:#075E54;padding:13px 16px;display:flex;align-items:center;gap:10px;}
.chat-av{width:34px;height:34px;background:var(--wa);border-radius:50%;display:grid;place-items:center;flex-shrink:0;}
.chat-name{font-weight:700;font-size:.88rem;color:#fff;}
.chat-sub{font-size:.71rem;color:rgba(255,255,255,.6);margin-top:1px;}
.chat-body{background:#ECE5DD;padding:18px 14px;display:flex;flex-direction:column;gap:10px;}
.bubble{max-width:76%;padding:10px 13px;border-radius:12px;font-size:.84rem;line-height:1.55;}
.bu{background:#DCF8C6;border-radius:12px 12px 2px 12px;align-self:flex-end;color:#1F2937;}
.bb{background:#fff;border-radius:12px 12px 12px 2px;align-self:flex-start;color:#1F2937;}
.b-time{font-size:.67rem;color:rgba(0,0,0,.35);text-align:right;margin-top:3px;}
.bb .b-time{text-align:left;}
.tok-hl{font-family:var(--mono);font-weight:700;letter-spacing:.05em;color:#0E7C7B;}
.tips{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:24px;}
.tip{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:16px;box-shadow:var(--shadow-sm);}
.tip-ico{width:34px;height:34px;border-radius:9px;display:grid;place-items:center;margin-bottom:10px;}
.tip-ico svg{width:17px;height:17px;}
.tip-t{font-weight:700;font-size:.84rem;color:var(--gray-900);margin-bottom:4px;}
.tip-b{font-size:.78rem;color:var(--gray-500);line-height:1.55;}
.ws{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:14px 18px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm);}
.ws-l{display:flex;align-items:center;gap:8px;font-size:.875rem;color:var(--gray-600);}
.ws-l svg{width:15px;height:15px;color:var(--gray-400);}
.ws-b{font-weight:700;color:var(--gray-900);}
.ws-a{font-size:.84rem;font-weight:700;color:var(--teal);text-decoration:none;}
.ws-a:hover{text-decoration:underline;}
.toast-c{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column;gap:8px;}
.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--gray-900);color:#fff;border-radius:10px;font-size:.84rem;font-weight:500;box-shadow:var(--shadow-md);animation:tin .3s ease-out;}
.toast.out{animation:tout .25s forwards;}
.toast svg{width:15px;height:15px;color:var(--green-m);flex-shrink:0;}
@media(max-width:640px){.cmd-hdr,.cmd-row{grid-template-columns:1fr 80px;}.cmd-hdr span:nth-child(2),.cmd-desc{display:none;}.tips{grid-template-columns:1fr;}.bc-actions{width:100%;}.btn-copy-num,.btn-msg{flex:1;justify-content:center;}}


/* ── Schedules/Edit ────────────────────────────────────────────── */
@keyframes spin{to{transform:rotate(360deg)}}
.page-body{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;padding:40px 24px 80px;}
.page-body .card{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:36px 32px;width:100%;max-width:620px;box-shadow:var(--shadow-md);}
.card-title{font-family:var(--font-h);font-size:1.3rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;margin-bottom:4px;}
.card-sub{font-size:.84rem;color:var(--gray-400);margin-bottom:28px;}
/* locked banner */
.locked-banner{background:var(--gray-100);border:1px solid var(--border);border-left:4px solid var(--gray-400);border-radius:10px;padding:14px 16px;margin-bottom:24px;}
.locked-label{font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:4px;}
.locked-value{font-weight:700;font-size:.95rem;color:var(--gray-700);}
.locked-meter{font-family:var(--mono);font-size:.9rem;color:var(--gray-600);margin-top:2px;}
/* field */
.field-group{margin-bottom:18px;}
.field-label{display:block;font-size:.78rem;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
.field-label .opt{font-weight:400;color:var(--gray-400);margin-left:4px;}
.fi{width:100%;height:44px;border:1.5px solid var(--border);border-radius:10px;padding:0 14px;font-size:.875rem;font-family:var(--font);color:var(--gray-900);background:var(--white);outline:none;transition:border-color var(--ease);}
.fi:focus{border-color:var(--blue);}
/* freq cards */
.freq-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;}
.freq-card{border:2px solid var(--border);border-radius:12px;padding:16px 18px;cursor:pointer;transition:all var(--ease);}
.freq-card:hover{border-color:var(--blue-m);}
.freq-card.selected{border-color:var(--blue);background:var(--blue-l);}
.fc-header{display:flex;align-items:center;gap:12px;}
.fc-icon{width:36px;height:36px;background:var(--gray-100);border-radius:9px;display:grid;place-items:center;flex-shrink:0;color:var(--gray-500);}
.freq-card.selected .fc-icon{background:var(--blue-m);color:var(--blue);}
.fc-icon svg{width:18px;height:18px;}
.fc-title{font-weight:700;font-size:.9rem;color:var(--gray-800);}
.freq-card.selected .fc-title{color:var(--blue);}
.fc-desc{font-size:.78rem;color:var(--gray-400);margin-top:2px;}
.fc-body{margin-top:14px;padding-top:14px;border-top:1px solid rgba(26,86,160,.12);display:none;}
.freq-card.selected .fc-body{display:block;}
.dom-row{display:flex;align-items:center;gap:10px;}
.dom-input{width:72px;height:40px;border:1.5px solid var(--border);border-radius:8px;padding:0 10px;font-size:.9rem;font-weight:700;text-align:center;font-family:var(--font);color:var(--gray-900);outline:none;transition:border-color var(--ease);}
.dom-input:focus{border-color:var(--blue);}
.dom-hint{font-size:.8rem;color:var(--gray-500);}
.dow-chips{display:flex;gap:6px;flex-wrap:wrap;}
.dow-chip{height:36px;min-width:44px;padding:0 12px;border-radius:100px;font-size:.8rem;font-weight:700;color:var(--gray-500);background:var(--gray-100);border:2px solid transparent;transition:all var(--ease);cursor:pointer;}
.dow-chip.act{background:var(--blue);color:#fff;border-color:var(--blue);}
.dow-chip:hover:not(.act){background:var(--gray-200);}
.cron-input{width:100%;height:40px;border:1.5px solid var(--border);border-radius:8px;padding:0 12px;font-size:.875rem;font-family:var(--mono);color:var(--gray-900);outline:none;transition:border-color var(--ease);}
.cron-input:focus{border-color:var(--blue);}
.cron-preview{margin-top:8px;padding:10px 12px;border-radius:8px;background:var(--teal-l);border:1px solid var(--teal-m);font-size:.8rem;color:var(--teal);font-weight:600;}
.cron-preview.error{background:var(--red-l);border-color:var(--red-m);color:var(--red);}
/* amount */
.amount-wrap{display:flex;align-items:center;border:2px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color var(--ease);}
.amount-wrap:focus-within{border-color:var(--teal);}
.amount-prefix{padding:0 14px;font-size:1rem;font-weight:700;color:var(--gray-400);background:var(--gray-100);height:48px;display:flex;align-items:center;border-right:1px solid var(--border);}
.amount-input{flex:1;height:48px;border:none;outline:none;padding:0 30px;font-size:1rem;font-weight:600;color:var(--gray-900);font-family:var(--font);}
.amount-hint{font-size:.8rem;color:var(--gray-500);margin-top:8px;line-height:1.5;}
.amount-hint strong{color:var(--gray-800);}
.wallet-balance{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;color:var(--teal);margin-top:4px;}
.low-balance-warn{display:flex;align-items:center;gap:8px;padding:10px 13px;background:var(--amber-l);border:1px solid var(--amber-m);border-radius:9px;font-size:.8rem;font-weight:600;color:#92400E;margin-top:10px;}
.low-balance-warn a{color:var(--amber);font-weight:700;}
/* nav buttons */
.nav-btns{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);}
.btn-save{display:inline-flex;align-items:center;gap:7px;height:44px;padding:0 22px;background:var(--teal);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all var(--ease);}
.btn-save:hover{background:var(--teal-d);}
.cancel-link{font-size:.82rem;color:var(--gray-400);font-weight:500;text-decoration:none;}
.cancel-link:hover{color:var(--gray-700);}
@media(max-width:640px){.page-body .card{padding:24px 20px;}}


/* ── Schedules/Create ──────────────────────────────────────────── */
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
@keyframes spin{to{transform:rotate(360deg)}}
.page-body{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;padding:40px 24px 80px;}
.page-body .card{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:36px 32px;width:100%;max-width:620px;box-shadow:var(--shadow-md);}
.card-title{font-family:var(--font-h);font-size:1.3rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;margin-bottom:4px;}
.card-sub{font-size:.84rem;color:var(--gray-400);margin-bottom:28px;}
/* steps */
.steps{display:flex;align-items:center;gap:0;margin-bottom:32px;}
.step{display:flex;align-items:center;flex:1;}
.step:last-child{flex:none;}
.step-circle{width:32px;height:32px;border-radius:50%;display:grid;place-items:center;font-size:.78rem;font-weight:800;flex-shrink:0;cursor:pointer;transition:all .2s;}
.step-circle.done{background:var(--teal);color:#fff;}
.step-circle.active{background:var(--blue);color:#fff;box-shadow:0 0 0 4px var(--blue-m);}
.step-circle.todo{background:var(--gray-100);color:var(--gray-400);}
.step-label{font-size:.72rem;font-weight:600;color:var(--gray-400);margin-top:5px;white-space:nowrap;}
.step-label.active{color:var(--blue);}
.step-label.done{color:var(--teal);}
.step-connector{flex:1;height:2px;background:var(--gray-200);margin:0 6px;margin-bottom:12px;}
.step-connector.done{background:var(--teal);}
.step-wrap{display:flex;flex-direction:column;align-items:center;}
/* panels */
.step-panel{display:none;animation:slideDown .25s ease-out;}
.step-panel.show{display:block;}
/* section label */
.section-label{font-size:.70rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:10px;}
/* disco grid */
.disco-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:24px;}
.disco-card{border:2px solid var(--border);border-radius:10px;padding:10px 8px;text-align:center;cursor:pointer;transition:all var(--ease);position:relative;}
.disco-card:hover{border-color:var(--blue-m);background:var(--blue-l);}
.disco-card.selected{border-color:var(--blue);background:var(--blue-l);transform:scale(1.02);}
.disco-av{width:32px;height:32px;border-radius:8px;margin:0 auto 6px;display:grid;place-items:center;font-size:.62rem;font-weight:800;color:#fff;}
.disco-nm{font-size:.70rem;font-weight:700;color:var(--gray-700);}
.disco-card.selected .disco-nm{color:var(--blue);}
.check-overlay{position:absolute;top:4px;right:4px;width:16px;height:16px;background:var(--blue);border-radius:50%;display:grid;place-items:center;opacity:0;transition:opacity var(--ease);}
.check-overlay svg{width:9px;height:9px;}
.disco-card.selected .check-overlay{opacity:1;}
/* field */
.field-group{margin-bottom:18px;}
.field-label{display:block;font-size:.78rem;font-weight:700;color:var(--gray-700);margin-bottom:6px;}
.field-label .opt{font-weight:400;color:var(--gray-400);margin-left:4px;}
.fi-wrap{position:relative;}
.fi{width:100%;height:44px;border:1.5px solid var(--border);border-radius:10px;padding:0 44px 0 14px;font-size:.875rem;font-family:var(--font);color:var(--gray-900);background:var(--white);outline:none;transition:border-color var(--ease);}
.fi.no-btn{padding-right:14px;}
.fi:focus{border-color:var(--blue);}
.fi.error{border-color:var(--red);animation:shake .3s;}
.btn-verify{position:absolute;right:8px;top:50%;transform:translateY(-50%);height:30px;padding:0 14px;background:var(--blue);color:#fff;border-radius:7px;font-size:.76rem;font-weight:700;border:none;cursor:pointer;transition:all var(--ease);}
.btn-verify:hover{background:var(--blue-d);}
.fi-icon{position:absolute;right:14px;top:50%;transform:translateY(-50%);pointer-events:none;}
.spinner{width:18px;height:18px;border:2px solid var(--gray-200);border-top-color:var(--blue);border-radius:50%;animation:spin .7s linear infinite;}
.verify-result{border-radius:10px;padding:11px 14px;margin-top:8px;display:flex;align-items:center;gap:9px;font-size:.84rem;animation:slideDown .25s;}
.verify-result.ok{background:var(--green-l);border:1px solid var(--green-m);}
.verify-result.ok .vr-text{color:#065F46;font-weight:600;}
.verify-result.fail{background:var(--red-l);border:1px solid var(--red-m);}
.verify-result.fail .vr-text{color:#991B1B;}
.vr-icon{width:18px;height:18px;flex-shrink:0;}
.type-tabs{display:flex;gap:6px;}
.type-tab{flex:1;height:40px;border-radius:9px;font-size:.84rem;font-weight:600;color:var(--gray-500);background:var(--gray-100);border:2px solid transparent;transition:all var(--ease);cursor:pointer;}
.type-tab.act{background:var(--blue-l);color:var(--blue);border-color:var(--blue-m);}
.type-tab:hover:not(.act){background:var(--gray-200);color:var(--gray-800);}
/* freq cards */
.freq-cards{display:flex;flex-direction:column;gap:10px;margin-bottom:20px;}
.freq-card{border:2px solid var(--border);border-radius:12px;padding:16px 18px;cursor:pointer;transition:all var(--ease);}
.freq-card:hover{border-color:var(--blue-m);}
.freq-card.selected{border-color:var(--blue);background:var(--blue-l);}
.fc-header{display:flex;align-items:center;gap:12px;}
.fc-icon{width:36px;height:36px;background:var(--gray-100);border-radius:9px;display:grid;place-items:center;flex-shrink:0;color:var(--gray-500);}
.freq-card.selected .fc-icon{background:var(--blue-m);color:var(--blue);}
.fc-icon svg{width:18px;height:18px;}
.fc-title{font-weight:700;font-size:.9rem;color:var(--gray-800);}
.freq-card.selected .fc-title{color:var(--blue);}
.fc-desc{font-size:.78rem;color:var(--gray-400);margin-top:2px;}
.fc-body{margin-top:14px;padding-top:14px;border-top:1px solid rgba(26,86,160,.12);display:none;}
.freq-card.selected .fc-body{display:block;}
.dom-row{display:flex;align-items:center;gap:10px;}
.dom-input{width:72px;height:40px;border:1.5px solid var(--border);border-radius:8px;padding:0 10px;font-size:.9rem;font-weight:700;text-align:center;font-family:var(--font);color:var(--gray-900);outline:none;transition:border-color var(--ease);}
.dom-input:focus{border-color:var(--blue);}
.dom-hint{font-size:.8rem;color:var(--gray-500);}
.dow-chips{display:flex;gap:6px;flex-wrap:wrap;}
.dow-chip{height:36px;min-width:44px;padding:0 12px;border-radius:100px;font-size:.8rem;font-weight:700;color:var(--gray-500);background:var(--gray-100);border:2px solid transparent;transition:all var(--ease);cursor:pointer;}
.dow-chip.act{background:var(--blue);color:#fff;border-color:var(--blue);}
.dow-chip:hover:not(.act){background:var(--gray-200);}
.cron-input{width:100%;height:40px;border:1.5px solid var(--border);border-radius:8px;padding:0 12px;font-size:.875rem;font-family:var(--mono);color:var(--gray-900);outline:none;transition:border-color var(--ease);}
.cron-input:focus{border-color:var(--blue);}
.cron-preview{margin-top:8px;padding:10px 12px;border-radius:8px;background:var(--teal-l);border:1px solid var(--teal-m);font-size:.8rem;color:var(--teal);font-weight:600;}
.cron-preview.error{background:var(--red-l);border-color:var(--red-m);color:var(--red);}
/* amount */
.amount-wrap{display:flex;align-items:center;border:2px solid var(--border);border-radius:10px;overflow:hidden;transition:border-color var(--ease);}
.amount-wrap:focus-within{border-color:var(--teal);}
.amount-prefix{padding:0 14px;font-size:1rem;font-weight:700;color:var(--gray-400);background:var(--gray-100);height:48px;display:flex;align-items:center;border-right:1px solid var(--border);}
.amount-input{flex:1;height:48px;border:none;outline:none;padding:0 30px;font-size:1rem;font-weight:600;color:var(--gray-900);font-family:var(--font);}
.amount-hint{font-size:.8rem;color:var(--gray-500);margin-top:8px;line-height:1.5;}
.amount-hint strong{color:var(--gray-800);}
.wallet-balance{display:inline-flex;align-items:center;gap:5px;font-size:.78rem;font-weight:600;color:var(--teal);margin-top:4px;}
.low-balance-warn{display:flex;align-items:center;gap:8px;padding:10px 13px;background:var(--amber-l);border:1px solid var(--amber-m);border-radius:9px;font-size:.8rem;font-weight:600;color:#92400E;margin-top:10px;}
.low-balance-warn a{color:var(--amber);font-weight:700;}
/* review */
.review-card{border:1px solid var(--border);border-left:4px solid var(--teal);border-radius:12px;padding:20px;margin-bottom:20px;}
.review-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.rv-label{font-size:.70rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);margin-bottom:3px;}
.rv-value{font-size:.9rem;font-weight:600;color:var(--gray-800);}
.rv-value.big{font-family:var(--font-h);font-size:1.2rem;font-weight:800;color:var(--blue);}
.rv-value.mono{font-family:var(--mono);font-size:.82rem;}
.first-run-card{background:var(--teal-l);border:1px solid var(--teal-m);border-radius:10px;padding:14px 16px;display:flex;align-items:center;gap:10px;margin-bottom:20px;}
.fr-icon{color:var(--teal);}
.fr-text{font-size:.84rem;color:var(--teal-d);}
.fr-date{font-weight:700;}
/* nav buttons */
.nav-btns{display:flex;align-items:center;justify-content:space-between;margin-top:24px;padding-top:20px;border-top:1px solid var(--border);}
.btn-back{display:inline-flex;align-items:center;gap:6px;height:44px;padding:0 20px;background:var(--white);border:2px solid var(--border);border-radius:10px;font-size:.875rem;font-weight:700;color:var(--gray-600);cursor:pointer;transition:all var(--ease);}
.btn-back:hover{border-color:var(--gray-400);color:var(--gray-800);}
.btn-next{display:inline-flex;align-items:center;gap:7px;height:44px;padding:0 22px;background:var(--blue);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all var(--ease);}
.btn-next:hover{background:var(--blue-d);}
.btn-activate{display:inline-flex;align-items:center;gap:7px;height:44px;padding:0 22px;background:var(--teal);color:#fff;border:none;border-radius:10px;font-size:.875rem;font-weight:700;cursor:pointer;transition:all var(--ease);}
    .btn-activate:hover {
        background: #0a5e5d;
    }
.btn-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;}
.cancel-link{font-size:.82rem;color:var(--gray-400);font-weight:500;text-decoration:none;}
.cancel-link:hover{color:var(--gray-700);}
.toast-c{position:fixed;bottom:24px;right:24px;z-index:100;display:flex;flex-direction:column;gap:8px;}
.toast{display:flex;align-items:center;gap:10px;padding:12px 18px;background:var(--gray-900);color:#fff;border-radius:10px;font-size:.84rem;font-weight:500;box-shadow:var(--shadow-md);max-width:300px;}
/* saved meter list */
.saved-meter-list{display:flex;flex-direction:column;gap:10px;margin-bottom:8px;}
.sm-card{display:flex;align-items:center;gap:14px;border:2px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all var(--ease);position:relative;}
.sm-card:hover{border-color:var(--blue-m);background:var(--blue-l);}
.sm-card.selected{border-color:var(--blue);background:var(--blue-l);}
.sm-badge{flex-shrink:0;padding:3px 10px;border-radius:100px;font-size:.70rem;font-weight:800;color:#fff;white-space:nowrap;}
.sm-body{flex:1;min-width:0;}
.sm-nick{font-size:.9rem;font-weight:700;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sm-card.selected .sm-nick{color:var(--blue);}
.sm-meta{font-size:.78rem;color:var(--gray-500);margin-top:2px;}
.sm-meta .mono{font-family:var(--mono);font-size:.75rem;}
.sm-owner{font-size:.75rem;color:var(--gray-400);margin-top:2px;}
.sm-check{width:22px;height:22px;background:var(--blue);border-radius:50%;display:grid;place-items:center;flex-shrink:0;opacity:0;transition:opacity var(--ease);}
.sm-check svg{width:11px;height:11px;}
.sm-card.selected .sm-check{opacity:1;}
@media(max-width:640px){.review-grid{grid-template-columns:1fr;}.step-label{display:none;}.page-body .card{padding:24px 20px;}}


/* ── Wallet/Index ──────────────────────────────────────────────── */
/* MAIN */
.main{max-width:1280px;margin:0 auto;padding:32px 24px 80px;}
/* LOW BALANCE BANNER */
.low-banner{display:flex;align-items:center;justify-content:space-between;background:var(--amber-l);border:1px solid var(--amber-m);border-radius:12px;padding:12px 18px;margin-bottom:20px;}
.lb-left{display:flex;align-items:center;gap:9px;font-size:.875rem;font-weight:600;color:#92400E;}
.lb-left svg{width:16px;height:16px;color:var(--amber);flex-shrink:0;}
.lb-link{font-size:.84rem;font-weight:700;color:var(--amber);}
.lb-link:hover{text-decoration:underline;}
/* HERO CARD */
.hero{background:linear-gradient(135deg,#fff 0%,var(--teal-l) 100%);border:1px solid var(--border);border-left:6px solid var(--teal);border-radius:16px;padding:32px 32px 28px;box-shadow:var(--shadow-md);margin-bottom:28px;display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:24px;}
.hero-label{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:8px;}
.hero-bal{font-family:var(--font-h);font-size:3rem;font-weight:800;color:var(--gray-900);letter-spacing:-.03em;line-height:1;}
.hero-bal-cents{font-size:1.6rem;color:var(--gray-400);}
.hero-meta{display:flex;align-items:center;gap:10px;margin-top:14px;flex-wrap:wrap;}
.hero-upd{font-size:.78rem;color:var(--gray-400);}
.hero-tag{display:inline-flex;align-items:center;gap:5px;padding:3px 10px;border-radius:100px;background:var(--teal-l);border:1px solid var(--teal-m);font-size:.72rem;font-weight:700;color:var(--teal);}
.hero-tag svg{width:11px;height:11px;}
.hero-actions{display:flex;gap:10px;flex-shrink:0;flex-wrap:wrap;}
.btn-topup{display:inline-flex;align-items:center;gap:8px;height:44px;padding:0 22px;background:var(--teal);color:#fff;border-radius:10px;font-size:.875rem;font-weight:700;border:none;cursor:pointer;transition:all var(--ease);}
.btn-topup:hover{background:var(--teal-d);}
.btn-topup svg{width:16px;height:16px;}
.btn-sched{display:inline-flex;align-items:center;gap:7px;height:44px;padding:0 20px;background:var(--white);border:2px solid var(--teal);color:var(--teal);border-radius:10px;font-size:.875rem;font-weight:700;text-decoration:none;transition:all var(--ease);}
.btn-sched:hover{background:var(--teal-l);}
.btn-sched svg{width:15px;height:15px;}
/* SECTION HEADER */
.sec-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px;flex-wrap:wrap;gap:10px;}
.sec-title{font-family:var(--font-h);font-size:1.05rem;font-weight:800;color:var(--gray-900);letter-spacing:-.01em;}
.filter-tabs{display:flex;gap:4px;background:var(--gray-100);border-radius:9px;padding:3px;}
.ft{height:32px;padding:0 14px;border-radius:7px;font-size:.8rem;font-weight:600;color:var(--gray-500);background:transparent;border:none;cursor:pointer;transition:all var(--ease);}
.ft:hover:not(.act){color:var(--gray-700);}
.ft.act{background:var(--white);color:var(--gray-900);box-shadow:var(--shadow-sm);}
/* TABLE CARD */
.tc{background:var(--white);border:1px solid var(--border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;}
.wt{width:100%;border-collapse:collapse;}
.wt thead th{padding:11px 20px;font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);text-align:left;border-bottom:1px solid var(--border);background:var(--surface);white-space:nowrap;}
.wt tbody tr{border-bottom:1px solid var(--border);transition:background var(--ease);}
.wt tbody tr:last-child{border-bottom:none;}
.wt tbody tr:hover{background:#F8FBFF;}
.wt td{padding:14px 20px;font-size:.875rem;vertical-align:middle;}
/* badges */
.bdg{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:.71rem;font-weight:700;white-space:nowrap;}
.bdg-credit{background:var(--green-l);color:#065F46;}
.bdg-debit{background:var(--amber-l);color:#92400E;}
.bdg-refund{background:var(--blue-l);color:#1E40AF;}
/* description cell */
.desc-main{font-weight:600;color:var(--gray-800);font-size:.875rem;}
.desc-ref{font-size:.72rem;font-family:var(--mono);color:var(--gray-400);margin-top:2px;}
/* amount cell */
.amt-credit{font-weight:700;color:var(--green);}
.amt-debit{font-weight:700;color:var(--gray-700);}
.amt-refund{font-weight:700;color:var(--blue);}
.bal-after{font-weight:600;color:var(--gray-500);font-size:.84rem;}
.dt-main{font-weight:600;color:var(--gray-800);font-size:.83rem;}
.dt-time{font-size:.72rem;color:var(--gray-400);margin-top:1px;font-family:var(--mono);}
/* empty state */
.empty{display:flex;flex-direction:column;align-items:center;padding:64px 24px;text-align:center;}
.empty-ring{width:80px;height:80px;background:var(--teal-l);border-radius:50%;display:grid;place-items:center;margin-bottom:20px;color:var(--teal);}
.empty-h{font-family:var(--font-h);font-size:1.08rem;font-weight:800;color:var(--gray-800);margin-bottom:8px;}
.empty-p{font-size:.875rem;color:var(--gray-400);line-height:1.7;max-width:300px;margin-bottom:24px;}
/* pagination */
.pag{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-top:1px solid var(--border);}
.pag-info{font-size:.82rem;color:var(--gray-400);}
.pag-btns{display:flex;gap:4px;}
.pag-btn{width:34px;height:34px;border-radius:8px;background:transparent;border:1.5px solid var(--border);font-size:.82rem;font-weight:600;color:var(--gray-600);display:grid;place-items:center;text-decoration:none;transition:all var(--ease);}
.pag-btn:hover{background:var(--blue-l);border-color:var(--blue-m);color:var(--blue);}
.pag-btn.act{background:var(--blue);border-color:var(--blue);color:#fff;}
/* MODAL */
.modal-bg{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:100;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .2s;}
.modal-bg.open{opacity:1;pointer-events:auto;}
.modal{background:var(--white);border-radius:18px;padding:28px;width:100%;max-width:440px;box-shadow:0 24px 60px rgba(0,0,0,.2);transform:scale(.96) translateY(-8px);transition:transform .25s ease-out,opacity .25s;opacity:0;}
.modal-bg.open .modal{transform:none;opacity:1;}
.modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:22px;}
.modal-title{font-family:var(--font-h);font-size:1.1rem;font-weight:800;color:var(--gray-900);}
.modal-close{width:32px;height:32px;border-radius:8px;background:var(--gray-100);display:grid;place-items:center;color:var(--gray-500);border:none;cursor:pointer;transition:all var(--ease);}
.modal-close:hover{background:var(--gray-200);color:var(--gray-800);}
.modal-close svg{width:14px;height:14px;}
.modal-label{font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:8px;}
.pills{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:16px;}
.pill{height:36px;padding:0 16px;border-radius:100px;font-size:.84rem;font-weight:700;color:var(--gray-500);background:var(--gray-100);border:1.5px solid transparent;cursor:pointer;transition:all var(--ease);}
.pill:hover{background:var(--blue-l);color:var(--blue);}
.pill.act{background:var(--blue-l);color:var(--blue);border-color:var(--blue-m);}
.amount-row{display:flex;align-items:center;background:var(--white);border:2px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:16px;transition:border-color var(--ease);}
.amount-row:focus-within{border-color:var(--teal);}
.amount-prefix{padding:0 14px;font-size:1rem;font-weight:700;color:var(--gray-400);background:var(--gray-100);height:48px;display:flex;align-items:center;border-right:1px solid var(--border);}
.amount-input{flex:1;height:48px;border:none;outline:none;padding:0 30px;font-size:1rem;font-weight:600;color:var(--gray-900);font-family:var(--font);}
.modal-note{font-size:.78rem;color:var(--gray-400);line-height:1.6;margin-bottom:20px;padding:12px 14px;background:var(--surface);border-radius:8px;}
.btn-modal-pay{width:100%;height:48px;background:var(--teal);color:#fff;border-radius:10px;font-size:.9rem;font-weight:700;display:flex;align-items:center;justify-content:center;gap:8px;border:none;cursor:pointer;transition:all var(--ease);}
.btn-modal-pay:hover{background:var(--teal-d);}
.btn-modal-pay svg{width:16px;height:16px;}
@media(max-width:900px){.hero{flex-direction:column;align-items:flex-start;}.hero-bal{font-size:2.2rem;}.hero-actions{width:100%;}.btn-topup,.btn-sched{flex:1;justify-content:center;}.sec-header{flex-direction:column;align-items:flex-start;}}
@media(max-width:640px){.main{padding:20px 16px 80px;}}


/* ── WhatsApp/Verify ───────────────────────────────────────────── */
@keyframes shake{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-4px)}80%{transform:translateX(4px)}}
.page-body{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px 80px;}
.page-body .card{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:40px 36px;width:100%;max-width:480px;box-shadow:var(--shadow-md);}
.s2-top{text-align:center;margin-bottom:24px;}
.s2-title{font-family:var(--font-h);font-size:1.2rem;font-weight:800;color:var(--gray-900);margin-bottom:6px;}
.s2-sub{font-size:.84rem;color:var(--gray-500);line-height:1.6;}
.phone-masked{font-family:'JetBrains Mono',monospace;font-weight:700;color:var(--gray-900);}
.otp-wrap{display:flex;gap:8px;justify-content:center;margin-bottom:20px;}
.otp-box{width:54px;height:62px;border:2px solid var(--border);border-radius:12px;text-align:center;font-size:1.4rem;font-weight:800;font-family:var(--font-h);color:var(--gray-900);outline:none;transition:all var(--ease);background:var(--white);}
.otp-box:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-m);}
.otp-box.filled{border-color:var(--blue);background:#EFF6FF;}
.otp-box.error{border-color:var(--red);animation:shake .3s;}
.otp-error{text-align:center;font-size:.82rem;font-weight:600;color:var(--red);margin-top:4px;margin-bottom:12px;min-height:20px;}
.resend-row{text-align:center;margin-bottom:24px;}
.resend-btn{font-size:.82rem;background:none;border:none;font-weight:600;color:var(--gray-400);cursor:default;}
.resend-btn.active{color:var(--blue);cursor:pointer;}
.resend-btn.active:hover{text-decoration:underline;}
.btn-verify{width:100%;height:52px;background:var(--wa);color:#fff;border-radius:12px;font-size:.95rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:9px;border:none;cursor:pointer;transition:all var(--ease);}
.btn-verify:hover{background:var(--wa-d);}
.text-danger{font-size:.82rem;color:#DC2626;margin-bottom:12px;display:block;text-align:center;}
.back-link{display:block;text-align:center;margin-top:14px;font-size:.82rem;color:var(--gray-400);text-decoration:none;}
.back-link:hover{color:var(--gray-700);}
.delivery-warn{background:#FFFBEB;border:1px solid #FCD34D;border-radius:10px;padding:10px 14px;font-size:.82rem;color:#92400E;margin-bottom:18px;display:flex;gap:8px;align-items:flex-start;}
.delivery-warn svg{flex-shrink:0;margin-top:1px;}


/* ── Pay/Success ───────────────────────────────────────────────── */
@keyframes spin { to { transform: rotate(360deg); } }


/* ── WhatsApp/Link ─────────────────────────────────────────────── */
.page-body{min-height:calc(100vh - 64px);display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 24px 80px;}
.page-body .card{background:var(--white);border:1px solid var(--border);border-radius:20px;padding:40px 36px;width:100%;max-width:480px;box-shadow:var(--shadow-md);}
.wa-logo-wrap{width:72px;height:72px;background:var(--wa);border-radius:50%;display:grid;place-items:center;margin:0 auto 20px;}
.wa-logo-wrap svg{width:40px;height:40px;}
.s1-title{font-family:var(--font-h);font-size:1.5rem;font-weight:800;color:var(--gray-900);text-align:center;letter-spacing:-.025em;margin-bottom:6px;}
.s1-sub{font-size:.875rem;color:var(--gray-400);text-align:center;line-height:1.6;margin-bottom:24px;}
.feature-rows{display:flex;flex-direction:column;gap:8px;margin-bottom:28px;}
.fr{display:flex;align-items:center;gap:12px;background:var(--white);border:1px solid var(--border);border-left:3px solid var(--wa);border-radius:10px;padding:12px 14px;}
.fr-cmd{font-family:var(--mono);font-size:.82rem;font-weight:700;color:var(--gray-900);flex-shrink:0;min-width:100px;}
.fr-arrow{color:var(--gray-200);flex-shrink:0;font-size:.8rem;}
.fr-result{font-size:.8rem;color:var(--gray-500);}
.fl{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);display:block;margin-bottom:8px;}
.fi-wrap{display:flex;align-items:center;background:var(--white);border:2px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:8px;transition:border-color var(--ease);}
.fi-wrap:focus-within{border-color:var(--wa);}
.fi-prefix{padding:0 14px;font-size:.9rem;font-weight:700;color:var(--gray-400);background:var(--gray-100);height:48px;display:flex;align-items:center;border-right:1px solid var(--border);}
.fi-phone{flex:1;height:48px;border:none;outline:none;padding:0 14px;font-size:.95rem;font-family:var(--mono);font-weight:600;color:var(--gray-900);}
.btn-send{width:100%;height:52px;background:var(--wa);color:#fff;border-radius:12px;font-size:.95rem;font-weight:800;display:flex;align-items:center;justify-content:center;gap:10px;border:none;cursor:pointer;transition:all var(--ease);font-family:var(--font-h);}
.btn-send:hover{background:var(--wa-d);}
.btn-send svg{width:20px;height:20px;}
.cancel-link{display:block;text-align:center;margin-top:14px;font-size:.82rem;color:var(--gray-400);text-decoration:none;}
.cancel-link:hover{color:var(--gray-700);}
.text-danger{font-size:.82rem;color:#DC2626;margin-bottom:12px;display:block;}

/* ── WhatsApp link — phone option cards ── */
.wa-error-banner{display:flex;align-items:center;gap:8px;background:#FEF2F2;border:1px solid #FECACA;border-radius:10px;padding:11px 14px;margin-bottom:16px;font-size:.83rem;color:#DC2626;}
.wa-option{display:flex;align-items:flex-start;gap:14px;border:2px solid var(--border);border-radius:12px;padding:14px 16px;cursor:pointer;transition:all 150ms ease-out;margin-bottom:10px;background:var(--white);}
.wa-option:hover{border-color:#86EFAC;}
.wa-option-selected{border-color:var(--wa);background:#F0FDF4;}
.wa-option-radio{flex-shrink:0;margin-top:2px;}
.wa-radio-dot{width:18px;height:18px;border-radius:50%;border:2px solid var(--gray-300);background:var(--white);display:flex;align-items:center;justify-content:center;transition:all 150ms ease-out;}
.wa-radio-dot::after{content:'';width:8px;height:8px;border-radius:50%;background:transparent;transition:background 150ms ease-out;}
.wa-radio-dot.active{border-color:var(--wa);}
.wa-radio-dot.active::after{background:var(--wa);}
.wa-option-body{flex:1;min-width:0;}
.wa-option-title{font-size:.88rem;font-weight:700;color:var(--gray-900);}
.wa-option-sub{font-size:.77rem;color:var(--gray-400);margin-top:2px;}
.wa-option-phone{display:inline-flex;align-items:center;gap:6px;margin-top:5px;padding:3px 10px;background:rgba(37,211,102,.1);border:1px solid rgba(37,211,102,.25);border-radius:100px;font-size:.82rem;font-weight:700;color:#15803D;font-family:var(--mono);}
.wa-option-phone svg{color:#15803D;flex-shrink:0;}
.wa-fmt-hint{font-size:.75rem;color:var(--gray-400);margin-top:6px;}
.wa-fmt-hint code{background:var(--gray-100);padding:1px 5px;border-radius:4px;font-size:.73rem;color:var(--gray-600);}
[x-cloak]{display:none !important;}


/* ── Analytics/Index ───────────────────────────────────────────── */
/* TABS */
.tabs-wrap{background:var(--white);border-bottom:1px solid var(--border);}
.tabs{max-width:1280px;margin:0 auto;padding:0 24px;display:flex;}
.tab{display:inline-flex;align-items:center;gap:7px;height:48px;padding:0 18px;font-size:.875rem;font-weight:600;color:var(--gray-400);border-bottom:2px solid transparent;cursor:pointer;transition:all var(--ease);background:none;text-decoration:none;margin-bottom:-1px;}
.tab:hover{color:var(--gray-700);}
.tab.act{color:var(--blue);border-bottom-color:var(--blue);}
.tab svg{width:16px;height:16px;flex-shrink:0;}
/* PAGE HEADER */
.ph-wrap{background:var(--white);border-bottom:1px solid var(--border);}
.ph{max-width:1280px;margin:0 auto;padding:22px 24px 18px;display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:16px;}
.ph-title-row{display:flex;align-items:center;gap:11px;}
.ph-icon{width:40px;height:40px;background:var(--purple-l);border-radius:10px;display:grid;place-items:center;color:var(--purple);}
.ph-title{font-family:var(--font-h);font-size:1.45rem;font-weight:800;color:var(--gray-900);letter-spacing:-.025em;}
.ph-sub{font-size:.84rem;color:var(--gray-400);margin-top:3px;margin-left:51px;}
.ph-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap;}
.btn-ghost{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 16px;background:var(--white);border:1.5px solid var(--border);border-radius:8px;font-size:.84rem;font-weight:700;color:var(--gray-700);transition:all var(--ease);}
.btn-ghost:hover{border-color:var(--purple);color:var(--purple);background:var(--purple-l);}
.btn-ghost svg{width:15px;height:15px;}
.meter-sel{height:38px;border:1.5px solid var(--border);border-radius:8px;padding:0 12px;font-size:.84rem;font-family:var(--font);color:var(--gray-700);background:var(--white);outline:none;transition:border-color var(--ease);}
.meter-sel:focus{border-color:var(--blue);}
/* MAIN */
.main{max-width:1280px;margin:0 auto;padding:28px 24px 80px;}
/* SMART ALERTS BANNER */
.alerts-banner{display:flex;align-items:center;justify-content:space-between;background:var(--amber-l);border:1px solid var(--amber-m);border-radius:12px;padding:12px 18px;margin-bottom:24px;cursor:pointer;transition:all var(--ease);}
.alerts-banner:hover{border-color:var(--amber);}
.ab-left{display:flex;align-items:center;gap:10px;}
.ab-left svg{color:var(--amber);width:18px;height:18px;flex-shrink:0;}
.ab-text{font-size:.875rem;font-weight:600;color:#92400E;}
.ab-right{font-size:.8rem;font-weight:700;color:var(--amber);}
/* KPI CARDS */
.analytics-wrap .kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;}
.analytics-wrap .kpi-card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:20px 22px;box-shadow:var(--shadow-sm);position:relative;overflow:hidden;}
.analytics-wrap .kpi-card::before{content:'';position:absolute;top:0;left:0;width:4px;height:100%;border-radius:4px 0 0 4px;}
.analytics-wrap .kpi-card.c-blue::before{background:var(--blue);}
.analytics-wrap .kpi-card.c-teal::before{background:var(--teal);}
.analytics-wrap .kpi-card.c-amber::before{background:var(--amber);}
.analytics-wrap .kpi-card.c-purple::before{background:var(--purple);}
.analytics-wrap .kpi-label{font-size:.70rem;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--gray-400);margin-bottom:8px;}
.analytics-wrap .kpi-value{font-family:var(--font-h);font-size:2rem;font-weight:800;color:var(--gray-900);letter-spacing:-.02em;line-height:1;}
.analytics-wrap .kpi-note{font-size:.75rem;color:var(--gray-400);margin-top:6px;font-style:italic;}
/* SECTION CARDS */
.analytics-wrap .card{background:var(--white);border:1px solid var(--border);border-radius:14px;padding:24px;box-shadow:var(--shadow-sm);margin-bottom:20px;}
.analytics-wrap .card-title{font-family:var(--font-h);font-size:.95rem;font-weight:800;color:var(--gray-900);margin-bottom:4px;display:flex;align-items:center;gap:8px;}
.card-sub{font-size:.8rem;color:var(--gray-400);margin-bottom:20px;}
.card-title svg{width:16px;height:16px;color:var(--gray-400);}
/* CHART */
.chart-wrap{position:relative;width:100%;height:240px;}
.chart-legend{display:flex;gap:20px;margin-bottom:14px;flex-wrap:wrap;}
.leg-item{display:flex;align-items:center;gap:6px;font-size:.78rem;color:var(--gray-500);}
.leg-swatch{width:10px;height:10px;border-radius:2px;}
/* TWO COL */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;}
/* DISCO TABLE */
.disco-tbl{width:100%;border-collapse:collapse;}
.disco-tbl th{font-size:.69rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--gray-400);text-align:left;padding:8px 12px;border-bottom:1px solid var(--border);}
.disco-tbl td{font-size:.84rem;padding:10px 12px;border-bottom:1px solid var(--border);}
.disco-tbl tr:last-child td{border-bottom:none;}
.disco-tbl tbody tr:hover{background:var(--surface);}
.dav{width:24px;height:24px;border-radius:6px;display:inline-grid;place-items:center;font-size:.58rem;font-weight:800;color:#fff;vertical-align:middle;margin-right:7px;}
.d-spend{font-weight:700;color:var(--gray-900);}
/* SMART ALERT CARDS */
.alerts-section{margin-top:8px;}
.alert-card{display:flex;align-items:flex-start;gap:14px;padding:16px;background:var(--white);border:1px solid var(--border);border-left:4px solid var(--amber);border-radius:12px;margin-bottom:12px;position:relative;box-shadow:var(--shadow-sm);}
.alert-card.tariff{border-left-color:var(--red);}
.alert-icon{width:36px;height:36px;border-radius:9px;display:grid;place-items:center;flex-shrink:0;}
.alert-card:not(.tariff) .alert-icon{background:var(--amber-l);color:var(--amber);}
.alert-card.tariff .alert-icon{background:var(--red-l);color:var(--red);}
.alert-icon svg{width:18px;height:18px;}
.alert-body{flex:1;}
.alert-title{font-weight:700;font-size:.875rem;margin-bottom:4px;}
.alert-card:not(.tariff) .alert-title{color:#92400E;}
.alert-card.tariff .alert-title{color:#991B1B;}
.alert-text{font-size:.84rem;color:var(--gray-600);line-height:1.6;}
.alert-dismiss{position:absolute;top:12px;right:12px;width:24px;height:24px;border-radius:6px;background:transparent;display:grid;place-items:center;color:var(--gray-400);cursor:pointer;transition:all var(--ease);border:none;}
.alert-dismiss:hover{background:var(--gray-100);color:var(--gray-700);}
.alert-dismiss svg{width:13px;height:13px;}
/* EMPTY */
.analytics-wrap .empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;text-align:center;}
.analytics-wrap .empty-ring{width:80px;height:80px;background:var(--purple-l);border-radius:50%;display:grid;place-items:center;margin-bottom:20px;color:var(--purple);}
.analytics-wrap .empty-h{font-family:var(--font-h);font-size:1.08rem;font-weight:800;color:var(--gray-800);margin-bottom:8px;}
.analytics-wrap .empty-p{font-size:.875rem;color:var(--gray-400);line-height:1.7;max-width:320px;}
@media(max-width:960px){.analytics-wrap .kpi-row{grid-template-columns:1fr 1fr;}.two-col{grid-template-columns:1fr;}}
@media(max-width:640px){.analytics-wrap .kpi-row{grid-template-columns:1fr 1fr;}}
