/* Onixx Mini App — Fullstack edition */

:root{
  --bg0:#000000;
  --bg1:#07070a;
  --txt:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.62);
  --muted2:rgba(255,255,255,.44);
  --glass:rgba(255,255,255,.06);
  --glass2:rgba(255,255,255,.08);
  --border:rgba(255,255,255,.12);
  --border2:rgba(255,255,255,.08);
  --shadow: 0 10px 40px rgba(0,0,0,.55);
  --radius:22px;
  --radius2:18px;
  --tap: cubic-bezier(.2,.8,.2,1);
}

*{ box-sizing:border-box; }
html,body{ height:100%; }
body{
  margin:0;
  color:var(--txt);
  background:radial-gradient(1200px 700px at 50% -200px, #2b1b49 0%, rgba(0,0,0,0) 55%),
             linear-gradient(180deg, var(--bg1), var(--bg0));
  font-family: -apple-system, BlinkMacSystemFont, "SF Pro Display", "SF Pro Text",
               "Segoe UI", Roboto, Inter, Arial, system-ui, sans-serif;
  letter-spacing: .2px;
  overflow-x:hidden;
}

.bg{
  position:fixed;
  inset:0;
  z-index:-2;
  background: radial-gradient(900px 600px at 20% 10%, rgba(155, 115, 255, .18) 0%, rgba(0,0,0,0) 65%),
              radial-gradient(700px 500px at 90% 30%, rgba(120, 70, 255, .15) 0%, rgba(0,0,0,0) 62%);
}

.noise{
  position:absolute;
  inset:0;
  opacity:.08;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='250' height='250'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='250' height='250' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
  mix-blend-mode: overlay;
  pointer-events:none;
}

.orbs{
  position:absolute;
  inset:-10%;
  pointer-events:none;
  z-index:-1;
}

.orb{
  position:absolute;
  border-radius:999px;
  filter: blur(52px);
  opacity:.85;
  mix-blend-mode: screen;
  will-change: transform;
}
.orb::before{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background: radial-gradient(circle at 30% 30%,
      rgba(199, 140, 255, .95) 0%,
      rgba(145, 90, 255, .55) 25%,
      rgba(80, 40, 200, .18) 55%,
      rgba(0,0,0,0) 72%);
}

.o1{ width:520px; height:520px; left:-120px; top:-80px; animation: float1 18s var(--tap) infinite alternate; }
.o2{ width:420px; height:420px; left: 60%; top:-140px; animation: float2 22s var(--tap) infinite alternate; }
.o3{ width:560px; height:560px; left: 48%; top: 45%; animation: float3 26s var(--tap) infinite alternate; opacity:.75; }
.o4{ width:380px; height:380px; left:-140px; top: 55%; animation: float4 20s var(--tap) infinite alternate; opacity:.7; }
.o5{ width:300px; height:300px; left: 78%; top: 68%; animation: float5 24s var(--tap) infinite alternate; opacity:.65; }

@keyframes float1{ from{ transform:translate3d(0,0,0) scale(1); } to{ transform:translate3d(120px, 120px, 0) scale(1.08);} }
@keyframes float2{ from{ transform:translate3d(0,0,0) scale(1); } to{ transform:translate3d(-140px, 170px, 0) scale(1.05);} }
@keyframes float3{ from{ transform:translate3d(0,0,0) scale(1); } to{ transform:translate3d(120px, -110px, 0) scale(1.12);} }
@keyframes float4{ from{ transform:translate3d(0,0,0) scale(1); } to{ transform:translate3d(170px, -70px, 0) scale(1.07);} }
@keyframes float5{ from{ transform:translate3d(0,0,0) scale(1); } to{ transform:translate3d(-110px, -150px, 0) scale(1.08);} }

@media (prefers-reduced-motion: reduce){
  .orb{ animation:none !important; }
  *{ scroll-behavior:auto !important; }
}

/* Top bar */
.topbar{
  position:sticky;
  top:0;
  padding: calc(14px + env(safe-area-inset-top)) 16px 14px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  z-index:10;
  background: linear-gradient(180deg, rgba(0,0,0,.72) 0%, rgba(0,0,0,.25) 70%, rgba(0,0,0,0) 100%);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  min-width:0;
}
.logo{
  width:42px;
  height:42px;
  display:grid;
  place-items:center;
  border-radius:14px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: var(--shadow);
}
.brandText{ min-width:0; }
.title{
  font-weight: 760;
  font-size: 16px;
  line-height: 1.15;
}
.subtitle{
  margin-top:4px;
  display:flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  color:var(--muted);
}
.dot{ opacity:.6; }
.pill{
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding: 5px 10px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.84);
}
.iconBtn{
  width:44px;
  height:44px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.86);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: var(--shadow);
  display:grid;
  place-items:center;
  cursor:pointer;
  transition: transform 180ms var(--tap), background 180ms var(--tap);
}
.iconBtn:active{ transform: scale(.96); }
.smallBtn{ width:40px; height:40px; border-radius:14px; }

/* Content layout */
.wrap{
  padding: 8px 16px calc(86px + env(safe-area-inset-bottom));
  max-width: 780px;
  margin: 0 auto;
}

.glass{
  background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(255,255,255,.045));
  border: 1px solid rgba(255,255,255,.10);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  backdrop-filter: blur(18px) saturate(140%);
  -webkit-backdrop-filter: blur(18px) saturate(140%);
}

.hero{
  padding: 16px;
  animation: rise .55s var(--tap) both;
}
@keyframes rise{
  from{ opacity:0; transform: translate3d(0, 10px, 0); }
  to{ opacity:1; transform: translate3d(0, 0, 0); }
}

.heroRow{
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.avatar{
  width:52px;
  height:52px;
  border-radius: 18px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.12);
  box-shadow: 0 10px 30px rgba(0,0,0,.35);
  flex: 0 0 auto;
  overflow:hidden;
}
.avatar img{ width:100%; height:100%; object-fit:cover; }

.h1{ font-weight: 820; font-size: 18px; margin-top: 2px; }
.p{ margin-top:6px; color: var(--muted); font-size: 13px; line-height: 1.35; }

.heroActions{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-top: 14px;
}

.btn{
  width:100%;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  color: var(--txt);
  border-radius: 18px;
  padding: 12px 12px;
  cursor:pointer;
  display:flex;
  align-items:center;
  gap: 10px;
  text-align:left;
  transition: transform 180ms var(--tap), background 180ms var(--tap), border-color 180ms var(--tap);
}
.btn:active{ transform: scale(.98); }
.btn.primary{
  background: linear-gradient(180deg, rgba(176, 124, 255, .22), rgba(120, 70, 255, .10));
  border-color: rgba(176, 124, 255, .30);
}
.btnIcon{ width:26px; height:26px; display:grid; place-items:center; font-size:18px; }
.btnText{ display:flex; flex-direction:column; min-width:0; }
.btnTitle{ font-weight:720; font-size:14px; }
.btnSub{ font-size:12px; color: var(--muted); margin-top:2px; white-space:nowrap; overflow:hidden; text-overflow:ellipsis;}
.chev{ margin-left:auto; opacity:.55; font-size: 20px; transform: translateY(-1px); }

.grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.card{
  padding: 14px;
  border-radius: var(--radius2);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  color:var(--txt);
  box-shadow: 0 18px 40px rgba(0,0,0,.45);
  cursor:pointer;
  display:flex;
  flex-direction:column;
  gap: 10px;
  text-align:left;
  transition: transform 180ms var(--tap), background 180ms var(--tap), border-color 180ms var(--tap);
  position:relative;
  overflow:hidden;
}
.card::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius: inherit;
  border: 1px solid rgba(255,255,255,.06);
  pointer-events:none;
}
.card:active{ transform: scale(.985); }
.cardIcon{ font-size: 20px; }
.cardBody{ display:flex; flex-direction:column; gap:2px; }
.cardTitle{ font-weight:780; font-size:14px; }
.cardSub{ font-size:12px; color:var(--muted); }
.cardHint{
  margin-top:auto;
  align-self:flex-start;
  font-size: 11px;
  color: rgba(255,255,255,.72);
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.07);
  border: 1px solid rgba(255,255,255,.10);
}

/* Screens + panels */
.screen{ display:none; }
.screen.active{ display:block; }

.panel{ padding: 14px; }
.panelHead{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap: 12px;
}
.panelTitle{ font-weight: 840; font-size: 16px; }
.panelSub{ font-size: 12px; margin-top: 4px; }

.kv{ margin-top: 12px; display:flex; flex-direction:column; gap: 10px; }
.kvRow{ display:flex; align-items:center; justify-content:space-between; gap: 10px; padding: 10px 12px; border-radius: 16px; border: 1px solid rgba(255,255,255,.10); background: rgba(0,0,0,.18); }
.kvK{ font-size: 12px; color: var(--muted); }
.kvV{ font-size: 13px; font-weight: 760; }

.linksBlock{ margin-top: 14px; }
.blockTitle{ font-weight: 760; font-size: 13px; margin-bottom: 10px; }
.linksList{ display:flex; flex-direction:column; gap: 10px; }
.linkItem{
  padding: 12px 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  cursor:pointer;
  transition: transform 180ms var(--tap), border-color 180ms var(--tap);
}
.linkItem:active{ transform: scale(.99); }
.linkTop{ display:flex; align-items:center; justify-content:space-between; gap: 10px; }
.linkLabel{ font-weight: 780; font-size: 12px; }
.linkCopy{ font-size: 12px; color: rgba(255,255,255,.78); opacity:.75; }
.linkUrl{
  margin-top: 8px;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  font-size: 12px;
  color: rgba(255,255,255,.86);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

/* Plans */
.plans{
  margin-top: 12px;
  display:grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.plan{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  cursor:pointer;
  transition: transform 180ms var(--tap), background 180ms var(--tap), border-color 180ms var(--tap);
}
.plan:active{ transform: scale(.985); }
.planLeft{ display:flex; flex-direction:column; gap:2px; min-width:0; }
.planName{ font-weight: 760; font-size: 13px; }
.planMeta{ font-size: 12px; color: var(--muted); }
.planPrice{
  font-weight: 840;
  letter-spacing: .2px;
}

.payBox{
  margin-top: 14px;
  padding: 12px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.payTitle{ font-weight: 820; }
.payRow{ display:flex; align-items:center; justify-content:space-between; margin-top: 10px; font-size: 12px; }
.payActions{ margin-top: 12px; display:grid; grid-template-columns: 1fr; gap: 10px; }

/* Referral */
.refCard{
  margin-top: 12px;
  padding: 12px;
  border-radius: 20px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
}
.refLabel{ font-size: 12px; }
.refLink{
  margin-top: 10px;
  padding: 10px 10px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.refActions{ margin-top: 12px; display:grid; grid-template-columns: 1fr; gap: 10px; }

.muted{ color: var(--muted); }
.small{ font-size: 12px; }
.mono{ font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace; }

/* Bottom sheet */
.sheetOverlay{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.45);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  z-index: 40;
}
.sheet{
  position:fixed;
  left: 12px;
  right: 12px;
  bottom: calc(74px + env(safe-area-inset-bottom));
  transform: translate3d(0, 40px, 0);
  opacity: 0;
  pointer-events:none;
  z-index: 50;
  border-radius: 24px;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(15,15,18,.9), rgba(0,0,0,.82));
  box-shadow: 0 30px 90px rgba(0,0,0,.65);
  backdrop-filter: blur(22px) saturate(150%);
  -webkit-backdrop-filter: blur(22px) saturate(150%);
}
.sheet.open{
  transform: translate3d(0, 0, 0);
  opacity: 1;
  pointer-events:auto;
  transition: transform 220ms var(--tap), opacity 220ms var(--tap);
}
.sheetHandle{
  width: 44px;
  height: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,.22);
  margin: 10px auto 8px;
}
.sheetHeader{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 0 12px 12px;
}
.sheetTitle{ font-weight: 800; font-size: 14px; }
.sheetBody{
  padding: 0 12px 14px;
  display:flex;
  flex-direction:column;
  gap: 12px;
}
.field{ display:flex; flex-direction:column; gap: 8px; }
.fieldLabel{ font-size: 12px; color: var(--muted); }
.input{
  height: 46px;
  padding: 0 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: var(--txt);
  outline:none;
}
.input:focus{
  border-color: rgba(176,124,255,.45);
  box-shadow: 0 0 0 3px rgba(176,124,255,.12);
}
.full{ width:100%; justify-content:flex-start; }

/* Tabbar */
.tabbar{
  position: fixed;
  left: 12px;
  right: 12px;
  bottom: calc(10px + env(safe-area-inset-bottom));
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  padding: 10px;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  box-shadow: 0 22px 70px rgba(0,0,0,.55);
  z-index: 30;
}
.tab{
  border: none;
  background: transparent;
  color: rgba(255,255,255,.74);
  padding: 8px 10px;
  border-radius: 16px;
  cursor:pointer;
  display:flex;
  flex-direction:column;
  gap: 6px;
  align-items:center;
  justify-content:center;
  transition: transform 180ms var(--tap), background 180ms var(--tap), color 180ms var(--tap);
}
.tab:active{ transform: scale(.97); }
.tab.active{
  background: rgba(255,255,255,.07);
  color: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.10);
}
.tabIcon{ font-size: 16px; line-height: 1; }
.tabTxt{ font-size: 11px; }

.toast{
  position: fixed;
  left: 50%;
  bottom: calc(86px + env(safe-area-inset-bottom));
  transform: translateX(-50%) translateY(20px);
  opacity: 0;
  z-index: 80;
  padding: 10px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
  color: rgba(255,255,255,.88);
  font-size: 12px;
  pointer-events:none;
}
.toast.show{
  opacity: 1;
  transform: translateX(-50%) translateY(0);
  transition: transform 220ms var(--tap), opacity 220ms var(--tap);
}

@media (max-width: 420px){
  .heroActions{ grid-template-columns: 1fr; }
  .grid{ grid-template-columns: 1fr; }
}
