/* =========================================================
   SubZuu PWA App Shell
   File: /pwa/subzuu-pwa.css
========================================================= */

html.pc-pwa-mode body {
  padding-top: calc(66px + env(safe-area-inset-top)) !important;
  padding-bottom: calc(92px + env(safe-area-inset-bottom)) !important;
}

/* =========================================================
   PWA HEADER
   Keep the real website header, but make it app-like.
========================================================= */

html.pc-pwa-mode #AppHeader {
  display: block !important;
  position: fixed !important;
  top: 0 !important;
  left: 0 !important;
  right: 0 !important;
  z-index: 999998 !important;

  background: rgba(10, 10, 10, 0.96) !important;
  border-bottom: 1px solid rgba(255, 255, 255, 0.10) !important;

  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;
}

html.pc-pwa-mode #AppHeader > div {
  max-width: none !important;
  padding-left: 12px !important;
  padding-right: 12px !important;
}

html.pc-pwa-mode #AppHeader .flex.h-16.items-center.justify-between {
  position: relative !important;
  height: calc(58px + env(safe-area-inset-top)) !important;
  padding-top: env(safe-area-inset-top) !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}

/* =========================================================
   SubZuu PWA Header Brand â€” Clean App Title
   Fixes bad selector issue by targeting exact spans.
========================================================= */

html.pc-pwa-mode #AppHeader .pc-header-brand {
  position: absolute !important;
  left: 50% !important;
  top: calc(50% + env(safe-area-inset-top) / 2) !important;
  transform: translate(-50%, -50%) !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 10px !important;

  width: auto !important;
  max-width: min(90vw, 420px) !important;
  min-width: 0 !important;

  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  text-decoration: none !important;
}

/* Hide old vertical accent bar */
html.pc-pwa-mode #AppHeader .pc-header-brand > span:first-child {
  display: none !important;
}

/* ONLY the logo wrapper â€” this is the important fix */
html.pc-pwa-mode #AppHeader .pc-header-brand > span:nth-of-type(2) {
  width: 44px !important;
  height: 44px !important;
  min-width: 44px !important;
  max-width: 44px !important;
  min-height: 44px !important;
  max-height: 44px !important;
  flex: 0 0 44px !important;

  box-sizing: border-box !important;
  padding: 4px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  border-radius: 13px !important;
  overflow: hidden !important;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.08),
      rgba(255,255,255,0.025)
    ),
    rgba(6,6,6,0.94) !important;

  box-shadow:
    0 0 0 1px rgba(255,255,255,0.14),
    0 10px 28px rgba(0,0,0,0.42),
    0 0 18px color-mix(in srgb, var(--pc-accent, #E50000) 20%, transparent) !important;
}

/* Logo image */
html.pc-pwa-mode #AppHeader .pc-header-brand > span:nth-of-type(2) img[data-brand-logo] {
  width: 100% !important;
  height: 100% !important;
  max-width: 100% !important;
  max-height: 100% !important;

  display: block !important;

  object-fit: contain !important;
  object-position: center !important;
}

/* Brand name â€” no bubble, no wrapper, no squeeze */
html.pc-pwa-mode #AppHeader .pc-header-brand [data-brand-name] {
  display: block !important;
  flex: 1 1 auto !important;
  min-width: 0 !important;
  max-width: min(68vw, 280px) !important;

  padding: 0 !important;
  margin: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;

  color: #ffffff !important;
  font-size: 19px !important;
  font-weight: 850 !important;
  line-height: 1.05 !important;
  letter-spacing: 0.02em !important;
  text-transform: none !important;

  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;

  text-align: left !important;
  text-shadow: 0 2px 16px rgba(0,0,0,0.55) !important;
}

/* Small accent mark beside the name */
html.pc-pwa-mode #AppHeader .pc-header-brand [data-brand-name]::after {
  content: "" !important;
  display: block !important;

  width: 100% !important;
  height: 2px !important;

  margin-top: 6px !important;

  border-radius: 999px !important;

  background:
    linear-gradient(
      90deg,
      transparent 0%,
      var(--pc-accent, #E50000) 15%,
      var(--pc-accent, #E50000) 85%,
      transparent 100%
    ) !important;

  opacity: 0.9 !important;

  box-shadow:
    0 0 8px color-mix(
      in srgb,
      var(--pc-accent, #E50000) 40%,
      transparent
    ) !important;
}

/* Remove any previous fake dot/swoop */
html.pc-pwa-mode #AppHeader .pc-header-brand::after {
  content: none !important;
  display: none !important;
}

/* Hide website nav/actions visually in the PWA header.
   The real actions are now available from the PWA footer. */
html.pc-pwa-mode #AppHeader nav.hidden.md\:flex,
html.pc-pwa-mode #AppHeader .hidden.md\:flex.items-center.gap-2,
html.pc-pwa-mode #AppHeader #menuBtn,
html.pc-pwa-mode #AppHeader #mobileNav,
html.pc-pwa-mode #AppHeader #pcMobileHeaderActions {
  display: none !important;
}

/* Do not force modals/drawers open */
html.pc-pwa-mode #pcInboxModal.hidden,
html.pc-pwa-mode #pcHeaderSearch.hidden,
html.pc-pwa-mode #pcHeaderLinks.hidden {
  display: none !important;
}


/* =========================================================
   HIDE ORIGINAL WEBSITE FOOTER IN PWA
========================================================= */

html.pc-pwa-mode body > footer,
html.pc-pwa-mode footer.bg-\[\#0F0F0F\],
html.pc-pwa-mode footer.text-gray-300 {
  display: none !important;
  visibility: hidden !important;
  height: 0 !important;
  min-height: 0 !important;
  max-height: 0 !important;
  overflow: hidden !important;
  pointer-events: none !important;
}

/* =========================================================
   PWA FOOTER / APP ACTION CAROUSEL
   Fixed consistent position across every PWA page
========================================================= */

.pc-pwa-bottom-nav {
  display: none;
}

html.pc-pwa-mode .pc-pwa-bottom-nav {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  top: auto !important;
  bottom: 0 !important;

  width: 100vw !important;
  height: calc(82px + env(safe-area-inset-bottom)) !important;
  min-height: calc(82px + env(safe-area-inset-bottom)) !important;
  max-height: calc(82px + env(safe-area-inset-bottom)) !important;

  z-index: 999999 !important;

  display: grid !important;
  grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
  align-items: center !important;
  justify-items: center !important;
  gap: 0 !important;

  overflow: hidden !important;

  box-sizing: border-box !important;

  padding-left: 6px !important;
  padding-right: 6px !important;
  padding-top: 8px !important;
  padding-bottom: calc(8px + env(safe-area-inset-bottom)) !important;

  background: rgba(10, 10, 10, 0.98) !important;
  border-top: 1px solid rgba(255, 255, 255, 0.12) !important;

  backdrop-filter: blur(16px) !important;
  -webkit-backdrop-filter: blur(16px) !important;

  transform: translateZ(0) !important;
}

html.pc-pwa-mode .pc-pwa-bottom-nav::-webkit-scrollbar {
  display: none !important;
}

html.pc-pwa-mode body {
  padding-bottom: calc(100px + env(safe-area-inset-bottom)) !important;
}

.pc-pwa-bottom-nav a,
.pc-pwa-bottom-nav button {
  appearance: none !important;
  -webkit-appearance: none !important;
  border: 0 !important;

  width: 100% !important;
  min-width: 0 !important;
  max-width: none !important;

  height: 64px !important;
  min-height: 64px !important;
  max-height: 64px !important;

  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;

  position: relative !important;

  color: #d1d5db !important;
  background: transparent !important;
  text-decoration: none !important;

  font-size: 10px !important;
  font-weight: 800 !important;
  line-height: 1.1 !important;
  text-align: center !important;

  padding: 7px 2px !important;
  border-radius: 18px !important;

  cursor: pointer !important;
  box-sizing: border-box !important;

  touch-action: manipulation !important;
  -webkit-tap-highlight-color: transparent !important;
  user-select: none !important;
  -webkit-user-select: none !important;
}

.pc-pwa-bottom-nav a *,
.pc-pwa-bottom-nav button * {
  pointer-events: none !important;
}

.pc-pwa-bottom-nav a:active,
.pc-pwa-bottom-nav button:active {
  transform: scale(0.96) !important;
}

.pc-pwa-bottom-nav a > span,
.pc-pwa-bottom-nav button > span {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  width: 26px !important;
  height: 26px !important;

  margin-bottom: 4px !important;
  text-align: center !important;
}

.pc-pwa-bottom-nav svg {
  width: 24px !important;
  height: 24px !important;

  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;

  display: block !important;
}

.pc-pwa-bottom-nav a.is-active,
.pc-pwa-bottom-nav button.is-active {
  color: var(--pc-accent, #ffffff) !important;
  background: rgba(255, 255, 255, 0.08) !important;
}

/* Avatar menu button */
.pc-pwa-bottom-nav .pc-pwa-avatar-icon {
  width: 34px !important;
  height: 34px !important;
  border-radius: 999px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  overflow: hidden !important;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.10),
      rgba(255,255,255,0.035)
    ),
    rgba(6,6,6,0.96) !important;

  box-shadow:
    0 0 0 1px rgba(255,255,255,.16),
    0 8px 24px rgba(0,0,0,.45),
    0 0 14px color-mix(in srgb, var(--pc-accent, #E50000) 20%, transparent) !important;

  margin-bottom: 0 !important;
}

.pc-pwa-bottom-nav .pc-pwa-avatar-icon svg {
  width: 22px !important;
  height: 22px !important;
}

.pc-pwa-bottom-nav .pc-pwa-avatar-icon img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}

.pc-pwa-bottom-nav [data-pwa-avatar-menu="1"] {
  padding-top: 0 !important;
  padding-bottom: 0 !important;
}

.pc-pwa-nav-badge {
  position: absolute !important;
  top: 5px !important;
  right: 18px !important;

  display: none !important;
  min-width: 17px !important;
  height: 17px !important;
  padding: 0 5px !important;

  border-radius: 999px !important;
  background: var(--pc-accent, #E50000) !important;
  color: #ffffff !important;

  font-size: 10px !important;
  font-weight: 900 !important;
  line-height: 17px !important;
  text-align: center !important;

  box-shadow: 0 0 0 2px rgba(0, 0, 0, 0.85) !important;
}

.pc-pwa-bottom-nav .has-badge {
  position: relative !important;
}

@media (max-width: 380px) {
html.pc-pwa-mode #AppHeader .pc-header-brand {
  max-width: min(92vw, 380px) !important;
  gap: 9px !important;
}

html.pc-pwa-mode #AppHeader .pc-header-brand > span:nth-of-type(2) {
  width: 40px !important;
  height: 40px !important;
  min-width: 40px !important;
  max-width: 40px !important;
  min-height: 40px !important;
  max-height: 40px !important;
  flex: 0 0 40px !important;
  padding: 4px !important;
  border-radius: 12px !important;
}

html.pc-pwa-mode #AppHeader .pc-header-brand [data-brand-name] {
  font-size: 16px !important;
  max-width: min(68vw, 250px) !important;
}
}

/* =========================================================
   PWA Simulated Splash Screen
   Premium creator app launch
   Must stay OUTSIDE the @media block.
========================================================= */

.pc-pwa-splash {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2147483647 !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  background:
    radial-gradient(
      circle at 50% 48%,
      color-mix(in srgb, var(--pc-accent, #E50000) 18%, transparent) 0%,
      color-mix(in srgb, var(--pc-accent, #E50000) 8%, transparent) 18%,
      transparent 42%
    ),
    linear-gradient(
      180deg,
      #030303 0%,
      #050505 42%,
      #020202 100%
    ) !important;

  opacity: 1 !important;
  visibility: visible !important;
  pointer-events: all !important;

  transition:
    opacity 900ms ease,
    visibility 900ms ease !important;
}

.pc-pwa-splash.is-hidden {
  opacity: 0 !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

.pc-pwa-splash-card {
  position: relative !important;

  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  justify-content: center !important;

  gap: 12px !important;
  transform: translateY(-12px) !important;
}

.pc-pwa-splash-card::before {
  content: "" !important;
  position: absolute !important;
  width: 210px !important;
  height: 210px !important;
  border-radius: 999px !important;

  background:
    radial-gradient(
      circle,
      color-mix(in srgb, var(--pc-accent, #E50000) 20%, transparent) 0%,
      transparent 66%
    ) !important;

  filter: blur(10px) !important;
  opacity: 0.85 !important;
  z-index: -1 !important;
}

.pc-pwa-splash-logo {
  width: 112px !important;
  height: 112px !important;

  box-sizing: border-box !important;
  padding: 10px !important;

  border-radius: 28px !important;

  object-fit: contain !important;
  object-position: center !important;

  background:
    linear-gradient(
      180deg,
      rgba(255,255,255,0.08),
      rgba(255,255,255,0.025)
    ),
    rgba(6,6,6,0.94) !important;

  border: 1px solid rgba(255,255,255,0.16) !important;

  animation: pcSplashFloat 2.4s ease-in-out infinite;

  box-shadow:
    0 0 0 1px rgba(255,255,255,0.06),
    0 22px 70px rgba(0,0,0,0.72),
    0 0 42px color-mix(in srgb, var(--pc-accent, #E50000) 26%, transparent) !important;
}

.pc-pwa-splash-name {
  max-width: 84vw !important;

  color: #ffffff !important;
  font-size: 24px !important;
  font-weight: 900 !important;
  line-height: 1.05 !important;
  letter-spacing: 0.01em !important;

  text-align: center !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;

  text-shadow:
    0 2px 18px rgba(0,0,0,0.72),
    0 0 24px color-mix(in srgb, var(--pc-accent, #E50000) 16%, transparent) !important;
}

.pc-pwa-splash-line {
  width: 58px !important;
  height: 3px !important;
  margin-top: 2px !important;

  border-radius: 999px !important;

  background:
    linear-gradient(
      90deg,
      transparent 0%,
      color-mix(in srgb, var(--pc-accent, #E50000) 70%, #ffffff) 18%,
      var(--pc-accent, #E50000) 50%,
      color-mix(in srgb, var(--pc-accent, #E50000) 70%, #ffffff) 82%,
      transparent 100%
    ) !important;

  opacity: 0.95 !important;

  box-shadow:
    0 0 12px color-mix(in srgb, var(--pc-accent, #E50000) 55%, transparent),
    0 0 28px color-mix(in srgb, var(--pc-accent, #E50000) 28%, transparent) !important;
}

@keyframes pcSplashFloat {
  0% {
    transform: translateY(0px) scale(1);
  }

  50% {
    transform: translateY(-5px) scale(1.025);
  }

  100% {
    transform: translateY(0px) scale(1);
  }
}

@media (max-width: 380px) {
  .pc-pwa-splash-logo {
    width: 104px !important;
    height: 104px !important;
    border-radius: 26px !important;
    padding: 10px !important;
  }

  .pc-pwa-splash-name {
    font-size: 22px !important;
    max-width: 86vw !important;
  }
}

/* =========================================================
   PWA Avatar Menu
   Opens from footer avatar button
========================================================= */

.pc-pwa-avatar-menu {
  position: fixed !important;
  inset: 0 !important;
  z-index: 999998 !important;
  display: block !important;
  pointer-events: auto !important;
}

.pc-pwa-avatar-menu.is-hidden {
  display: none !important;
  pointer-events: none !important;
}

.pc-pwa-avatar-menu-backdrop {
  position: absolute !important;
  inset: 0 !important;
  border: 0 !important;
  background: rgba(0,0,0,0.48) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
}

.pc-pwa-avatar-menu-panel {
  position: absolute !important;
  left: 10px !important;
  right: 10px !important;
  bottom: calc(92px + env(safe-area-inset-bottom)) !important;

  max-height: min(72dvh, 620px) !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;

  border-radius: 28px !important;
  padding: 14px !important;

  background:
    radial-gradient(
      circle at 80% 0%,
      color-mix(in srgb, var(--pc-accent, #E50000) 18%, transparent),
      transparent 38%
    ),
    rgba(9,9,9,0.96) !important;

  border: 1px solid rgba(255,255,255,0.12) !important;

  box-shadow:
    0 24px 80px rgba(0,0,0,0.72),
    0 0 0 1px rgba(255,255,255,0.04),
    0 0 42px color-mix(in srgb, var(--pc-accent, #E50000) 16%, transparent) !important;

  animation: pcPwaAvatarMenuUp 180ms ease-out both !important;
}

@keyframes pcPwaAvatarMenuUp {
  from {
    opacity: 0;
    transform: translateY(18px) scale(0.985);
  }

  to {
    opacity: 1;
    transform: translateY(0) scale(1);
  }
}

.pc-pwa-avatar-menu-profile {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;

  padding: 12px !important;
  border-radius: 22px !important;

  background: rgba(255,255,255,0.055) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
}

.pc-pwa-avatar-menu-avatar {
  width: 48px !important;
  height: 48px !important;
  border-radius: 999px !important;

  overflow: hidden !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  background: rgba(255,255,255,0.08) !important;

  box-shadow:
    0 0 0 1px rgba(255,255,255,0.14),
    0 10px 24px rgba(0,0,0,0.45) !important;

  flex: 0 0 auto !important;
}

.pc-pwa-avatar-menu-avatar img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  display: block !important;
}

.pc-pwa-avatar-menu-avatar svg {
  width: 25px !important;
  height: 25px !important;
  fill: none !important;
  stroke: #ffffff !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.pc-pwa-avatar-menu-profile-text {
  min-width: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
}

.pc-pwa-avatar-menu-profile-text strong {
  color: #ffffff !important;
  font-size: 15px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.pc-pwa-avatar-menu-profile-text span {
  color: rgba(255,255,255,0.58) !important;
  font-size: 12px !important;
  font-weight: 650 !important;
}

.pc-pwa-avatar-menu-actions {
  margin-top: 12px !important;
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 8px !important;
}

.pc-pwa-avatar-menu-row {
  width: 100% !important;
  appearance: none !important;
  -webkit-appearance: none !important;

  border: 0 !important;
  border-radius: 18px !important;

  display: flex !important;
  align-items: center !important;
  gap: 12px !important;

  padding: 12px !important;

  background: rgba(255,255,255,0.045) !important;
  color: #ffffff !important;

  text-align: left !important;
  cursor: pointer !important;

  box-shadow: inset 0 0 0 1px rgba(255,255,255,0.085) !important;
}

.pc-pwa-avatar-menu-row:active {
  transform: scale(0.99) !important;
}

.pc-pwa-menu-ico {
  width: 38px !important;
  height: 38px !important;
  border-radius: 14px !important;

  display: flex !important;
  align-items: center !important;
  justify-content: center !important;

  flex: 0 0 38px !important;

  background: rgba(255,255,255,0.07) !important;
  color: #ffffff !important;
}

.pc-pwa-menu-ico svg {
  width: 21px !important;
  height: 21px !important;
  fill: none !important;
  stroke: currentColor !important;
  stroke-width: 2 !important;
  stroke-linecap: round !important;
  stroke-linejoin: round !important;
}

.pc-pwa-avatar-menu-row strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
}

.pc-pwa-avatar-menu-row small {
  display: block !important;
  margin-top: 3px !important;
  color: rgba(255,255,255,0.55) !important;
  font-size: 11px !important;
  font-weight: 650 !important;
  line-height: 1.2 !important;
}

.pc-pwa-avatar-menu-auth {
  background:
    linear-gradient(
      180deg,
      color-mix(in srgb, var(--pc-accent, #E50000) 24%, rgba(255,255,255,0.045)),
      rgba(255,255,255,0.045)
    ) !important;
}

.pc-pwa-avatar-menu-verified {
  margin-top: 12px !important;
  padding: 12px !important;
  border-radius: 20px !important;

  display: grid !important;
  grid-template-columns: 42px minmax(0, 1fr) auto !important;
  align-items: center !important;
  gap: 10px !important;

  background: rgba(255,255,255,0.045) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
}

.pc-pwa-avatar-menu-verified img {
  width: 38px !important;
  height: 38px !important;
  border-radius: 999px !important;
  display: block !important;
}

.pc-pwa-avatar-menu-verified strong {
  display: block !important;
  color: #ffffff !important;
  font-size: 13px !important;
  font-weight: 900 !important;
  line-height: 1.1 !important;
}

.pc-pwa-avatar-menu-verified span {
  display: block !important;
  margin-top: 2px !important;
  color: rgba(255,255,255,0.58) !important;
  font-size: 11px !important;
  font-weight: 650 !important;
}

.pc-pwa-avatar-menu-verified em {
  color: rgba(255,255,255,0.48) !important;
  font-size: 10px !important;
  font-style: normal !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}

.pc-pwa-avatar-menu-section {
  margin-top: 12px !important;
  padding-top: 12px !important;
  border-top: 1px solid rgba(255,255,255,0.10) !important;
}

.pc-pwa-avatar-menu-heading {
  margin-bottom: 8px !important;
  color: rgba(255,255,255,0.48) !important;
  font-size: 11px !important;
  font-weight: 900 !important;
  text-transform: uppercase !important;
  letter-spacing: 0.14em !important;
}

.pc-pwa-avatar-menu-links,
.pc-pwa-avatar-menu-legal,
.pc-pwa-avatar-menu-socials {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
}

.pc-pwa-avatar-menu-links a,
.pc-pwa-avatar-menu-legal a,
.pc-pwa-avatar-menu-socials a {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  min-height: 36px !important;
  padding: 8px 11px !important;

  border-radius: 999px !important;

  color: rgba(255,255,255,0.88) !important;
  background: rgba(255,255,255,0.055) !important;
  border: 1px solid rgba(255,255,255,0.09) !important;

  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;
}

.pc-pwa-avatar-menu-copy {
  margin: 10px 0 0 0 !important;
  color: rgba(255,255,255,0.45) !important;
  font-size: 11px !important;
  font-weight: 650 !important;
}

html.pc-pwa-avatar-menu-open,
body.pc-pwa-avatar-menu-open {
  overflow: hidden !important;
}

@media (max-width: 380px) {
  .pc-pwa-avatar-menu-panel {
    left: 8px !important;
    right: 8px !important;
    padding: 12px !important;
    border-radius: 24px !important;
  }

  .pc-pwa-avatar-menu-verified {
    grid-template-columns: 38px minmax(0, 1fr) !important;
  }

  .pc-pwa-avatar-menu-verified em {
    display: none !important;
  }
}
/* PWA Avatar Menu: footer social icons + button links */
.pc-pwa-avatar-menu-socials--icons {
  gap: 10px !important;
}

.pc-pwa-avatar-menu-socials--icons a {
  width: 42px !important;
  height: 42px !important;
  min-width: 42px !important;
  padding: 0 !important;
  border-radius: 14px !important;
}

.pc-pwa-avatar-menu-socials--icons svg {
  width: 21px !important;
  height: 21px !important;
  fill: currentColor !important;
  display: block !important;
}

.pc-pwa-avatar-menu-links button {
  appearance: none !important;
  -webkit-appearance: none !important;

  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  min-height: 36px !important;
  padding: 8px 11px !important;

  border-radius: 999px !important;

  color: rgba(255,255,255,0.88) !important;
  background: rgba(255,255,255,0.055) !important;
  border: 1px solid rgba(255,255,255,0.09) !important;

  font-size: 12px !important;
  font-weight: 800 !important;
  line-height: 1 !important;
  text-decoration: none !important;

  cursor: pointer !important;
}

/* =========================================================
   PWA Balanced Shell Fix
   Keeps content and modals BETWEEN app header and footer.
========================================================= */

html.pc-pwa-mode body {
  padding-top: calc(72px + env(safe-area-inset-top)) !important;
  padding-bottom: calc(112px + env(safe-area-inset-bottom)) !important;
}

/* Enough breathing room for page bottoms, without creating huge Explore gaps */

/* Avatar menu must fit between header and footer */
html.pc-pwa-mode .pc-pwa-avatar-menu {
  z-index: 999997 !important;
}

html.pc-pwa-mode .pc-pwa-avatar-menu-panel {
  bottom: calc(92px + env(safe-area-inset-bottom)) !important;
  max-height: calc(100dvh - 178px - env(safe-area-inset-top) - env(safe-area-inset-bottom)) !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

/* Footer/help/learn modals should sit between header and footer */
html.pc-pwa-mode #pcFootLearn,
html.pc-pwa-mode #pcInboxModal,
html.pc-pwa-mode #pcHeaderSearch,
html.pc-pwa-mode #pcHeaderLinks {
  position: fixed !important;
  left: 0 !important;
  right: 0 !important;
  top: calc(58px + env(safe-area-inset-top)) !important;
  bottom: calc(82px + env(safe-area-inset-bottom)) !important;
  height: auto !important;
  z-index: 999997 !important;
}

/* Modal wrapper fills only the safe middle area */
html.pc-pwa-mode #pcFootLearn > div.absolute.inset-0,
html.pc-pwa-mode #pcInboxModal > div.absolute.inset-0,
html.pc-pwa-mode #pcHeaderSearch > div.absolute.inset-0,
html.pc-pwa-mode #pcHeaderLinks > div.absolute.inset-0 {
  inset: 0 !important;
  padding: 10px !important;
  box-sizing: border-box !important;
  align-items: center !important;
  justify-content: center !important;
}

/* Modal panels fit inside that middle area */
html.pc-pwa-mode #pcFootLearn .pc-panel,
html.pc-pwa-mode #pcInboxModal .pc-inbox-panel,
html.pc-pwa-mode #pcHeaderSearch [role="dialog"],
html.pc-pwa-mode #pcHeaderLinks .pc-panel {
  height: 100% !important;
  max-height: 100% !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Only modal body scrolls */
html.pc-pwa-mode #pcFootLearn .pc-panel .overflow-y-auto,
html.pc-pwa-mode #pcInboxModal #pcInboxMessageScroller,
html.pc-pwa-mode #pcHeaderSearch .overflow-y-auto,
html.pc-pwa-mode #pcHeaderLinks .overflow-y-auto {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

/* Keep modal headers/footers visible */
html.pc-pwa-mode #pcFootLearn .pc-panel > div:first-child,
html.pc-pwa-mode #pcFootLearn .pc-panel > div:last-child,
html.pc-pwa-mode #pcInboxModal .pc-inbox-panel > div:first-child {
  flex: 0 0 auto !important;
}

/* =========================================================
   Home + Subscribe bottom clearance only
   Lets final Help/CTA buttons scroll above the PWA footer.
   Does NOT affect Explore.
========================================================= */

html.pc-pwa-mode.pc-pwa-page-home main,
html.pc-pwa-mode.pc-pwa-page-home body > [data-auth-guard],
html.pc-pwa-mode.pc-pwa-page-subscribe main,
html.pc-pwa-mode.pc-pwa-page-subscribe body > [data-auth-guard] {
  padding-bottom: calc(96px + env(safe-area-inset-bottom)) !important;
}

html.pc-pwa-mode.pc-pwa-page-home main::after,
html.pc-pwa-mode.pc-pwa-page-subscribe main::after {
  content: "" !important;
  display: block !important;
  height: calc(72px + env(safe-area-inset-bottom)) !important;
}
/* =========================================================
   PWA FAQ bottom clearance
   Fixes Get Help CTA being hidden behind app footer.
   Only affects pages that actually have #faqs.
========================================================= */

html.pc-pwa-mode #faqs {
  margin-bottom: calc(120px + env(safe-area-inset-bottom)) !important;
  padding-bottom: calc(104px + env(safe-area-inset-bottom)) !important;
  scroll-margin-bottom: calc(140px + env(safe-area-inset-bottom)) !important;
}

/* =========================================================
   PWA Hide Scrollbars
   Keep scrolling enabled.
   Hide visual scrollbar chrome.
========================================================= */

html.pc-pwa-mode,
html.pc-pwa-mode body,
html.pc-pwa-mode main,
html.pc-pwa-mode .overflow-y-auto {
  scrollbar-width: none !important;      /* Firefox */
  -ms-overflow-style: none !important;   /* Old Edge */
}

html.pc-pwa-mode::-webkit-scrollbar,
html.pc-pwa-mode body::-webkit-scrollbar,
html.pc-pwa-mode main::-webkit-scrollbar,
html.pc-pwa-mode .overflow-y-auto::-webkit-scrollbar {
  width: 0 !important;
  height: 0 !important;
  display: none !important;
}

/* =========================================================
   PWA Inbox Mobile Portrait Layout
   App-style inbox for small screens only.
========================================================= */
@media (max-width: 640px) {
  html.pc-pwa-mode #pcInboxModal:not(.hidden) {
    position: fixed !important;
    inset: auto 0 auto 0 !important;
    top: calc(58px + env(safe-area-inset-top)) !important;
    bottom: calc(82px + env(safe-area-inset-bottom)) !important;
    height: auto !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) > div.absolute.inset-0 {
    inset: 0 !important;
    padding: 8px !important;
    align-items: stretch !important;
    justify-content: stretch !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-panel {
    width: 100% !important;
    height: 100% !important;
    max-height: 100% !important;
    border-radius: 20px !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }

  /* Header tighter */
  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-panel > div:nth-child(2) {
    padding: 10px 12px !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxSubtext {
    display: none !important;
  }

  /* Toolbar: keep filters and New Message on same line */
  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-panel > div:nth-child(3) {
    padding: 8px 10px !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-panel > div:nth-child(3) > div {
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 6px !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-filter {
    min-height: 32px !important;
    padding: 6px 9px !important;
    font-size: 11px !important;
    white-space: nowrap !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxComposeBtn {
    min-height: 32px !important;
    height: 32px !important;
    padding: 0 10px !important;
    border-radius: 999px !important;
    font-size: 11px !important;
    white-space: nowrap !important;
  }

  /* Main layout: messages get most of the screen */
  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-layout {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    height: 100% !important;
    display: grid !important;
    grid-template-rows: minmax(92px, 24%) minmax(0, 1fr) !important;
    overflow: hidden !important;
  }

  /* Conversation list becomes compact */
  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-thread-pane {
    min-height: 0 !important;
    overflow: hidden !important;
    border-right: 0 !important;
    border-bottom: 1px solid rgba(255,255,255,.10) !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-thread-pane > div:first-child {
    display: none !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxThreadList {
    height: 100% !important;
    max-height: 100% !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxThreadItems {
    padding: 8px !important;
  }

  /* Hide wasted selected-conversation header on mobile */
  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-message-pane > div:first-child {
    display: none !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-message-pane,
  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxMessagePane {
    min-height: 0 !important;
    overflow: hidden !important;
    display: flex !important;
    flex-direction: column !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxMessageScroller {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    padding: 12px !important;
    overflow-y: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxMessageItems {
    max-width: none !important;
    gap: 10px !important;
  }

  /* Reply section compact by default */
  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-reply-bar {
    flex: 0 0 auto !important;
    padding: 8px 10px !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-reply-bar label {
    display: none !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-reply-bar > div:last-child {
    flex-direction: row !important;
    align-items: center !important;
    gap: 8px !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxReplyBox {
    min-height: 42px !important;
    height: 42px !important;
    max-height: 96px !important;
    font-size: 16px !important;
    border-radius: 14px !important;
    padding: 10px 12px !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxReplyBox:focus {
    height: 86px !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxSendBtn {
    height: 42px !important;
    min-height: 42px !important;
    padding: 0 14px !important;
    border-radius: 14px !important;
    flex: 0 0 auto !important;
  }
}