/* =========================================================
   playcre8te PWA App Shell
   File: /pwa/playcre8te-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;
}

/* =========================================================
   playcre8te 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;
}

/* =========================================================
   PWA Search Modal Fit Fix
   Keeps avatar-menu Search results between app header/footer.
   Fixes large result sets overflowing behind the footer.
========================================================= */

html.pc-pwa-mode #pcHeaderSearch:not(.hidden) {
  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;
  overflow: hidden !important;
}

html.pc-pwa-mode #pcHeaderSearch:not(.hidden) > div.absolute.inset-0 {
  position: absolute !important;
  inset: 0 !important;
  padding: 8px !important;
  box-sizing: border-box !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: center !important;
  overflow: hidden !important;
}

html.pc-pwa-mode #pcHeaderSearch:not(.hidden) .pc-panel {
  width: 100% !important;
  max-width: 64rem !important;
  height: 100% !important;
  max-height: 100% !important;
  min-height: 0 !important;
  overflow: hidden !important;

  display: flex !important;
  flex-direction: column !important;
}

html.pc-pwa-mode #pcHeaderSearch:not(.hidden) .pc-panel > div:first-child,
html.pc-pwa-mode #pcHeaderSearch:not(.hidden) .pc-panel > div:last-child {
  flex: 0 0 auto !important;
}

html.pc-pwa-mode #pcHeaderSearch:not(.hidden) .pc-panel > div.overflow-y-auto {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

html.pc-pwa-mode #pcHeaderSearch:not(.hidden) #pcHeaderSearchGrid {
  padding-bottom: 16px !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 MyHub bottom clearance
   Adds space after the page content, not inside cards.
========================================================= */

html.pc-pwa-mode.pc-pwa-page-myhub main {
  padding-bottom: calc(120px + env(safe-area-inset-bottom)) !important;
}

html.pc-pwa-mode.pc-pwa-page-myhub #purchases,
html.pc-pwa-mode.pc-pwa-page-myhub #creator {
  scroll-margin-bottom: calc(140px + env(safe-area-inset-bottom)) !important;
}

/* =========================================================
   PWA Signup bottom clearance
   Keeps bottom of signup card above app footer.
========================================================= */

html.pc-pwa-mode.pc-pwa-page-signup main {
  padding-bottom: calc(130px + env(safe-area-inset-bottom)) !important;
}

html.pc-pwa-mode.pc-pwa-page-signup #fan-signup-form {
  scroll-margin-bottom: calc(150px + 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 Polish
   Smaller toolbar + compact reply/send row.
========================================================= */
@media (max-width: 640px) {
  /* Toolbar row: filters + New Message stay on one line */
  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-panel > div:nth-child(3) {
    padding: 7px 8px !important;
  }

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

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-panel > div:nth-child(3) > div > div:first-child {
    display: flex !important;
    flex-wrap: nowrap !important;
    gap: 5px !important;
    min-width: 0 !important;
    flex: 1 1 auto !important;
    overflow-x: auto !important;
    scrollbar-width: none !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-panel > div:nth-child(3) > div > div:first-child::-webkit-scrollbar {
    display: none !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-inbox-filter {
    height: 30px !important;
    min-height: 30px !important;
    padding: 0 8px !important;
    font-size: 10.5px !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
    flex: 0 0 auto !important;
  }

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

  /* Reply area: make it smaller so Send button is visible */
  html.pc-pwa-mode #pcInboxModal:not(.hidden) .pc-reply-bar {
    padding: 6px 8px !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 {
    display: flex !important;
    flex-direction: row !important;
    flex-wrap: nowrap !important;
    align-items: center !important;
    gap: 6px !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxReplyBox {
    height: 36px !important;
    min-height: 36px !important;
    max-height: 72px !important;
    padding: 8px 10px !important;
    border-radius: 13px !important;
    font-size: 16px !important;
    line-height: 1.15 !important;
  }

  html.pc-pwa-mode #pcInboxModal:not(.hidden) #pcInboxSendBtn {
    height: 36px !important;
    min-height: 36px !important;
    padding: 0 10px !important;
    border-radius: 13px !important;
    font-size: 12px !important;
    flex: 0 0 auto !important;
    white-space: nowrap !important;
  }
}

/* =========================================================
   PWA Access UI Modal Fit
   Keeps Access / Purchases / Rentals / Medialist modals
   between the PWA app header and app footer.
========================================================= */
html.pc-pwa-mode #pcAccessDrawer:not(.hidden),
html.pc-pwa-mode #pcMedialistMore:not(.hidden),
html.pc-pwa-mode #pcPurchasesMore:not(.hidden),
html.pc-pwa-mode #pcRentalsMore:not(.hidden) {
  position: fixed !important;
  top: calc(58px + env(safe-area-inset-top)) !important;
  bottom: calc(82px + env(safe-area-inset-bottom)) !important;
  left: 0 !important;
  right: 0 !important;
  height: auto !important;
  z-index: 9998 !important;
}

/* Make modal wrapper fill only the available app space */
html.pc-pwa-mode #pcAccessDrawer:not(.hidden) > div.absolute.inset-x-0,
html.pc-pwa-mode #pcMedialistMore:not(.hidden) > div.absolute.inset-0,
html.pc-pwa-mode #pcPurchasesMore:not(.hidden) > div.absolute.inset-0,
html.pc-pwa-mode #pcRentalsMore:not(.hidden) > div.absolute.inset-0 {
  position: absolute !important;
  inset: 0 !important;
  padding: 8px !important;
  display: flex !important;
  align-items: stretch !important;
  justify-content: center !important;
}

/* Access drawer panel */
html.pc-pwa-mode #pcAccessDrawer:not(.hidden) > div.absolute.inset-x-0 > div {
  width: 100% !important;
  max-width: 42rem !important;
  max-height: 100% !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Purchases / Rentals / Medialist panel */
html.pc-pwa-mode #pcMedialistMore:not(.hidden) .pc-panel,
html.pc-pwa-mode #pcPurchasesMore:not(.hidden) .pc-panel,
html.pc-pwa-mode #pcRentalsMore:not(.hidden) .pc-panel {
  width: 100% !important;
  max-height: 100% !important;
  overflow: hidden !important;
  display: flex !important;
  flex-direction: column !important;
}

/* Only the inner content area should scroll */
html.pc-pwa-mode #pcMedialistMore:not(.hidden) .pc-panel > div.overflow-y-auto,
html.pc-pwa-mode #pcPurchasesMore:not(.hidden) .pc-panel > div.overflow-y-auto,
html.pc-pwa-mode #pcRentalsMore:not(.hidden) .pc-panel > div.overflow-y-auto {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  max-height: none !important;
  overflow-y: auto !important;
  -webkit-overflow-scrolling: touch !important;
}

/* Keep modal headers/footers visible */
html.pc-pwa-mode #pcMedialistMore:not(.hidden) .pc-panel > div:first-child,
html.pc-pwa-mode #pcPurchasesMore:not(.hidden) .pc-panel > div:first-child,
html.pc-pwa-mode #pcRentalsMore:not(.hidden) .pc-panel > div:first-child,
html.pc-pwa-mode #pcMedialistMore:not(.hidden) .pc-panel > div:last-child,
html.pc-pwa-mode #pcPurchasesMore:not(.hidden) .pc-panel > div:last-child,
html.pc-pwa-mode #pcRentalsMore:not(.hidden) .pc-panel > div:last-child {
  flex: 0 0 auto !important;
}

/* Mobile tightening */
@media (max-width: 640px) {
  html.pc-pwa-mode #pcAccessDrawer:not(.hidden),
  html.pc-pwa-mode #pcMedialistMore:not(.hidden),
  html.pc-pwa-mode #pcPurchasesMore:not(.hidden),
  html.pc-pwa-mode #pcRentalsMore:not(.hidden) {
    top: calc(58px + env(safe-area-inset-top)) !important;
    bottom: calc(82px + env(safe-area-inset-bottom)) !important;
  }

  html.pc-pwa-mode #pcAccessDrawer:not(.hidden) > div.absolute.inset-x-0,
  html.pc-pwa-mode #pcMedialistMore:not(.hidden) > div.absolute.inset-0,
  html.pc-pwa-mode #pcPurchasesMore:not(.hidden) > div.absolute.inset-0,
  html.pc-pwa-mode #pcRentalsMore:not(.hidden) > div.absolute.inset-0 {
    padding: 6px !important;
  }

  html.pc-pwa-mode #pcAccessDrawer:not(.hidden) .grid {
    grid-template-columns: 1fr 1fr !important;
  }

  html.pc-pwa-mode #pcAccessDrawer:not(.hidden) .grid > :first-child {
    grid-column: 1 / -1 !important;
  }
}

/* =========================================================
   PWA Inbox Footer Badge Desktop/Tablet Position Fix
   Keeps unread count attached to the Inbox icon instead of
   drifting to the far right of the wide footer button.
========================================================= */

@media (min-width: 641px) {
  html.pc-pwa-mode .pc-pwa-bottom-nav .has-badge .pc-pwa-nav-badge {
    right: auto !important;
    left: calc(50% + 10px) !important;
    top: 6px !important;
    transform: none !important;
  }
}

/* =========================================================
   PWA Hide Floating Pills
   Hide only the floating Access + Inbox pills inside the app.
   Do NOT hide:
   - PWA footer Inbox icon
   - Home inline Access UI
   - Live pill
========================================================= */

/* Floating Inbox pill from pc-inbox-pill.js */
html.pc-pwa-mode #pcInboxChip {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* Floating Access pill only.
   This targets the pill/launcher, not the Home inline access UI. */
html.pc-pwa-mode #pcAccessPill,
html.pc-pwa-mode #pcAccessChip,
html.pc-pwa-mode [data-pc-access-pill],
html.pc-pwa-mode [data-access-pill],
html.pc-pwa-mode .pc-access-pill,
html.pc-pwa-mode .pc-access-chip {
  display: none !important;
  visibility: hidden !important;
  pointer-events: none !important;
}

/* =========================================================
   PWA Explore: Hero / Sections Breathing Room
   Fixes app-only compressed spacing around hero + first section.
   Website pages untouched.
========================================================= */

html.pc-pwa-mode #HeroCarousel {
  margin-bottom: 24px !important;
}

html.pc-pwa-mode #pcNotificationSection.hidden + section,
html.pc-pwa-mode #pcNotificationSection.hidden + [data-pc-section] {
  margin-top: 24px !important;
}

@media (max-width: 640px) {
  html.pc-pwa-mode #HeroCarousel {
    margin-bottom: 28px !important;
  }

  html.pc-pwa-mode #pcNotificationSection.hidden + section,
  html.pc-pwa-mode #pcNotificationSection.hidden + [data-pc-section] {
    margin-top: 28px !important;
  }
}
