/* ╔══════════════════════════════════════════════════════════╗
   ║  style.css — ReactWA v2 Premium UI                      ║
   ╚══════════════════════════════════════════════════════════╝ */

@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&family=JetBrains+Mono:wght@400;600&display=swap');

/* ─── TOKENS ─────────────────────────────────────────────── */
:root {
  --bg:      #030805;
  --bg2:     #060f09;
  --bg3:     #091410;
  --g1:      #22c55e;
  --g2:      #16a34a;
  --g3:      #15803d;
  --g-glow:  rgba(34,197,94,.18);
  --gold:    #eab308;
  --purple:  #a855f7;
  --orange:  #f97316;
  --red:     #ef4444;
  --teal:    #14b8a6;
  --success: #4ade80;
  --glass:   rgba(255,255,255,.032);
  --glass2:  rgba(255,255,255,.06);
  --border:  rgba(34,197,94,.14);
  --border2: rgba(255,255,255,.07);
  --t1:      #f0fdf4;
  --t2:      #86efac;
  --t3:      #4ade80;
  --t4:      #166534;
  --r:       22px;
  --r2:      16px;
  --r3:      12px;
  --shadow:  0 24px 64px rgba(0,0,0,.6);
  --glow:    0 0 60px rgba(34,197,94,.12);
}

/* ─── RESET ──────────────────────────────────────────────── */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
/* Remove purple tap highlight on mobile */
* { -webkit-tap-highlight-color: transparent; tap-highlight-color: transparent; }
button, a { -webkit-tap-highlight-color: transparent; outline:none; }
html { scroll-behavior:smooth; scroll-padding-top:72px; }
body {
  background: var(--bg);
  color: var(--t1);
  font-family: 'Plus Jakarta Sans', sans-serif;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  line-height: 1.6;
}
a { color:inherit; text-decoration:none; }
button { font-family: inherit; cursor:pointer; border:none; }
input, textarea { font-family: inherit; }

/* ─── NOISE + AMBIENT ─────────────────────────────────────── */
body::before {
  content:'';
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.022'/%3E%3C/svg%3E");
}

#aurora { position:fixed; inset:0; z-index:0; pointer-events:none; overflow:hidden; }
.ab { position:absolute; border-radius:50%; filter:blur(120px); animation:afloat 28s ease-in-out infinite; }
.ab1 { width:900px;height:900px;background:radial-gradient(circle,rgba(34,197,94,.07),transparent 70%);top:-300px;right:-200px; }
.ab2 { width:600px;height:600px;background:radial-gradient(circle,rgba(20,184,166,.06),transparent 70%);bottom:-200px;left:-150px;animation-delay:-11s; }
.ab3 { width:450px;height:450px;background:radial-gradient(circle,rgba(34,197,94,.04),transparent 70%);top:40%;left:25%;animation-delay:-20s; }
@keyframes afloat {
  0%,100%{transform:translateY(0) scale(1) rotate(0deg)}
  33%{transform:translateY(-60px) scale(1.06) rotate(1deg)}
  66%{transform:translateY(30px) scale(.95) rotate(-1deg)}
}

#grid-bg {
  position:fixed; inset:0; z-index:0; pointer-events:none;
  background-image:linear-gradient(rgba(34,197,94,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(34,197,94,.025) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 90% 90% at 50% 30%,black 0%,transparent 100%);
}

.page { position:relative; z-index:1; }

/* ─── SCROLLBAR ───────────────────────────────────────────── */
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--g3); border-radius:4px; }

/* ═══════════════════════════════════════════════════════════
   NAVBAR
═══════════════════════════════════════════════════════════ */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:999;
  height:68px;
  background:rgba(3,8,5,.8);
  backdrop-filter:blur(28px) saturate(200%);
  border-bottom:1px solid var(--border2);
  transition:transform .45s cubic-bezier(.4,0,.2,1), box-shadow .3s;
}
#navbar.hidden { transform:translateY(-100%); }
#navbar.scrolled { box-shadow:0 4px 48px rgba(0,0,0,.6); border-bottom-color:var(--border); }

.nav-inner {
  max-width:1160px; margin:0 auto; padding:0 24px;
  height:100%; display:flex; align-items:center; justify-content:space-between; gap:20px;
}
.nav-logo { display:flex; align-items:center; gap:12px; }
.nav-logo-mark {
  position:relative; width:40px; height:40px;
  display:flex; align-items:center; justify-content:center;
}
.nav-logo-mark-inner {
  width:40px; height:40px; border-radius:13px;
  background:linear-gradient(135deg,var(--g1) 0%,var(--g2) 60%,var(--teal) 100%);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 28px rgba(34,197,94,.4), 0 4px 12px rgba(0,0,0,.4);
  position:relative; overflow:hidden;
}
.nav-logo-mark-inner::after {
  content:''; position:absolute; top:0; left:0; right:0; height:50%;
  background:linear-gradient(180deg,rgba(255,255,255,.25),transparent);
  border-radius:13px 13px 0 0;
}
.nav-logo-name {
  font-size:1.3rem; font-weight:800; letter-spacing:-.03em;
  background:linear-gradient(135deg,#fff 30%,var(--g1));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.nav-badge {
  font-size:.65rem; font-weight:700; letter-spacing:.1em; text-transform:uppercase;
  padding:3px 9px; border-radius:100px;
  background:linear-gradient(135deg,rgba(34,197,94,.2),rgba(20,184,166,.15));
  color:var(--g1); border:1px solid rgba(34,197,94,.3);
}
.nav-links { display:flex; align-items:center; gap:2px; }
.nav-link {
  padding:7px 15px; border-radius:10px;
  font-size:.875rem; font-weight:500; color:rgba(240,253,244,.5);
  transition:all .2s; background:none;
}
.nav-link:hover { color:var(--t1); background:rgba(255,255,255,.06); }
.nav-cta {
  display:flex; align-items:center; gap:8px;
  padding:9px 20px; border-radius:11px;
  background:linear-gradient(135deg,var(--g1),var(--g2));
  color:#000; font-size:.875rem; font-weight:700;
  box-shadow:0 4px 24px rgba(34,197,94,.35), inset 0 1px 0 rgba(255,255,255,.3);
  transition:all .25s;
}
.nav-cta:hover { transform:translateY(-1px); box-shadow:0 8px 32px rgba(34,197,94,.5); }
.hamburger { display:none; flex-direction:column; gap:5px; padding:4px; background:none; }
.hamburger span { display:block; width:22px; height:2px; background:rgba(240,253,244,.6); border-radius:4px; transition:all .3s; }
.mob-menu {
  display:none; position:fixed; top:68px; left:0; right:0; z-index:998;
  background:rgba(3,8,5,.97); border-bottom:1px solid var(--border2);
  backdrop-filter:blur(24px); padding:12px; flex-direction:column; gap:4px;
}
.mob-menu.open { display:flex; }
.mob-link { padding:12px 16px; border-radius:11px; font-size:.95rem; font-weight:500; color:rgba(240,253,244,.6); background:none; text-align:left; transition:all .2s; }
.mob-link:hover { background:rgba(255,255,255,.06); color:var(--t1); }
@media(max-width:768px){
  .nav-links,.nav-cta { display:none; }
  .hamburger { display:flex; }
}

/* ═══════════════════════════════════════════════════════════
   HERO
═══════════════════════════════════════════════════════════ */
.hero {
  min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  text-align:center; padding:110px 24px 80px;
  position:relative; overflow:hidden;
}
.hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 20px; border-radius:100px;
  border:1px solid rgba(34,197,94,.2);
  background:linear-gradient(135deg,rgba(34,197,94,.08),rgba(20,184,166,.06));
  font-size:.8rem; font-weight:600; color:var(--g1); letter-spacing:.06em; text-transform:uppercase;
  margin-bottom:32px; backdrop-filter:blur(8px);
  animation:fade-up .8s ease .1s both;
}
.badge-dot {
  width:7px; height:7px; border-radius:50%;
  background:var(--g1); box-shadow:0 0 12px var(--g1);
  animation:pulse-dot 2s ease-in-out infinite;
}
@keyframes pulse-dot { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.3;transform:scale(.6)} }

.hero h1 {
  font-size:clamp(2.8rem,8vw,6rem);
  font-weight:800; letter-spacing:-.04em; line-height:1.02;
  margin-bottom:24px;
  animation:fade-up .8s ease .25s both;
}
.h1-white { color:#fff; }
.h1-green {
  background:linear-gradient(135deg, #4ade80 0%, #22c55e 40%, #86efac 100%);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  position:relative;
}
.hero-sub {
  font-size:clamp(1rem,2.5vw,1.2rem); color:rgba(134,239,172,.7); font-weight:400;
  max-width:580px; margin:0 auto 44px; line-height:1.75;
  animation:fade-up .8s ease .4s both;
}
.hero-actions {
  display:flex; align-items:center; justify-content:center; gap:14px; flex-wrap:wrap;
  animation:fade-up .8s ease .55s both;
}
.btn-primary {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 32px; border-radius:14px;
  background:linear-gradient(135deg,var(--g1),var(--g2));
  color:#000; font-size:1rem; font-weight:700;
  box-shadow:0 8px 36px rgba(34,197,94,.4), inset 0 1px 0 rgba(255,255,255,.35);
  transition:all .3s; position:relative; overflow:hidden;
}
.btn-primary::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent 50%);
  border-radius:14px;
}
.btn-primary:hover { transform:translateY(-3px); box-shadow:0 16px 48px rgba(34,197,94,.55); }
.btn-outline {
  display:inline-flex; align-items:center; gap:10px;
  padding:15px 32px; border-radius:14px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1);
  color:var(--t1); font-size:1rem; font-weight:500;
  transition:all .3s; backdrop-filter:blur(8px);
}
.btn-outline:hover { background:rgba(255,255,255,.08); border-color:rgba(34,197,94,.3); }

.hero-stats {
  display:flex; align-items:center; justify-content:center; gap:48px; flex-wrap:wrap;
  margin-top:72px; animation:fade-up .8s ease .7s both;
}
.hero-stat { text-align:center; }
.stat-num {
  font-size:2.4rem; font-weight:800; letter-spacing:-.04em;
  background:linear-gradient(135deg,#fff,var(--g1));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-label { font-size:.75rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:rgba(134,239,172,.5); margin-top:4px; }
.stat-div { width:1px; height:40px; background:var(--border2); }

.scroll-hint {
  position:absolute; bottom:32px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:6px;
  color:rgba(134,239,172,.3); font-size:.75rem; font-weight:500;
  animation:bounce-v 2.5s ease-in-out infinite;
}
@keyframes bounce-v { 0%,100%{transform:translateX(-50%) translateY(0)} 55%{transform:translateX(-50%) translateY(9px)} }
@keyframes fade-up { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }

/* ─── MARQUEE ─────────────────────────────────────────────── */
.marquee-wrap {
  border-top:1px solid var(--border2); border-bottom:1px solid var(--border2);
  background:rgba(255,255,255,.015); overflow:hidden; padding:16px 0;
}
.marquee-track { display:flex; gap:56px; animation:marquee 30s linear infinite; width:max-content; }
.marquee-track:hover { animation-play-state:paused; }
.m-item { display:flex; align-items:center; gap:10px; white-space:nowrap; font-size:.875rem; font-weight:500; color:rgba(134,239,172,.5); }
.m-icon { color:var(--g1); display:flex; flex-shrink:0; }
@keyframes marquee { from{transform:translateX(0)} to{transform:translateX(-50%)} }

/* ═══════════════════════════════════════════════════════════
   SECTION BASE
═══════════════════════════════════════════════════════════ */
.section { padding:88px 24px; }
.s-inner { max-width:1160px; margin:0 auto; }
.s-tag {
  display:inline-flex; align-items:center; gap:8px;
  font-size:.72rem; font-weight:700; letter-spacing:.15em; text-transform:uppercase;
  color:var(--g1); margin-bottom:14px;
}
.s-tag::before { content:''; display:block; width:24px; height:2px; background:var(--g1); border-radius:4px; }
.s-title {
  font-size:clamp(2rem,4vw,3.2rem); font-weight:800;
  letter-spacing:-.03em; line-height:1.1; margin-bottom:16px;
}
.s-title .hl {
  background:linear-gradient(135deg,var(--g1),#86efac);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}
.s-desc { color:rgba(134,239,172,.65); font-size:1.05rem; font-weight:400; max-width:520px; }

/* ═══════════════════════════════════════════════════════════
   HOW IT WORKS — 3D Cards
═══════════════════════════════════════════════════════════ */
.how-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:20px; margin-top:52px;
}
.how-card {
  background:var(--glass);
  border:1px solid var(--border2);
  border-radius:var(--r); padding:32px 26px;
  position:relative; overflow:hidden;
  transition:all .4s cubic-bezier(.4,0,.2,1);
  transform-style:preserve-3d;
  cursor:default;
}
.how-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(34,197,94,.06),transparent 55%);
  opacity:0; transition:opacity .4s;
}
.how-card::after {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,rgba(34,197,94,.4),transparent);
  opacity:0; transition:opacity .4s;
}
.how-card:hover { border-color:rgba(34,197,94,.25); transform:translateY(-6px) rotateX(2deg); box-shadow:0 24px 60px rgba(0,0,0,.5),var(--glow); }
.how-card:hover::before, .how-card:hover::after { opacity:1; }
.how-num {
  font-size:3.5rem; font-weight:800; letter-spacing:-.06em; line-height:1;
  background:linear-gradient(135deg,rgba(34,197,94,.6),rgba(34,197,94,.1));
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  margin-bottom:20px;
}
.how-icon-wrap {
  width:52px; height:52px; border-radius:15px; margin-bottom:20px;
  background:linear-gradient(135deg,rgba(34,197,94,.15),rgba(20,184,166,.1));
  border:1px solid rgba(34,197,94,.2);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 24px rgba(34,197,94,.1);
  transition:all .3s;
}
.how-card:hover .how-icon-wrap { background:linear-gradient(135deg,rgba(34,197,94,.25),rgba(20,184,166,.2)); transform:scale(1.08); box-shadow:0 12px 32px rgba(34,197,94,.2); }
.how-icon-wrap svg { color:var(--g1); }
.how-card h3 { font-size:1.1rem; font-weight:700; margin-bottom:8px; letter-spacing:-.01em; }
.how-card p { font-size:.875rem; color:rgba(134,239,172,.6); line-height:1.65; }

/* ═══════════════════════════════════════════════════════════
   PACKAGES — 3D Premium Cards
═══════════════════════════════════════════════════════════ */
.pkg-grid {
  display:grid; grid-template-columns:repeat(auto-fit,minmax(250px,1fr));
  gap:20px; margin-top:52px;
}
.pkg-card {
  background:var(--glass);
  border:1px solid var(--border2);
  border-radius:var(--r); padding:28px 24px;
  position:relative; overflow:hidden;
  transition:all .4s cubic-bezier(.4,0,.2,1);
  cursor:pointer; transform-style:preserve-3d;
}
.pkg-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(34,197,94,.04),transparent 60%);
  opacity:0; transition:opacity .35s; pointer-events:none;
}
.pkg-card:hover { border-color:rgba(34,197,94,.3); transform:translateY(-6px) rotateX(1.5deg); box-shadow:0 28px 64px rgba(0,0,0,.5),var(--glow); }
.pkg-card:hover::before { opacity:1; }
.pkg-card.popular {
  border-color:rgba(234,179,8,.3);
  background:linear-gradient(145deg,rgba(234,179,8,.04),var(--glass));
}
.pkg-card.popular:hover { border-color:rgba(234,179,8,.5); box-shadow:0 28px 64px rgba(0,0,0,.5),0 0 60px rgba(234,179,8,.1); }
.pkg-top-line {
  position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--g1),transparent);
  opacity:0; transition:opacity .35s;
}
.pkg-card:hover .pkg-top-line { opacity:1; }
.pkg-card.popular .pkg-top-line { opacity:1; background:linear-gradient(90deg,transparent,var(--gold),transparent); }

.pkg-badge {
  display:inline-flex; align-items:center; gap:5px;
  padding:4px 12px; border-radius:100px; margin-bottom:18px;
  font-size:.7rem; font-weight:700; letter-spacing:.08em; text-transform:uppercase;
}
.pkg-badge-popular { background:rgba(234,179,8,.15); color:var(--gold); border:1px solid rgba(234,179,8,.3); }
.pkg-badge-sale { background:rgba(168,85,247,.15); color:var(--purple); border:1px solid rgba(168,85,247,.3); }
.pkg-badge-value { background:rgba(249,115,22,.15); color:var(--orange); border:1px solid rgba(249,115,22,.3); }

.pkg-icon-wrap {
  width:48px; height:48px; border-radius:14px; margin-bottom:18px;
  display:flex; align-items:center; justify-content:center;
  transition:all .3s;
}
.pkg-card:hover .pkg-icon-wrap { transform:scale(1.1) rotateY(8deg); }

.pkg-name { font-size:1.1rem; font-weight:800; letter-spacing:-.02em; margin-bottom:4px; }
.pkg-desc { font-size:.82rem; color:rgba(134,239,172,.5); margin-bottom:20px; }
.pkg-count { font-size:2.6rem; font-weight:800; letter-spacing:-.05em; line-height:1; margin-bottom:2px; }
.pkg-count-label { font-size:.78rem; font-weight:500; color:rgba(134,239,172,.5); margin-bottom:18px; }
.pkg-price { font-size:1.4rem; font-weight:800; letter-spacing:-.02em; margin-bottom:20px; }
.pkg-price small { font-size:.85rem; font-weight:400; color:rgba(134,239,172,.4); }
.pkg-card.disabled {
  opacity:.45; cursor:not-allowed; pointer-events:none;
  filter:grayscale(80%);
}
.pkg-card.disabled .pkg-btn {
  background:rgba(255,255,255,.05) !important;
  border-color:rgba(255,255,255,.1) !important;
  color:rgba(255,255,255,.25) !important;
  box-shadow:none !important; cursor:not-allowed;
}
.pkg-card.disabled .pkg-count,
.pkg-card.disabled .pkg-name { color:rgba(255,255,255,.3) !important; }

.pkg-card.disabled::after {
  content:'Tidak Tersedia';
  position:absolute; top:12px; right:12px;
  font-size:.65rem; font-weight:700; letter-spacing:.08em;
  padding:3px 10px; border-radius:100px;
  background:rgba(255,255,255,.07); color:rgba(255,255,255,.3);
  border:1px solid rgba(255,255,255,.1);
  text-transform:uppercase;
}

.pkg-select-item.disabled {
  opacity:.35; cursor:not-allowed; pointer-events:none; filter:grayscale(70%);
}

.pkg-btn {
  width:100%; padding:12px; border-radius:12px;
  font-size:.9rem; font-weight:700; transition:all .25s;
  display:flex; align-items:center; justify-content:center; gap:7px;
}
.pkg-btn-outline {
  background:rgba(34,197,94,.08); border:1px solid rgba(34,197,94,.2);
  color:var(--g1);
}
.pkg-btn-outline:hover, .pkg-card.popular .pkg-btn-outline {
  background:linear-gradient(135deg,var(--g1),var(--g2));
  border-color:transparent; color:#000;
  box-shadow:0 6px 24px rgba(34,197,94,.35);
}

/* ═══════════════════════════════════════════════════════════
   ORDER FORM
═══════════════════════════════════════════════════════════ */
.order-wrap { max-width:660px; margin:52px auto 0; }

/* Step bar */
.step-bar {
  display:flex; align-items:flex-start;
  justify-content:center; gap:0; margin-bottom:40px;
}
.step-item { display:flex; flex-direction:column; align-items:center; gap:8px; flex:1; position:relative; }
.step-item:not(:last-child)::after {
  content:''; position:absolute; top:17px; left:55%;
  width:90%; height:1px;
  background:var(--border2); transition:background .5s;
}
.step-item.done:not(:last-child)::after { background:var(--g1); }
.step-circle {
  width:34px; height:34px; border-radius:50%;
  background:rgba(255,255,255,.04); border:1px solid var(--border2);
  display:flex; align-items:center; justify-content:center;
  font-size:.8rem; font-weight:700; color:rgba(134,239,172,.35);
  transition:all .4s; z-index:1;
}
.step-item.active .step-circle {
  background:rgba(34,197,94,.15); border-color:var(--g1);
  color:var(--g1); box-shadow:0 0 24px rgba(34,197,94,.3);
}
.step-item.done .step-circle {
  background:var(--g1); border-color:var(--g1); color:#000;
  box-shadow:0 0 20px rgba(34,197,94,.4);
}
.step-label { font-size:.7rem; font-weight:600; letter-spacing:.05em; text-transform:uppercase; color:rgba(134,239,172,.3); text-align:center; }
.step-item.active .step-label { color:var(--g1); }
.step-item.done .step-label { color:rgba(134,239,172,.5); }

/* Panel */
.order-panel {
  background:linear-gradient(145deg,rgba(255,255,255,.035),rgba(255,255,255,.018));
  border:1px solid var(--border2);
  border-radius:var(--r); overflow:hidden;
  box-shadow:0 32px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.04);
  backdrop-filter:blur(24px);
}
.panel-header {
  padding:24px 28px; background:rgba(34,197,94,.03);
  border-bottom:1px solid var(--border2);
  position:relative;
}
.panel-header::after {
  content:''; position:absolute; bottom:-1px; left:28px; right:28px; height:1px;
  background:linear-gradient(90deg,transparent,rgba(34,197,94,.3),transparent);
}
.panel-header h2 { font-size:1.15rem; font-weight:700; letter-spacing:-.01em; }
.panel-header p { font-size:.875rem; color:rgba(134,239,172,.55); margin-top:4px; }
.panel-body { padding:28px; }

/* Form steps */
.form-step { display:none; animation:fade-up .35s ease; }
.form-step.active { display:block; }

/* Fields */
.field { margin-bottom:22px; }
.field label {
  display:block; font-size:.85rem; font-weight:600;
  color:rgba(134,239,172,.7); margin-bottom:9px; letter-spacing:.02em;
}
.req { color:var(--red); }
.field-input {
  width:100%; padding:13px 16px; border-radius:var(--r3);
  background:rgba(255,255,255,.04); border:1px solid var(--border2);
  color:var(--t1); font-size:.95rem; font-family:'Plus Jakarta Sans',sans-serif;
  outline:none; transition:all .25s;
}
.field-input:focus {
  border-color:var(--g1); background:rgba(34,197,94,.05);
  box-shadow:0 0 0 3px rgba(34,197,94,.1);
}
.field-input::placeholder { color:rgba(134,239,172,.25); }
.field-hint { font-size:.78rem; color:rgba(134,239,172,.35); margin-top:7px; display:flex; align-items:center; gap:5px; }

/* Package selector in form */
.pkg-select-grid {
  display:grid; grid-template-columns:1fr 1fr; gap:10px; margin-top:8px;
}
.psi {
  padding:14px 16px; border-radius:var(--r3);
  background:rgba(255,255,255,.03); border:1px solid var(--border2);
  cursor:pointer; transition:all .25s; position:relative; overflow:hidden;
}
.psi::before { content:''; position:absolute; inset:0; background:linear-gradient(135deg,rgba(34,197,94,.07),transparent); opacity:0; transition:opacity .25s; }
.psi:hover { border-color:rgba(34,197,94,.2); transform:translateY(-1px); }
.psi:hover::before { opacity:1; }
.psi.selected { border-color:var(--g1); background:rgba(34,197,94,.08); box-shadow:0 0 20px rgba(34,197,94,.12); }
.psi.selected::before { opacity:1; }
.psi-name { font-size:.82rem; font-weight:700; color:rgba(134,239,172,.6); margin-bottom:4px; }
.psi-count { font-size:1.15rem; font-weight:800; letter-spacing:-.02em; }
.psi-price { font-size:.78rem; color:rgba(134,239,172,.45); margin-top:3px; }
.psi-badge { font-size:.62rem; font-weight:700; color:var(--gold); margin-top:3px; letter-spacing:.04em; }

/* Emoji grid */
.emoji-grid { display:flex; flex-wrap:wrap; gap:8px; margin-top:8px; }
.emoji-btn {
  width:44px; height:44px; border-radius:11px;
  background:rgba(255,255,255,.04); border:1px solid var(--border2);
  font-size:1.25rem; cursor:pointer; transition:all .2s;
  display:flex; align-items:center; justify-content:center;
}
.emoji-btn:hover { background:rgba(255,255,255,.08); transform:scale(1.12); }
.emoji-btn.selected { background:rgba(34,197,94,.15); border-color:var(--g1); box-shadow:0 0 16px rgba(34,197,94,.2); transform:scale(1.14); }
.emoji-custom-wrap { display:flex; gap:10px; align-items:center; margin-top:12px; }
.emoji-custom-input {
  flex:1; padding:11px 14px; border-radius:var(--r3);
  background:rgba(255,255,255,.04); border:1px solid var(--border2);
  color:var(--t1); font-size:1.2rem; outline:none; transition:border-color .25s;
}
.emoji-custom-input:focus { border-color:var(--g1); }

/* Order summary */
.order-summary {
  background:rgba(34,197,94,.04); border:1px solid rgba(34,197,94,.12);
  border-radius:var(--r2); padding:20px; margin-bottom:20px;
}
.s-row {
  display:flex; justify-content:space-between; align-items:flex-start;
  padding:8px 0; border-bottom:1px solid rgba(255,255,255,.04);
  font-size:.9rem; gap:12px;
}
.s-row:last-child { border-bottom:none; font-weight:700; color:var(--g1); font-size:1rem; padding-top:14px; }
.s-row-label { color:rgba(134,239,172,.5); flex-shrink:0; }
.s-row-val { text-align:right; word-break:break-all; }

/* Warning box */
.warn-box {
  background:rgba(234,179,8,.06); border:1px solid rgba(234,179,8,.18);
  border-radius:var(--r3); padding:13px 16px;
  font-size:.83rem; color:#fde68a; line-height:1.55;
  display:flex; gap:10px; align-items:flex-start; margin-bottom:20px;
}
.warn-box svg { flex-shrink:0; margin-top:1px; color:var(--gold); }

/* Payment QR */
.qr-wrap { display:flex; flex-direction:column; align-items:center; gap:20px; }
#qr-canvas {
  background:#fff; border-radius:20px; padding:16px;
  box-shadow:0 0 0 1px rgba(255,255,255,.1), 0 0 60px rgba(34,197,94,.15), 0 20px 60px rgba(0,0,0,.5);
  transition:all .3s;
}
#qr-canvas:hover { transform:scale(1.02); box-shadow:0 0 0 1px rgba(255,255,255,.15), 0 0 80px rgba(34,197,94,.25), 0 24px 70px rgba(0,0,0,.6); }
.pay-amount-box {
  width:100%; background:rgba(34,197,94,.06); border:1px solid rgba(34,197,94,.15);
  border-radius:var(--r2); padding:18px 24px; text-align:center;
}
.pay-amount-label { font-size:.75rem; font-weight:600; letter-spacing:.1em; text-transform:uppercase; color:rgba(134,239,172,.5); }
.pay-amount-num { font-size:2.2rem; font-weight:800; letter-spacing:-.04em; color:var(--g1); line-height:1.1; margin-top:4px; }
.pay-amount-note { font-size:.78rem; color:rgba(134,239,172,.4); margin-top:6px; }
.pay-timer {
  display:flex; align-items:center; gap:8px;
  font-size:.875rem; color:rgba(134,239,172,.6); font-family:'JetBrains Mono',monospace;
}
.timer-dot { width:8px; height:8px; border-radius:50%; background:var(--gold); box-shadow:0 0 10px var(--gold); animation:pulse-dot 1.5s ease-in-out infinite; }
.pay-hint { font-size:.8rem; color:rgba(134,239,172,.35); text-align:center; max-width:280px; line-height:1.55; }

/* Status badges */
.status-badge {
  display:inline-flex; align-items:center; gap:7px;
  padding:7px 18px; border-radius:100px; font-size:.85rem; font-weight:600;
}
.s-pending { background:rgba(234,179,8,.1); color:var(--gold); border:1px solid rgba(234,179,8,.2); }
.s-paid { background:rgba(74,222,128,.1); color:var(--success); border:1px solid rgba(74,222,128,.22); }
.s-expired { background:rgba(239,68,68,.1); color:var(--red); border:1px solid rgba(239,68,68,.2); }
.s-dot {
  width: 7px;
  height: 7px;
  min-width: 7px;
  min-height: 7px;
  border-radius: 50%;
  background: currentColor;
  display: inline-block;
  flex-shrink: 0;
  animation: pulse-dot 2s ease-in-out infinite;
}

/* Success */
.success-wrap { text-align:center; padding:24px 0; }
.success-icon {
  width:80px; height:80px; border-radius:50%; margin:0 auto 22px;
  background:rgba(34,197,94,.1); border:2px solid var(--g1);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 0 48px rgba(34,197,94,.25);
  animation:pop .55s cubic-bezier(.34,1.56,.64,1);
}
@keyframes pop { from{transform:scale(0) rotate(-10deg);opacity:0} to{transform:scale(1) rotate(0);opacity:1} }
.success-wrap h2 { font-size:1.5rem; font-weight:800; margin-bottom:8px; }
.success-wrap p { font-size:.9rem; color:rgba(134,239,172,.6); }

/* Form nav buttons */
.form-nav { display:flex; gap:10px; justify-content:flex-end; margin-top:26px; }
.btn-back {
  padding:12px 22px; border-radius:var(--r3);
  background:rgba(255,255,255,.05); border:1px solid var(--border2);
  color:rgba(134,239,172,.6); font-size:.9rem; font-weight:600; transition:all .2s;
}
.btn-back:hover { background:rgba(255,255,255,.09); color:var(--t1); }
.btn-next {
  padding:12px 28px; border-radius:var(--r3);
  background:linear-gradient(135deg,var(--g1),var(--g2));
  color:#000; font-size:.9rem; font-weight:700; transition:all .25s;
  box-shadow:0 4px 24px rgba(34,197,94,.35), inset 0 1px 0 rgba(255,255,255,.25);
  display:flex; align-items:center; gap:8px;
}
.btn-next:hover { box-shadow:0 8px 32px rgba(34,197,94,.5); transform:translateY(-1px); }
.btn-next:disabled { opacity:.4; cursor:not-allowed; transform:none; box-shadow:none; }
.btn-cancel {
  padding:10px 20px; border-radius:var(--r3);
  background:rgba(239,68,68,.07); border:1px solid rgba(239,68,68,.15);
  color:var(--red); font-size:.875rem; font-weight:600; transition:all .2s;
  display:flex; align-items:center; gap:6px;
}
.btn-cancel:hover { background:rgba(239,68,68,.14); }

/* ═══════════════════════════════════════════════════════════
   HISTORY
═══════════════════════════════════════════════════════════ */
.history-bar {
  display:flex; align-items:center; justify-content:space-between;
  gap:12px; flex-wrap:wrap; margin:36px 0 20px;
}
.history-search {
  padding:11px 16px; border-radius:var(--r3); min-width:240px;
  background:rgba(255,255,255,.04); border:1px solid var(--border2);
  color:var(--t1); font-size:.9rem; outline:none;
  transition:all .25s; font-family:'Plus Jakarta Sans',sans-serif;
}
.history-search:focus { border-color:rgba(34,197,94,.3); background:rgba(34,197,94,.04); }
.history-search::placeholder { color:rgba(134,239,172,.25); }
.btn-clear {
  padding:11px 18px; border-radius:var(--r3);
  background:rgba(239,68,68,.07); border:1px solid rgba(239,68,68,.14);
  color:var(--red); font-size:.875rem; font-weight:600; transition:all .2s;
  display:flex; align-items:center; gap:7px;
}
.btn-clear:hover { background:rgba(239,68,68,.14); }
.history-empty { text-align:center; padding:64px 24px; color:rgba(134,239,172,.3); }
.history-empty-icon { width:64px; height:64px; margin:0 auto 16px; opacity:.3; }
.history-empty p { font-size:.9rem; }
.history-list { display:flex; flex-direction:column; gap:12px; }
.history-item {
  background:var(--glass); border:1px solid var(--border2); border-radius:var(--r2);
  padding:18px 20px; display:flex; align-items:center; gap:16px;
  transition:all .25s;
}
.history-item:hover { border-color:rgba(34,197,94,.2); background:rgba(34,197,94,.04); transform:translateX(3px); }
.history-item-icon {
  width:46px; height:46px; border-radius:13px; flex-shrink:0;
  background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.15);
  display:flex; align-items:center; justify-content:center; font-size:1.5rem;
}
.history-info { flex:1; min-width:0; }
.history-channel { font-size:.9rem; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.history-meta { font-size:.78rem; color:rgba(134,239,172,.45); margin-top:3px; }
.history-right { text-align:right; flex-shrink:0; }
.history-amount { font-size:1rem; font-weight:700; color:var(--g1); }
.history-status { margin-top:4px; }

/* ═══════════════════════════════════════════════════════════
   FAQ
═══════════════════════════════════════════════════════════ */
.faq-list { max-width:740px; margin:44px auto 0; display:flex; flex-direction:column; gap:10px; }
.faq-item {
  background:var(--glass); border:1px solid var(--border2);
  border-radius:var(--r2); overflow:hidden; transition:border-color .25s;
}
.faq-item:hover { border-color:rgba(34,197,94,.18); }
.faq-q {
  display:flex; justify-content:space-between; align-items:center;
  padding:18px 22px; cursor:pointer; font-weight:600; font-size:.95rem;
  gap:16px;
}
.faq-chevron { flex-shrink:0; color:rgba(134,239,172,.35); transition:all .35s; }
.faq-item.open .faq-chevron { transform:rotate(180deg); color:var(--g1); }
.faq-a { max-height:0; overflow:hidden; transition:max-height .4s cubic-bezier(.4,0,.2,1); }
.faq-a-inner { padding:0 22px 18px; font-size:.9rem; color:rgba(134,239,172,.55); line-height:1.7; }
.faq-item.open .faq-a { max-height:200px; }
.faq-item.open { border-color:rgba(34,197,94,.2); }

/* ═══════════════════════════════════════════════════════════
   SUPPORT BANNER
═══════════════════════════════════════════════════════════ */
.support-banner {
  background:linear-gradient(135deg,rgba(34,197,94,.07),rgba(20,184,166,.05));
  border:1px solid rgba(34,197,94,.15); border-radius:var(--r);
  padding:44px 40px; display:flex;
  align-items:center; justify-content:space-between; gap:32px;
  flex-wrap:wrap; position:relative; overflow:hidden;
}
.support-banner::before {
  content:''; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--g1),transparent);
}
.support-banner::after {
  content:''; position:absolute; bottom:-60px; right:-60px;
  width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle,rgba(34,197,94,.08),transparent 70%);
  pointer-events:none;
}
.support-text h2 { font-size:1.6rem; font-weight:800; letter-spacing:-.02em; margin-bottom:8px; }
.support-text p { font-size:.9rem; color:rgba(134,239,172,.6); line-height:1.6; }
.support-actions { display:flex; flex-direction:column; gap:10px; flex-shrink:0; }
.btn-wa {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 26px; border-radius:var(--r2);
  background:linear-gradient(135deg,#25D366,#1ebe59);
  color:#000; font-size:.95rem; font-weight:700;
  box-shadow:0 6px 28px rgba(37,211,102,.35), inset 0 1px 0 rgba(255,255,255,.3);
  transition:all .3s;
}
.btn-wa:hover { transform:translateY(-2px); box-shadow:0 12px 40px rgba(37,211,102,.5); }
.btn-channel {
  display:inline-flex; align-items:center; gap:10px;
  padding:12px 22px; border-radius:var(--r2);
  background:rgba(255,255,255,.05); border:1px solid var(--border2);
  color:rgba(134,239,172,.7); font-size:.875rem; font-weight:500; transition:all .25s;
}
.btn-channel:hover { background:rgba(255,255,255,.09); border-color:rgba(34,197,94,.25); color:var(--t1); }

/* ═══════════════════════════════════════════════════════════
   FOOTER
═══════════════════════════════════════════════════════════ */
footer {
  padding:40px 24px; border-top:1px solid var(--border2); background:var(--bg);
}
.footer-inner {
  max-width:1160px; margin:0 auto;
  display:flex; align-items:center; justify-content:space-between; gap:16px; flex-wrap:wrap;
}
.footer-logo { display:flex; align-items:center; gap:10px; }
.footer-copy { font-size:.82rem; color:rgba(134,239,172,.3); }
.footer-links { display:flex; gap:20px; }
.footer-link { font-size:.82rem; color:rgba(134,239,172,.3); transition:color .2s; cursor:pointer; }
.footer-link:hover { color:var(--g1); }

/* ─── FLOAT WA ────────────────────────────────────────────── */
.float-wa {
  position:fixed; bottom:28px; right:28px; z-index:900;
  width:62px; height:62px; border-radius:50%;
  background:linear-gradient(135deg,#25D366,#1ebe59);
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 8px 32px rgba(37,211,102,.5); transition:all .3s;
}
.float-wa:hover { transform:scale(1.1) translateY(-2px); box-shadow:0 14px 44px rgba(37,211,102,.65); }
.wa-ring {
  position:absolute; inset:-5px; border-radius:50%;
  border:2px solid rgba(37,211,102,.35);
  animation:ring 2.5s ease-out infinite;
}
.wa-ring2 { animation-delay:.8s; }
@keyframes ring { 0%{transform:scale(1);opacity:.8} 100%{transform:scale(1.55);opacity:0} }

/* ─── TOAST ───────────────────────────────────────────────── */
#toast-container {
  position:fixed; bottom:110px; right:24px; z-index:9999;
  display:flex; flex-direction:column; gap:8px; align-items:flex-end;
}
.toast {
  padding:12px 18px; border-radius:var(--r3); font-size:.875rem; font-weight:500;
  background:rgba(15,25,18,.95); border:1px solid var(--border2);
  box-shadow:0 8px 32px rgba(0,0,0,.5); animation:toast-in .3s ease; max-width:300px;
  backdrop-filter:blur(16px);
}
@keyframes toast-in { from{opacity:0;transform:translateX(16px)} to{opacity:1;transform:translateX(0)} }
.toast.success { border-color:rgba(74,222,128,.3); color:var(--success); }
.toast.error { border-color:rgba(239,68,68,.3); color:var(--red); }
.toast.info { border-color:var(--border); color:var(--g1); }

/* ─── SPINNER ─────────────────────────────────────────────── */
.spinner {
  width:20px; height:20px; border-radius:50%;
  border:2px solid rgba(0,0,0,.2); border-top-color:#000;
  animation:spin .65s linear infinite; flex-shrink:0;
}
@keyframes spin { to{transform:rotate(360deg)} }

/* ─── REVEAL ──────────────────────────────────────────────── */
.reveal { opacity:0; transform:translateY(32px); transition:opacity .7s ease,transform .7s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }

/* ─── RESPONSIVE ──────────────────────────────────────────── */
@media(max-width:640px){
  .hero-stats { gap:20px; }
  .stat-div { display:none; }
  .pkg-grid { grid-template-columns:1fr 1fr; }
  .pkg-select-grid { grid-template-columns:1fr 1fr; }
  .support-banner { flex-direction:column; text-align:center; }
  .support-actions { align-items:center; }
  .footer-inner { flex-direction:column; text-align:center; }
  .step-label { font-size:.6rem; }
}
@media(max-width:380px){
  .pkg-grid, .pkg-select-grid { grid-template-columns:1fr; }
}


/* ═══════════════════════════════════════════════════════════
   LIGHTWEIGHT ALIVE — CSS-only, transform+opacity only (GPU)
═══════════════════════════════════════════════════════════ */

/* 1. Online dot — perfectly round + soft ring */
.badge-dot { position: relative; }
.badge-dot::after {
  content: ''; position: absolute; inset: -3px;
  border-radius: 50%; border: 1.5px solid var(--g1);
  animation: ring-out 2.5s ease-out infinite; opacity: 0;
}
@keyframes ring-out {
  0%   { transform: scale(.7); opacity: .7; }
  100% { transform: scale(2.2); opacity: 0; }
}

/* 2. Subtle floating aurora blobs — CSS only, no JS */
.ab1 { animation: afloat 22s ease-in-out infinite; }
.ab2 { animation: afloat 28s ease-in-out infinite reverse; }
.ab3 { animation: afloat 18s ease-in-out infinite; animation-delay:-7s; }

/* 3. Pkg card — soft glow on hover only (no loop animation) */
.pkg-card { transition: transform .35s ease, box-shadow .35s ease, border-color .35s ease; }
.pkg-card:not(.disabled):hover {
  box-shadow: 0 8px 48px rgba(34,197,94,.18), var(--shadow);
}

/* 4. Step active indicator — minimal pulse */
.step-item.active .step-circle {
  animation: step-glow 2.5s ease-in-out infinite;
}
@keyframes step-glow {
  0%,100% { box-shadow: 0 0 0 3px rgba(34,197,94,.12); }
  50%      { box-shadow: 0 0 0 6px rgba(34,197,94,.06), 0 0 18px rgba(34,197,94,.3); }
}

/* 5. History items — simple fade-up on appear */
@keyframes fade-in-up {
  from { opacity:0; transform:translateY(10px); }
  to   { opacity:1; transform:translateY(0); }
}
.history-item { animation: fade-in-up .25s ease both; }
.history-item:nth-child(1){animation-delay:.03s}
.history-item:nth-child(2){animation-delay:.07s}
.history-item:nth-child(3){animation-delay:.11s}
.history-item:nth-child(4){animation-delay:.15s}

/* 6. Send history button */
.btn-send-history {
  display: inline-flex; align-items: center; gap: 5px;
  margin-top: 7px; padding: 5px 12px; border-radius: 8px;
  background: rgba(34,197,94,.1); border: 1px solid rgba(34,197,94,.22);
  color: var(--g1); font-size: .72rem; font-weight: 700;
  cursor: pointer; transition: background .2s, transform .2s; white-space: nowrap;
}
.btn-send-history:hover {
  background: rgba(34,197,94,.2); transform: translateY(-1px);
}
.btn-send-history svg { flex-shrink:0; }

/* 7. Nav badge — once every 8s subtle flash, CSS-only */
.nav-badge { animation: badge-flash 8s ease-in-out infinite; }
@keyframes badge-flash {
  0%,90%,100% { opacity:1; }
  93%          { opacity:.5; }
  96%          { opacity:1; }
}

/* 8. Scroll-reveal — lightweight, reuse existing .reveal */
/* Already handled by IntersectionObserver in initReveal() */

/* 9. Marquee pause on hover */
.marquee-track:hover { animation-play-state: paused; }

/* 10. Smooth btn-primary press feel */
.btn-primary:active { transform: scale(.97); }
.nav-cta:active { transform: scale(.97); }

/* ═══════════════════════════════════════════════════════════
   HISTORY EMOJI FIX
═══════════════════════════════════════════════════════════ */
.history-emojis {
  font-size: 1rem; letter-spacing: 2px; margin-top: 4px;
  line-height: 1.3;
}
.history-item-icon {
  font-size: 1.4rem; line-height: 1;
  overflow: hidden; white-space: nowrap;
}

/* ADMIN NAV BUTTON */
.admin-nav-btn {
  display:flex; align-items:center; justify-content:center;
  width:38px; height:38px; border-radius:10px; margin-left:4px;
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  color:rgba(134,239,172,.5); cursor:pointer; transition:all .2s;
}
.admin-nav-btn:hover { background:rgba(34,197,94,.1); color:var(--g1); border-color:rgba(34,197,94,.3); }

/* ═══════════════════════════════════════════════════════════
   ADMIN LOGIN MODAL
═══════════════════════════════════════════════════════════ */
.admin-overlay {
  position:fixed; inset:0; z-index:2000;
  background:rgba(0,0,0,.75); backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  animation:fade-in .2s ease;
}
@keyframes fade-in { from{opacity:0} to{opacity:1} }

.admin-modal {
  position:relative; width:100%; max-width:380px;
  background:var(--bg2); border:1px solid var(--border);
  border-radius:24px; padding:40px 36px 36px;
  box-shadow:0 32px 80px rgba(0,0,0,.6), 0 0 0 1px rgba(34,197,94,.08);
  animation:modal-pop .3s cubic-bezier(.34,1.56,.64,1);
}
@keyframes modal-pop { from{transform:scale(.9);opacity:0} to{transform:scale(1);opacity:1} }

.admin-modal-close {
  position:absolute; top:16px; right:16px;
  width:30px; height:30px; border-radius:8px;
  background:rgba(255,255,255,.06); border:none;
  color:rgba(134,239,172,.5); cursor:pointer; font-size:.9rem;
  transition:all .2s; display:flex; align-items:center; justify-content:center;
}
.admin-modal-close:hover { background:rgba(239,68,68,.15); color:var(--red); }

.admin-modal-logo {
  width:56px; height:56px; border-radius:16px; margin:0 auto 20px;
  background:linear-gradient(135deg,rgba(34,197,94,.15),rgba(20,184,166,.1));
  border:1px solid rgba(34,197,94,.25);
  display:flex; align-items:center; justify-content:center;
  color:var(--g1);
}

.admin-modal-title {
  font-size:1.35rem; font-weight:800; text-align:center;
  letter-spacing:-.02em; margin-bottom:6px;
}
.admin-modal-sub {
  font-size:.82rem; color:rgba(134,239,172,.45);
  text-align:center; margin-bottom:28px;
}

.admin-field { margin-bottom:12px; }
.admin-input {
  width:100%; padding:13px 16px; border-radius:12px;
  background:rgba(255,255,255,.05); border:1px solid var(--border2);
  color:var(--t1); font-size:.9rem; outline:none;
  transition:border-color .2s; font-family:inherit;
}
.admin-input:focus { border-color:var(--g1); }

.admin-login-err {
  font-size:.8rem; color:var(--red);
  background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.2);
  border-radius:9px; padding:9px 13px; margin-bottom:12px;
}

.admin-login-btn {
  width:100%; padding:14px; border-radius:13px; margin-top:4px;
  background:linear-gradient(135deg,var(--g1),var(--g2));
  color:#000; font-size:.95rem; font-weight:700;
  display:flex; align-items:center; justify-content:center; gap:8px;
  cursor:pointer; border:none; transition:all .25s;
  box-shadow:0 6px 28px rgba(34,197,94,.35);
}
.admin-login-btn:hover { transform:translateY(-1px); box-shadow:0 10px 36px rgba(34,197,94,.5); }

/* ═══════════════════════════════════════════════════════════
   ADMIN PANEL (fullscreen overlay)
═══════════════════════════════════════════════════════════ */
.admin-panel {
  position:fixed; inset:0; z-index:1900;
  background:var(--bg); flex-direction:column; overflow:hidden;
}

.admin-panel-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 28px; border-bottom:1px solid var(--border2);
  background:var(--bg2); flex-shrink:0; flex-wrap:wrap; gap:10px;
}
.admin-panel-title {
  display:flex; align-items:center; gap:10px;
  font-size:1rem; font-weight:700; color:var(--g1);
}
.admin-panel-actions { display:flex; gap:10px; }

.admin-refresh-btn {
  display:flex; align-items:center; gap:6px;
  padding:8px 16px; border-radius:9px;
  background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.2);
  color:var(--g1); font-size:.82rem; font-weight:600; cursor:pointer; transition:all .2s;
}
.admin-refresh-btn:hover { background:rgba(34,197,94,.18); }
.admin-logout-btn {
  padding:8px 16px; border-radius:9px;
  background:rgba(239,68,68,.08); border:1px solid rgba(239,68,68,.18);
  color:var(--red); font-size:.82rem; font-weight:600; cursor:pointer; transition:all .2s;
}
.admin-logout-btn:hover { background:rgba(239,68,68,.15); }

.admin-panel-stats {
  display:flex; gap:14px; padding:20px 28px 0; flex-wrap:wrap; flex-shrink:0;
}
.admin-stat-card {
  flex:1; min-width:120px; padding:16px 20px; border-radius:14px;
  background:var(--glass); border:1px solid var(--border2);
}
.admin-stat-card.success { border-color:rgba(34,197,94,.2); background:rgba(34,197,94,.05); }
.admin-stat-card.revenue { border-color:rgba(234,179,8,.2); background:rgba(234,179,8,.05); }
.asc-num { font-size:1.4rem; font-weight:800; color:var(--t1); }
.admin-stat-card.success .asc-num { color:var(--success); }
.admin-stat-card.revenue .asc-num { color:var(--gold); font-size:1.1rem; }
.asc-label { font-size:.72rem; color:rgba(134,239,172,.45); margin-top:3px; letter-spacing:.05em; text-transform:uppercase; }

.admin-panel-body { flex:1; overflow-y:auto; padding:16px 28px 28px; }

.admin-filter-bar { margin-bottom:16px; }
.admin-search-input {
  width:100%; max-width:400px; padding:11px 16px; border-radius:11px;
  background:rgba(255,255,255,.05); border:1px solid var(--border2);
  color:var(--t1); font-size:.875rem; outline:none; font-family:inherit;
  transition:border-color .2s;
}
.admin-search-input:focus { border-color:var(--g1); }

.admin-tx-list { display:flex; flex-direction:column; gap:10px; }

.admin-tx-item {
  display:flex; align-items:center; gap:14px;
  background:var(--glass); border:1px solid var(--border2);
  border-radius:14px; padding:16px 18px; transition:all .2s;
}
.admin-tx-item:hover { border-color:rgba(34,197,94,.2); background:rgba(34,197,94,.03); }

.admin-tx-emoji {
  width:44px; height:44px; border-radius:12px; flex-shrink:0;
  background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.15);
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; line-height:1;
}
.admin-tx-info { flex:1; min-width:0; }
.admin-tx-id { font-size:.72rem; color:rgba(134,239,172,.35); font-family:'JetBrains Mono',monospace; word-break:break-all; }
.admin-tx-channel { font-size:.82rem; font-weight:600; word-break:break-all; line-height:1.4; color:var(--g1); }
.admin-tx-meta { font-size:.76rem; color:rgba(134,239,172,.45); margin-top:2px; }
.admin-tx-time { font-size:.72rem; color:rgba(134,239,172,.3); margin-top:3px; }
.admin-tx-right { text-align:right; flex-shrink:0; display:flex; flex-direction:column; align-items:flex-end; }
.admin-tx-amount { font-size:.95rem; font-weight:700; color:var(--g1); }

.admin-loading {
  display:flex; align-items:center; gap:12px;
  color:rgba(134,239,172,.4); padding:32px 0; justify-content:center;
}
.admin-spinner {
  width:18px; height:18px; border-radius:50%;
  border:2px solid rgba(34,197,94,.2); border-top-color:var(--g1);
  animation:spin .7s linear infinite;
}
@keyframes spin { to{transform:rotate(360deg)} }
.admin-empty, .admin-error {
  text-align:center; padding:40px 20px;
  color:rgba(134,239,172,.35); font-size:.9rem; line-height:1.7;
}
.admin-error { color:var(--red); }

@media(max-width:600px){
  .admin-modal { padding:32px 22px 28px; }
  .admin-panel-header { padding:14px 16px; }
  .admin-panel-body { padding:12px 16px 24px; }
  .admin-panel-stats { padding:14px 16px 0; }
}

/* ═══════════════════════════════════════════════════════════
   ADMIN TX CARD — Format pesan WA
═══════════════════════════════════════════════════════════ */
.admin-tx-list { display:flex; flex-direction:column; gap:14px; }

.admin-tx-card {
  background:var(--bg3);
  border:1px solid rgba(34,197,94,.15);
  border-radius:16px; padding:18px 20px;
  font-size:.85rem; line-height:1.7;
  transition:border-color .2s;
}
.admin-tx-card:hover { border-color:rgba(34,197,94,.3); }

.atx-header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:2px; gap:10px;
}
.atx-header-left { display:flex; align-items:center; gap:8px; }
.atx-bell { font-size:1rem; }
.atx-title {
  font-size:.75rem; font-weight:800; letter-spacing:.1em;
  color:var(--t1);
}

.atx-divider {
  height:1px; background:rgba(255,255,255,.06);
  margin:10px 0;
}

.atx-status-line {
  font-size:.85rem; color:var(--success); font-weight:500;
}

.atx-section-label {
  font-size:.78rem; font-weight:700; color:rgba(134,239,172,.55);
  margin-bottom:6px;
}

.atx-rows { display:flex; flex-direction:column; gap:4px; padding-left:4px; }
.atx-row {
  display:flex; align-items:baseline; gap:6px;
  font-size:.83rem; color:var(--t1); flex-wrap:wrap;
}
.atx-dot { color:rgba(134,239,172,.4); flex-shrink:0; }
.atx-key { color:rgba(134,239,172,.55); flex-shrink:0; }
.atx-code {
  font-family:'JetBrains Mono',monospace;
  font-size:.72rem; background:rgba(255,255,255,.07);
  padding:2px 7px; border-radius:5px; color:var(--t2);
  word-break:break-all;
}
.atx-amount { color:var(--g1); font-weight:700; }

.atx-link {
  display:block; color:var(--g1); font-size:.82rem;
  word-break:break-all; text-decoration:underline;
  text-decoration-color:rgba(34,197,94,.3);
  padding-left:4px; line-height:1.5;
}
.atx-link:hover { text-decoration-color:var(--g1); }

.atx-value {
  font-size:.85rem; color:var(--t1);
  padding-left:4px;
}

.atx-wa-btn {
  display:inline-flex; align-items:center; gap:7px;
  margin-top:4px; padding:8px 16px; border-radius:9px;
  background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.22);
  color:var(--g1); font-size:.78rem; font-weight:700;
  cursor:pointer; transition:all .2s;
}
.atx-wa-btn:hover { background:rgba(34,197,94,.2); transform:translateY(-1px); }

@media(max-width:480px){
  .admin-tx-card { padding:14px 14px; }
  .atx-code { font-size:.65rem; }
}
