
:root{
  /* Tema MiziVerse */
  --bg: radial-gradient(circle at 5% 5%, #0f172a 0%, #020617 25%, #000 80%);
  --text:#eef4ff; --muted:#95a3c4;
  --accent:#8b5cf6; --accent2:#0ea5e9;
  --ok:#22c55e; --warn:#f59e0b; --err:#ef4444;
  --bd: rgba(146,170,255,.22);
  --header-h:64px;
}
/* ===== Wrapper agar tombol Back punya jarak dari header ===== */
.back-wrap {
  display: flex;
  align-items: center;
  padding: 14px 18px 0; /* jarak ke bawah header */
}

/* ===== Back Button ===== */
.btn-back {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 1rem;
  color: var(--accent2);
  background: rgba(10,15,30,.45);
  border: 1px solid rgba(136,160,255,.35);
  box-shadow: 0 0 12px rgba(139,92,246,.15);
  backdrop-filter: blur(6px);
  cursor: pointer;
  transition: all .25s ease;
}

.btn-back .icon {
  width: 22px;
  height: 22px;
  stroke: var(--accent2);
  transition: transform .25s ease;
}

/* efek hover */
.btn-back:hover {
  color: #fff;
  background: linear-gradient(90deg, rgba(139,92,246,.25), rgba(14,165,233,.25));
  box-shadow:
    0 0 15px rgba(139,92,246,.35),
    0 0 30px rgba(14,165,233,.25);
  transform: translateY(-2px);
}
.btn-back:hover .icon {
  transform: translateX(-4px);
}
/* ============= Header ============= */
header.app-hd{
  position:sticky; top:0; z-index:50;
  display:flex; align-items:center; gap:12px;
  padding:12px 16px;
  background:linear-gradient(110deg, rgba(4,6,15,1) 0%, rgba(27,33,69,.35) 57%, rgba(139,92,246,.12) 100%);
  border-bottom:1px solid rgba(147,178,255,.35);
  backdrop-filter:saturate(150%) blur(16px);
  box-shadow:0 14px 38px rgba(0,0,0,.28);
}
.brand{
  position:relative; font-weight:800; letter-spacing:.2px; display:flex; align-items:center; gap:.5rem;
}
.brand::before{
  content:""; width:34px; height:34px; border-radius:50%;
  background: url("../assets/mive.png") center/cover no-repeat;
  border:1px solid rgba(174,203,255,.5);
  box-shadow:0 0 15px rgba(139,92,246,.8), 0 0 30px rgba(14,165,233,.35), inset 0 0 8px rgba(255,255,255,.08);
  flex-shrink:0; animation:glowPulse 3.2s ease-in-out infinite;
}

/* ============= Base Reset ============= */
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
  color:var(--text);
  background:var(--bg);
  background-attachment:fixed;
}


@keyframes glowPulse{
  0%,100%{box-shadow:0 0 15px rgba(139,92,246,.8), 0 0 30px rgba(14,165,233,.35)}
  50%{box-shadow:0 0 25px rgba(139,92,246,1), 0 0 45px rgba(14,165,233,.55)}
}
.brand span{color:var(--accent)}

.wallet{
  margin-left:auto; display:flex; align-items:center; gap:10px;
}

/* ============= Layout ============= */
main{max-width:1100px; margin:0 auto; padding:22px 16px 60px}
.wrap{
  position:relative; border:1px solid var(--bd); border-radius:18px; padding:18px;
  background:
    radial-gradient(circle at 15% 15%, rgba(136,105,255,.08) 0%, rgba(5,8,22,.05) 65%),
    linear-gradient(140deg, rgba(6,9,19,.35), rgba(2,6,23,.1));
  box-shadow:0 18px 35px rgba(0,0,0,.25);
  backdrop-filter:blur(10px);
  overflow:hidden;
}
.grid{display:grid; gap:16px}
.g-2{grid-template-columns:1.1fr .9fr}
@media(max-width:900px){.g-2{grid-template-columns:1fr}}

/* ============= Card (Light version) ============= */
.card {
  position: relative;
  border-radius: 16px;
  padding: 16px;
  border: 1px solid var(--bd);
  background:
    radial-gradient(circle at 0% 0%, rgba(122,162,255,0.10) 0%, rgba(17,27,54,0) 46%),
    linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  box-shadow: 0 10px 20px rgba(0,0,0,.18);
  transition: transform .25s ease, border-color .25s ease, box-shadow .25s ease;
  overflow: hidden;
}

.card:hover {
  transform: translateY(-3px);
  border-color: rgba(134,186,255,.45);
  box-shadow: 0 14px 28px rgba(0,0,0,.22), 0 0 8px rgba(139,92,246,.2);
}

.card::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 16px;
  border: 1px solid rgba(139,92,246,.15);
  box-shadow: 0 0 6px rgba(139,92,246,.1), 0 0 12px rgba(56,189,248,.1);
  opacity: .4;
  pointer-events: none;
}


/* ============= Typography ============= */
h1{margin:10px 0 8px; font-size:1.6rem}
h2{margin:0 0 10px; font-size:1.2rem}
.mono{font-family:ui-monospace,Menlo,Consolas,monospace}

/* ============= Stats ============= */
.stats{
  display:grid; grid-template-columns:repeat(4,minmax(0,1fr)); gap:10px;
}
@media(max-width:900px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{
  background:rgba(255,255,255,.03); border:1px solid var(--bd);
  border-radius:12px; padding:12px;
  animation: statGlow 6s ease-in-out infinite;
}
.stat .lbl{color:var(--muted); font-size:.78rem}
.stat .val{margin-top:6px; font-weight:800}
@keyframes statGlow {
  0%, 100% { box-shadow: 0 0 0 rgba(139,92,246,0); }
  50% { box-shadow: 0 0 12px rgba(139,92,246,.18); }
}
.stat:nth-child(odd){ animation-delay: .8s; }

/* ============= Form ============= */
.row{display:flex; gap:10px; align-items:center; flex-wrap:wrap}
.field{display:flex; flex-direction:column; gap:8px; margin:8px 0}
.field input{
  padding:12px; border-radius:10px; background:#0b1222; border:1px solid var(--bd); color:var(--text);
}
.helper{color:var(--muted); font-size:.8rem}
.sep{height:1px; background:linear-gradient(90deg,transparent,rgba(255,255,255,.12),transparent); margin:12px 0}

/* ============= Buttons ============= */
.btn{
  position: relative;
  display:inline-flex; align-items:center; justify-content:center;
  padding:10px 18px; border-radius:12px; font-weight:700; cursor:pointer;
  background:transparent; color:var(--accent); border:1px solid var(--accent);
  transition: all .25s ease;
}
.btn:disabled{opacity:.6; cursor:not-allowed}

.btn.primary{
  background: linear-gradient(135deg, #7e22ce 0%, #2563eb 100%);
  color: #fff;
  border: 1px solid rgba(120,150,255,0.35);
  box-shadow:
    0 0 12px rgba(126,34,206,.4),
    0 0 25px rgba(37,99,235,.3),
    inset 0 0 6px rgba(255,255,255,.15);
  overflow: hidden;
}
.btn.primary:hover{
  background: linear-gradient(135deg, #8b5cf6 0%, #38bdf8 100%);
  box-shadow:
    0 0 20px rgba(139,92,246,.55),
    0 0 40px rgba(56,189,248,.45),
    inset 0 0 10px rgba(255,255,255,.25);
  transform: translateY(-1px);
}
.btn.primary:active{ transform: scale(.97); box-shadow: 0 0 8px rgba(139,92,246,.3); }
/* outline futuristik (mask border) */
.btn.primary::before{
  content:""; position:absolute; inset:0; border-radius:inherit;
  border:2px solid transparent;
  background: linear-gradient(60deg, #8b5cf6, #38bdf8, #7e22ce) border-box;
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  mask-composite: exclude; -webkit-mask-composite: destination-out;
  pointer-events:none; opacity:.7; filter: blur(1px);
}
/* state connected */
.btn.connected{
  background: linear-gradient(90deg, var(--accent), var(--accent2));
  color:#0a0f1a; border:none;
  box-shadow: 0 0 12px rgba(139,92,246,.35), 0 0 18px rgba(14,165,233,.25);
  cursor: default;
}
/* ===== HINT TOOLTIP FUTURISTIK ===== */
.hint {
  display: inline-block;
  width: 16px; height: 16px;
  line-height: 15px;
  text-align: center;
  font-weight: 700;
  border-radius: 50%;
  color: var(--accent2);
  background: rgba(56,189,248,.1);
  border: 1px solid rgba(56,189,248,.35);
  margin-left: 4px;
  cursor: pointer;
  font-size: 0.75rem;
  transition: all 0.2s ease;
  position: relative;
}
.hint:hover {
  background: rgba(56,189,248,.25);
  box-shadow: 0 0 6px rgba(56,189,248,.4);
}

/* tooltip text */
.hint::after {
  content: attr(data-tip);
  position: absolute;
  bottom: 130%;
  left: 50%;
  transform: translateX(-50%);
  background: rgba(10,15,26,.95);
  color: #eaf2ff;
  font-size: 0.75rem;
  padding: 8px 10px;
  border-radius: 8px;
  border: 1px solid rgba(136,160,255,.25);
  box-shadow: 0 8px 24px rgba(0,0,0,.45);
  opacity: 0;
  pointer-events: none;
  width: max-content;
  max-width: 220px;
  white-space: normal;
  text-align: center;
  line-height: 1.2;
  transition: opacity .25s ease, transform .25s ease;
  z-index: 200;
}

/* animasi muncul */
.hint:hover::after {
  opacity: 1;
  transform: translateX(-50%) translateY(-4px);
}
/* ============= Address Chip ============= */
#addrChip{
  min-width: 90px;
  text-align: center;
  border: 1px solid rgba(56,189,248,.35);
  background: rgba(56,189,248,.1);
  color: var(--accent2);
  font-weight: 600;
  border-radius: 999px;
  padding: 6px 10px;
}


.btn-load {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: #38bdf8;
  color: white;
  border: none;
  padding: 12px 24px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 15px;
  transition: opacity 0.2s ease;
}
.btn-load:disabled {
  opacity: 0.7;
  cursor: not-allowed;
}

/* Spinner (lingkaran berputar) */
.spinner {
  display: none;
  width: 18px;
  height: 18px;
  border: 2px solid rgba(255,255,255,0.4);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spin 0.9s linear infinite;
}
@keyframes spin {
  to { transform: rotate(360deg); }
}

/* Saat tombol loading */
.btn-load.loading .label {
  opacity: 0;
  pointer-events: none;
}
.btn-load.loading .spinner {
  display: inline-block;
}

/* ============= Toast (Top-Center, Dark Glow) ============= */
.toast-stack{
  position: fixed;
  top: 16px;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  flex-direction: column;
  gap: 10px;
  z-index: 9999;
  pointer-events: none;
}
.toast{
  position: relative;
  pointer-events: auto;
  min-width: 260px;
  max-width: 92vw;
  padding: 12px 16px 12px 20px;
  border-radius: 14px;
  font-size: .9rem;
  font-weight: 500;
  color: var(--text, #eef4ff);
  background: radial-gradient(circle at 5% 10%, rgba(20,25,45,.9) 0%, rgba(5,8,22,.95) 60%);
  border: 1px solid rgba(136,160,255,.25);
  box-shadow:
    0 4px 14px rgba(0,0,0,.6),
    0 0 18px rgba(139,92,246,.15),
    0 0 25px rgba(14,165,233,.1);
  backdrop-filter: blur(6px);
  opacity: 0;
  transform: translateY(-14px) scale(.97);
  transition: opacity .25s ease, transform .25s ease;
}
.toast.show{ opacity:1; transform: translateY(0) scale(1); }
.toast.leaving{ opacity:0; transform: translateY(-10px) scale(.97); }


.toast::before{
  content:""; position:absolute; left:0; top:0; bottom:0; width:4px;
  border-radius:14px 0 0 14px;
  background: linear-gradient(180deg, var(--accent, #8b5cf6), var(--accent2, #0ea5e9));
  box-shadow: 0 0 10px rgba(139,92,246,.5), 0 0 20px rgba(14,165,233,.35);
}
.toast.info::before   { background: linear-gradient(180deg,#60a5fa,#3b82f6); }
.toast.success::before{ background: linear-gradient(180deg,#34d399,#10b981); }
.toast.warn::before   { background: linear-gradient(180deg,#fbbf24,#f59e0b); }
.toast.error::before  { background: linear-gradient(180deg,#f87171,#ef4444); }

/* ============= Modal ============= */
.modal{position:fixed; inset:0; display:none; z-index:1400;}
.modal.show{display:block;}
.modal__backdrop{
  position:absolute; inset:0; background:rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  opacity:0; transition:opacity .2s ease;
}
.modal.show .modal__backdrop{opacity:1;}
.modal__panel{
  position:absolute; inset:auto 0 0 0; margin:auto; top:15%;
  width:min(520px, 92vw);
  background:rgba(10,15,26,.95);
  border:1px solid rgba(146,170,255,.25);
  border-radius:14px;
  box-shadow:0 18px 45px rgba(0,0,0,.45);
  transform:translateY(-8px) scale(.98);
  opacity:0; transition:transform .2s ease, opacity .2s ease;
}
.modal.show .modal__panel{transform:translateY(0) scale(1); opacity:1;}
.modal__header{display:flex; align-items:center; justify-content:space-between; padding:14px 14px 8px;}
.modal__body{padding:2px 14px 8px; color:var(--text);}
.modal__footer{display:flex; gap:10px; justify-content:flex-end; padding:12px 14px 14px;}
.modal__x{
  width:34px; height:34px; border-radius:8px; cursor:pointer;
  background:transparent; color:var(--text); border:1px solid rgba(146,170,255,.25);
}
.modal__x:hover{background:rgba(255,255,255,.06);}


/* ============= Skeleton (Static Version) ============= */
.skeleton {
  position: relative;
  overflow: hidden;
  background: linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
  border: 1px solid rgba(146,170,255,.12);
  border-radius: 10px;
  box-shadow: inset 0 0 4px rgba(255,255,255,.05);
}
.skeleton::after { content: none; } /* hapus shimmer effect */

.skel-line { height: 12px; margin: 6px 0; background: rgba(255,255,255,.05); border-radius: 4px; }
.skel-box  { height: 64px; background: rgba(255,255,255,.05); border-radius: 8px; }

/* ============= Button Loading ============= */
.btn[aria-busy="true"]{ position:relative; pointer-events:none; opacity:.85; }
.btn[aria-busy="true"]::before{
  content:""; position:absolute; left:10px; top:50%; transform: translateY(-50%);
  width:16px; height:16px; border-radius:50%;
  border:2px solid rgba(255,255,255,.35); border-top-color:#fff; animation: spin .8s linear infinite;
}
@keyframes spin{ to{ transform: translateY(-50%) rotate(360deg);} }
.btn.primary[aria-busy="true"]::before{
  border: 2px solid rgba(0,0,0,.25); border-top-color: rgba(0,0,0,.75);
}

@media (prefers-reduced-motion: reduce){
  .card, .skeleton::after{ animation: none; transition: none; }
  .btn[aria-busy="true"]::before { animation: none; }
}

@media (min-width: 960px) {
  .layout {
    display: grid;
    grid-template-columns: 1fr 360px; /* main | aside */
    gap: 20px;
    align-items: start;
  }


  .card { padding: 16px 18px; border-radius: 14px; }
  h1, h2 { line-height: 1.2; margin: 4px 0 10px; }
  .muted { font-size: 14px; }

  /* Stats: dari 2 kolom → 3–4 kolom di desktop */
  .stats {
    display: grid;
    grid-template-columns: repeat(3, minmax(0,1fr));
    gap: 10px;
  }

  .stats.stats-claim,
  aside .stats {
    grid-template-columns: repeat(4, minmax(0,1fr));
  }

  .stat {
    padding: 12px 14px;
    background: var(--card, #0e1627);
    border: 1px solid rgba(255,255,255,.06);
    border-radius: 12px;
  }
  .lbl {
    display: flex;
    align-items: center;
    gap: 8px;
    font-weight: 600;
  }
  .val.mono { font-variant-numeric: tabular-nums; font-size: 15px; }

  aside.card {
    position: sticky;
    top: 16px;
    max-height: calc(100vh - 24px);
    overflow: auto;
  }

  /* Bar KPI lebih rapat */
  .kpi { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
  .badge { font-size: 12px; padding: 6px 10px; border-radius: 999px; }
}


.lbl .hint{
  display:inline-flex; justify-content:center; align-items:center;
  width:16px; height:16px; border-radius:50%;
  background:var(--accent, #38bdf8); color:#fff; font-size:12px;
  cursor:help; position:relative; user-select:none;
}
.lbl .hint::after{
  content: attr(data-tip);
  position:absolute; z-index:20;
  left:50%; bottom:125%; transform:translateX(-50%);
  background:#0e1627; color:#eaf2ff; border:1px solid rgba(255,255,255,.08);
  padding:8px 10px; border-radius:8px; font-size:12px; line-height:1.35;
  white-space:nowrap; box-shadow:0 8px 24px rgba(0,0,0,.35);
  opacity:0; pointer-events:none; transition:opacity .15s ease;
}
.lbl .hint::before{
  /* segitiga kecil */
  content:""; position:absolute; left:50%; bottom:115%; transform:translateX(-50%);
  border:6px solid transparent; border-top-color:#0e1627; opacity:0; transition:opacity .15s ease;
}
.lbl .hint:hover::after,
.lbl .hint:hover::before{ opacity:1; }

.lbl .hint:focus::after,
.lbl .hint:focus::before{ opacity:1; outline:none; }

@media (min-width: 960px) {
  .row { display:flex; gap:12px; align-items:center; }
  #btnClaim, #btnRefresh { min-height:40px; }
}
@media (min-width: 960px) {
  body {
    display: flex;
    flex-direction: column;
    align-items: center;
  }

  .layout {
    display: grid;
    grid-template-columns: 360px 1fr; /* kiri = 360px, kanan = sisa lebar */
    gap: 24px;
    width: 100%;
    max-width: 1300px;
    align-items: start;
  }

  main.grid.g-2 {
    display: flex;
    flex-direction: column;
    gap: 20px;
  }

  aside.card {
    position: sticky;
    top: 80px;
    height: fit-content;
  }
}

/* ====== Preferensi ====== */
@media (prefers-reduced-motion: reduce) {
  .lbl .hint::after, .lbl .hint::before { transition: none; }
}

/* ===== RESPONSIVE ===== */
@media(max-width:768px){
  .wallet{margin-left:unset}
}
