*{margin:0;padding:0;box-sizing:border-box}
:root{
  --bg:#0F1923;
  --card:#1B2A3A;
  --card-hover:#1F3044;
  --card-inner:#152232;
  --border:rgba(255,255,255,.06);
  --border-hover:rgba(255,255,255,.12);
  --accent:#2AABEE;
  --accent-hover:#1E96D1;
  --accent-glow:rgba(42,171,238,.15);
  --text:#E8ECF0;
  --text2:#CBD5E0;
  --muted:#5A7A94;
  --green:#34D399;
  --green-bg:rgba(52,211,153,.1);
  --red:#F87171;
  --red-bg:rgba(248,113,113,.1);
  --orange:#FBBF24;
  --orange-bg:rgba(251,191,36,.1);
  --yellow:#FFD60A;
  --radius:16px;
  --radius-sm:12px;
  --font:'Plus Jakarta Sans',system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
}
html,body{
  font-family:var(--font);
  background:var(--bg);color:var(--text);
  min-height:100vh;-webkit-font-smoothing:antialiased;
}
body{
  display:flex;justify-content:center;
  background:
    radial-gradient(ellipse 600px 400px at 20% 0%,rgba(42,171,238,.07) 0%,transparent 70%),
    radial-gradient(ellipse 500px 300px at 80% 100%,rgba(52,211,153,.04) 0%,transparent 70%),
    var(--bg);
}
.app{width:100%;max-width:430px;min-height:100vh;padding:0 16px 40px;position:relative}

/* ─── Screens ─── */
.screen{display:none}.screen.active{display:block}

/* ─── Header ─── */
.header{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-bottom:12px}
.header-left{display:flex;align-items:center;gap:10px}
.header-logo-img{width:28px;height:28px;border-radius:8px;filter:drop-shadow(0 0 8px rgba(42,171,238,.3))}
.header-brand{display:flex;flex-direction:column;gap:1px}
.header-logo{font-size:17px;font-weight:800;color:var(--accent);letter-spacing:-.3px}
.header-sub{font-size:11px;color:var(--muted);font-weight:500;letter-spacing:.3px;text-transform:uppercase}
.header-actions{display:flex;align-items:center;gap:2px}
.btn-header{
  background:transparent;border:none;color:var(--muted);
  width:40px;height:40px;border-radius:10px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .25s ease;position:relative;
}
.btn-header::before{content:'';position:absolute;inset:0;border-radius:10px;background:transparent;transition:background .25s ease}
.btn-header:hover{color:var(--text)}
.btn-header:hover::before{background:rgba(255,255,255,.05)}
.btn-header:active::before{background:rgba(42,171,238,.1)}
.btn-header svg{position:relative;z-index:1}

/* ─── Sub-header ─── */
.sub-header{display:flex;align-items:center;justify-content:space-between;padding:16px 0;margin-bottom:12px}
.sub-header-left{display:flex;align-items:center;gap:12px}
.btn-back{
  background:transparent;border:none;color:var(--muted);
  width:38px;height:38px;border-radius:10px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .25s ease;
}
.btn-back:hover{color:var(--text);background:rgba(255,255,255,.05)}
.sub-header-title{font-size:17px;font-weight:700;color:var(--text)}

/* ─── Hero Card ─── */
.hero{
  background:linear-gradient(135deg,var(--card) 0%,rgba(42,171,238,.08) 100%);
  border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;margin-bottom:12px;position:relative;overflow:hidden;
}
.hero::before{
  content:'';position:absolute;top:-50px;right:-50px;width:140px;height:140px;
  background:radial-gradient(circle,rgba(42,171,238,.1) 0%,transparent 70%);
  border-radius:50%;pointer-events:none;
}
.hero-account{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--border)}
.hero-email{font-size:14px;color:var(--text2);font-weight:600}
.hero-badge{font-size:12px;font-weight:700;padding:4px 12px;border-radius:20px}
.hero-badge-active{background:var(--green-bg);color:var(--green)}
.hero-badge-expired{background:var(--red-bg);color:var(--red)}
.hero-days-row{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:14px}
.hero-days{font-size:34px;font-weight:800;color:var(--text);letter-spacing:-1px;line-height:1}
.hero-days span{font-size:16px;font-weight:600;color:var(--muted);letter-spacing:0}
.hero-date{font-size:14px;color:var(--muted);font-weight:600}
.hero-progress{background:rgba(255,255,255,.04);border-radius:8px;height:6px;margin-bottom:18px;overflow:hidden}
.hero-progress-bar{height:100%;border-radius:8px;background:linear-gradient(90deg,var(--accent),#34D399);transition:width .6s ease}
.hero-nosub{font-size:15px;color:var(--muted);font-weight:500;text-align:center;padding:8px 0 18px}
.hero-actions{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.hero-tile{
  background:var(--card-inner);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:14px;cursor:pointer;
  transition:all .25s ease;display:flex;align-items:center;gap:11px;
}
.hero-tile:hover{background:var(--card-hover);border-color:var(--border-hover)}
.hero-tile:active{transform:scale(.98)}
.hero-tile-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.hero-tile-icon svg{width:18px;height:18px}
.hero-tile-icon-blue{background:var(--accent-glow);color:var(--accent)}
.hero-tile-icon-accent{background:rgba(42,171,238,.12);color:var(--accent)}
.hero-tile-info{min-width:0}
.hero-tile-label{font-size:13px;font-weight:700;color:var(--text)}
.hero-tile-value{font-size:12px;color:var(--muted);font-weight:500;margin-top:1px}

/* ─── Menu List ─── */
.menu-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;margin-bottom:12px}
.menu-item{
  display:flex;align-items:center;gap:14px;padding:15px 18px;cursor:pointer;
  transition:background .2s ease;border-bottom:1px solid var(--border);text-decoration:none;color:inherit;
}
.menu-item:last-child{border-bottom:none}
.menu-item:hover{background:var(--card-hover)}
.menu-item:active{background:rgba(42,171,238,.06)}
.menu-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.menu-icon-green{background:var(--green-bg);color:var(--green)}
.menu-icon-muted{background:rgba(90,122,148,.1);color:var(--muted)}
.menu-icon svg{width:20px;height:20px}
.menu-content{flex:1;min-width:0}
.menu-label{font-size:15px;font-weight:600;color:var(--text)}
.menu-desc{font-size:12px;color:var(--muted);margin-top:1px;font-weight:500}
.menu-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.menu-chevron{color:var(--muted);opacity:.4;transition:opacity .2s}
.menu-item:hover .menu-chevron{opacity:.7}

/* ─── Section label ─── */
.section-label{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;padding:8px 4px 8px}
.section-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:20px 0 10px}

/* ─── Card ─── */
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:18px;margin-bottom:12px}
.card-title{font-size:11px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px}

/* ─── Badges ─── */
.badge{display:inline-block;font-size:12px;font-weight:700;padding:4px 10px;border-radius:20px}
.badge-green{background:var(--green-bg);color:var(--green)}
.badge-red{background:var(--red-bg);color:var(--red)}
.badge-orange{background:var(--orange-bg);color:var(--orange)}
.badge-muted{background:rgba(90,122,148,.1);color:var(--muted)}

/* ─── Buttons ─── */
.btn{width:100%;padding:14px;border:none;border-radius:var(--radius-sm);font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;font-family:var(--font)}
.btn-primary{background:var(--accent);color:#fff;min-height:50px;display:flex;align-items:center;justify-content:center}
.btn-primary:hover{background:var(--accent-hover)}
.btn-primary:disabled{opacity:.5;cursor:not-allowed}
.btn-secondary{background:rgba(42,171,238,.1);color:var(--accent);border:1px solid rgba(42,171,238,.25)}
.btn-secondary:hover{background:rgba(42,171,238,.18)}
.btn-fixed{min-height:50px;display:flex;align-items:center;justify-content:center}

/* ─── Icon button (legacy compat) ─── */
.btn-icon{
  background:var(--card);border:1px solid var(--border);color:var(--muted);
  width:38px;height:38px;border-radius:10px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .25s ease;
}
.btn-icon:hover{border-color:var(--border-hover);color:var(--text);background:var(--card-hover)}
.btn-icon:disabled{opacity:.3;cursor:default}

/* ─── Forms ─── */
.form-group{margin-bottom:16px}
.form-label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
.form-input{
  width:100%;padding:14px 16px;background:var(--card-inner);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-size:16px;font-family:var(--font);outline:none;transition:border-color .25s;
}
.form-input:focus{border-color:var(--accent)}
.form-input::placeholder{color:rgba(90,122,148,.5)}
.code-input{text-align:center;font-size:24px;letter-spacing:8px;font-weight:600}
.form-hint{font-size:12px;color:var(--muted);margin-top:8px}

/* ─── Auth (new) ─── */
.auth-hero{
  padding-top:70px;margin-bottom:32px;text-align:center;
}
.auth-hero-logo{
  width:72px;height:72px;border-radius:18px;margin-bottom:14px;
  filter:drop-shadow(0 0 20px rgba(42,171,238,.25));
}
.auth-hero-title{font-size:30px;font-weight:800;color:var(--accent);letter-spacing:-.5px;margin-bottom:4px}
.auth-hero-sub{font-size:14px;color:var(--muted);font-weight:500}

.auth-card{
  background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:20px;margin-bottom:16px;
}
.auth-input{
  width:100%;padding:15px 16px;
  background:var(--card-inner);border:1px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text);
  font-size:16px;font-family:var(--font);font-weight:500;
  outline:none;transition:all .25s;margin-bottom:12px;
}
.auth-input:focus{border-color:var(--accent);background:rgba(42,171,238,.04)}
.auth-input::placeholder{color:var(--muted);opacity:.5}
/* OTP cells */
.otp-row{
  display:flex;gap:8px;justify-content:center;margin-bottom:16px;
}
.otp-cell{
  width:48px;height:58px;
  background:var(--card-inner);border:2px solid var(--border);
  border-radius:var(--radius-sm);color:var(--text);
  font-size:24px;font-weight:800;font-family:var(--font);
  text-align:center;outline:none;
  transition:all .25s ease;
  caret-color:var(--accent);
}
.otp-cell:focus{
  border-color:var(--accent);
  background:rgba(42,171,238,.06);
  box-shadow:0 0 0 3px rgba(42,171,238,.12);
}
.otp-cell.filled{
  border-color:rgba(42,171,238,.4);
  background:rgba(42,171,238,.04);
}
.auth-submit{
  width:100%;padding:15px;border:none;border-radius:var(--radius-sm);
  background:var(--accent);color:#fff;font-size:16px;font-weight:700;
  font-family:var(--font);cursor:pointer;transition:all .25s;
  display:flex;align-items:center;justify-content:center;min-height:50px;
  box-shadow:0 2px 16px rgba(42,171,238,.25);
}
.auth-submit:hover{background:var(--accent-hover);box-shadow:0 4px 24px rgba(42,171,238,.35);transform:translateY(-1px)}
.auth-submit:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.auth-hint{
  font-size:13px;color:var(--muted);text-align:center;margin-top:12px;font-weight:500;
}
.auth-hint strong{color:var(--text2)}

.auth-divider{
  display:flex;align-items:center;gap:12px;margin-bottom:16px;
  font-size:12px;color:var(--muted);font-weight:500;text-transform:uppercase;letter-spacing:.5px;
}
.auth-divider::before,.auth-divider::after{content:"";flex:1;height:1px;background:var(--border)}

.auth-socials{display:flex;gap:10px;margin-bottom:16px}
.auth-social-btn{
  flex:1;padding:14px;border:1px solid var(--border);
  border-radius:var(--radius-sm);background:var(--card);
  color:var(--text);font-size:14px;font-weight:600;
  font-family:var(--font);cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  transition:all .25s;
}
.auth-social-btn:hover{background:var(--card-hover);border-color:var(--border-hover)}
.auth-social-btn:active{transform:scale(.98)}
.auth-social-icon{width:20px;height:20px;flex-shrink:0}

.auth-back{
  background:none;border:none;color:var(--muted);font-size:14px;font-weight:500;
  font-family:var(--font);cursor:pointer;padding:8px 0;
  display:flex;align-items:center;justify-content:center;gap:6px;
  width:100%;transition:color .2s;
}
.auth-back:hover{color:var(--text)}

/* ─── Telegram screen ─── */
.tg-polling{display:flex;align-items:center;justify-content:center;gap:8px}

/* ─── Active Payments ─── */
.pay-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;
  cursor:pointer;transition:all .25s ease;
}
.pay-card:hover{border-color:var(--border-hover);background:var(--card-hover)}
.pay-left{display:flex;align-items:center;gap:12px}
.pay-icon{width:38px;height:38px;border-radius:10px;background:var(--orange-bg);display:flex;align-items:center;justify-content:center}
.pay-amount{font-size:15px;font-weight:700;color:var(--text)}
.pay-meta{font-size:12px;color:var(--muted);margin-top:2px;font-weight:500}
.pay-status{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;white-space:nowrap}
.pay-status-pending{background:var(--orange-bg);color:var(--orange)}
/* legacy compat */
.active-pay-card{background:var(--card-inner);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 14px;margin-bottom:8px;cursor:pointer;display:flex;justify-content:space-between;align-items:center;transition:border-color .2s}
.active-pay-card:hover{border-color:var(--accent)}

/* ─── Plans ─── */
.plan-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 20px;margin-bottom:10px;cursor:pointer;
  transition:all .25s ease;position:relative;overflow:hidden;
}
.plan-card:hover{border-color:var(--accent);background:var(--card-hover)}
.plan-card:active{transform:scale(.99)}
.plan-details{display:flex;justify-content:space-between;align-items:center}
.plan-duration{font-size:16px;font-weight:700;color:var(--text)}
.plan-perday{font-size:13px;color:var(--muted);font-weight:500;margin-top:4px}
.plan-price{font-size:22px;font-weight:800;color:var(--text)}
.plan-price span{font-size:13px;font-weight:500;color:var(--muted)}
.plan-discount{
  position:absolute;top:0;right:0;
  background:var(--green);color:#fff;font-size:10px;font-weight:800;
  letter-spacing:.5px;text-transform:uppercase;
  padding:4px 12px 4px 14px;border-radius:0 16px 0 12px;
}
.plans-trigger{display:none}

/* ─── Payment Methods ─── */
.method-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;margin-bottom:10px;cursor:pointer;
  transition:all .25s ease;display:flex;align-items:center;gap:14px;position:relative;
}
.method-card.enabled:hover{border-color:var(--accent);background:var(--card-hover)}
.method-card.enabled:active{transform:scale(.99)}
.method-card.disabled{opacity:.45;cursor:default}
.method-icon{width:40px;height:40px;background:var(--accent-glow);border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;color:var(--accent)}
.method-icon svg{width:22px;height:22px}
.method-info{flex:1}
.method-name{font-size:16px;font-weight:600;color:var(--text)}
.method-desc{font-size:12px;color:var(--muted);margin-top:2px}
.method-badge-soon{font-size:11px;font-weight:700;background:rgba(90,122,148,.1);color:var(--muted);padding:4px 10px;border-radius:20px;white-space:nowrap}

/* ─── Crypto ─── */
.crypto-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:16px}
.crypto-grid-3{grid-template-columns:1fr 1fr 1fr}
.crypto-btn{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px;cursor:pointer;text-align:center;transition:all .25s ease;
  color:var(--text);display:flex;flex-direction:column;align-items:center;
}
.crypto-btn:hover{border-color:var(--accent);background:var(--card-hover)}
.crypto-btn:active{transform:scale(.98)}
.crypto-icon{margin-bottom:4px}
.crypto-currency{font-size:15px;font-weight:700;margin-bottom:2px}
.crypto-network{font-size:11px;color:var(--muted)}
.crypto-group-title{font-size:11px;font-weight:700;color:var(--muted);margin:14px 0 8px;text-transform:uppercase;letter-spacing:.5px}
.crypto-group-title:first-child{margin-top:0}
.net-item{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px 16px;cursor:pointer;transition:all .25s ease;
  color:var(--text);display:flex;align-items:center;gap:12px;margin-bottom:8px;
}
.net-item:hover{border-color:var(--accent);background:var(--card-hover)}
.net-item:active{transform:scale(.98)}

/* ─── Payment Details ─── */
.payment-qr{display:flex;justify-content:center;margin:16px 0}
.payment-qr img{width:200px;height:200px;border-radius:var(--radius-sm);background:#fff;padding:8px}
.copy-field{
  background:var(--card-inner);border:1px solid var(--border);border-radius:10px;
  padding:12px 14px;display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px;
}
.copy-field-label{font-size:11px;color:var(--muted);margin-bottom:2px}
.copy-field-value{font-size:13px;color:var(--text);word-break:break-all;font-family:"SF Mono",Monaco,Consolas,monospace}
.copy-icon-btn{flex-shrink:0;background:none;border:none;color:var(--muted);cursor:pointer;padding:4px;transition:color .2s;width:26px;height:26px;display:flex;align-items:center;justify-content:center}
.copy-icon-btn:hover{color:var(--accent)}
.pay-order-id{text-align:center;font-size:10px;color:rgba(90,122,148,.4);margin-top:8px;word-break:break-all;font-family:"SF Mono",Monaco,Consolas,monospace}

/* ─── Timer ─── */
.timer{text-align:center;font-size:20px;color:var(--muted);margin:12px 0;font-weight:600;letter-spacing:1px}
.timer strong{color:var(--orange);font-size:22px}

/* ─── Status ─── */
.status-msg{text-align:center;padding:24px 16px}
.status-icon{font-size:48px;margin-bottom:12px}
.status-title{font-size:18px;font-weight:700;margin-bottom:6px}
.status-text{font-size:14px;color:var(--muted)}

/* ─── Underpaid ─── */
.underpaid-notice{background:var(--orange-bg);border:1px solid rgba(251,191,36,.2);border-radius:10px;padding:12px 14px;margin:10px 0;font-size:13px;color:var(--orange)}
.underpaid-progress{background:rgba(255,255,255,.04);border-radius:6px;height:6px;margin:8px 0 4px;overflow:hidden}
.underpaid-progress-bar{height:100%;background:var(--orange);border-radius:6px;transition:width .4s ease}

/* ─── Devices ─── */
.device-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;margin-bottom:8px;display:flex;align-items:center;gap:14px;transition:all .25s ease;
}
.device-icon{
  width:42px;height:42px;border-radius:11px;background:var(--accent-glow);
  color:var(--accent);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.device-icon svg{width:20px;height:20px}
.device-info{flex:1;min-width:0}
.device-name{font-size:15px;font-weight:700;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.device-meta{font-size:12px;color:var(--muted);margin-top:2px;font-weight:500}
.device-seen{font-size:11px;color:var(--muted);margin-top:2px;font-weight:500;opacity:.7}
.device-delete{
  flex-shrink:0;background:transparent;border:none;color:var(--muted);
  width:38px;height:38px;border-radius:10px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .25s ease;
}
.device-delete:hover{color:var(--red);background:var(--red-bg)}
.device-current{
  font-size:10px;font-weight:700;color:var(--green);background:var(--green-bg);
  padding:2px 7px;border-radius:4px;margin-left:8px;text-transform:uppercase;letter-spacing:.3px;
}

/* ─── History ─── */
.history-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:16px 18px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.history-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}
.history-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.history-icon-ok{background:var(--green-bg);color:var(--green)}
.history-icon-fail{background:var(--red-bg);color:var(--red)}
.history-icon-pending{background:var(--orange-bg);color:var(--orange)}
.history-icon svg{width:18px;height:18px}
.history-info{flex:1;min-width:0}
.history-amount{font-size:15px;font-weight:700;color:var(--text)}
.history-detail{font-size:12px;color:var(--muted);margin-top:2px;font-weight:500}
.history-meta{font-size:12px;color:var(--muted);margin-top:2px;font-weight:500}
.history-right{text-align:right;flex-shrink:0}
.history-date{font-size:12px;color:var(--muted);font-weight:500}
.history-status{font-size:11px;font-weight:700;margin-top:3px}
.history-status-ok{color:var(--green)}
.history-status-fail{color:var(--red)}
.history-status-pending{color:var(--orange)}
.history-nav{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 0}
.history-nav button{
  background:var(--card);border:1px solid var(--border);color:var(--muted);
  width:38px;height:38px;border-radius:10px;cursor:pointer;
  display:flex;align-items:center;justify-content:center;transition:all .25s ease;font-family:var(--font);
}
.history-nav button:hover:not(:disabled){color:var(--text);background:var(--card-hover)}
.history-nav button:disabled{opacity:.3;cursor:default}
.history-page{font-size:13px;color:var(--muted);font-weight:600;padding:0 8px}

/* ─── Promos ─── */
.promo-input-row{display:flex;gap:8px;margin-bottom:4px}
.promo-input{
  flex:1;padding:14px 16px;background:var(--card-inner);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-size:15px;font-weight:600;font-family:var(--font);
  outline:none;transition:border-color .25s;text-transform:uppercase;letter-spacing:1px;
}
.promo-input:focus{border-color:var(--accent)}
.promo-input::placeholder{color:var(--muted);opacity:.5;text-transform:none;letter-spacing:0;font-weight:500}
.btn-apply{
  background:var(--accent);color:#fff;border:none;
  padding:0 22px;border-radius:var(--radius-sm);
  font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font);
  transition:all .25s ease;white-space:nowrap;
}
.btn-apply:hover{background:var(--accent-hover)}
.btn-apply:disabled{opacity:.5;cursor:not-allowed}
.promo-history-item{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px 16px;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between;
}
.promo-code{font-size:14px;font-weight:700;color:var(--accent);font-family:"SF Mono",Monaco,Consolas,monospace;letter-spacing:.5px}
.promo-result{font-size:12px;color:var(--muted);margin-top:3px;font-weight:500}
.promo-date{font-size:11px;color:var(--muted);font-weight:500;text-align:right}

/* ─── Spinner ─── */
.spinner{display:inline-block;width:20px;height:20px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.screen-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:16px}
.screen-loading .spinner{width:32px;height:32px;border-width:3px}

/* ─── Toast ─── */
.toast{
  position:fixed;top:16px;left:50%;transform:translateX(-50%);
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:12px 20px;font-size:14px;color:var(--text);z-index:1000;
  max-width:400px;text-align:center;animation:toastIn .3s ease;
  box-shadow:0 4px 24px rgba(0,0,0,.5);overflow:hidden;font-family:var(--font);
}
.toast-error{border-color:rgba(248,113,113,.3)}.toast-error .toast-bar{background:var(--red)}
.toast-success{border-color:rgba(52,211,153,.3)}.toast-success .toast-bar{background:var(--green)}
.toast-warning{border-color:rgba(251,191,36,.3)}.toast-warning .toast-bar{background:var(--orange)}
@keyframes toastIn{from{opacity:0;transform:translateX(-50%) translateY(-10px)}to{opacity:1;transform:translateX(-50%) translateY(0)}}
.toast-bar{position:absolute;bottom:0;left:0;height:3px;background:var(--accent);border-radius:0 0 12px 12px;animation:toastBar 4s linear forwards}
@keyframes toastBar{from{width:100%}to{width:0%}}

/* ─── Info field ─── */
.info-field{background:var(--card-inner);border:1px solid var(--border);border-radius:10px;padding:12px 14px;margin-bottom:10px}
.info-field-label{font-size:11px;color:var(--muted);margin-bottom:2px}
.info-field-value{font-size:13px;color:var(--text)}

/* ─── Empty state ─── */
.empty-state{text-align:center;padding:40px 20px}
.empty-text{font-size:14px;color:var(--muted);font-weight:500}

/* ─── Payment page (new) ─── */
.payment-card{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;margin-bottom:12px;overflow:hidden;
}
.payment-qr{display:flex;justify-content:center;margin:0 0 18px}
.payment-qr img{width:200px;height:200px;border-radius:var(--radius-sm);background:#fff;padding:8px}
.copy-field{
  background:var(--card-inner);border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:14px 16px;display:flex;justify-content:space-between;align-items:center;margin-bottom:10px;gap:10px;
}
.pay-actions{display:flex;gap:10px;margin-top:16px}
.btn-pay-confirm{
  flex:1;padding:14px;border:none;border-radius:var(--radius-sm);
  font-size:15px;font-weight:700;cursor:pointer;font-family:var(--font);
  background:var(--accent);color:#fff;
  display:flex;align-items:center;justify-content:center;min-height:50px;
  transition:all .25s ease;box-shadow:0 2px 12px rgba(42,171,238,.2);
}
.btn-pay-confirm:hover{background:var(--accent-hover);box-shadow:0 4px 20px rgba(42,171,238,.3);transform:translateY(-1px)}
.btn-pay-confirm:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}
.btn-pay-cancel{
  flex:1;padding:14px;border:1px solid rgba(248,113,113,.25);border-radius:var(--radius-sm);
  font-size:15px;font-weight:700;cursor:pointer;font-family:var(--font);
  background:rgba(248,113,113,.06);color:var(--red);
  display:flex;align-items:center;justify-content:center;min-height:50px;
  transition:all .25s ease;
}
.btn-pay-cancel:hover{background:rgba(248,113,113,.12);border-color:rgba(248,113,113,.4)}
.btn-pay-cancel:disabled{opacity:.5;cursor:not-allowed}
.payment-status-badge{text-align:center;margin:14px 0}
.payment-timer{text-align:center;font-size:20px;color:var(--muted);margin:12px 0;font-weight:600;letter-spacing:1px}
.payment-timer strong{color:var(--orange);font-size:22px}
.payment-order-id{text-align:center;font-size:10px;color:rgba(90,122,148,.4);margin-top:8px;word-break:break-all;font-family:"SF Mono",Monaco,Consolas,monospace}

/* ─── Promo input (standalone, no card wrap) ─── */
.promo-input-row{
  display:flex;gap:8px;margin-bottom:16px;
}
.promo-input{
  flex:1;padding:14px 16px;background:var(--card);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  color:var(--text);font-size:15px;font-weight:700;font-family:var(--font);
  outline:none;transition:all .25s;text-transform:uppercase;letter-spacing:2px;
}
.promo-input:focus{border-color:var(--accent);background:var(--card-hover)}
.promo-input::placeholder{color:var(--muted);opacity:.4;font-weight:600;letter-spacing:2px}
.btn-apply{
  background:var(--accent);color:#fff;border:none;
  padding:0 24px;border-radius:var(--radius-sm);
  font-size:14px;font-weight:700;cursor:pointer;font-family:var(--font);
  transition:all .25s ease;white-space:nowrap;
  box-shadow:0 2px 12px rgba(42,171,238,.2);
}
.btn-apply:hover{background:var(--accent-hover);box-shadow:0 4px 16px rgba(42,171,238,.3)}
.btn-apply:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}

/* ─── Screen hint ─── */
.screen-hint{
  font-size:13px;color:var(--muted);font-weight:500;line-height:1.5;
  padding:0 2px 14px;
}
.screen-hint strong{color:var(--text2);font-weight:600}

/* ─── Glow animation for renew tile ─── */
.hero-tile-glow{
  animation:tileGlow 2s ease-in-out infinite;
  border-color:rgba(42,171,238,.3);
}
@keyframes tileGlow{
  0%,100%{box-shadow:0 0 0 0 rgba(42,171,238,.15);border-color:rgba(42,171,238,.3)}
  50%{box-shadow:0 0 16px 4px rgba(42,171,238,.2);border-color:rgba(42,171,238,.5)}
}

/* ─── Animations ─── */
@keyframes fadeUp{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}
.anim{animation:fadeUp .45s ease both}
.a1{animation-delay:.05s}.a2{animation-delay:.1s}.a3{animation-delay:.15s}
.a4{animation-delay:.2s}.a5{animation-delay:.25s}.a6{animation-delay:.3s}

/* ─── Legacy compat ─── */
.profile-row{display:none}
.profile-label{display:none}
.profile-value{display:none}
.sub-info{display:flex;justify-content:space-between;font-size:13px;color:var(--muted);margin-top:4px}
.progress-wrap{background:rgba(255,255,255,.04);border-radius:8px;height:6px;margin:12px 0 6px;overflow:hidden}
.progress-bar{height:100%;border-radius:8px;background:linear-gradient(90deg,var(--accent),#34D399);transition:width .4s ease}

@media(max-width:430px){.app{padding:0 12px 32px}}
