:root {
  color-scheme: dark;
  --bg: #070808;
  --panel: rgba(18, 20, 21, 0.72);
  --panel-strong: rgba(20, 23, 24, 0.94);
  --text: #f1f4f3;
  --muted: #8d9697;
  --cyan: #a7eee9;
  --blue: #91c9d0;
  --pink: #9e8fb0;
  --lime: #a8ead1;
  --danger: #ff6b6b;
  --line: rgba(255, 255, 255, 0.12);
  --shadow: 0 24px 70px rgba(0, 0, 0, 0.42);
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  min-height: 100%;
  background:
    radial-gradient(circle at 24% 0%, rgba(167, 238, 233, 0.11), transparent 30rem),
    radial-gradient(circle at 92% 4%, rgba(145, 201, 208, 0.08), transparent 25rem),
    linear-gradient(145deg, #060707 0%, #101314 52%, #080909 100%);
  color: var(--text);
}

button,
input {
  font: inherit;
}

button,
.button-link {
  border: 0;
  border-radius: 8px;
  background: linear-gradient(135deg, #dffbf7, #8fd3d5);
  color: #051010;
  cursor: pointer;
  font-weight: 800;
  min-height: 62px;
  padding: 0 20px;
  box-shadow: 0 14px 38px rgba(143, 211, 213, 0.16);
  transition: transform 180ms ease, filter 180ms ease, opacity 180ms ease;
}

button:active,
.button-link:active {
  transform: translateY(1px) scale(0.99);
}

button.secondary,
.button-link.secondary {
  background: rgba(255, 255, 255, 0.075);
  color: var(--text);
  border: 1px solid var(--line);
  box-shadow: none;
}

button.quiet,
.button-link.quiet {
  min-height: 48px;
  opacity: 0.88;
}

.button-link {
  align-items: center;
  display: flex;
  justify-content: center;
  text-decoration: none;
}

button.mini {
  min-height: 36px;
  padding: 0 12px;
  font-size: 13px;
}

.hidden {
  display: none !important;
}

.browser-placeholder {
  color: var(--text);
  display: none;
  min-height: 100vh;
  place-items: center;
  padding: 24px;
  text-align: center;
}

.landing-page {
  display: grid;
  min-height: 100vh;
  overflow: hidden;
  place-items: center;
  position: relative;
}

.landing-page::before {
  animation: landingGlow 9s ease-in-out infinite alternate;
  background:
    radial-gradient(circle at 30% 22%, rgba(167, 238, 233, 0.16), transparent 28rem),
    radial-gradient(circle at 76% 18%, rgba(158, 143, 176, 0.13), transparent 24rem);
  content: "";
  inset: -20%;
  position: absolute;
}

.landing-grid {
  animation: gridDrift 18s linear infinite;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.055) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.055) 1px, transparent 1px);
  background-size: 42px 42px;
  inset: 0;
  mask-image: linear-gradient(to bottom, transparent, #000 18%, #000 74%, transparent);
  opacity: 0.32;
  position: absolute;
}

.landing-hero {
  padding: 28px 22px;
  position: relative;
  text-align: center;
  z-index: 2;
}

.landing-kicker {
  color: var(--cyan);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 0.18em;
  margin: 0 0 12px;
  text-transform: uppercase;
}

.landing-hero h1 {
  font-size: clamp(42px, 14vw, 82px);
  line-height: 0.95;
  margin: 0;
  text-shadow: 0 0 36px rgba(167, 238, 233, 0.16);
  white-space: normal;
}

.landing-subtitle {
  color: var(--muted);
  font-size: clamp(17px, 4.4vw, 22px);
  margin: 18px auto 26px;
  max-width: 340px;
}

.landing-button {
  align-items: center;
  background: linear-gradient(135deg, #dffbf7, #8fd3d5);
  border-radius: 8px;
  box-shadow: 0 18px 46px rgba(143, 211, 213, 0.2), 0 0 32px rgba(167, 238, 233, 0.1);
  color: #051010;
  display: inline-flex;
  font-weight: 900;
  justify-content: center;
  min-height: 58px;
  padding: 0 22px;
  text-decoration: none;
}

.landing-link-note {
  color: var(--muted);
  font-size: 14px;
  margin: 14px 0 0;
}

.landing-mascot {
  animation: mascotFloat 6s ease-in-out infinite;
  bottom: 6vh;
  filter: grayscale(0.18) saturate(0.95) drop-shadow(0 0 36px rgba(167, 238, 233, 0.12));
  max-width: 430px;
  opacity: 0.2;
  pointer-events: none;
  position: fixed;
  right: -120px;
  width: 86vw;
  z-index: 1;
}

@keyframes landingGlow {
  from {
    opacity: 0.72;
    transform: scale(1);
  }

  to {
    opacity: 1;
    transform: scale(1.06);
  }
}

@keyframes gridDrift {
  from {
    background-position: 0 0;
  }

  to {
    background-position: 42px 84px;
  }
}

@keyframes mascotFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(-2deg);
  }

  50% {
    transform: translate3d(-8px, -18px, 0) rotate(1deg);
  }
}

button:disabled {
  cursor: progress;
  filter: saturate(0.5);
  opacity: 0.68;
}

button.danger {
  border-color: rgba(255, 107, 107, 0.35);
  color: #ffd6d6;
}

.app-shell {
  width: min(100%, 520px);
  margin: 0 auto;
  padding: calc(24px + env(safe-area-inset-top)) 18px calc(32px + env(safe-area-inset-bottom));
  position: relative;
  z-index: 1;
}

.topbar {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin: 8px 0 22px;
}

.brand-lockup {
  align-items: center;
  display: flex;
  gap: 12px;
  min-width: 0;
}

.brand-emblem {
  aspect-ratio: 1;
  border: 1px solid rgba(167, 238, 233, 0.18);
  border-radius: 8px;
  box-shadow: 0 0 28px rgba(167, 238, 233, 0.08);
  height: 54px;
  object-fit: cover;
  opacity: 0.88;
  width: 54px;
}

.mascot-watermark {
  bottom: 35%;
  filter: grayscale(0.25) saturate(0.85);
  left: 50%;
  max-width: 520px;
  opacity: 0.18;
  pointer-events: none;
  position: fixed;
  transform: translateX(-50%);
  width: 105vw;
  z-index: 0;
}

.eyebrow,
small,
.section-title span {
  color: var(--muted);
  letter-spacing: 0;
  margin: 0;
}

h1,
h2 {
  letter-spacing: 0;
  margin: 0;
}

h1 {
  font-size: 31px;
  line-height: 1.04;
  white-space: nowrap;
}

h2 {
  font-size: 18px;
}

.glass {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 8px;
  box-shadow: var(--shadow);
  backdrop-filter: blur(24px);
}

.status-panel {
  padding: 22px;
}

.status-orbit {
  align-items: center;
  display: flex;
  gap: 14px;
  margin-bottom: 14px;
}

.status-orbit.inactive span {
  background: var(--danger);
  box-shadow: 0 0 0 8px rgba(255, 107, 107, 0.09), 0 0 26px rgba(255, 107, 107, 0.55);
}

.status-orbit span {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--lime);
  box-shadow: 0 0 0 8px rgba(168, 234, 209, 0.08), 0 0 26px rgba(168, 234, 209, 0.38);
}

.expiry-line {
  color: var(--muted);
  font-size: 15px;
  margin: 0;
}

.device-card {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid var(--line);
  border-radius: 8px;
}

.actions {
  display: grid;
  gap: 11px;
  grid-template-columns: 1fr;
  margin: 16px 0 22px;
}

.access-actions {
  display: grid;
  gap: 11px;
  grid-template-columns: 1fr;
}

.key-panel {
  padding: 16px;
  margin-top: 14px;
}

.admin-panel {
  display: grid;
  gap: 12px;
  margin: 0 0 22px;
  padding: 16px;
}

.admin-sheet {
  max-height: min(86vh, 720px);
  overflow: auto;
}

.admin-users,
.admin-debug,
.admin-user-card {
  display: grid;
  gap: 10px;
}

.admin-debug,
.admin-user-row,
.admin-user-card,
.admin-grant-form {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 12px;
}

.admin-grant-form {
  display: grid;
  gap: 10px;
  margin-bottom: 10px;
}

.admin-grant-form label {
  color: var(--muted);
  display: grid;
  font-size: 13px;
  gap: 6px;
}

.admin-grant-form input {
  background: rgba(255, 255, 255, 0.075);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  min-height: 42px;
  padding: 0 10px;
}

.admin-grant-grid {
  display: grid;
  gap: 10px;
  grid-template-columns: 1fr 1fr;
}

.admin-user-row {
  color: var(--text);
  display: grid;
  gap: 4px;
  min-height: 0;
  position: relative;
  text-align: left;
  touch-action: manipulation;
  width: 100%;
  -webkit-tap-highlight-color: transparent;
}

.admin-user-row * {
  pointer-events: auto;
}

.admin-user-row.loading {
  opacity: 0.74;
}

.admin-user-row span,
.admin-meta {
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.admin-row-loader,
.admin-card-loader {
  color: var(--cyan);
  font-size: 13px;
}

.admin-card-loader {
  border: 2px solid rgba(255, 255, 255, 0.16);
  border-top-color: var(--cyan);
  border-radius: 50%;
  height: 26px;
  margin-top: 8px;
  width: 26px;
  animation: spin 850ms linear infinite;
}

.admin-actions {
  display: grid;
  gap: 8px;
  grid-template-columns: 1fr;
  margin-top: 12px;
}

.invite-url {
  display: block;
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-all;
  white-space: normal;
  font-size: 12px;
  line-height: 1.35;
}

#inviteCreateResult,
#inviteCreateHint {
  max-width: 100%;
  overflow-wrap: anywhere;
  word-break: break-word;
  white-space: normal;
}

.invite-actions {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
  width: 100%;
}

.invite-admin-card {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
  padding: 12px;
  margin-top: 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  background: rgba(11, 15, 24, 0.72);
}

.invite-admin-list {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.invite-admin-list .admin-user-row {
  width: 100%;
  max-width: 100%;
  box-sizing: border-box;
}

.invite-list-title {
  font-weight: 800;
  margin-bottom: 8px;
}

.invite-compact-row {
  display: block;
  padding: 10px 12px;
}

.invite-compact-row strong {
  display: block;
  margin-bottom: 8px;
}

.invite-compact-row .invite-actions {
  max-width: 220px;
}

#inviteCreateResult,
#inviteCreateHint {
  display: block;
  max-width: 100%;
  overflow-x: hidden;
  overflow-wrap: anywhere;
  word-break: break-all;
  white-space: normal;
  box-sizing: border-box;
}

html,
body,
#app,
.landing-page,
.admin-panel,
.app-shell,
.admin-sheet,
.admin-user-card,
.invite-admin-card,
.invite-admin-list,
.invite-admin-list .admin-user-row,
#adminModal,
#adminModal .modal-inner {
  max-width: 100%;
  overflow-x: hidden !important;
}

.diagnostics summary {
  cursor: pointer;
  font-weight: 900;
  list-style: none;
  min-height: 44px;
  display: flex;
  align-items: center;
  touch-action: manipulation;
}

.diagnostics summary::-webkit-details-marker {
  display: none;
}

.diagnostics summary::after {
  content: "+";
  color: var(--cyan);
  margin-left: auto;
}

.diagnostics[open] summary::after {
  content: "-";
}

.diagnostics-grid {
  display: grid;
  gap: 6px;
  padding-top: 8px;
}

.section-title {
  align-items: center;
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.qr-wrap {
  display: grid;
  min-height: 220px;
  place-items: center;
  padding: 10px 0 6px;
}

.qr-wrap img {
  background: #081019;
  border: 1px solid rgba(73, 245, 212, 0.25);
  border-radius: 8px;
  display: none;
  max-width: 210px;
  width: 72%;
}

.toast {
  background: var(--panel-strong);
  border: 1px solid var(--line);
  border-radius: 8px;
  bottom: 20px;
  box-shadow: var(--shadow);
  color: var(--text);
  left: 50%;
  opacity: 0;
  padding: 12px 14px;
  pointer-events: none;
  position: fixed;
  transform: translate(-50%, 16px);
  transition: opacity 180ms ease, transform 180ms ease;
  width: min(90vw, 360px);
  z-index: 20;
}

.modal {
  align-items: flex-end;
  display: flex;
  inset: 0;
  justify-content: center;
  padding: 18px;
  position: fixed;
  z-index: 30;
}

.modal-backdrop {
  background: rgba(0, 0, 0, 0.58);
  inset: 0;
  position: absolute;
}

.modal-sheet {
  max-width: 520px;
  padding: 18px;
  position: relative;
  width: 100%;
}

.modal-head {
  align-items: center;
  display: flex;
  justify-content: space-between;
  margin-bottom: 14px;
}

.icon-button {
  background: rgba(255, 255, 255, 0.08);
  border: 1px solid var(--line);
  box-shadow: none;
  color: var(--text);
  font-size: 24px;
  line-height: 1;
  min-height: 40px;
  padding: 0;
  width: 40px;
}

.device-tabs {
  display: grid;
  gap: 8px;
  grid-template-columns: repeat(3, 1fr);
  margin-bottom: 14px;
}

.tab {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid var(--line);
  box-shadow: none;
  color: var(--text);
  min-height: 44px;
  padding: 0 10px;
}

.tab.active {
  background: rgba(167, 238, 233, 0.16);
  border-color: rgba(167, 238, 233, 0.34);
}

.device-help {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 16px;
}

.device-help p {
  line-height: 1.5;
  margin: 0 0 12px;
}

.device-help h3 {
  font-size: 15px;
  margin: 18px 0 8px;
}

.device-help ol {
  margin: 0 0 12px 20px;
  padding: 0;
}

.device-help li {
  line-height: 1.5;
  margin-bottom: 6px;
}

.device-help span {
  color: var(--muted);
  display: block;
  font-size: 14px;
}

.app-links {
  display: grid;
  gap: 8px;
  margin-bottom: 14px;
}

.app-link {
  align-items: center;
  background: rgba(255, 255, 255, 0.075);
  border: 1px solid var(--line);
  border-radius: 8px;
  color: var(--text);
  display: flex;
  font-weight: 800;
  min-height: 48px;
  padding: 0 12px;
  text-decoration: none;
}

.app-link.placeholder {
  justify-content: flex-start;
  min-height: 48px;
  opacity: 0.7;
  width: 100%;
}

.plans-list {
  display: grid;
  gap: 10px;
}

.plan-button {
  align-items: center;
  background: rgba(255, 255, 255, 0.075);
  border: 1px solid var(--line);
  box-shadow: none;
  color: var(--text);
  display: flex;
  justify-content: space-between;
  min-height: 64px;
  text-align: left;
}

.plan-button strong {
  color: var(--cyan);
}

.no-slots {
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 10px;
  padding: 16px;
}

.no-slots span {
  color: var(--muted);
  line-height: 1.45;
}

.toast.show {
  opacity: 1;
  transform: translate(-50%, 0);
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}

@media (max-width: 390px) {
  h1 {
    font-size: 26px;
  }

  .brand-emblem {
    height: 48px;
    width: 48px;
  }
}
.onboarding-panel { padding: 16px; margin: 0 0 16px; }
.onboarding-panel p { margin: 8px 0; color: var(--text); line-height: 1.45; }
.onboarding-panel ol { margin: 8px 0 10px 20px; }
.onboarding-panel li { margin-bottom: 6px; }
.help-shell { width: min(100%, 820px); margin: 0 auto; padding: 24px 16px 40px; }
.help-card-grid { display: grid; gap: 12px; grid-template-columns: repeat(2, minmax(0,1fr)); }
.help-card { display:block; text-decoration:none; color:var(--text); background: var(--panel); border:1px solid var(--line); border-radius: 8px; padding:16px; }
.help-block { background: var(--panel); border:1px solid var(--line); border-radius:8px; padding:16px; margin: 12px 0; }
@media (max-width: 560px){ .help-card-grid{grid-template-columns:1fr;} }

.plans-topup {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--line);
  border-radius: 8px;
  display: grid;
  gap: 8px;
  margin-top: 10px;
  padding: 10px;
}

.support-card {
  background: rgba(255, 255, 255, 0.035);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 8px;
  display: grid;
  gap: 8px;
  margin-top: 14px;
  padding: 10px;
}

.plans-topup-copy,
.support-card-copy {
  align-items: center;
  display: flex;
  gap: 9px;
  text-align: left;
}

.plans-topup-icon,
.support-card-icon {
  align-items: center;
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  display: inline-flex;
  font-size: 18px;
  height: 36px;
  justify-content: center;
  width: 36px;
}

.plans-topup-copy strong,
.support-card-copy strong {
  display: block;
  font-size: 13px;
}

.plans-topup-copy p,
.support-card-copy p {
  color: rgba(141, 150, 151, 0.82);
  font-size: 12px;
  line-height: 1.3;
  margin: 2px 0 0;
}

.plans-topup-link,
.support-contact-link {
  align-items: center;
  background: rgba(255, 255, 255, 0.055);
  border: 1px solid rgba(255, 255, 255, 0.11);
  border-radius: 8px;
  color: rgba(241, 244, 243, 0.9);
  display: flex;
  font-size: 13px;
  font-weight: 800;
  justify-content: center;
  min-height: 38px;
  padding: 0 10px;
  text-decoration: none;
}

.plans-topup-link:active,
.support-contact-link:active {
  transform: translateY(1px) scale(0.99);
}

.plans-topup-hint {
  color: rgba(141, 150, 151, 0.76);
  font-size: 11px;
  line-height: 1.3;
  margin: 0;
  text-align: center;
}

.help-alert { background: rgba(167, 238, 233, 0.08); border: 1px solid rgba(167, 238, 233, 0.32); border-radius: 8px; padding: 12px; margin: 10px 0 12px; }
.help-alert p { margin: 0 0 10px; line-height: 1.42; }
.help-alert p:last-child { margin-bottom: 0; }

.support-card-main { margin: -6px 0 16px; }
.support-card-main .support-contact-link { width: 100%; }

.reserve-landing {
  display: grid;
  gap: 10px;
  margin-top: 14px;
  padding: 14px;
  width: min(100%, 380px);
  position: static;
  z-index: auto;
}
.reserve-landing h2 {
  margin: 0;
  font-size: 18px;
}
.reserve-landing-text {
  margin: 0;
  color: var(--muted);
  line-height: 1.42;
  font-size: 14px;
}
.reserve-landing .secondary {
  min-height: 44px;
}
.reserve-loading,
.reserve-error {
  margin: 0;
  font-size: 13px;
  line-height: 1.4;
}
.reserve-error { color: #ffb3b3; }
.reserve-result {
  display: grid;
  gap: 10px;
  justify-items: center;
}
#reserveQrImage {
  width: 190px;
  max-width: 100%;
  border-radius: 8px;
  border: 1px solid rgba(255, 255, 255, 0.2);
  background: #081019;
}
.reserve-timer {
  margin: 0;
  font-size: 22px;
  font-weight: 800;
}
@media (max-width: 480px) {
  .reserve-landing { width: 100%; padding: 12px; }
  #reserveQrImage { width: 170px; }
}


.reserve-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,.82);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999;
  padding: 20px;
}

.reserve-modal {
  width: 100%;
  max-width: 360px;
  background: #101418;
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 24px;
  padding: 24px;
  text-align: center;
}

.reserve-title {
  font-size: 28px;
  font-weight: 700;
  margin-bottom: 18px;
}

.reserve-overlay-qr {
  width: 100%;
  max-width: 280px;
  border-radius: 16px;
  margin: 0 auto 20px;
  display: block;
  background: white;
}

.reserve-overlay-hint {
  margin-top: 18px;
  opacity: .75;
  line-height: 1.5;
}

@media (min-width: 700px) {
  .reserve-overlay {
    align-items: flex-start;
    padding-top: 80px;
    overflow-y: auto;
  }

  .reserve-modal {
    max-width: 360px;
    transform: scale(0.85);
    transform-origin: top center;
  }

  .reserve-overlay-qr {
    max-width: 220px;
  }

  .reserve-title {
    font-size: 24px;
  }
}

/* desktop reserve card cleanup */
@media (min-width: 700px) {
  .reserve-card,
  #reserveAccessCard {
    width: 100%;
    max-width: 420px;
    margin-left: auto;
    margin-right: auto;
  }

  .reserve-overlay {
    position: fixed !important;
    inset: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    background: rgba(0,0,0,.82) !important;
    z-index: 999999 !important;
    padding: 24px !important;
  }

  .reserve-overlay.hidden {
    display: none !important;
  }

  .reserve-modal {
    position: relative !important;
    width: 100% !important;
    max-width: 360px !important;
    margin: 0 auto !important;
    transform: none !important;
  }

  .reserve-overlay-qr {
    width: 260px !important;
    max-width: 260px !important;
    height: 260px !important;
    object-fit: contain !important;
  }
}

.help-sheet {
  max-width: 560px;
  max-height: min(720px, calc(100vh - 32px));
  overflow-y: auto;
}

.help-modal-head {
  align-items: center;
  gap: 10px;
}

.help-back {
  border: 0;
  background: rgba(255, 255, 255, 0.09);
  color: #f4f7fb;
  border-radius: 8px;
  padding: 9px 12px;
  font-weight: 700;
}

.help-intro {
  margin: 0 0 14px;
  color: rgba(244, 247, 251, 0.72);
}

.help-sections {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.help-section-button {
  min-height: 54px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.08);
  color: #f4f7fb;
  font-size: 16px;
  font-weight: 800;
  text-align: left;
  padding: 0 14px;
}

.help-section-button:active,
.help-back:active {
  transform: translateY(1px);
}

.help-detail {
  color: rgba(244, 247, 251, 0.86);
}

.help-detail ol,
.help-detail ul {
  margin: 0;
  padding-left: 22px;
}

.help-detail li {
  margin: 0 0 10px;
  line-height: 1.48;
}

.help-extra {
  margin-top: 14px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
}

.help-extra summary {
  cursor: pointer;
  font-weight: 800;
}

.help-extra ul {
  margin-top: 10px;
}

.help-detail-action {
  width: 100%;
  margin-top: 16px;
}

@media (max-width: 520px) {
  .help-sheet {
    max-height: calc(100vh - 20px);
  }

  .help-sections {
    grid-template-columns: 1fr;
  }

  .help-modal-head h2 {
    font-size: 20px;
  }
}

/* Premium motion layer */
:root {
  --motion-spring: cubic-bezier(0.2, 0.9, 0.22, 1);
  --motion-smooth: cubic-bezier(0.16, 1, 0.3, 1);
  --glow-cyan: rgba(167, 238, 233, 0.28);
  --glow-green: rgba(168, 234, 209, 0.24);
  --glow-red: rgba(255, 107, 107, 0.22);
}

body {
  position: relative;
  overflow-x: hidden;
}

body::before,
body::after {
  content: "";
  pointer-events: none;
  position: fixed;
  z-index: 0;
  will-change: transform, opacity;
}

body::before {
  inset: -28vh -18vw auto;
  height: 70vh;
  background:
    radial-gradient(circle at 18% 24%, rgba(167, 238, 233, 0.13), transparent 30rem),
    radial-gradient(circle at 78% 34%, rgba(145, 201, 208, 0.1), transparent 26rem),
    radial-gradient(circle at 52% 74%, rgba(158, 143, 176, 0.07), transparent 22rem);
  filter: blur(8px);
  opacity: 0.88;
  animation: ambientField 18s var(--motion-smooth) infinite alternate;
}

body::after {
  inset: auto -20vw -34vh;
  height: 62vh;
  background:
    radial-gradient(circle at 28% 62%, rgba(168, 234, 209, 0.09), transparent 24rem),
    radial-gradient(circle at 82% 42%, rgba(167, 238, 233, 0.08), transparent 28rem);
  filter: blur(10px);
  opacity: 0.68;
  animation: ambientFieldLower 22s var(--motion-smooth) infinite alternate;
}

.landing-page,
.app-shell,
.toast,
.modal,
.access-granted-overlay,
.reserve-overlay {
  isolation: isolate;
}

.glass {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.075), rgba(255, 255, 255, 0.03)),
    var(--panel);
  box-shadow:
    0 24px 70px rgba(0, 0, 0, 0.42),
    inset 0 1px 0 rgba(255, 255, 255, 0.08);
}

.status-panel,
.key-panel,
.support-card,
.reserve-landing {
  animation: panelFloatIn 520ms var(--motion-smooth) both;
}

.status-orbit span {
  position: relative;
  animation: statusBreathActive 2.8s ease-in-out infinite;
  transition: background 420ms ease, box-shadow 420ms ease;
}

.status-orbit span::after {
  content: "";
  position: absolute;
  inset: -10px;
  border-radius: 999px;
  border: 1px solid rgba(168, 234, 209, 0.22);
  opacity: 0.7;
  animation: statusRing 2.8s ease-in-out infinite;
}

.status-orbit.inactive span {
  animation-name: statusBreathInactive;
}

.status-orbit.inactive span::after {
  border-color: rgba(255, 107, 107, 0.24);
}

button,
.button-link,
.landing-button,
.plans-topup-link,
.support-contact-link {
  position: relative;
  overflow: hidden;
  -webkit-tap-highlight-color: transparent;
  touch-action: manipulation;
  transform: translateZ(0);
  transition:
    transform 360ms var(--motion-spring),
    box-shadow 360ms ease,
    border-color 260ms ease,
    background 260ms ease,
    filter 260ms ease,
    opacity 260ms ease;
}

button:not(:disabled):active,
.button-link:not(:disabled):active,
.landing-button:active,
.plans-topup-link:active,
.support-contact-link:active {
  transform: translateY(1px) scale(0.975);
  filter: saturate(1.08) brightness(1.04);
}

button:not(.secondary):not(.quiet)::after,
.landing-button::after {
  content: "";
  position: absolute;
  inset: -40% auto -40% -70%;
  width: 52%;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.42), transparent);
  transform: skewX(-18deg);
  opacity: 0;
}

button:not(.secondary):not(.quiet):active::after,
.landing-button:active::after {
  animation: buttonGlint 560ms ease;
}

button.secondary:not(:disabled):active,
.button-link.secondary:active {
  box-shadow: 0 0 0 1px rgba(167, 238, 233, 0.18), 0 12px 34px rgba(167, 238, 233, 0.08);
  border-color: rgba(167, 238, 233, 0.28);
}

.modal:not(.hidden) .modal-backdrop {
  animation: modalBackdropIn 320ms ease both;
  backdrop-filter: blur(14px);
}

.modal:not(.hidden) .modal-sheet {
  animation: modalSheetIn 440ms var(--motion-smooth) both;
  transform-origin: 50% 100%;
}

.toast.show {
  animation: toastIn 260ms var(--motion-smooth) both;
}

.qr-wrap {
  position: relative;
  overflow: hidden;
}

.qr-wrap.qr-ready::before {
  content: "";
  position: absolute;
  left: 12%;
  right: 12%;
  top: 18%;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(167, 238, 233, 0.72), transparent);
  filter: blur(0.4px);
  opacity: 0;
  animation: qrScan 2.2s ease-in-out 420ms infinite;
  z-index: 2;
}

.qr-wrap.qr-ready img,
.reserve-overlay-qr,
#reserveQrImage:not([src=""]) {
  animation: qrReveal 640ms var(--motion-smooth) both;
  box-shadow: 0 0 0 1px rgba(167, 238, 233, 0.18), 0 18px 46px rgba(167, 238, 233, 0.1);
}

.reserve-overlay:not(.hidden) {
  animation: modalBackdropIn 300ms ease both;
  backdrop-filter: blur(16px);
}

.reserve-overlay:not(.hidden) .reserve-modal {
  animation: modalSheetIn 430ms var(--motion-smooth) both;
}

.access-granted-overlay {
  align-items: center;
  background: rgba(3, 5, 6, 0.72);
  backdrop-filter: blur(18px);
  display: flex;
  inset: 0;
  justify-content: center;
  padding: 22px;
  position: fixed;
  z-index: 80;
}

.access-granted-overlay:not(.hidden) {
  animation: modalBackdropIn 340ms ease both;
}

.access-granted-card {
  display: grid;
  gap: 14px;
  justify-items: center;
  max-width: 360px;
  padding: 28px 24px;
  text-align: center;
  width: 100%;
  animation: accessCardReveal 620ms var(--motion-smooth) both;
}

.access-loader {
  border: 1px solid rgba(167, 238, 233, 0.18);
  border-radius: 999px;
  display: grid;
  height: 72px;
  place-items: center;
  position: relative;
  width: 72px;
}

.access-loader::before,
.access-loader::after {
  border: 2px solid transparent;
  border-radius: inherit;
  content: "";
  inset: 7px;
  position: absolute;
}

.access-loader::before {
  border-top-color: rgba(167, 238, 233, 0.82);
  border-right-color: rgba(167, 238, 233, 0.24);
  animation: spin 920ms linear infinite;
}

.access-loader::after {
  inset: 17px;
  border-bottom-color: rgba(168, 234, 209, 0.74);
  animation: spin 1350ms linear infinite reverse;
}

.access-loader span {
  background: var(--lime);
  border-radius: 50%;
  box-shadow: 0 0 26px rgba(168, 234, 209, 0.48);
  height: 9px;
  width: 9px;
}

.access-sequence-text {
  color: rgba(241, 244, 243, 0.72);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin: 0;
  text-transform: uppercase;
}

.access-granted-title {
  color: #dffbf7;
  font-size: 25px;
  letter-spacing: 0.1em;
  text-shadow: 0 0 28px rgba(167, 238, 233, 0.34);
  animation: accessTitle 1.8s ease-in-out infinite alternate;
}

.access-granted-subtitle {
  color: var(--muted);
  margin: -6px 0 0;
}

@keyframes ambientField {
  from { transform: translate3d(-2vw, -1vh, 0) scale(1); opacity: 0.64; }
  to { transform: translate3d(3vw, 2vh, 0) scale(1.06); opacity: 0.92; }
}

@keyframes ambientFieldLower {
  from { transform: translate3d(3vw, 1vh, 0) scale(1.02); opacity: 0.5; }
  to { transform: translate3d(-2vw, -2vh, 0) scale(1.08); opacity: 0.76; }
}

@keyframes panelFloatIn {
  from { opacity: 0; transform: translate3d(0, 10px, 0) scale(0.985); }
  to { opacity: 1; transform: translate3d(0, 0, 0) scale(1); }
}

@keyframes statusBreathActive {
  0%, 100% { box-shadow: 0 0 0 7px rgba(168, 234, 209, 0.08), 0 0 24px rgba(168, 234, 209, 0.34); }
  50% { box-shadow: 0 0 0 13px rgba(168, 234, 209, 0.04), 0 0 38px rgba(167, 238, 233, 0.46); }
}

@keyframes statusBreathInactive {
  0%, 100% { box-shadow: 0 0 0 7px rgba(255, 107, 107, 0.08), 0 0 24px rgba(255, 107, 107, 0.32); }
  50% { box-shadow: 0 0 0 13px rgba(255, 107, 107, 0.04), 0 0 36px rgba(255, 107, 107, 0.42); }
}

@keyframes statusRing {
  0%, 100% { transform: scale(0.92); opacity: 0.25; }
  50% { transform: scale(1.24); opacity: 0.72; }
}

@keyframes buttonGlint {
  0% { opacity: 0; transform: translateX(0) skewX(-18deg); }
  24% { opacity: 0.7; }
  100% { opacity: 0; transform: translateX(330%) skewX(-18deg); }
}

@keyframes modalBackdropIn {
  from { opacity: 0; }
  to { opacity: 1; }
}

@keyframes modalSheetIn {
  from { opacity: 0; transform: translate3d(0, 18px, 0) scale(0.96); filter: blur(8px); }
  to { opacity: 1; transform: translate3d(0, 0, 0) scale(1); filter: blur(0); }
}

@keyframes toastIn {
  from { opacity: 0; transform: translate(-50%, 18px) scale(0.98); }
  to { opacity: 1; transform: translate(-50%, 0) scale(1); }
}

@keyframes qrReveal {
  from { opacity: 0; transform: translate3d(0, 8px, 0) scale(0.96); filter: blur(8px); }
  to { opacity: 1; transform: translate3d(0, 0, 0) scale(1); filter: blur(0); }
}

@keyframes qrScan {
  0%, 100% { opacity: 0; transform: translateY(-58px); }
  18%, 70% { opacity: 0.72; }
  82% { opacity: 0; transform: translateY(156px); }
}

@keyframes accessCardReveal {
  from { opacity: 0; transform: translate3d(0, 12px, 0) scale(0.94); filter: blur(10px); }
  to { opacity: 1; transform: translate3d(0, 0, 0) scale(1); filter: blur(0); }
}

@keyframes accessTitle {
  from { opacity: 0.78; text-shadow: 0 0 18px rgba(167, 238, 233, 0.22); }
  to { opacity: 1; text-shadow: 0 0 34px rgba(167, 238, 233, 0.44); }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: 1ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: 1ms !important;
  }
}

.metric-tick {
  animation: metricTick 460ms var(--motion-smooth) both;
  font-variant-numeric: tabular-nums;
}

@keyframes metricTick {
  from { opacity: 0.5; transform: translate3d(0, 4px, 0); filter: blur(3px); }
  to { opacity: 1; transform: translate3d(0, 0, 0); filter: blur(0); }
}

/* Premium ambient background upgrade */
.ambient-visual-layer {
  inset: 0;
  overflow: hidden;
  pointer-events: none;
  position: fixed;
  z-index: 0;
}

.ambient-visual-layer::before {
  content: "";
  position: absolute;
  inset: -20%;
  background-image:
    radial-gradient(circle at 20% 30%, rgba(255, 255, 255, 0.055) 0 1px, transparent 1.5px),
    radial-gradient(circle at 76% 68%, rgba(167, 238, 233, 0.05) 0 1px, transparent 1.8px);
  background-size: 18px 18px, 29px 29px;
  filter: blur(0.25px);
  opacity: 0.22;
  animation: ambientNoiseDrift 16s steps(8) infinite;
  mix-blend-mode: screen;
}

.ambient-visual-layer::after {
  content: "";
  position: absolute;
  inset: -12%;
  background:
    linear-gradient(115deg, transparent 0 42%, rgba(167, 238, 233, 0.035) 48%, transparent 55% 100%),
    radial-gradient(ellipse at 50% 20%, rgba(167, 238, 233, 0.045), transparent 44%);
  opacity: 0.62;
  animation: liquidGlassTilt 20s var(--motion-smooth) infinite alternate;
}

.ambient-blob {
  border-radius: 999px;
  filter: blur(42px);
  opacity: 0.48;
  position: absolute;
  transform: translate3d(0, 0, 0);
  will-change: transform, opacity;
}

.ambient-blob-a {
  background: radial-gradient(circle, rgba(167, 238, 233, 0.22), rgba(167, 238, 233, 0.02) 66%, transparent 72%);
  height: 46vh;
  left: -12vw;
  top: 6vh;
  width: 58vw;
  animation: blobSailA 24s var(--motion-smooth) infinite alternate;
}

.ambient-blob-b {
  background: radial-gradient(circle, rgba(145, 201, 208, 0.16), rgba(91, 126, 136, 0.025) 68%, transparent 74%);
  height: 50vh;
  right: -18vw;
  top: 16vh;
  width: 56vw;
  animation: blobSailB 28s var(--motion-smooth) infinite alternate;
}

.ambient-blob-c {
  background: radial-gradient(circle, rgba(168, 234, 209, 0.13), rgba(168, 234, 209, 0.02) 62%, transparent 72%);
  bottom: -18vh;
  height: 42vh;
  left: 24vw;
  width: 58vw;
  animation: blobSailC 30s var(--motion-smooth) infinite alternate;
}

.ambient-smoke {
  background:
    radial-gradient(ellipse at 18% 42%, rgba(255, 255, 255, 0.045), transparent 42%),
    radial-gradient(ellipse at 78% 22%, rgba(167, 238, 233, 0.045), transparent 46%),
    radial-gradient(ellipse at 52% 74%, rgba(145, 201, 208, 0.035), transparent 52%);
  filter: blur(20px) saturate(0.9);
  inset: -16%;
  opacity: 0.42;
  position: absolute;
  transform-origin: 50% 50%;
  animation: smokeFold 34s ease-in-out infinite alternate;
}

.ambient-rain {
  inset: 0;
  mask-image: linear-gradient(to bottom, transparent 0%, #000 14%, #000 78%, transparent 100%);
  opacity: 0.52;
  position: absolute;
}

.ambient-rain span {
  animation: digitalRainFall var(--rain-duration) linear infinite;
  animation-delay: var(--rain-delay);
  color: rgba(167, 238, 233, var(--rain-alpha));
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  font-size: 16px;
  line-height: 1;
  opacity: 0;
  position: absolute;
  text-shadow: 0 0 12px rgba(167, 238, 233, 0.18);
  top: -12vh;
  transform: translate3d(0, -12vh, 0);
  writing-mode: vertical-rl;
}

.ambient-rain span::after {
  content: "|\A ·\A ˙\A |\A •";
  white-space: pre;
}

.ambient-scan {
  background: linear-gradient(90deg, transparent, rgba(167, 238, 233, 0.16), rgba(255, 255, 255, 0.05), transparent);
  filter: blur(1px);
  height: 1px;
  left: -25%;
  opacity: 0;
  position: absolute;
  top: 22%;
  transform: rotate(-8deg) translate3d(-15%, 0, 0);
  width: 150%;
  animation: scanSweep 9.5s ease-in-out infinite;
}

.landing-page,
.app-shell {
  position: relative;
  z-index: 1;
}

.landing-page::before {
  opacity: 0.95;
  mix-blend-mode: screen;
}

.landing-grid {
  opacity: 0.24;
}

.landing-mascot {
  filter:
    grayscale(0.12)
    saturate(1.08)
    drop-shadow(0 0 22px rgba(167, 238, 233, 0.24))
    drop-shadow(0 0 58px rgba(91, 190, 190, 0.16));
  opacity: 0.29;
}

.mascot-watermark {
  filter:
    grayscale(0.16)
    saturate(1.02)
    drop-shadow(0 0 24px rgba(167, 238, 233, 0.18))
    drop-shadow(0 0 64px rgba(91, 190, 190, 0.12));
  opacity: 0.24;
}

@keyframes ambientNoiseDrift {
  0% { transform: translate3d(0, 0, 0); }
  25% { transform: translate3d(-1.4%, 0.9%, 0); }
  50% { transform: translate3d(1.2%, -1.1%, 0); }
  75% { transform: translate3d(-0.6%, -0.8%, 0); }
  100% { transform: translate3d(0.9%, 1.2%, 0); }
}

@keyframes liquidGlassTilt {
  from { transform: translate3d(-2vw, -1vh, 0) rotate(-1deg) scale(1.02); }
  to { transform: translate3d(2vw, 2vh, 0) rotate(1.2deg) scale(1.08); }
}

@keyframes blobSailA {
  from { transform: translate3d(-3vw, -1vh, 0) scale(1); opacity: 0.34; }
  to { transform: translate3d(12vw, 7vh, 0) scale(1.16); opacity: 0.55; }
}

@keyframes blobSailB {
  from { transform: translate3d(4vw, 1vh, 0) scale(1.04); opacity: 0.3; }
  to { transform: translate3d(-11vw, 8vh, 0) scale(1.18); opacity: 0.48; }
}

@keyframes blobSailC {
  from { transform: translate3d(-4vw, 4vh, 0) scale(1.05); opacity: 0.24; }
  to { transform: translate3d(8vw, -8vh, 0) scale(1.18); opacity: 0.42; }
}

@keyframes smokeFold {
  from { transform: translate3d(-2vw, 0, 0) rotate(-2deg) scale(1); opacity: 0.28; }
  to { transform: translate3d(2vw, -2vh, 0) rotate(2deg) scale(1.08); opacity: 0.46; }
}

@keyframes digitalRainFall {
  0% { opacity: 0; transform: translate3d(0, -16vh, 0); }
  12% { opacity: 0.72; }
  72% { opacity: 0.44; }
  100% { opacity: 0; transform: translate3d(0, 116vh, 0); }
}

@keyframes scanSweep {
  0%, 72% { opacity: 0; transform: rotate(-8deg) translate3d(-24%, 0, 0); }
  78% { opacity: 0.52; }
  90% { opacity: 0.16; }
  100% { opacity: 0; transform: rotate(-8deg) translate3d(24%, 46vh, 0); }
}

@media (max-width: 520px) {
  .ambient-blob {
    filter: blur(34px);
  }

  .ambient-rain span {
    font-size: 13px;
  }

  .landing-mascot {
    opacity: 0.27;
    right: -104px;
  }

  .mascot-watermark {
    opacity: 0.2;
  }
}

@media (prefers-reduced-motion: reduce) {
  .ambient-visual-layer::before,
  .ambient-visual-layer::after,
  .ambient-blob,
  .ambient-smoke,
  .ambient-rain span,
  .ambient-scan {
    animation: none !important;
  }
}

/* Performance rollback for ambient background */
.ambient-rain,
.ambient-smoke {
  display: none !important;
}

.ambient-visual-layer {
  contain: strict;
  opacity: 0.88;
}

.ambient-visual-layer::before {
  background:
    radial-gradient(circle at 18% 20%, rgba(167, 238, 233, 0.12), transparent 34rem),
    radial-gradient(circle at 82% 18%, rgba(145, 201, 208, 0.08), transparent 30rem),
    radial-gradient(circle at 56% 86%, rgba(168, 234, 209, 0.06), transparent 28rem) !important;
  background-size: auto !important;
  filter: none !important;
  inset: -8% !important;
  mix-blend-mode: normal !important;
  opacity: 0.72 !important;
  animation: ambientLiteDrift 28s var(--motion-smooth) infinite alternate !important;
}

.ambient-visual-layer::after {
  background:
    linear-gradient(112deg, transparent 0 46%, rgba(167, 238, 233, 0.045) 50%, transparent 56% 100%) !important;
  inset: -18% !important;
  opacity: 0.34 !important;
  animation: liquidLiteSweep 18s ease-in-out infinite !important;
}

.ambient-blob {
  filter: none !important;
  opacity: 0.34 !important;
  will-change: transform, opacity;
}

.ambient-blob-a {
  background: radial-gradient(circle, rgba(167, 238, 233, 0.13), transparent 68%) !important;
  animation: blobLiteA 34s var(--motion-smooth) infinite alternate !important;
}

.ambient-blob-b {
  background: radial-gradient(circle, rgba(145, 201, 208, 0.09), transparent 70%) !important;
  animation: blobLiteB 38s var(--motion-smooth) infinite alternate !important;
}

.ambient-blob-c {
  background: radial-gradient(circle, rgba(168, 234, 209, 0.07), transparent 70%) !important;
  animation: blobLiteC 42s var(--motion-smooth) infinite alternate !important;
}

.ambient-scan {
  background: linear-gradient(90deg, transparent, rgba(167, 238, 233, 0.09), transparent) !important;
  filter: none !important;
  opacity: 0 !important;
  animation: scanLiteSweep 14s ease-in-out infinite !important;
}

.landing-mascot {
  filter: drop-shadow(0 0 26px rgba(167, 238, 233, 0.18)) !important;
  opacity: 0.34 !important;
}

.mascot-watermark {
  filter: drop-shadow(0 0 22px rgba(167, 238, 233, 0.13)) !important;
  opacity: 0.27 !important;
}

@keyframes ambientLiteDrift {
  from { transform: translate3d(-1vw, -0.5vh, 0) scale(1); opacity: 0.62; }
  to { transform: translate3d(1.2vw, 1vh, 0) scale(1.04); opacity: 0.78; }
}

@keyframes liquidLiteSweep {
  0%, 100% { transform: translate3d(-6vw, -2vh, 0) rotate(-1deg); opacity: 0.18; }
  50% { transform: translate3d(5vw, 2vh, 0) rotate(1deg); opacity: 0.34; }
}

@keyframes blobLiteA {
  from { transform: translate3d(-2vw, -1vh, 0) scale(1); opacity: 0.22; }
  to { transform: translate3d(6vw, 4vh, 0) scale(1.08); opacity: 0.36; }
}

@keyframes blobLiteB {
  from { transform: translate3d(2vw, 0, 0) scale(1); opacity: 0.18; }
  to { transform: translate3d(-5vw, 4vh, 0) scale(1.06); opacity: 0.31; }
}

@keyframes blobLiteC {
  from { transform: translate3d(-1vw, 2vh, 0) scale(1); opacity: 0.14; }
  to { transform: translate3d(4vw, -3vh, 0) scale(1.05); opacity: 0.25; }
}

@keyframes scanLiteSweep {
  0%, 80% { opacity: 0; transform: rotate(-7deg) translate3d(-20%, 0, 0); }
  86% { opacity: 0.34; }
  100% { opacity: 0; transform: rotate(-7deg) translate3d(18%, 34vh, 0); }
}

@media (max-width: 768px) {
  body::before,
  body::after {
    filter: none !important;
    animation-duration: 42s !important;
  }

  .ambient-visual-layer::before,
  .ambient-visual-layer::after {
    animation: none !important;
  }

  .ambient-blob {
    display: none !important;
  }

  .ambient-scan {
    animation-duration: 22s !important;
  }

  .landing-mascot {
    filter: none !important;
    opacity: 0.32 !important;
  }

  .mascot-watermark {
    filter: none !important;
    opacity: 0.22 !important;
  }

  .glass {
    backdrop-filter: blur(14px);
  }

  .modal:not(.hidden) .modal-backdrop,
  .reserve-overlay:not(.hidden) {
    backdrop-filter: blur(8px);
  }
}

@media (prefers-reduced-motion: reduce) {
  .ambient-visual-layer,
  .ambient-visual-layer::before,
  .ambient-visual-layer::after,
  .ambient-blob,
  .ambient-scan,
  .landing-grid,
  .landing-page::before,
  body::before,
  body::after {
    animation: none !important;
  }
}

/* Main screen content polish */
.status-panel {
  overflow: hidden;
  position: relative;
}

.status-panel::after {
  background: linear-gradient(115deg, transparent 0 42%, rgba(167, 238, 233, 0.055) 50%, transparent 58% 100%);
  content: "";
  inset: 0;
  opacity: 0.55;
  pointer-events: none;
  position: absolute;
}

.status-panel > * {
  position: relative;
  z-index: 1;
}

.status-orbit span {
  border: 1px solid rgba(216, 255, 249, 0.7);
  height: 20px;
  width: 20px;
}

.status-orbit span::before {
  border: 1px solid rgba(168, 234, 209, 0.3);
  border-radius: inherit;
  content: "";
  inset: -6px;
  position: absolute;
}

.status-orbit.inactive span::before {
  border-color: rgba(255, 107, 107, 0.3);
}

.locked-state,
.active-state {
  display: grid;
  gap: 10px;
}

.locked-state strong {
  color: rgba(241, 244, 243, 0.94);
  font-size: 17px;
  letter-spacing: 0.01em;
}

.locked-state p {
  color: var(--muted);
  line-height: 1.42;
  margin: 0;
}

.feature-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 2px;
}

.feature-chips span {
  background: rgba(255, 255, 255, 0.065);
  border: 1px solid rgba(167, 238, 233, 0.15);
  border-radius: 999px;
  color: rgba(223, 251, 247, 0.86);
  font-size: 12px;
  font-weight: 800;
  padding: 7px 10px;
}

.traffic-progress {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.09);
  border-radius: 999px;
  height: 9px;
  margin-top: 2px;
  overflow: hidden;
}

.traffic-progress span {
  background: linear-gradient(90deg, rgba(168, 234, 209, 0.85), rgba(167, 238, 233, 0.95));
  border-radius: inherit;
  box-shadow: 0 0 18px rgba(167, 238, 233, 0.26);
  display: block;
  height: 100%;
  min-width: 3%;
  transition: width 520ms var(--motion-smooth);
}

.traffic-progress.is-unlimited span {
  opacity: 0.72;
}

.status-footer,
.capacity-line {
  color: rgba(141, 150, 151, 0.82);
  font-size: 12px;
  margin: 0;
}

.status-footer {
  color: rgba(167, 238, 233, 0.68);
  font-weight: 800;
  letter-spacing: 0.02em;
}

.capacity-line {
  margin-top: 12px;
}

.actions > button:not(.hidden):first-child,
.actions > button#renewKeyBtn:not(.hidden) {
  box-shadow: 0 18px 46px rgba(143, 211, 213, 0.18), 0 0 0 1px rgba(223, 251, 247, 0.12) inset;
}

.mascot-watermark {
  bottom: 18% !important;
  left: 54% !important;
  max-width: 560px;
  opacity: 0.24 !important;
  transform: translateX(-50%) rotate(-4deg);
  width: 112vw;
}

@media (max-width: 768px) {
  .status-panel {
    padding: 20px;
  }

  .feature-chips span {
    padding: 7px 9px;
  }

  .mascot-watermark {
    bottom: 12% !important;
    left: 58% !important;
    opacity: 0.2 !important;
    width: 122vw;
  }
}

/* Premium cleanup: calmer main screen */
.brand-lockup h1 {
  font-size: 28px;
  letter-spacing: 0;
}

.status-panel {
  padding: 18px 18px 16px;
}

.status-panel::after {
  opacity: 0.28;
}

.status-orbit {
  gap: 11px;
  margin-bottom: 10px;
}

.status-orbit strong {
  color: rgba(241, 244, 243, 0.92);
  font-size: 17px;
  font-weight: 850;
  line-height: 1.2;
}

.status-orbit span {
  border-width: 1px;
  box-shadow: 0 0 0 5px rgba(168, 234, 209, 0.055), 0 0 18px rgba(168, 234, 209, 0.24);
  flex: 0 0 14px;
  height: 14px;
  width: 14px;
}

.status-orbit span::before {
  inset: -5px;
  opacity: 0.7;
}

.status-orbit span::after {
  inset: -8px;
  opacity: 0.32;
}

.status-orbit.inactive span {
  box-shadow: 0 0 0 5px rgba(255, 107, 107, 0.045), 0 0 17px rgba(255, 107, 107, 0.22);
}

.locked-state {
  gap: 0;
}

.locked-state strong,
.feature-chips {
  display: none !important;
}

.locked-state p {
  color: rgba(141, 150, 151, 0.88);
  font-size: 14px;
  line-height: 1.45;
  margin: 0;
}

.active-state {
  gap: 8px;
}

.expiry-line {
  font-size: 14px;
  line-height: 1.38;
}

.traffic-progress {
  height: 8px;
  margin: 1px 0 2px;
}

.status-footer {
  color: rgba(167, 238, 233, 0.7);
  font-size: 12px;
  font-weight: 750;
  letter-spacing: 0;
}

.capacity-line {
  color: rgba(141, 150, 151, 0.76);
  font-size: 12px;
  margin-top: 10px;
}

.mascot-watermark {
  bottom: 16% !important;
  left: 50% !important;
  max-width: 520px;
  opacity: 0.23 !important;
  transform: translateX(-50%) rotate(-2deg) !important;
  width: min(118vw, 560px);
}

.actions {
  margin-top: 14px;
}

@media (max-width: 768px) {
  .brand-lockup h1 {
    font-size: 26px;
  }

  .status-panel {
    padding: 17px;
  }

  .mascot-watermark {
    bottom: 10% !important;
    left: 50% !important;
    opacity: 0.2 !important;
    width: 116vw;
  }
}

@keyframes statusBreathActive {
  0%, 100% { box-shadow: 0 0 0 5px rgba(168, 234, 209, 0.055), 0 0 16px rgba(168, 234, 209, 0.22); }
  50% { box-shadow: 0 0 0 8px rgba(168, 234, 209, 0.035), 0 0 22px rgba(167, 238, 233, 0.3); }
}

@keyframes statusBreathInactive {
  0%, 100% { box-shadow: 0 0 0 5px rgba(255, 107, 107, 0.045), 0 0 15px rgba(255, 107, 107, 0.2); }
  50% { box-shadow: 0 0 0 8px rgba(255, 107, 107, 0.028), 0 0 20px rgba(255, 107, 107, 0.26); }
}

/* Hero composition refinement */
.app-shell {
  padding-top: calc(34px + env(safe-area-inset-top));
}

.topbar {
  align-items: center;
  justify-content: center;
  margin: 8px 0 34px;
  text-align: center;
}

.brand-lockup {
  align-items: center;
  display: grid;
  gap: 14px;
  justify-items: center;
}

.brand-lockup > div {
  display: grid;
  gap: 8px;
  justify-items: center;
}

.brand-emblem {
  border-color: rgba(167, 238, 233, 0.26);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.04) inset,
    0 16px 42px rgba(0, 0, 0, 0.28),
    0 0 32px rgba(167, 238, 233, 0.16);
  height: 64px;
  opacity: 0.96;
  width: 64px;
}

.brand-lockup .eyebrow {
  color: rgba(141, 150, 151, 0.72);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.22em;
  text-transform: uppercase;
}

.brand-lockup h1 {
  color: rgba(241, 244, 243, 0.96);
  font-size: 30px;
  line-height: 1;
  text-shadow: 0 0 28px rgba(167, 238, 233, 0.08);
}

.status-panel {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.064), rgba(255, 255, 255, 0.026)),
    rgba(18, 20, 21, 0.58);
  border-color: rgba(255, 255, 255, 0.105);
  box-shadow:
    0 18px 54px rgba(0, 0, 0, 0.34),
    inset 0 1px 0 rgba(255, 255, 255, 0.07);
  margin-top: 0;
  padding: 16px 17px 15px;
  backdrop-filter: blur(20px) saturate(1.05);
}

.status-orbit {
  margin-bottom: 8px;
}

.mascot-watermark {
  bottom: 2% !important;
  left: 50% !important;
  max-width: 620px;
  opacity: 0.24 !important;
  transform: translateX(-50%) rotate(-2deg) !important;
  width: min(132vw, 620px);
}

@media (max-width: 768px) {
  .app-shell {
    padding-top: calc(28px + env(safe-area-inset-top));
  }

  .topbar {
    margin: 4px 0 30px;
  }

  .brand-lockup {
    gap: 13px;
  }

  .brand-emblem {
    height: 62px;
    width: 62px;
  }

  .brand-lockup h1 {
    font-size: 28px;
  }

  .brand-lockup .eyebrow {
    font-size: 10px;
    letter-spacing: 0.2em;
  }

  .status-panel {
    padding: 15px 16px 14px;
  }

  .mascot-watermark {
    bottom: 0 !important;
    opacity: 0.21 !important;
    width: 132vw;
  }
}

@media (max-width: 390px) {
  .topbar {
    margin-bottom: 26px;
  }

  .brand-emblem {
    height: 58px;
    width: 58px;
  }

  .brand-lockup h1 {
    font-size: 26px;
  }
}

/* Premium private access composition pass */
.ambient-scan,
.ambient-rain,
.ambient-smoke {
  display: none !important;
}

.ambient-visual-layer {
  opacity: 1;
}

.ambient-visual-layer::before {
  background:
    radial-gradient(circle at 50% 26%, rgba(167, 238, 233, 0.13), transparent 23rem),
    radial-gradient(circle at 50% 54%, rgba(145, 201, 208, 0.085), transparent 34rem),
    radial-gradient(circle at 18% 8%, rgba(255, 255, 255, 0.045), transparent 20rem) !important;
  opacity: 0.84 !important;
}

.ambient-visual-layer::after {
  background:
    radial-gradient(ellipse at 50% 34%, rgba(167, 238, 233, 0.05), transparent 42%),
    linear-gradient(180deg, rgba(255, 255, 255, 0.025), transparent 42%) !important;
  opacity: 0.48 !important;
  animation: none !important;
}

.ambient-blob {
  display: none !important;
}

.app-shell {
  padding-top: calc(38px + env(safe-area-inset-top));
}

.app-shell::before {
  background:
    radial-gradient(circle at 50% 0%, rgba(167, 238, 233, 0.13), transparent 19rem),
    radial-gradient(ellipse at 50% 38%, rgba(255, 255, 255, 0.035), transparent 22rem);
  content: "";
  height: 360px;
  left: 50%;
  pointer-events: none;
  position: fixed;
  top: 0;
  transform: translateX(-50%);
  width: min(100vw, 720px);
  z-index: 0;
}

.topbar {
  margin: 4px 0 44px;
}

.brand-lockup {
  gap: 16px;
}

.brand-lockup > div {
  gap: 10px;
}

.brand-emblem {
  background: rgba(255, 255, 255, 0.035);
  border-color: rgba(167, 238, 233, 0.32);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.055) inset,
    0 18px 44px rgba(0, 0, 0, 0.32),
    0 0 42px rgba(167, 238, 233, 0.2);
  height: 70px;
  opacity: 1;
  width: 70px;
}

.brand-lockup .eyebrow {
  color: rgba(141, 150, 151, 0.64);
  font-size: 10px;
  letter-spacing: 0.26em;
}

.brand-lockup h1 {
  color: rgba(246, 250, 249, 0.98);
  font-size: 31px;
  font-weight: 860;
  text-shadow: 0 0 30px rgba(167, 238, 233, 0.1);
}

.mascot-watermark {
  bottom: auto !important;
  filter: none !important;
  left: 50% !important;
  max-width: 760px !important;
  opacity: 0.22 !important;
  top: 150px !important;
  transform: translateX(-50%) rotate(-2deg) !important;
  width: min(150vw, 760px) !important;
  z-index: 0;
}

.app-shell.is-active .mascot-watermark {
  opacity: 0.27 !important;
}

.status-panel {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.072), rgba(255, 255, 255, 0.024)),
    rgba(18, 20, 21, 0.48) !important;
  border-color: rgba(255, 255, 255, 0.095) !important;
  box-shadow:
    0 16px 48px rgba(0, 0, 0, 0.28),
    inset 0 1px 0 rgba(255, 255, 255, 0.075) !important;
  padding: 14px 16px 13px !important;
  backdrop-filter: blur(22px) saturate(1.08) !important;
}

.status-panel::after {
  opacity: 0.2 !important;
}

.status-orbit {
  margin-bottom: 7px;
}

.status-orbit strong {
  font-size: 16px;
}

.locked-state p,
.expiry-line {
  color: rgba(180, 188, 188, 0.78);
}

.active-state {
  gap: 7px;
}

.traffic-progress {
  background: rgba(255, 255, 255, 0.06);
}

.capacity-line {
  margin-top: 9px;
}

@media (max-width: 768px) {
  .app-shell {
    padding-top: calc(34px + env(safe-area-inset-top));
  }

  .app-shell::before {
    height: 300px;
  }

  .topbar {
    margin: 2px 0 38px;
  }

  .brand-emblem {
    height: 68px;
    width: 68px;
  }

  .brand-lockup h1 {
    font-size: 29px;
  }

  .mascot-watermark {
    opacity: 0.2 !important;
    top: 145px !important;
    width: 152vw !important;
  }

  .app-shell.is-active .mascot-watermark {
    opacity: 0.24 !important;
  }

  .status-panel {
    backdrop-filter: blur(16px) saturate(1.04) !important;
    padding: 14px 15px 13px !important;
  }
}

@media (max-width: 390px) {
  .topbar {
    margin-bottom: 34px;
  }

  .brand-emblem {
    height: 64px;
    width: 64px;
  }

  .brand-lockup h1 {
    font-size: 27px;
  }

  .mascot-watermark {
    top: 138px !important;
    width: 158vw !important;
  }
}

/* Hero layering correction: no hard overlays */
.ambient-visual-layer::before {
  background:
    radial-gradient(circle at 44% 18%, rgba(167, 238, 233, 0.105), transparent 20rem),
    radial-gradient(circle at 62% 42%, rgba(145, 201, 208, 0.07), transparent 28rem),
    radial-gradient(circle at 18% 2%, rgba(255, 255, 255, 0.035), transparent 18rem),
    radial-gradient(circle at 84% 82%, rgba(168, 234, 209, 0.045), transparent 24rem) !important;
  opacity: 0.82 !important;
}

.ambient-visual-layer::after,
.app-shell::before,
.status-panel::after {
  background:
    radial-gradient(circle at 50% 34%, rgba(167, 238, 233, 0.04), transparent 24rem),
    radial-gradient(circle at 50% 58%, rgba(255, 255, 255, 0.022), transparent 18rem) !important;
  opacity: 0.28 !important;
  animation: none !important;
}

.topbar {
  justify-content: flex-start !important;
  margin: 0 0 32px !important;
  text-align: left !important;
}

.brand-lockup {
  align-items: center !important;
  display: flex !important;
  gap: 15px !important;
  justify-items: initial !important;
}

.brand-lockup > div {
  align-items: flex-start !important;
  display: grid !important;
  gap: 7px !important;
  justify-items: start !important;
}

.brand-emblem {
  height: 68px !important;
  width: 68px !important;
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.05) inset,
    0 14px 34px rgba(0, 0, 0, 0.24),
    0 0 30px rgba(167, 238, 233, 0.16) !important;
}

.brand-lockup .eyebrow {
  color: rgba(141, 150, 151, 0.62) !important;
  letter-spacing: 0.24em !important;
}

.brand-lockup h1 {
  font-size: 30px !important;
  line-height: 1.02 !important;
}

.mascot-watermark {
  bottom: auto !important;
  filter: none !important;
  left: 50% !important;
  opacity: 0.205 !important;
  top: 18px !important;
  transform: translateX(-50%) rotate(-2deg) !important;
  width: min(156vw, 780px) !important;
}

.app-shell.is-active .mascot-watermark {
  opacity: 0.245 !important;
}

.status-panel {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.058), rgba(255, 255, 255, 0.018)),
    rgba(18, 20, 21, 0.405) !important;
  border-color: rgba(255, 255, 255, 0.082) !important;
  box-shadow:
    0 14px 42px rgba(0, 0, 0, 0.24),
    inset 0 1px 0 rgba(255, 255, 255, 0.068) !important;
  backdrop-filter: blur(20px) saturate(1.06) !important;
}

@media (max-width: 768px) {
  .topbar {
    margin: 0 0 30px !important;
  }

  .brand-lockup {
    gap: 13px !important;
  }

  .brand-emblem {
    height: 64px !important;
    width: 64px !important;
  }

  .brand-lockup h1 {
    font-size: 28px !important;
  }

  .mascot-watermark {
    opacity: 0.195 !important;
    top: 34px !important;
    width: 164vw !important;
  }

  .app-shell.is-active .mascot-watermark {
    opacity: 0.23 !important;
  }

  .status-panel {
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.054), rgba(255, 255, 255, 0.018)),
      rgba(18, 20, 21, 0.43) !important;
    backdrop-filter: blur(14px) saturate(1.03) !important;
  }
}

@media (max-width: 390px) {
  .brand-lockup {
    gap: 12px !important;
  }

  .brand-emblem {
    height: 60px !important;
    width: 60px !important;
  }

  .brand-lockup h1 {
    font-size: 26px !important;
  }

  .mascot-watermark {
    top: 42px !important;
    width: 170vw !important;
  }
}

/* Seamless glass cleanup */
.ambient-visual-layer::after,
.app-shell::before,
.status-panel::after {
  display: none !important;
  background: none !important;
  opacity: 0 !important;
}

.ambient-visual-layer::before {
  background:
    radial-gradient(circle at 50% 10%, rgba(167, 238, 233, 0.095), transparent 19rem),
    radial-gradient(circle at 52% 38%, rgba(145, 201, 208, 0.06), transparent 27rem),
    radial-gradient(circle at 18% 0%, rgba(255, 255, 255, 0.028), transparent 18rem),
    radial-gradient(circle at 88% 78%, rgba(168, 234, 209, 0.035), transparent 24rem) !important;
  opacity: 0.78 !important;
}

.mascot-watermark {
  top: -118px !important;
  opacity: 0.2 !important;
  width: min(174vw, 860px) !important;
}

.app-shell.is-active .mascot-watermark {
  opacity: 0.24 !important;
}

.status-panel {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.052), rgba(255, 255, 255, 0.016)),
    rgba(18, 20, 21, 0.32) !important;
  border-color: rgba(255, 255, 255, 0.07) !important;
  box-shadow:
    0 12px 34px rgba(0, 0, 0, 0.19),
    inset 0 1px 0 rgba(255, 255, 255, 0.058) !important;
  backdrop-filter: blur(18px) saturate(1.06) !important;
}

#getKeyBtn,
#renewKeyBtn:not(.hidden) {
  background:
    linear-gradient(135deg, rgba(223, 251, 247, 0.28), rgba(143, 211, 213, 0.18)) !important;
  border: 1px solid rgba(167, 238, 233, 0.34) !important;
  box-shadow:
    0 16px 38px rgba(0, 0, 0, 0.22),
    0 0 34px rgba(167, 238, 233, 0.12),
    inset 0 1px 0 rgba(255, 255, 255, 0.16) !important;
  color: rgba(239, 255, 253, 0.96) !important;
  text-shadow: 0 1px 16px rgba(167, 238, 233, 0.18);
  backdrop-filter: blur(16px) saturate(1.08);
}

.status-orbit.inactive span {
  animation: statusBreathInactive 3.4s ease-in-out infinite !important;
  box-shadow: 0 0 0 4px rgba(255, 107, 107, 0.035), 0 0 14px rgba(255, 107, 107, 0.18) !important;
}

@media (max-width: 768px) {
  .mascot-watermark {
    top: -76px !important;
    opacity: 0.19 !important;
    width: 178vw !important;
  }

  .app-shell.is-active .mascot-watermark {
    opacity: 0.225 !important;
  }

  .status-panel {
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.016)),
      rgba(18, 20, 21, 0.36) !important;
    backdrop-filter: blur(14px) saturate(1.03) !important;
  }

  #getKeyBtn,
  #renewKeyBtn:not(.hidden) {
    backdrop-filter: blur(10px) saturate(1.04);
  }
}

@media (max-width: 390px) {
  .mascot-watermark {
    top: -58px !important;
    width: 184vw !important;
  }
}

/* Glass transparency tuning for mascot visibility */
.status-panel {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.044), rgba(255, 255, 255, 0.012)),
    rgba(18, 20, 21, 0.245) !important;
  border-color: rgba(255, 255, 255, 0.062) !important;
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.16),
    inset 0 1px 0 rgba(255, 255, 255, 0.052) !important;
  backdrop-filter: blur(18px) saturate(1.04) !important;
}

.status-panel.is-active {
  background:
    linear-gradient(145deg, rgba(255, 255, 255, 0.05), rgba(255, 255, 255, 0.014)),
    rgba(18, 20, 21, 0.27) !important;
}

#getKeyBtn,
#renewKeyBtn:not(.hidden) {
  background:
    linear-gradient(135deg, rgba(167, 238, 233, 0.18), rgba(143, 211, 213, 0.105)),
    rgba(10, 22, 23, 0.24) !important;
  border: 1px solid rgba(167, 238, 233, 0.38) !important;
  box-shadow:
    0 12px 30px rgba(0, 0, 0, 0.18),
    0 0 28px rgba(167, 238, 233, 0.105),
    inset 0 1px 0 rgba(255, 255, 255, 0.18),
    inset 0 -18px 38px rgba(167, 238, 233, 0.035) !important;
  color: rgba(241, 255, 253, 0.98) !important;
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.24);
  backdrop-filter: blur(18px) saturate(1.08);
}

#getKeyBtn:not(.hidden) {
  animation: lockedCtaGlow 4.2s ease-in-out infinite;
}

#renewKeyBtn:not(.hidden) {
  animation: activeCtaGlow 4.2s ease-in-out infinite;
}

#getKeyBtn:not(:disabled):active,
#renewKeyBtn:not(.hidden):not(:disabled):active {
  background:
    linear-gradient(135deg, rgba(167, 238, 233, 0.24), rgba(143, 211, 213, 0.14)),
    rgba(10, 22, 23, 0.3) !important;
}

@keyframes lockedCtaGlow {
  0%, 100% {
    border-color: rgba(167, 238, 233, 0.32);
    box-shadow:
      0 12px 30px rgba(0, 0, 0, 0.18),
      0 0 24px rgba(167, 238, 233, 0.08),
      0 0 18px rgba(255, 107, 107, 0.035),
      inset 0 1px 0 rgba(255, 255, 255, 0.16),
      inset 0 -18px 38px rgba(167, 238, 233, 0.03);
  }
  50% {
    border-color: rgba(167, 238, 233, 0.46);
    box-shadow:
      0 12px 30px rgba(0, 0, 0, 0.18),
      0 0 34px rgba(167, 238, 233, 0.14),
      0 0 24px rgba(255, 107, 107, 0.055),
      inset 0 1px 0 rgba(255, 255, 255, 0.2),
      inset 0 -18px 38px rgba(167, 238, 233, 0.045);
  }
}

@keyframes activeCtaGlow {
  0%, 100% {
    border-color: rgba(168, 234, 209, 0.34);
    box-shadow:
      0 12px 30px rgba(0, 0, 0, 0.18),
      0 0 25px rgba(168, 234, 209, 0.09),
      inset 0 1px 0 rgba(255, 255, 255, 0.16),
      inset 0 -18px 38px rgba(168, 234, 209, 0.03);
  }
  50% {
    border-color: rgba(168, 234, 209, 0.5);
    box-shadow:
      0 12px 30px rgba(0, 0, 0, 0.18),
      0 0 36px rgba(168, 234, 209, 0.16),
      inset 0 1px 0 rgba(255, 255, 255, 0.2),
      inset 0 -18px 38px rgba(168, 234, 209, 0.05);
  }
}

@media (max-width: 768px) {
  .status-panel {
    background:
      linear-gradient(145deg, rgba(255, 255, 255, 0.042), rgba(255, 255, 255, 0.012)),
      rgba(18, 20, 21, 0.29) !important;
    backdrop-filter: blur(14px) saturate(1.03) !important;
  }

  #getKeyBtn,
  #renewKeyBtn:not(.hidden) {
    background:
      linear-gradient(135deg, rgba(167, 238, 233, 0.17), rgba(143, 211, 213, 0.1)),
      rgba(10, 22, 23, 0.28) !important;
    backdrop-filter: blur(12px) saturate(1.04);
  }
}

/* Dual mascot ghost-through-glass layer */
.mascot-watermark-back {
  z-index: 0 !important;
}

.mascot-watermark-front {
  filter: none;
  left: 50%;
  max-width: 860px;
  mix-blend-mode: screen;
  opacity: 0.085;
  pointer-events: none;
  position: fixed;
  top: -118px;
  transform: translateX(-50%) rotate(-2deg);
  width: min(174vw, 860px);
  z-index: 3;
  -webkit-mask-image: radial-gradient(ellipse at 50% 38%, #000 0 24%, rgba(0, 0, 0, 0.72) 34%, rgba(0, 0, 0, 0.22) 52%, transparent 72%);
  mask-image: radial-gradient(ellipse at 50% 38%, #000 0 24%, rgba(0, 0, 0, 0.72) 34%, rgba(0, 0, 0, 0.22) 52%, transparent 72%);
}

.app-shell.is-active .mascot-watermark-front {
  opacity: 0.105;
}

.topbar > *,
.status-panel > *,
.actions > *,
.access-actions > *,
.support-card > *,
.admin-panel > *,
.key-panel > * {
  position: relative;
  z-index: 4;
}

.status-panel,
.actions,
.support-card,
.admin-panel,
.key-panel {
  isolation: auto;
}

@media (max-width: 768px) {
  .mascot-watermark-front {
    opacity: 0.075;
    top: -76px;
    width: 178vw;
  }

  .app-shell.is-active .mascot-watermark-front {
    opacity: 0.095;
  }
}

@media (max-width: 390px) {
  .mascot-watermark-front {
    top: -58px;
    width: 184vw;
  }
}

/* Match status and primary CTA to action-card glass */
.status-panel,
.status-panel.is-active {
  background: rgba(255, 255, 255, 0.075) !important;
  border: 1px solid var(--line) !important;
  box-shadow:
    0 14px 40px rgba(0, 0, 0, 0.18),
    inset 0 1px 0 rgba(255, 255, 255, 0.055) !important;
  backdrop-filter: blur(18px) saturate(1.04) !important;
}

#getKeyBtn,
#renewKeyBtn:not(.hidden) {
  background: rgba(255, 255, 255, 0.075) !important;
  border: 1px solid rgba(167, 238, 233, 0.32) !important;
  box-shadow:
    0 12px 34px rgba(0, 0, 0, 0.16),
    0 0 24px rgba(167, 238, 233, 0.09),
    inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
  color: var(--text) !important;
  text-shadow: none !important;
  backdrop-filter: blur(18px) saturate(1.04);
}

#getKeyBtn:not(.hidden) {
  animation: glassLockedCtaGlow 4.8s ease-in-out infinite !important;
}

#renewKeyBtn:not(.hidden) {
  animation: glassActiveCtaGlow 4.8s ease-in-out infinite !important;
}

#getKeyBtn:not(:disabled):active,
#renewKeyBtn:not(.hidden):not(:disabled):active {
  background: rgba(255, 255, 255, 0.105) !important;
  border-color: rgba(167, 238, 233, 0.42) !important;
}

@keyframes glassLockedCtaGlow {
  0%, 100% {
    border-color: rgba(167, 238, 233, 0.28);
    box-shadow:
      0 12px 34px rgba(0, 0, 0, 0.16),
      0 0 18px rgba(167, 238, 233, 0.07),
      0 0 12px rgba(255, 107, 107, 0.025),
      inset 0 1px 0 rgba(255, 255, 255, 0.08);
  }
  50% {
    border-color: rgba(167, 238, 233, 0.42);
    box-shadow:
      0 12px 34px rgba(0, 0, 0, 0.16),
      0 0 28px rgba(167, 238, 233, 0.12),
      0 0 16px rgba(255, 107, 107, 0.04),
      inset 0 1px 0 rgba(255, 255, 255, 0.1);
  }
}

@keyframes glassActiveCtaGlow {
  0%, 100% {
    border-color: rgba(168, 234, 209, 0.3);
    box-shadow:
      0 12px 34px rgba(0, 0, 0, 0.16),
      0 0 18px rgba(168, 234, 209, 0.08),
      inset 0 1px 0 rgba(255, 255, 255, 0.08);
  }
  50% {
    border-color: rgba(168, 234, 209, 0.46);
    box-shadow:
      0 12px 34px rgba(0, 0, 0, 0.16),
      0 0 30px rgba(168, 234, 209, 0.14),
      inset 0 1px 0 rgba(255, 255, 255, 0.1);
  }
}

@media (max-width: 768px) {
  .status-panel,
  .status-panel.is-active {
    background: rgba(255, 255, 255, 0.075) !important;
    backdrop-filter: blur(14px) saturate(1.03) !important;
  }

  #getKeyBtn,
  #renewKeyBtn:not(.hidden) {
    background: rgba(255, 255, 255, 0.075) !important;
    backdrop-filter: blur(12px) saturate(1.03);
  }
}

/* Targeted glass blocks: status, primary CTA, support */
.status-panel,
.status-panel.is-active,
.support-card-main {
  background: rgba(255, 255, 255, 0.065) !important;
  border: 1px solid rgba(255, 255, 255, 0.105) !important;
  box-shadow:
    0 10px 28px rgba(0, 0, 0, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.055) !important;
  backdrop-filter: blur(16px) saturate(1.03) !important;
}

.support-card-main .support-contact-link {
  background: rgba(255, 255, 255, 0.058) !important;
  border-color: rgba(255, 255, 255, 0.105) !important;
}

#getKeyBtn,
#renewKeyBtn:not(.hidden) {
  background:
    linear-gradient(135deg, rgba(167, 238, 233, 0.092), rgba(255, 255, 255, 0.055)),
    rgba(255, 255, 255, 0.065) !important;
  border: 1px solid rgba(167, 238, 233, 0.46) !important;
  box-shadow:
    0 10px 30px rgba(0, 0, 0, 0.14),
    0 0 26px rgba(167, 238, 233, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.11),
    inset 0 -16px 34px rgba(167, 238, 233, 0.026) !important;
  color: rgba(245, 255, 253, 0.98) !important;
  text-shadow: 0 1px 14px rgba(0, 0, 0, 0.28), 0 0 18px rgba(167, 238, 233, 0.08) !important;
  backdrop-filter: blur(16px) saturate(1.04);
}

#getKeyBtn:not(.hidden) {
  animation: targetLockedCtaGlow 4.8s ease-in-out infinite !important;
}

#renewKeyBtn:not(.hidden) {
  animation: targetActiveCtaGlow 4.8s ease-in-out infinite !important;
}

#getKeyBtn:not(:disabled):active,
#renewKeyBtn:not(.hidden):not(:disabled):active {
  background:
    linear-gradient(135deg, rgba(167, 238, 233, 0.13), rgba(255, 255, 255, 0.07)),
    rgba(255, 255, 255, 0.085) !important;
}

@keyframes targetLockedCtaGlow {
  0%, 100% {
    border-color: rgba(167, 238, 233, 0.38);
    box-shadow:
      0 10px 30px rgba(0, 0, 0, 0.14),
      0 0 22px rgba(167, 238, 233, 0.085),
      0 0 14px rgba(255, 107, 107, 0.026),
      inset 0 1px 0 rgba(255, 255, 255, 0.1),
      inset 0 -16px 34px rgba(167, 238, 233, 0.022);
  }
  50% {
    border-color: rgba(167, 238, 233, 0.55);
    box-shadow:
      0 10px 30px rgba(0, 0, 0, 0.14),
      0 0 34px rgba(167, 238, 233, 0.15),
      0 0 20px rgba(255, 107, 107, 0.046),
      inset 0 1px 0 rgba(255, 255, 255, 0.14),
      inset 0 -16px 34px rgba(167, 238, 233, 0.035);
  }
}

@keyframes targetActiveCtaGlow {
  0%, 100% {
    border-color: rgba(168, 234, 209, 0.46);
    box-shadow:
      0 10px 30px rgba(0, 0, 0, 0.14),
      0 0 24px rgba(168, 234, 209, 0.1),
      inset 0 1px 0 rgba(255, 255, 255, 0.1),
      inset 0 -16px 34px rgba(168, 234, 209, 0.026);
  }
  50% {
    border-color: rgba(168, 234, 209, 0.65);
    box-shadow:
      0 10px 30px rgba(0, 0, 0, 0.14),
      0 0 38px rgba(168, 234, 209, 0.18),
      inset 0 1px 0 rgba(255, 255, 255, 0.14),
      inset 0 -16px 34px rgba(168, 234, 209, 0.04);
  }
}

@media (max-width: 768px) {
  .status-panel,
  .status-panel.is-active,
  .support-card-main {
    background: rgba(255, 255, 255, 0.07) !important;
    backdrop-filter: blur(12px) saturate(1.02) !important;
  }

  #getKeyBtn,
  #renewKeyBtn:not(.hidden) {
    background:
      linear-gradient(135deg, rgba(167, 238, 233, 0.09), rgba(255, 255, 255, 0.052)),
      rgba(255, 255, 255, 0.068) !important;
    backdrop-filter: blur(10px) saturate(1.02);
  }
}

/* CTA transparency and performance pass */
#getKeyBtn,
#renewKeyBtn:not(.hidden) {
  animation: none !important;
  background: rgba(255, 255, 255, 0.075) !important;
  border: 1px solid rgba(167, 238, 233, 0.42) !important;
  box-shadow:
    0 8px 22px rgba(0, 0, 0, 0.14),
    0 0 18px rgba(167, 238, 233, 0.08),
    inset 0 1px 0 rgba(255, 255, 255, 0.09) !important;
  color: var(--text) !important;
  text-shadow: 0 1px 12px rgba(0, 0, 0, 0.28) !important;
  backdrop-filter: none !important;
  transition: transform 220ms var(--motion-spring), border-color 180ms ease, box-shadow 180ms ease, background 180ms ease !important;
}

#renewKeyBtn:not(.hidden) {
  border-color: rgba(168, 234, 209, 0.48) !important;
  box-shadow:
    0 8px 22px rgba(0, 0, 0, 0.14),
    0 0 20px rgba(168, 234, 209, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.09) !important;
}

#getKeyBtn:not(:disabled):active,
#renewKeyBtn:not(.hidden):not(:disabled):active {
  background: rgba(255, 255, 255, 0.095) !important;
  border-color: rgba(167, 238, 233, 0.56) !important;
  box-shadow:
    0 6px 18px rgba(0, 0, 0, 0.12),
    0 0 16px rgba(167, 238, 233, 0.1),
    inset 0 1px 0 rgba(255, 255, 255, 0.1) !important;
}

.status-panel,
.status-panel.is-active,
.support-card-main {
  box-shadow:
    0 8px 22px rgba(0, 0, 0, 0.13),
    inset 0 1px 0 rgba(255, 255, 255, 0.045) !important;
  backdrop-filter: blur(10px) saturate(1.02) !important;
}

@media (max-width: 768px) {
  #getKeyBtn,
  #renewKeyBtn:not(.hidden) {
    box-shadow:
      0 6px 16px rgba(0, 0, 0, 0.12),
      0 0 12px rgba(167, 238, 233, 0.07),
      inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
  }

  #renewKeyBtn:not(.hidden) {
    box-shadow:
      0 6px 16px rgba(0, 0, 0, 0.12),
      0 0 14px rgba(168, 234, 209, 0.08),
      inset 0 1px 0 rgba(255, 255, 255, 0.08) !important;
  }

  .status-panel,
  .status-panel.is-active,
  .support-card-main {
    backdrop-filter: blur(8px) saturate(1.01) !important;
    box-shadow:
      0 6px 16px rgba(0, 0, 0, 0.12),
      inset 0 1px 0 rgba(255, 255, 255, 0.04) !important;
  }
}

/* Safe landing-only hotfix: scoped to #landingPage and .landing-* */
#landingPage.landing-page {
  align-items: center;
  background:
    linear-gradient(155deg, #050913 0%, #070d19 48%, #040811 100%),
    #050913;
  display: grid;
  min-height: 100vh;
  overflow: hidden;
  padding: 18px;
  place-items: center;
  position: relative;
}

#landingPage.landing-page::before {
  animation: landingSafeDrift 18s ease-in-out infinite alternate;
  background:
    radial-gradient(ellipse at 24% 16%, rgba(106, 148, 225, 0.18), transparent 40%),
    radial-gradient(ellipse at 78% 22%, rgba(84, 130, 213, 0.13), transparent 42%),
    radial-gradient(ellipse at 50% 86%, rgba(67, 108, 190, 0.14), transparent 44%);
  content: "";
  inset: -20%;
  pointer-events: none;
  position: absolute;
}

#landingPage .landing-grid,
#landingPage .landing-mascot {
  display: none !important;
}

#landingPage .landing-aurora {
  animation: landingSafeAurora 20s ease-in-out infinite alternate;
  background: linear-gradient(90deg, transparent, rgba(118, 170, 248, 0.22), rgba(184, 218, 255, 0.10), transparent);
  filter: blur(22px);
  height: 26vh;
  left: -10%;
  pointer-events: none;
  position: absolute;
  right: -10%;
}

#landingPage .landing-aurora-a {
  bottom: 14%;
}

#landingPage .landing-aurora-b {
  animation-duration: 26s;
  bottom: 6%;
  opacity: 0.66;
  transform: rotate(3deg);
}

#landingPage .landing-hero {
  background: transparent;
  border: 0;
  box-shadow: none;
  max-width: 420px;
  padding: 0;
  position: relative;
  text-align: center;
  width: min(100%, 420px);
  z-index: 2;
}

#landingPage .landing-hero h1 {
  color: #f4f8ff;
  font-size: 68px;
  font-weight: 300;
  letter-spacing: 0;
  line-height: 0.94;
  margin: 0 0 12px;
  text-shadow: 0 0 16px rgba(220, 236, 255, 0.16);
}

#landingPage .landing-subtitle {
  color: rgba(210, 223, 243, 0.88);
  font-size: 20px;
  font-weight: 400;
  line-height: 1.34;
  margin: 0 auto 24px;
}

#landingPage .landing-button {
  align-items: center;
  animation: landingSafeButtonGlow 6.2s ease-in-out infinite;
  background: linear-gradient(180deg, rgba(14, 24, 42, 0.78), rgba(8, 15, 28, 0.90));
  border: 1px solid rgba(129, 182, 255, 0.62);
  border-radius: 999px;
  box-shadow:
    0 0 0 1px rgba(117, 173, 250, 0.12),
    0 12px 28px rgba(0, 9, 24, 0.42),
    0 0 20px rgba(86, 144, 235, 0.20),
    inset 0 1px 0 rgba(236, 246, 255, 0.12);
  color: #edf5ff;
  display: inline-flex;
  font-size: 18px;
  font-weight: 500;
  gap: 10px;
  justify-content: center;
  min-height: 56px;
  overflow: hidden;
  padding: 0 24px;
  position: relative;
  text-decoration: none;
  width: min(100%, 328px);
}

#landingPage .landing-button::after {
  animation: landingSafeSweep 3.8s linear infinite;
  background: linear-gradient(90deg, transparent, rgba(203, 232, 255, 0.08), rgba(225, 242, 255, 0.46), rgba(203, 232, 255, 0.08), transparent);
  content: "";
  inset: 0;
  position: absolute;
  transform: translateX(-130%);
}

#landingPage .landing-button span {
  font-size: 25px;
  font-weight: 300;
  line-height: 1;
}

#landingPage,
#landingPage * {
  box-sizing: border-box;
}

#landingPage.landing-page,
#landingPage .landing-hero {
  max-width: 100%;
  overflow-x: hidden;
}

@keyframes landingSafeDrift {
  0% {
    transform: translate3d(-1%, -1%, 0) scale(1);
  }
  100% {
    transform: translate3d(1%, 1%, 0) scale(1.03);
  }
}

@keyframes landingSafeAurora {
  0% {
    transform: translate3d(-2%, 4px, 0) rotate(-5deg);
  }
  100% {
    transform: translate3d(2%, -6px, 0) rotate(-3deg);
  }
}

@keyframes landingSafeButtonGlow {
  0%, 100% {
    box-shadow:
      0 0 0 1px rgba(117, 173, 250, 0.12),
      0 12px 28px rgba(0, 9, 24, 0.42),
      0 0 20px rgba(86, 144, 235, 0.20),
      inset 0 1px 0 rgba(236, 246, 255, 0.12);
  }
  50% {
    box-shadow:
      0 0 0 1px rgba(136, 191, 255, 0.18),
      0 12px 28px rgba(0, 9, 24, 0.42),
      0 0 30px rgba(102, 160, 246, 0.28),
      inset 0 1px 0 rgba(236, 246, 255, 0.16);
  }
}

@keyframes landingSafeSweep {
  0%, 20% {
    transform: translateX(-130%);
  }
  60%, 100% {
    transform: translateX(130%);
  }
}

@media (max-width: 480px) {
  #landingPage.landing-page {
    padding: 16px;
  }

  #landingPage .landing-hero h1 {
    font-size: 56px;
  }

  #landingPage .landing-subtitle {
    font-size: 17px;
    margin-bottom: 20px;
  }

  #landingPage .landing-button {
    font-size: 17px;
    min-height: 54px;
    width: min(100%, 308px);
  }

  #landingPage .landing-button span {
    font-size: 23px;
  }
}

/* Delicate CTA accent without heavy fill */
#getKeyBtn,
#renewKeyBtn:not(.hidden) {
  border-color: rgba(167, 238, 233, 0.54) !important;
  box-shadow:
    0 8px 22px rgba(0, 0, 0, 0.13),
    0 0 22px rgba(167, 238, 233, 0.11),
    inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
}

#renewKeyBtn:not(.hidden) {
  border-color: rgba(168, 234, 209, 0.62) !important;
  box-shadow:
    0 8px 22px rgba(0, 0, 0, 0.13),
    0 0 24px rgba(168, 234, 209, 0.13),
    inset 0 1px 0 rgba(255, 255, 255, 0.14) !important;
}

#getKeyBtn::before,
#renewKeyBtn::before {
  background: linear-gradient(90deg, transparent, rgba(223, 251, 247, 0.42), transparent);
  content: "";
  height: 1px;
  left: 12px;
  opacity: 0.72;
  position: absolute;
  right: 12px;
  top: 1px;
}

#getKeyBtn:not(:disabled):active,
#renewKeyBtn:not(.hidden):not(:disabled):active {
  animation: ctaTapGlow 420ms ease-out !important;
}

@keyframes ctaTapGlow {
  0% {
    box-shadow:
      0 8px 22px rgba(0, 0, 0, 0.13),
      0 0 18px rgba(167, 238, 233, 0.1),
      inset 0 1px 0 rgba(255, 255, 255, 0.12);
  }
  45% {
    box-shadow:
      0 8px 22px rgba(0, 0, 0, 0.13),
      0 0 34px rgba(167, 238, 233, 0.18),
      inset 0 1px 0 rgba(255, 255, 255, 0.18);
  }
  100% {
    box-shadow:
      0 8px 22px rgba(0, 0, 0, 0.13),
      0 0 22px rgba(167, 238, 233, 0.11),
      inset 0 1px 0 rgba(255, 255, 255, 0.14);
  }
}

@media (max-width: 768px) {
  #getKeyBtn,
  #renewKeyBtn:not(.hidden) {
    box-shadow:
      0 6px 16px rgba(0, 0, 0, 0.12),
      0 0 14px rgba(167, 238, 233, 0.08),
      inset 0 1px 0 rgba(255, 255, 255, 0.12) !important;
  }
}
