/* ==========================================================================
   LANDING.CSS
   1. Fonts and root
   2. Base
   3. Layout shell
   4. Shared frame blocks
   5. Text color accents
   6. Hero
   7. Feature tags
   8. Sections
   9. Newsletter signal
   10. Highlight panel
   11. Mission cards
   12. Universe panels
   13. Footer
   14. Responsive
   ========================================================================== */


/* ===============================
   1. Fonts and root
   =============================== */

:root {
  --va-bg-main: #05050a;
  --va-bg-deep: rgba(10, 10, 18, 0.96);
  --va-bg-panel: rgba(12, 12, 20, 0.88);
  --va-bg-panel-strong: rgba(12, 12, 20, 0.94);
  --va-text: #f4f1ff;
  --va-text-soft: rgba(244, 241, 255, 0.88);
  --va-text-dim: rgba(244, 241, 255, 0.70);
  --va-frame-light: #fdf7df;
  --va-frame-soft: rgba(253, 247, 223, 0.78);
  --va-ivory-warm: #fff5dc;
  --va-frame-outer: rgba(108, 248, 255, 0.72);
  --va-frame-glow: rgba(108, 248, 255, 0.32);
  --va-violet: #b000ff;
  --va-violet-soft: #ddb8ff;
  --va-pink: #ff62d4;
  --va-pink-soft: #ffd6f4;
  --va-yellow: #efe29b;
  --va-yellow-soft: #f5edc4;
  --va-cyan: #6cf8ff;
  --va-cyan-soft: #d2fbff;
  --va-green: #8bff7e;
  --va-green-soft: #e0ffd6;
  --va-border-soft: rgba(255, 255, 255, 0.16);
  --va-radius-lg: 16px;
  --va-radius-md: 10px;
  --va-radius-sm: 6px;
  --va-max: 1320px;
}


/* ===============================
   2. Base
   =============================== */

* {
  box-sizing: border-box;
}

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  min-height: 100vh;
  color: var(--va-text);
  background:
    radial-gradient(circle at top left, rgba(111, 95, 160, 0.28), transparent 34%),
    radial-gradient(circle at top right, rgba(255, 102, 204, 0.22), transparent 28%),
    linear-gradient(180deg, #05050a 0%, #090914 55%, #05050a 100%);
  font-family: 'Noto Sans', Arial, sans-serif;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  background: url("../../assets/background-and-foreground/stars-video-bg.png") center top / cover no-repeat;
  opacity: 0.12;
  pointer-events: none;
}

body::after {
  content: "";
  position: fixed;
  inset: 0;
  background:
    linear-gradient(rgba(5, 5, 10, 0.14), rgba(5, 5, 10, 0.22)),
    url("../../assets/background-and-foreground/texture-for-blue-neon.png") center / cover repeat;
  mix-blend-mode: soft-light;
  opacity: 0.18;
  pointer-events: none;
}

img {
  display: block;
  max-width: 100%;
}


/* ===============================
   3. Layout shell
   =============================== */

.va-landing {
  position: relative;
  z-index: 1;
  width: min(calc(100% - 26px), var(--va-max));
  margin: 0 auto;
  padding: 26px 0 46px;
}

.va-page-frame {
  position: relative;
  padding: 18px;
  border: 2px solid var(--va-frame-outer);
  border-radius: 20px;
  background: rgba(4, 4, 10, 0.44);
  box-shadow:
    0 0 16px rgba(108, 248, 255, 0.24),
    0 0 28px rgba(108, 248, 255, 0.16),
    inset 0 0 14px rgba(108, 248, 255, 0.08);
}

.va-grid {
  display: grid;
  gap: 36px;
}

.va-grid--three {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}

.va-grid--two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.va-card-row--centered {
  width: 100%;
  display: flex;
  justify-content: center;
  margin-top: 40px;
}


/* ===============================
   4. Shared frame blocks
   =============================== */

.va-hero,
.va-section,
.va-footer {
  position: relative;
  overflow: hidden;
  background: var(--va-bg-panel);
  border: 3px solid rgba(253, 247, 223, 0.84);
  border-radius: var(--va-radius-lg);
  box-shadow:
    0 0 16px rgba(253, 247, 223, 0.24),
    0 0 28px rgba(253, 247, 223, 0.16),
    0 18px 42px rgba(0, 0, 0, 0.44);
}

.va-section {
  margin-top: 30px;
  padding: 34px 30px 32px;
}

.va-section__head {
  margin-bottom: 44px;
  text-align: center;
}

.va-section__kicker {
  margin: 0;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 0.9rem;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--va-frame-light);
  text-shadow: 0 0 6px rgba(253, 247, 223, 0.28), 0 0 14px rgba(253, 247, 223, 0.14);
  text-decoration: underline;
  text-decoration-thickness: 2px;
  text-underline-offset: 0.28em;
}

.va-section__title {
  margin: 16px 0 0;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: clamp(1.75rem, 1.2rem + 1.2vw, 2.55rem);
  line-height: 1.18;
  color: var(--va-frame-light);
  text-shadow:
    0 0 12px rgba(253, 247, 223, 0.42),
    0 0 24px rgba(253, 247, 223, 0.22),
    0 0 36px rgba(253, 247, 223, 0.10);
}

.va-section__subline {
  margin: 18px 0 0;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 0.98rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--va-cyan-soft);
  text-shadow: 0 0 8px rgba(108, 248, 255, 0.38), 0 0 18px rgba(108, 248, 255, 0.20);
}

.va-section__intro {
  width: min(100%, 1020px);
  margin: 24px auto 0;
}

.va-section__intro p {
  margin: 0;
  font-size: 1.12rem;
  line-height: 1.9;
  color: var(--va-text-soft);
}

.va-section__intro p + p {
  margin-top: 14px;
}

.va-inline-separator,
.va-feature-panel__separator,
.va-mission-separator {
  height: 2px;
  margin: 28px auto 30px;
  background: linear-gradient(90deg, transparent 0%, rgba(253, 247, 223, 0.14) 12%, rgba(253, 247, 223, 0.78) 50%, rgba(253, 247, 223, 0.14) 88%, transparent 100%);
}


/* ===============================
   5. Text color accents
   =============================== */

.t-vox {
  font-style: italic;
  color: var(--va-yellow);
  text-shadow: 0 0 10px rgba(239, 226, 155, 0.44), 0 0 20px rgba(239, 226, 155, 0.24), 0 0 30px rgba(239, 226, 155, 0.12);
}

.t-dark {
  font-style: italic;
  color: var(--va-violet);
  text-shadow: 0 0 12px rgba(176, 0, 255, 0.72), 0 0 26px rgba(176, 0, 255, 0.38), 0 0 40px rgba(176, 0, 255, 0.18);
}

.t-strange {
  font-style: italic;
  color: var(--va-pink);
  text-shadow: 0 0 8px rgba(255, 102, 204, 0.34), 0 0 18px rgba(255, 102, 204, 0.14);
}

.t-lore {
  font-style: italic;
  color: var(--va-violet-soft);
  text-shadow: 0 0 8px rgba(187, 174, 255, 0.34), 0 0 18px rgba(187, 174, 255, 0.18), 0 0 28px rgba(187, 174, 255, 0.10);
}

.t-dark-strong {
  font-style: italic;
  color: var(--va-violet);
  text-shadow: 0 0 12px rgba(176, 0, 255, 0.72), 0 0 26px rgba(176, 0, 255, 0.38), 0 0 40px rgba(176, 0, 255, 0.18);
}

.t-strange-strong {
  font-style: italic;
  color: #ff5fcf;
  text-shadow: 0 0 10px rgba(255, 95, 207, 0.44), 0 0 22px rgba(255, 95, 207, 0.24), 0 0 32px rgba(255, 95, 207, 0.12);
}

.t-ship {
  font-style: italic;
  color: #63f6ff;
  text-shadow: 0 0 12px rgba(99, 246, 255, 0.64), 0 0 28px rgba(99, 246, 255, 0.34), 0 0 42px rgba(99, 246, 255, 0.18);
}

.t-sculpt {
  font-style: italic;
  color: #ffe98f;
  text-shadow: 0 0 8px rgba(255, 233, 143, 0.28), 0 0 16px rgba(255, 233, 143, 0.12);
}

.t-mini {
  font-style: italic;
  color: var(--va-green);
  text-shadow: 0 0 10px rgba(139, 255, 126, 0.36), 0 0 20px rgba(139, 255, 126, 0.20), 0 0 30px rgba(139, 255, 126, 0.10);
}


.t-pale {
  font-style: italic;
  color: #f3edc8;
  text-shadow: 0 0 8px rgba(243, 237, 200, 0.28), 0 0 16px rgba(243, 237, 200, 0.12);
}

.t-reward {
  font-style: italic;
  color: #ffd23c;
  text-shadow: 0 0 14px rgba(255, 210, 60, 0.76), 0 0 30px rgba(255, 210, 60, 0.42), 0 0 46px rgba(255, 210, 60, 0.22);
}

.t-chapter {
  font-family: 'Orbitron', Arial, sans-serif;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: #ffd23c;
  text-shadow: 0 0 14px rgba(255, 210, 60, 0.76), 0 0 30px rgba(255, 210, 60, 0.42), 0 0 46px rgba(255, 210, 60, 0.22);
}

.t-violet-strong {
  font-style: italic;
  color: #c9a8ff;
  text-shadow: 0 0 14px rgba(201, 168, 255, 0.74), 0 0 30px rgba(201, 168, 255, 0.40), 0 0 46px rgba(201, 168, 255, 0.20);
}


/* ===============================
   6. Hero
   =============================== */

.va-hero {
  padding: 34px 32px 32px;
  text-align: center;
  background:
    linear-gradient(rgba(12, 12, 20, 0.95), rgba(10, 10, 18, 0.95)),
    url("../../assets/background-and-foreground/texture-for-blue-neon.png") center / cover repeat;
}

.va-hero__spot {
  position: absolute;
  top: -120px;
  width: 320px;
  height: 320px;
  border-radius: 50%;
  filter: blur(64px);
  pointer-events: none;
}

.va-hero__spot--violet {
  left: -86px;
  background: rgba(111, 95, 160, 0.34);
}

.va-hero__spot--pink {
  right: -86px;
  background: rgba(255, 102, 204, 0.28);
}

.va-hero__logoWrap {
  position: relative;
  z-index: 1;
  width: min(100%, 540px);
  margin: 0 auto 24px;
}

.va-hero__logo {
  width: 100%;
  filter:
    drop-shadow(0 0 12px rgba(253, 247, 223, 0.20))
    drop-shadow(0 0 22px rgba(207, 196, 255, 0.20));
}

.va-hero__kicker {
  margin: 0;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 1.12rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--va-cyan-soft);
  text-shadow: 0 0 8px rgba(108, 248, 255, 0.44), 0 0 18px rgba(108, 248, 255, 0.22), 0 0 28px rgba(108, 248, 255, 0.10);
}


.va-hero__title {
  margin: 40px 0 0;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: clamp(2.3rem, 1.85rem + 1.45vw, 3.45rem);
  line-height: 1.08;
  text-transform: uppercase;
  color: var(--va-frame-light);
  text-shadow:
    0 0 14px rgba(253, 247, 223, 0.48),
    0 0 28px rgba(253, 247, 223, 0.24),
    0 0 42px rgba(253, 247, 223, 0.12);
}


.va-hero__subtitle {
  width: min(100%, 780px);
  margin: 0 auto;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: clamp(1.12rem, 0.98rem + 0.42vw, 1.38rem);
  line-height: 1.6;
  letter-spacing: 0.05em;
  color: var(--va-cyan);
  text-shadow:
    0 0 10px rgba(108, 248, 255, 0.62),
    0 0 22px rgba(108, 248, 255, 0.34),
    0 0 36px rgba(108, 248, 255, 0.16);
}

.va-hero__subtitle-emphasis {
  color: var(--va-pink);
  text-shadow:
    0 0 10px rgba(255, 102, 204, 0.42),
    0 0 20px rgba(255, 102, 204, 0.18),
    0 0 32px rgba(255, 102, 204, 0.14);
}


.va-hero__copy {
  width: min(100%, 1040px);
  margin: 34px auto 0;
}

.va-hero__copy p {
  margin: 0;
  font-size: clamp(1.08rem, 0.98rem + 0.30vw, 1.2rem);
  line-height: 1.9;
  color: var(--va-text-soft);
}

.va-hero__copy--focus {
  font-size: clamp(1.18rem, 1.05rem + 0.38vw, 1.34rem) !important;
}

.va-copy-separator {
  width: min(100%, 420px);
  height: 2px;
  margin: 18px auto;
  background: linear-gradient(90deg, transparent 0%, rgba(243, 237, 200, 0.16) 12%, rgba(243, 237, 200, 0.76) 50%, rgba(243, 237, 200, 0.16) 88%, transparent 100%);
}

.va-hero__copy p + p {
  margin-top: 16px;
}

.va-hero__statement {
  width: min(100%, 980px);
  margin: 0 auto;
  font-size: 1.26rem;
  line-height: 1.75;
  color: var(--va-frame-light);
  text-shadow: 0 0 10px rgba(253, 247, 223, 0.28), 0 0 22px rgba(253, 247, 223, 0.14);
}


.va-hero__copy--tail {
  margin-top: 0;
}


/* ===============================
   7. Feature tags
   =============================== */

.va-feature-panel {
  width: min(100%, 1060px);
  margin: 40px auto 0;
  padding: 24px 24px 28px;
  background: rgba(12, 12, 20, 0.76);
  border: 2px solid rgba(253, 247, 223, 0.78);
  border-radius: 12px;
  box-shadow: inset 0 0 14px rgba(253, 247, 223, 0.14), 0 0 16px rgba(253, 247, 223, 0.20);
}

.va-feature-panel__lead {
  display: flex;
  justify-content: center;
}

.va-feature-panel__lead--stacked {
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

.va-feature-panel__plus {
  display: inline-block;
  color: var(--va-frame-light);
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 2.2rem;
  font-weight: 700;
  line-height: 1;
  text-shadow: 0 0 10px rgba(253, 247, 223, 0.46), 0 0 22px rgba(253, 247, 223, 0.22);
}

.va-feature-panel__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 22px;
}

.va-tag {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 60px;
  padding: 12px 16px;
  background: rgba(12, 12, 20, 0.80);
  border: 2px solid rgba(253, 247, 223, 0.74);
  border-radius: var(--va-radius-sm);
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 0.95rem;
  letter-spacing: 0.06em;
  text-align: center;
  text-transform: uppercase;
  box-shadow: 0 0 14px rgba(253, 247, 223, 0.18), inset 0 0 12px rgba(253, 247, 223, 0.10);
}

.va-tag--gold,
.va-tag--yellow {
  color: var(--va-yellow);
  background: linear-gradient(180deg, rgba(239, 226, 155, 0.40), rgba(120, 94, 18, 0.20));
  border-color: rgba(239, 226, 155, 0.90);
  box-shadow: 0 0 16px rgba(239, 226, 155, 0.30), inset 0 0 14px rgba(239, 226, 155, 0.14);
  text-shadow: 0 0 10px rgba(239, 226, 155, 0.44), 0 0 20px rgba(239, 226, 155, 0.20);
}

.va-tag--cyan {
  color: var(--va-cyan);
  background: linear-gradient(180deg, rgba(108, 248, 255, 0.36), rgba(8, 84, 96, 0.18));
  border-color: rgba(108, 248, 255, 0.90);
  box-shadow: 0 0 16px rgba(108, 248, 255, 0.28), inset 0 0 14px rgba(108, 248, 255, 0.12);
  text-shadow: 0 0 10px rgba(108, 248, 255, 0.42), 0 0 20px rgba(108, 248, 255, 0.18);
}

.va-tag--violet {
  color: var(--va-violet-soft);
  background: linear-gradient(180deg, rgba(187, 174, 255, 0.36), rgba(76, 48, 128, 0.18));
  border-color: rgba(187, 174, 255, 0.90);
  box-shadow: 0 0 16px rgba(187, 174, 255, 0.28), inset 0 0 14px rgba(187, 174, 255, 0.12);
  text-shadow: 0 0 10px rgba(187, 174, 255, 0.42), 0 0 20px rgba(187, 174, 255, 0.18);
}

.va-tag--green {
  color: var(--va-green);
  background: linear-gradient(180deg, rgba(139, 255, 126, 0.34), rgba(34, 92, 28, 0.16));
  border-color: rgba(139, 255, 126, 0.88);
  box-shadow: 0 0 16px rgba(139, 255, 126, 0.26), inset 0 0 14px rgba(139, 255, 126, 0.10);
  text-shadow: 0 0 10px rgba(139, 255, 126, 0.40), 0 0 20px rgba(139, 255, 126, 0.16);
}

.va-tag--pink {
  color: var(--va-pink);
  background: linear-gradient(180deg, rgba(255, 102, 204, 0.38), rgba(108, 18, 82, 0.18));
  border-color: rgba(255, 102, 204, 0.92);
  box-shadow: 0 0 16px rgba(255, 102, 204, 0.28), inset 0 0 14px rgba(255, 102, 204, 0.12);
  text-shadow: 0 0 10px rgba(255, 102, 204, 0.42), 0 0 20px rgba(255, 102, 204, 0.18);
}

.va-tag--gold {
  min-height: 68px;
  min-width: min(100%, 420px);
  font-size: 1.02rem;
}


/* ===============================
   8. Sections
   =============================== */

.va-section--mission,
.va-section--universes {
  background:
    linear-gradient(rgba(12, 12, 20, 0.94), rgba(10, 10, 18, 0.94)),
    url("../../assets/background-and-foreground/texture-for-blue-neon.png") center / cover repeat;
}



/* ===============================
   9. Newsletter signal
   =============================== */

.va-section--newsletter {
  background:
    linear-gradient(rgba(12, 12, 20, 0.94), rgba(10, 10, 18, 0.94)),
    url("../../assets/background-and-foreground/texture-for-blue-neon.png") center / cover repeat;
}

.va-section--newsletter .va-section__head {
  margin-bottom: 30px;
}

.va-newsletter-panel {
  width: min(100%, 900px);
  margin: 0 auto;
  padding: 26px 24px 24px;
  background: rgba(10, 10, 18, 0.72);
  border: 2px solid rgba(108, 248, 255, 0.84);
  border-radius: 12px;
  box-shadow: 0 0 28px rgba(108, 248, 255, 0.28), 0 0 48px rgba(108, 248, 255, 0.12), inset 0 0 18px rgba(108, 248, 255, 0.10);
}

.va-newsletter-panel__text {
  margin: 0;
  text-align: center;
  font-size: 1.08rem;
  line-height: 1.84;
  color: var(--va-text-soft);
}

.va-newsletter-form {
  width: min(100%, 720px);
  margin: 24px auto 0;
}

.va-newsletter-form__label {
  display: block;
  margin: 0 0 10px;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 0.82rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--va-frame-light);
}

.va-newsletter-form__row {
  display: flex;
  gap: 14px;
  align-items: stretch;
}

.va-newsletter-form__input,
.va-newsletter-form__button {
  min-height: 56px;
  border-radius: 10px;
  font: inherit;
}

.va-newsletter-form__input {
  flex: 1 1 auto;
  min-width: 0;
  padding: 0 16px;
  color: var(--va-text);
  background: rgba(5, 5, 10, 0.88);
  border: 2px solid rgba(253, 247, 223, 0.58);
  box-shadow: inset 0 0 12px rgba(253, 247, 223, 0.10);
}

.va-newsletter-form__input::placeholder {
  color: rgba(244, 241, 255, 0.48);
}

.va-newsletter-form__input:focus-visible {
  outline: none;
  border-color: rgba(108, 248, 255, 0.96);
  box-shadow: 0 0 0 3px rgba(108, 248, 255, 0.14), inset 0 0 12px rgba(253, 247, 223, 0.10);
}

.va-newsletter-form__button {
  flex: 0 0 auto;
  padding: 0 22px;
  border: 2px solid rgba(108, 248, 255, 0.96);
  background: linear-gradient(180deg, rgba(24, 52, 92, 0.96), rgba(10, 24, 48, 0.96));
  color: var(--va-frame-light);
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 0.92rem;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  cursor: pointer;
  box-shadow: 0 0 18px rgba(108, 248, 255, 0.24), inset 0 0 12px rgba(108, 248, 255, 0.10);
}

.va-newsletter-form__button:hover,
.va-newsletter-form__button:focus-visible {
  outline: none;
  transform: translateY(-1px);
  box-shadow: 0 0 22px rgba(108, 248, 255, 0.32), inset 0 0 14px rgba(108, 248, 255, 0.14);
}

.va-newsletter-form__button:disabled {
  cursor: wait;
  opacity: 0.72;
  transform: none;
}

.va-newsletter-form__note,
.va-newsletter-form__status {
  margin: 12px 0 0;
  text-align: center;
  line-height: 1.7;
}

.va-newsletter-form__note {
  color: var(--va-text-dim);
}

.va-newsletter-form__status {
  min-height: 1.7em;
  color: var(--va-frame-light);
}

.va-newsletter-form__status[data-tone="success"] {
  color: var(--va-green-soft);
}

.va-newsletter-form__status[data-tone="error"] {
  color: #ffd0e7;
}

.va-newsletter-form__honeypot {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
}


/* ===============================
   10. Highlight panel
   =============================== */

.va-highlight {
  padding: 24px 26px;
  border-radius: 12px;
  background: linear-gradient(rgba(96, 74, 14, 0.86), rgba(32, 22, 6, 0.54) 34%, rgba(12, 12, 20, 0.94));
  border: 3px solid rgba(239, 226, 155, 0.98);
  box-shadow: 0 0 32px rgba(239, 226, 155, 0.56), 0 0 56px rgba(239, 226, 155, 0.22), inset 0 0 24px rgba(239, 226, 155, 0.22), 0 12px 24px rgba(0, 0, 0, 0.32);
  text-align: center;
}

.va-highlight__title {
  margin: 0;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 1.28rem;
  line-height: 1.3;
  text-transform: uppercase;
  color: var(--va-yellow);
  text-shadow: 0 0 8px rgba(239, 226, 155, 0.42), 0 0 18px rgba(239, 226, 155, 0.22), 0 0 28px rgba(239, 226, 155, 0.10);
}

.va-highlight__text {
  margin: 14px auto 0;
  max-width: 84ch;
  font-size: 1.12rem;
  line-height: 1.84;
  color: var(--va-text-soft);
}


/* ===============================
   11. Mission cards
   =============================== */

.va-card {
  min-height: 100%;
  padding: 28px 24px 24px;
  background: var(--va-bg-panel-strong);
  border: 2px solid rgba(255, 255, 255, 0.24);
  border-radius: var(--va-radius-md);
  box-shadow: 0 10px 26px rgba(0, 0, 0, 0.34);
}

.va-card--wide {
  width: min(100%, 760px);
  margin: 24px auto 0;
}

.va-card--museum {
  background: linear-gradient(180deg, rgba(255, 245, 220, 0.38), rgba(112, 94, 56, 0.18) 38%, rgba(12, 12, 20, 0.94));
  border-color: rgba(255, 245, 220, 0.90);
  box-shadow: 0 0 18px rgba(255, 245, 220, 0.24), inset 0 0 16px rgba(255, 245, 220, 0.14), 0 12px 28px rgba(0, 0, 0, 0.34);
}

.va-card--expedition {
  background: linear-gradient(180deg, rgba(108, 248, 255, 0.36), rgba(10, 82, 96, 0.16) 38%, rgba(12, 12, 20, 0.94));
  border-color: rgba(108, 248, 255, 0.90);
  box-shadow: 0 0 18px rgba(108, 248, 255, 0.24), inset 0 0 16px rgba(108, 248, 255, 0.14), 0 12px 28px rgba(0, 0, 0, 0.34);
}

.va-card--collection {
  background: linear-gradient(180deg, rgba(139, 255, 126, 0.32), rgba(24, 88, 20, 0.15) 38%, rgba(12, 12, 20, 0.94));
  border-color: rgba(139, 255, 126, 0.88);
  box-shadow: 0 0 18px rgba(139, 255, 126, 0.22), inset 0 0 16px rgba(139, 255, 126, 0.12), 0 12px 28px rgba(0, 0, 0, 0.34);
}

.va-card--gamified {
  background: linear-gradient(180deg, rgba(255, 102, 204, 0.38), rgba(108, 18, 82, 0.16) 38%, rgba(12, 12, 20, 0.94));
  border-color: rgba(255, 102, 204, 0.92);
  box-shadow: 0 0 18px rgba(255, 102, 204, 0.24), inset 0 0 16px rgba(255, 102, 204, 0.14), 0 12px 28px rgba(0, 0, 0, 0.34);
  text-align: center;
}

.va-card--large {
  width: min(100%, 620px);
}

.va-card__title {
  margin: 0;
  font-family: 'Orbitron', Arial, sans-serif;
  font-size: 1.18rem;
  line-height: 1.3;
  text-transform: uppercase;
  }

.va-card--museum .va-card__title {
  color: var(--va-ivory-warm);
  text-shadow: 0 0 8px rgba(253, 247, 223, 0.36), 0 0 18px rgba(253, 247, 223, 0.18);
}

.va-card--expedition .va-card__title {
  color: var(--va-cyan);
  text-shadow: 0 0 12px rgba(108, 248, 255, 0.40), 0 0 24px rgba(108, 248, 255, 0.20);
}

.va-card--collection .va-card__title {
  color: var(--va-green);
  text-shadow: 0 0 12px rgba(139, 255, 126, 0.38), 0 0 24px rgba(139, 255, 126, 0.18);
}

.va-card--gamified .va-card__title {
  color: var(--va-pink);
  text-shadow: 0 0 12px rgba(255, 102, 204, 0.40), 0 0 24px rgba(255, 102, 204, 0.20);
}

.va-card__text {
  margin: 14px 0 0;
  font-size: 1.14rem;
  line-height: 1.84;
  color: var(--va-text-soft);
}


/* ===============================
   12. Universe panels
   =============================== */

.va-universe {
  position: relative;
  overflow: hidden;
  min-height: 100%;
  padding: 22px 22px 24px;
  background: rgba(10, 10, 18, 0.92);
  border-radius: 10px;
}

.va-universe__logoWrap {
  position: relative;
  z-index: 2;
  padding: 4px;
}

.va-universe__logo {
  width: min(100%, 360px);
  margin: 0 auto;
}

.va-universe__text {
  position: relative;
  z-index: 2;
  max-width: 36ch;
  margin: 16px auto 0;
  text-align: center;
  font-size: 1.06rem;
  line-height: 1.84;
}

.va-universe--violet {
  border: 5px ridge #bbaeff;
  background:
    linear-gradient(rgba(20, 20, 30, 0.95), rgba(10, 10, 20, 0.95)),
    url("../../assets/background-and-foreground/texture-for-blue-neon.png") center / cover;
  box-shadow:
    inset 0 0 20px rgba(138, 182, 255, 0.30),
    inset 0 0 42px rgba(187, 174, 255, 0.12),
    0 0 16px rgba(187, 174, 255, 0.46),
    0 0 34px rgba(187, 174, 255, 0.24),
    0 0 56px rgba(187, 174, 255, 0.12);
}

.va-universe--violet::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;
  pointer-events: none;
  background: radial-gradient(circle at 100% 0%, rgba(207, 196, 255, 0.12) 0%, rgba(207, 196, 255, 0.12) 28%, transparent 68%);
}

.va-universe--pink {
  border: 4px solid #ff66cc;
  background:
    linear-gradient(rgba(20, 0, 20, 0.95), rgba(15, 0, 20, 0.95)),
    url("../../assets/background-and-foreground/texture-for-blue-neon.png") center / cover;
  box-shadow:
    inset 0 0 18px rgba(255, 102, 204, 0.42),
    inset 0 0 38px rgba(255, 102, 204, 0.12),
    0 0 16px rgba(255, 102, 204, 0.50),
    0 0 34px rgba(255, 102, 204, 0.26),
    0 0 56px rgba(255, 51, 153, 0.14);
}

.va-universe--pink::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;
  background: repeating-linear-gradient(45deg, transparent 0, transparent 4px, rgba(255, 102, 204, 0.14) 4px, rgba(255, 102, 204, 0.14) 6px);
  pointer-events: none;
}

.va-universe--pink::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: 10px;
  pointer-events: none;
  background: radial-gradient(circle at 0% 0%, rgba(255, 102, 204, 0.12) 0%, rgba(255, 102, 204, 0.12) 28%, transparent 68%);
}

.va-universe__text--violet {
  color: #e7dfff;
}

.va-universe__text--pink {
  color: #ffe3f2;
}


/* ===============================
   13. Footer
   =============================== */

.va-footer {
  margin-top: 32px;
  padding: 18px 22px;
  text-align: center;
  background: rgba(10, 10, 18, 0.90);
}

.va-footer__text {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 10px;
  margin: 0;
  font-family: 'Orbitron', Arial, sans-serif;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}

.va-footer__brand,
.va-footer__status,
.va-footer__dot {
  color: var(--va-cyan);
  text-shadow: 0 0 10px rgba(108, 248, 255, 0.42), 0 0 22px rgba(108, 248, 255, 0.22), 0 0 34px rgba(108, 248, 255, 0.10);
}


.va-footer__brand {
  font-size: 1.08rem;
}


.va-footer__status {
  font-size: 1.12rem;
}


.va-footer__dot {
  font-size: 1rem;
}


/* ===============================
   14. Responsive
   =============================== */

@media (max-width: 1100px) {
  .va-feature-panel__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 980px) {
  .va-grid--three,
  .va-grid--two {
    grid-template-columns: 1fr;
  }

  .va-newsletter-form__row {
    flex-direction: column;
  }

  .va-newsletter-form__button {
    width: 100%;
  }

  .va-hero,
  .va-section {
    padding-left: 22px;
    padding-right: 22px;
  }
}

@media (max-width: 640px) {
  .va-landing {
    width: min(calc(100% - 16px), var(--va-max));
    padding-top: 14px;
  }

  .va-page-frame {
    padding: 12px;
  }

  .va-hero {
    padding: 24px 16px 24px;
  }

  .va-section {
    padding: 24px 16px 22px;
  }

  .va-hero__logoWrap {
    width: min(100%, 430px);
    margin-bottom: 10px;
  }

  .va-hero__kicker,
  .va-section__kicker,
  .va-footer__text {
    letter-spacing: 0.10em;
  }

  .va-hero__copy p,
  .va-section__intro p,
  .va-highlight__text,
  .va-card__text,
  .va-universe__text,
  .va-hero__statement,
  .va-newsletter-panel__text,
  .va-newsletter-form__note,
  .va-newsletter-form__status {
    font-size: 0.98rem;
    line-height: 1.75;
  }

  .va-newsletter-panel {
    padding: 22px 16px 20px;
  }

  .va-newsletter-form__input,
  .va-newsletter-form__button {
    min-height: 52px;
  }

  .va-feature-panel {
    padding: 18px 14px 20px;
  }

  .va-feature-panel__grid {
    grid-template-columns: 1fr;
  }

  .va-tag {
    width: 100%;
    min-height: 50px;
    font-size: 0.84rem;
  }

  .va-tag--gold {
    min-width: 100%;
  }

  .va-universe {
    padding: 18px 14px 20px;
  }

  .va-footer__brand,
  .va-footer__status,
  .va-footer__dot {
    font-size: 0.9rem;
  }
}

.va-tag--lead-secondary {
  min-height: 64px;
  min-width: min(100%, 360px);
  font-size: 0.98rem;
}


.va-hero__copy p,
.va-hero__statement,
.va-section__intro p,
.va-highlight__text,
.va-card__text,
.va-universe__text,
.va-footer__text {
  font-weight: 600;
}


.va-tag--ivory {
  color: var(--va-frame-light);
  background: linear-gradient(180deg, rgba(255, 245, 220, 0.38), rgba(112, 94, 56, 0.18));
  border-color: rgba(255, 245, 220, 0.90);
  box-shadow: 0 0 16px rgba(255, 245, 220, 0.28), inset 0 0 14px rgba(255, 245, 220, 0.12);
  text-shadow: 0 0 10px rgba(253, 247, 223, 0.44), 0 0 20px rgba(253, 247, 223, 0.18);
}

.va-inline-separator {
  margin: 28px auto 30px;
}

.va-hero__statement {
  padding: 4px 0;
}


.va-section--universes .va-grid--two {
  margin-top: 40px;
}


.va-section--mission .va-highlight {
  margin-top: 8px;
}

.va-section--mission .va-grid,
.va-section--mission .va-card-row--centered {
  margin-top: 16px;
}
