/* Royal theme + orbital catalog — AI App Store marketing */

/* Accent colors come from styles.css (#7C3AED → #22D3EE) — no gold override */

:root {
  /* Display accents — same stack as global headings (Space Grotesk) */
  --font-royal: var(--font-display);
  --color-royal: #1A0F2E;
  --color-royal-mid: #2A1848;
  --shadow-royal: 0 24px 80px rgba(0, 0, 0, 0.55), 0 0 0 1px rgba(124, 58, 237, 0.12);
}

[data-theme="light"] {
  --color-royal: #F5F0E8;
  --color-royal-mid: #FFFFFF;
  --shadow-royal: 0 24px 60px rgba(26, 15, 46, 0.12), 0 0 0 1px rgba(124, 58, 237, 0.2);
}

body {
  background-color: var(--color-bg-base);
}

/* ── Royal header ── */
.site-nav--royal {
  padding-block: 0;
  border-bottom: 1px solid rgba(124, 58, 237, 0.25);
}

.site-nav--royal::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(34, 211, 238, 0.06), transparent);
  pointer-events: none;
}

.nav-ornament {
  height: 3px;
  background: linear-gradient(90deg, transparent 5%, var(--color-accent-start) 25%, var(--color-accent-end) 50%, var(--color-accent-start) 75%, transparent 95%);
  opacity: 0.85;
}

.nav-inner--royal {
  padding-block: 1rem;
  position: relative;
}

.logo--royal {
  flex-direction: row;
  align-items: center;
  gap: 0.85rem;
}

/* Legacy circular crest — not used when .brand-mark image is present */
.logo__crest:not(.brand-mark) {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, var(--color-accent-start), var(--color-accent-end));
  box-shadow: 0 0 24px rgba(124, 58, 237, 0.45), 0 0 12px rgba(34, 211, 238, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.25);
  color: #fff;
  animation: crest-pulse 4s ease-in-out infinite;
}

.logo__crest:not(.brand-mark) svg {
  width: 22px;
  height: 22px;
}

.logo__text {
  display: flex;
  flex-direction: column;
}

.logo__wordmark--royal {
  font-family: var(--font-display);
  font-size: 1.125rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
  background: none;
  -webkit-text-fill-color: currentColor;
}

.logo__tagline--royal {
  font-family: var(--font-body);
  font-size: 0.625rem;
  font-weight: 500;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--color-accent-end);
}

.desktop-nav--royal a {
  font-family: var(--font-body);
  font-size: 0.8125rem;
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-muted);
  white-space: nowrap;
  position: relative;
}

.desktop-nav--royal a:hover,
.desktop-nav--royal a:focus-visible,
.desktop-nav--royal a.is-active {
  color: var(--color-text-primary);
}

.desktop-nav--royal a::after {
  content: '';
  position: absolute;
  left: 0;
  bottom: -4px;
  width: 100%;
  height: 1px;
  background: var(--gradient-accent);
  transform: scaleX(0);
  transform-origin: center;
  transition: transform var(--dur-base) var(--ease-out);
}

.desktop-nav--royal a:hover::after,
.desktop-nav--royal a.is-active::after {
  transform: scaleX(1);
}

.site-nav.scrolled {
  background: rgba(10, 8, 18, 0.82);
  backdrop-filter: blur(20px);
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.4);
}

/* ── Hero royal FX (mobile-first) ── */
.hero--royal {
  min-height: auto;
  display: flex;
  align-items: flex-start;
}

/* Wins over immersive #hero.section-panel { padding-block: 0 } */
#hero.hero--royal.section-panel {
  padding-block-start: clamp(5.5rem, 16vw, 8.5rem);
  padding-block-end: clamp(2.5rem, 8vw, 5rem);
}

.hero__lines {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.35;
}

.hero__lines path {
  fill: none;
  stroke: url(#accentGradient);
  stroke-width: 1;
  stroke-dasharray: 8 12;
  animation: line-flow 24s linear infinite;
}

.hero__lines path:nth-child(2) { animation-duration: 18s; animation-direction: reverse; opacity: 0.6; }
.hero__lines path:nth-child(3) { animation-duration: 30s; opacity: 0.4; }

.light-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(40px);
  pointer-events: none;
  animation: orb-drift 12s ease-in-out infinite;
}

.light-orb--1 {
  width: 280px;
  height: 280px;
  top: 8%;
  left: 12%;
  background: radial-gradient(circle, rgba(124, 58, 237, 0.35), transparent 70%);
}

.light-orb--2 {
  width: 200px;
  height: 200px;
  top: 40%;
  right: 8%;
  background: radial-gradient(circle, rgba(124, 58, 237, 0.25), transparent 70%);
  animation-delay: -4s;
}

.light-orb--3 {
  width: 160px;
  height: 160px;
  bottom: 12%;
  left: 35%;
  background: radial-gradient(circle, rgba(34, 211, 238, 0.2), transparent 70%);
  animation-delay: -7s;
}

.hero__title-royal {
  font-family: var(--font-royal);
  font-weight: 700;
  letter-spacing: -0.02em;
  line-height: 1.05;
}

.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.75rem;
  letter-spacing: 0.28em;
  text-transform: uppercase;
  color: var(--color-accent-end);
  margin-bottom: 1.25rem;
  padding: 0.35rem 1rem;
  border: 1px solid rgba(124, 58, 237, 0.35);
  border-radius: var(--radius-pill);
  background: rgba(124, 58, 237, 0.06);
}

.hero__visual--royal {
  display: block;
  min-height: clamp(240px, 55vw, 420px);
  width: 100%;
}

.orbit-preview {
  position: relative;
  width: 100%;
  max-width: 520px;
  margin-inline: auto;
  aspect-ratio: 1;
}

.hero-orbit-cards {
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.float-card--royal {
  width: 200px;
  padding: 1rem;
  border-color: rgba(124, 58, 237, 0.35);
  animation: float 5s ease-in-out infinite;
}

.float-card--royal .float-card__badge {
  background: rgba(124, 58, 237, 0.12);
  color: var(--color-accent-end);
  border-color: rgba(124, 58, 237, 0.3);
}

.orbit-preview__ring {
  position: absolute;
  inset: 8%;
  border: 1px dashed rgba(124, 58, 237, 0.25);
  border-radius: 50%;
  animation: ring-spin 48s linear infinite;
}

.orbit-preview__ring--inner {
  inset: 22%;
  animation-direction: reverse;
  animation-duration: 32s;
}

.orbit-preview__core {
  position: absolute;
  inset: 34%;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(124, 58, 237, 0.12), rgba(26, 15, 46, 0.85));
  border: 1px solid rgba(124, 58, 237, 0.35);
  display: grid;
  place-items: center;
  box-shadow: var(--shadow-glow);
  padding: 0.35rem;
}

/* ── KW Organizer modules grid (replaces orbital marketplace catalog) ── */
.apps--organizer {
  position: relative;
  padding-block: 3rem 5rem;
}

.organizer-modules__grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr);
  gap: 1.25rem;
}

.organizer-modules__empty {
  text-align: center;
  color: var(--color-text-muted);
  padding: 2rem 1rem;
}

.app-card--organizer {
  position: relative;
}

.app-card--organizer.is-hidden {
  display: none;
}

.app-card--organizer .app-card__badge {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-size: 0.65rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  padding: 0.2rem 0.5rem;
  border-radius: var(--radius-pill);
  background: rgba(124, 58, 237, 0.12);
  color: var(--color-accent-end);
  border: 1px solid rgba(124, 58, 237, 0.28);
}

.app-card--organizer .app-card__note {
  font-size: 0.78rem;
  color: var(--color-text-subtle);
  line-height: 1.4;
}

@media (min-width: 520px) {
  .organizer-modules__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (min-width: 900px) {
  .organizer-modules__grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 1.5rem;
  }
}

/* Legacy orbital styles (unused on homepage; kept for reference) */
.apps--royal {
  position: relative;
  padding-block: 5rem 8rem;
  overflow: hidden;
}

.apps__fx {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

#orb-canvas {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.5;
}

.apps__section-head {
  text-align: center;
  margin-bottom: 3rem;
  position: relative;
  z-index: 2;
}

.apps__section-head h2 {
  font-family: var(--font-royal);
  font-size: clamp(2.2rem, 5vw, 3.5rem);
  margin-bottom: 0.75rem;
}

.apps__section-head p {
  margin-inline: auto;
  max-width: 42ch;
  color: var(--color-accent-end);
  opacity: 0.85;
}

/* Mobile-first: horizontal snap rail; desktop orbit below 901px */
.app-orbit {
  position: relative;
  z-index: 2;
  min-height: auto;
  margin-top: 1.5rem;
  display: flex;
  gap: 1.25rem;
  overflow-x: auto;
  overscroll-behavior-x: contain;
  scroll-snap-type: x mandatory;
  padding: 1rem max(0px, env(safe-area-inset-right, 0px)) 2rem
    max(0px, env(safe-area-inset-left, 0px));
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}

.app-orbit__loading,
.app-orbit__empty {
  text-align: center;
  padding: 4rem 2rem;
  color: var(--color-text-muted);
  font-family: var(--font-royal);
  font-size: 1.25rem;
}

.app-orbit__loading::after {
  content: '';
  display: block;
  width: 48px;
  height: 48px;
  margin: 1.5rem auto 0;
  border: 2px solid rgba(124, 58, 237, 0.2);
  border-top-color: var(--color-accent-end);
  border-radius: 50%;
  animation: spin 0.9s linear infinite;
}

.app-card--orbit {
  position: relative;
  left: auto;
  top: auto;
  flex: 0 0 min(85vw, 320px);
  scroll-snap-align: center;
  width: min(300px, 88vw);
  padding: 0;
  border: none;
  background: transparent;
  transform-style: preserve-3d;
  transition:
    opacity var(--dur-base) var(--ease-out),
    transform var(--dur-slow) var(--ease-out),
    filter var(--dur-base) var(--ease-out);
  animation: none;
}

.app-card--orbit.is-hidden {
  opacity: 0;
  pointer-events: none;
  transform: scale(0.85) !important;
  filter: blur(4px);
}

.app-card--orbit .app-card__inner {
  position: relative;
  padding: 1.75rem;
  border-radius: 24px;
  background: linear-gradient(145deg, rgba(42, 24, 72, 0.92) 0%, rgba(18, 12, 28, 0.96) 100%);
  border: 1px solid rgba(124, 58, 237, 0.28);
  box-shadow: var(--shadow-royal);
  overflow: hidden;
  transform: rotateX(var(--tilt-x, 0deg)) rotateY(var(--tilt-y, 0deg));
  transition: box-shadow var(--dur-base) var(--ease-out), border-color var(--dur-base) var(--ease-out);
}

.app-card--orbit .app-card__inner::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(135deg, rgba(124, 58, 237, 0.12) 0%, transparent 45%);
  pointer-events: none;
}

.app-card--orbit .app-card__inner::after {
  content: '';
  position: absolute;
  top: -50%;
  left: -50%;
  width: 200%;
  height: 200%;
  background: conic-gradient(from 0deg, transparent, rgba(124, 58, 237, 0.15), transparent 30%);
  animation: shimmer 8s linear infinite;
  pointer-events: none;
  opacity: 0;
  transition: opacity var(--dur-base);
}

.app-card--orbit:hover .app-card__inner::after {
  opacity: 1;
}

.app-card--orbit:hover .app-card__inner {
  border-color: rgba(124, 58, 237, 0.55);
  box-shadow: var(--shadow-royal), var(--shadow-glow);
}

.app-card--orbit .app-card__icon {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  background: var(--gradient-accent);
  box-shadow: 0 8px 24px rgba(124, 58, 237, 0.25);
}

.app-card--orbit .app-card__tier {
  position: absolute;
  top: 1rem;
  right: 1rem;
  font-size: 0.65rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-accent-end);
  border: 1px solid rgba(124, 58, 237, 0.35);
  padding: 0.2rem 0.5rem;
  border-radius: var(--radius-pill);
}

.app-card--orbit .app-card__name {
  font-family: var(--font-royal);
  font-size: 1.35rem;
  margin-top: 0.5rem;
}

.app-card--orbit .app-card__highlights {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem;
  margin-top: 0.5rem;
}

.app-card--orbit .app-card__highlight {
  font-size: 0.65rem;
  padding: 0.2rem 0.45rem;
  border-radius: 6px;
  background: rgba(124, 58, 237, 0.1);
  color: var(--color-accent-end);
  border: 1px solid rgba(124, 58, 237, 0.15);
}

.category-pills--royal .pill--active {
  background: linear-gradient(135deg, var(--color-accent-start), var(--color-accent-end));
  color: #1A0F2E;
  font-weight: 600;
}

/* Visibility + layout: responsive.css (768px+) */

.hero__inner--royal {
  text-align: center;
}

.hero__text--royal {
  text-align: center;
}

.hero__ctas--royal {
  justify-content: center;
}

.hero__trust--royal {
  justify-content: center;
}

@media (min-width: 901px) {
  .hero--royal {
    min-height: 92vh;
    align-items: center;
  }

  #hero.hero--royal.section-panel {
    padding-block-start: 8.5rem;
    padding-block-end: 5rem;
  }

  .hero__inner--royal {
    grid-template-columns: 1fr 1fr;
    text-align: left;
  }

  .hero__text--royal {
    text-align: left;
  }

  .hero__ctas--royal {
    justify-content: flex-start;
  }

  .hero__trust--royal {
    justify-content: flex-start;
  }

  .hero__visual--royal {
    min-height: 420px;
  }

  .app-orbit {
    display: block;
    overflow: visible;
    min-height: 720px;
    padding: 0;
    margin-top: 2rem;
  }

  .app-card--orbit {
    position: absolute;
    flex: none;
    scroll-snap-align: unset;
    animation: card-float var(--float-dur, 7s) ease-in-out infinite;
    animation-delay: var(--float-delay, 0s);
  }
}

@keyframes crest-pulse {
  0%, 100% {
    box-shadow: 0 0 24px rgba(124, 58, 237, 0.45), 0 0 12px rgba(34, 211, 238, 0.25), inset 0 1px 0 rgba(255, 255, 255, 0.25);
  }
  50% {
    box-shadow: 0 0 36px rgba(124, 58, 237, 0.55), 0 0 20px rgba(34, 211, 238, 0.4), inset 0 1px 0 rgba(255, 255, 255, 0.35);
  }
}

@keyframes orb-drift {
  0%, 100% { transform: translate(0, 0) scale(1); }
  33% { transform: translate(24px, -18px) scale(1.08); }
  66% { transform: translate(-16px, 12px) scale(0.95); }
}

@keyframes line-flow {
  to { stroke-dashoffset: -200; }
}

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

@keyframes card-float {
  0%, 100% { translate: 0 0; }
  50% { translate: 0 -14px; }
}

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

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

@media (prefers-reduced-motion: reduce) {
  .light-orb,
  .hero__lines path,
  .orbit-preview__ring,
  .app-card--orbit,
  .logo__crest:not(.brand-mark),
  .app-card--orbit .app-card__inner::after,
  .why__orb,
  .why-node__marker {
    animation: none !important;
  }
}

/* ── Why stream (blue accent, no cards) ── */
.why--stream {
  position: relative;
  padding-block: 5rem 6rem;
  background: transparent;
  overflow: hidden;
}

.why--stream .why__container {
  position: relative;
  z-index: 2;
}

.why--stream h2 {
  font-family: var(--font-royal);
  margin-bottom: 3.5rem;
}

.why__fx {
  position: absolute;
  top: 0;
  bottom: 0;
  pointer-events: none;
  z-index: 0;
}

.why__orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(48px);
  animation: orb-drift 14s ease-in-out infinite;
}

.why__orb--1 {
  width: 220px;
  height: 220px;
  top: 15%;
  left: 10%;
  background: radial-gradient(circle, rgba(124, 58, 237, 0.35), transparent 70%);
}

.why__orb--2 {
  width: 180px;
  height: 180px;
  bottom: 10%;
  right: 8%;
  background: radial-gradient(circle, rgba(34, 211, 238, 0.28), transparent 70%);
  animation-delay: -5s;
}

.why-stream {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 3rem;
  max-width: 920px;
  margin-inline: auto;
  padding: 0;
}

.why-node {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 1.5rem 2rem;
  position: relative;
}

.why-node--left .why-node__body {
  grid-column: 1;
  grid-row: 1;
  text-align: right;
}

.why-node--left .why-node__marker {
  grid-column: 2;
  grid-row: 1;
}

.why-node--right .why-node__body {
  grid-column: 3;
  grid-row: 1;
  text-align: left;
}

.why-node--right .why-node__marker {
  grid-column: 2;
  grid-row: 1;
}

.why-node__marker {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: #fff;
  background: linear-gradient(135deg, #7C3AED, #22D3EE);
  box-shadow:
    0 0 0 4px rgba(124, 58, 237, 0.15),
    0 0 32px rgba(34, 211, 238, 0.35);
  animation: why-marker-pulse 3s ease-in-out infinite;
  z-index: 2;
}

.why-node:nth-child(2) .why-node__marker { animation-delay: -0.5s; }
.why-node:nth-child(3) .why-node__marker { animation-delay: -1s; }
.why-node:nth-child(4) .why-node__marker { animation-delay: -1.5s; }
.why-node:nth-child(5) .why-node__marker { animation-delay: -2s; }
.why-node:nth-child(6) .why-node__marker { animation-delay: -2.5s; }

.why-node__marker svg {
  width: 24px;
  height: 24px;
}

.why-node__body {
  padding: 0.25rem 0;
  max-width: 340px;
}

.why-node--left .why-node__body {
  margin-left: auto;
}

.why-node--right .why-node__body {
  margin-right: auto;
}

.why-node__body h3 {
  font-family: var(--font-display);
  font-size: 1.2rem;
  margin-bottom: 0.4rem;
  color: var(--color-text-primary);
}

.why-node__body p {
  font-size: 0.92rem;
  margin-bottom: 0.5rem;
  color: var(--color-text-muted);
  max-width: none;
}

.why-node__body a {
  font-size: 0.875rem;
  font-weight: 500;
  color: #22D3EE;
}

.why-node__body a:hover {
  color: #7C3AED;
}

@keyframes why-spine-flow {
  to { stroke-dashoffset: -32; }
}

@keyframes why-marker-pulse {
  0%, 100% {
    box-shadow:
      0 0 0 4px rgba(124, 58, 237, 0.15),
      0 0 32px rgba(34, 211, 238, 0.35);
  }
  50% {
    box-shadow:
      0 0 0 8px rgba(124, 58, 237, 0.22),
      0 0 48px rgba(34, 211, 238, 0.55);
  }
}

/* Why stream: mobile-first single column */
.why-node {
  grid-template-columns: auto 1fr;
  gap: 1.25rem;
}

.why-node--left .why-node__body,
.why-node--right .why-node__body {
  grid-column: 2;
  grid-row: 1;
  text-align: left;
  margin: 0;
  max-width: none;
}

.why-node--left .why-node__marker,
.why-node--right .why-node__marker {
  grid-column: 1;
  grid-row: 1;
}

@media (min-width: 721px) {
  .why-node {
    grid-template-columns: 1fr auto 1fr;
    gap: 1.5rem 2rem;
  }

  .why-node--left .why-node__body {
    grid-column: 1;
    grid-row: 1;
    text-align: right;
    margin-left: auto;
    max-width: 340px;
  }

  .why-node--left .why-node__marker {
    grid-column: 2;
    grid-row: 1;
  }

  .why-node--right .why-node__body {
    grid-column: 3;
    grid-row: 1;
    text-align: left;
    margin-right: auto;
    max-width: 340px;
  }

  .why-node--right .why-node__marker {
    grid-column: 2;
    grid-row: 1;
  }
}
