/* ============================================
   Component Styles
   ============================================ */

/* ===========================================
   HEADER
   =========================================== */
.site-header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 100;
  height: var(--header-height);
  display: flex;
  align-items: center;
  padding: 0 var(--space-6);
  transition: background var(--transition-base), box-shadow var(--transition-base);
}

.site-header.scrolled {
  background: rgba(13, 17, 23, 0.85);
  backdrop-filter: blur(var(--glass-blur));
  -webkit-backdrop-filter: blur(var(--glass-blur));
  box-shadow: 0 1px 0 var(--color-border);
}

.header-inner {
  width: 100%;
  max-width: var(--container-xl);
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.header-logo a {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  color: var(--color-text-primary);
  font-family: var(--font-heading);
  font-weight: var(--weight-bold);
  font-size: var(--text-lg);
}

.header-logo img {
  width: 32px;
  height: 32px;
}

.header-nav {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

.header-nav a {
  padding: var(--space-2) var(--space-3);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  border-radius: var(--radius-md);
  transition: color var(--transition-fast), background var(--transition-fast);
}

.header-nav a:hover {
  color: var(--color-text-primary);
  background: rgba(255, 255, 255, 0.05);
}

.header-social {
  display: flex;
  align-items: center;
  gap: var(--space-1);
}

.header-social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  color: var(--color-text-muted);
  border-radius: var(--radius-md);
  transition: color var(--transition-fast), background var(--transition-fast);
}

.header-social a:hover {
  color: var(--color-accent);
  background: var(--color-accent-soft);
}

.header-social svg {
  width: 18px;
  height: 18px;
}

/* Mobile nav toggle */
.nav-toggle {
  display: none;
  flex-direction: column;
  gap: 5px;
  padding: var(--space-2);
  cursor: pointer;
}

.nav-toggle span {
  display: block;
  width: 22px;
  height: 2px;
  background: var(--color-text-primary);
  border-radius: 2px;
  transition: transform var(--transition-fast), opacity var(--transition-fast);
}

.nav-toggle.active span:nth-child(1) {
  transform: rotate(45deg) translate(5px, 5px);
}

.nav-toggle.active span:nth-child(2) {
  opacity: 0;
}

.nav-toggle.active span:nth-child(3) {
  transform: rotate(-45deg) translate(5px, -5px);
}

/* Mobile drawer */
.mobile-nav {
  display: none;
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  bottom: 0;
  background: rgba(13, 17, 23, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  z-index: 99;
  padding: var(--space-8) var(--space-6);
  flex-direction: column;
  gap: var(--space-2);
}

.mobile-nav.open {
  display: flex;
}

.mobile-nav a {
  display: block;
  padding: var(--space-4) var(--space-4);
  color: var(--color-text-secondary);
  font-size: var(--text-lg);
  font-weight: var(--weight-medium);
  border-radius: var(--radius-md);
  transition: all var(--transition-fast);
}

.mobile-nav a:hover {
  color: var(--color-text-primary);
  background: rgba(255, 255, 255, 0.05);
}

.mobile-social {
  display: flex;
  gap: var(--space-4);
  margin-top: auto;
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
}

.mobile-social a {
  padding: var(--space-2);
  font-size: var(--text-base);
}

@media (max-width: 768px) {

  .header-nav,
  .header-social {
    display: none;
  }

  .nav-toggle {
    display: flex;
  }
}


/* ===========================================
   HERO
   =========================================== */
.hero {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: calc(var(--header-height) + var(--space-16)) var(--space-6) var(--space-16);
  overflow: hidden;
}

.hero-bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  overflow: hidden;
}

.hero-bg::before {
  content: '';
  position: absolute;
  inset: -50%;
  background:
    radial-gradient(ellipse at 20% 50%, rgba(0, 212, 255, 0.08) 0%, transparent 50%),
    radial-gradient(ellipse at 80% 20%, rgba(240, 160, 48, 0.06) 0%, transparent 50%),
    radial-gradient(ellipse at 50% 80%, rgba(0, 100, 200, 0.05) 0%, transparent 50%);
  animation: hero-gradient 20s ease infinite alternate;
}

@keyframes hero-gradient {
  0% {
    transform: translate(0, 0) scale(1);
  }

  50% {
    transform: translate(-5%, 3%) scale(1.05);
  }

  100% {
    transform: translate(3%, -2%) scale(1);
  }
}

/* Pixel grid overlay */
.hero-bg::after {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.015) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.015) 1px, transparent 1px);
  background-size: 24px 24px;
  mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
  -webkit-mask-image: radial-gradient(ellipse at center, black 30%, transparent 70%);
}

.hero-content {
  position: relative;
  z-index: 1;
  max-width: 800px;
}

.hero-logo {
  margin-bottom: var(--space-6);
}

.hero-logo img {
  max-width: 500px;
  height: auto;
  margin: 0 auto;
  filter: drop-shadow(0 0 40px rgba(0, 212, 255, 0.15));
}

@media (max-width: 640px) {
  .hero-logo img {
    max-width: 280px;
  }
}

.hero-tagline {
  font-size: var(--text-xl);
  color: var(--color-text-secondary);
  margin-bottom: var(--space-8);
  font-weight: var(--weight-normal);
  max-width: 640px;
  margin-left: auto;
  margin-right: auto;
}

.hero-actions {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: var(--space-6);
}

.hero-platforms {
  display: flex;
  gap: var(--space-6);
  justify-content: center;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.hero-platforms span {
  display: flex;
  align-items: center;
  gap: var(--space-2);
}

/* Hero before/after showcase */
.hero-showcase {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 640px;
  margin: var(--space-12) auto 0;
}

.hero-showcase .comparison-slider {
  box-shadow: var(--shadow-xl), 0 0 60px rgba(0, 212, 255, 0.1);
}

.hero-showcase-hint {
  margin-top: var(--space-3);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-align: center;
}

.hero-showcase-hint a {
  color: var(--color-text-secondary);
}


/* ===========================================
   PREVIEW / TRAILER
   =========================================== */
.preview-section {
  position: relative;
  padding: var(--space-16) var(--space-6);
  text-align: center;
}

.preview-container {
  max-width: 900px;
  margin: 0 auto;
  position: relative;
  cursor: pointer;
  border-radius: var(--radius-xl);
  overflow: hidden;
  box-shadow: var(--shadow-xl), 0 0 60px rgba(0, 212, 255, 0.08);
  transition: transform var(--transition-slow), box-shadow var(--transition-slow);
}

.preview-container:hover {
  transform: scale(1.02);
  box-shadow: var(--shadow-xl), 0 0 80px rgba(0, 212, 255, 0.12);
}

.preview-container img {
  width: 100%;
  height: auto;
  display: block;
}

.preview-play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
  transition: background var(--transition-base);
}

.preview-container:hover .preview-play {
  background: rgba(0, 0, 0, 0.15);
}

.preview-play svg {
  width: 72px;
  height: 72px;
  color: white;
  opacity: 0.8;
  filter: drop-shadow(0 2px 8px rgba(0, 0, 0, 0.5));
  transition: opacity var(--transition-fast), transform var(--transition-fast);
}

.preview-container:hover .preview-play svg {
  opacity: 1;
  transform: scale(1.1);
}

.preview-subtitle {
  margin-top: var(--space-6);
  font-size: var(--text-xl);
  color: var(--color-text-secondary);
}


/* ===========================================
   VIDEO OVERLAY
   =========================================== */
.video-overlay {
  position: fixed;
  inset: 0;
  z-index: 200;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.9);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--transition-base), visibility var(--transition-base);
}

.video-overlay.active {
  opacity: 1;
  visibility: visible;
}

.video-overlay-content {
  position: relative;
  width: 90%;
  max-width: 960px;
  aspect-ratio: 16 / 9;
}

.video-overlay-content iframe {
  width: 100%;
  height: 100%;
  border: none;
  border-radius: var(--radius-lg);
}

.video-overlay-close {
  position: absolute;
  top: -48px;
  right: 0;
  color: white;
  font-size: var(--text-2xl);
  padding: var(--space-2);
  cursor: pointer;
  opacity: 0.7;
  transition: opacity var(--transition-fast);
}

.video-overlay-close:hover {
  opacity: 1;
}


/* ===========================================
   SECTION HEADERS
   =========================================== */
.section-header {
  text-align: center;
  margin-bottom: var(--space-12);
}

.section-header h2 {
  margin-bottom: var(--space-3);
}

.section-header p {
  font-size: var(--text-lg);
  max-width: 600px;
  margin: 0 auto;
}

.section-label {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--weight-semibold);
  color: var(--color-accent);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: var(--space-3);
}


/* ===========================================
   NO GENERATIVE AI BAND
   =========================================== */
.ai-free-band {
  padding: 0 0 var(--space-20) 0;
}

.ai-free-inner {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  margin: 0 auto;
  padding: var(--space-6) var(--space-8);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-bottom: 3px solid var(--color-accent);
  border-radius: var(--radius-xl);
}

.ai-free-icon {
  font-size: 1.6rem;
  flex-shrink: 0;
}

.ai-free-icon .fa-robot {
  color: var(--color-text-secondary);
}

.ai-free-icon .fa-slash {
  color: var(--color-accent);
  /* bg-colored halo so the slash visibly "cuts" through the robot */
  text-shadow:
    0 0 2px var(--color-bg-elevated),
    0 0 2px var(--color-bg-elevated),
    0 0 2px var(--color-bg-elevated);
}

.ai-free-text h3 {
  font-size: var(--text-xl);
  margin-bottom: var(--space-2);
}

.ai-free-text p {
  font-size: var(--text-sm);
  margin: 0;
}

@media (max-width: 640px) {
  .ai-free-inner {
    flex-direction: column;
    text-align: center;
    gap: var(--space-4);
  }
}


/* ===========================================
   HOW IT WORKS (step cards)
   =========================================== */
.step-card {
  position: relative;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: transform var(--transition-base), border-color var(--transition-base);
}

.step-card:hover {
  transform: translateY(-4px);
  border-color: var(--color-accent-soft);
}

.step-number {
  position: absolute;
  top: var(--space-3);
  left: var(--space-3);
  z-index: 2;
  width: 32px;
  height: 32px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-weight: var(--weight-bold);
  color: var(--color-text-inverse);
  background: var(--color-accent);
  border-radius: var(--radius-full);
  box-shadow: var(--shadow-glow-accent);
}

.step-media {
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-bg-deep);
}

.step-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.step-body {
  padding: var(--space-5);
}

.step-body h4 {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}

.step-body h4 i {
  color: var(--color-accent);
}

.step-body p {
  font-size: var(--text-sm);
  margin: 0;
}


/* ===========================================
   FEATURE CARDS
   =========================================== */
.feature-section-title {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-8);
  text-align: center;
  color: var(--color-text-primary);
}

.feature-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}

.feature-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-lg);
  border-color: var(--color-accent-soft);
}

.feature-card-media {
  position: relative;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  background: var(--color-bg-deep);
}

.feature-card-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: opacity var(--transition-base);
}

/* Only the animated pixel-art result is pixelated; UI screenshots stay smooth.
   Add the `pixelated` class on a static img if its result looks blurry. */
.feature-card-media .feature-img-hover,
.feature-card-media img.pixelated {
  image-rendering: pixelated;
}

.feature-card-media .feature-img-hover {
  position: absolute;
  inset: 0;
  opacity: 0;
}

.feature-card:hover .feature-img-hover,
.feature-card.in-view .feature-img-hover {
  opacity: 1;
}

.feature-card:hover .feature-img-static,
.feature-card.in-view .feature-img-static {
  opacity: 0;
}

.feature-card-body {
  padding: var(--space-5);
}

.feature-card-body h4 {
  font-size: var(--text-lg);
  margin-bottom: var(--space-2);
}

.feature-card-body p {
  font-size: var(--text-sm);
  margin: 0;
}

/* Wide feature card (for dual images like key animation) */
.feature-card-wide {
  grid-column: 1 / -1;
}

.feature-card-wide .feature-card-media {
  display: grid;
  grid-template-columns: 1fr 1fr;
  aspect-ratio: auto;
}

.feature-card-wide .feature-card-media>div {
  aspect-ratio: 16 / 9;
  position: relative;
  overflow: hidden;
}

.feature-divider {
  border: none;
  border-top: 1px solid var(--color-border);
  margin: var(--space-12) 0;
}


/* ===========================================
   COMPARISON SLIDER (Examples)
   =========================================== */
/* Horizontal examples gallery */
.examples-gallery {
  position: relative;
  display: flex;
  align-items: center;
  gap: var(--space-2);
  max-width: var(--container-2xl);
  margin: 0 auto;
  padding: 0 var(--space-4);
}

.examples-track {
  display: flex;
  gap: var(--space-6);
  overflow-x: auto;
  scroll-snap-type: x mandatory;
  scroll-padding: var(--space-4);
  padding: var(--space-4) var(--space-2);
  scrollbar-width: thin;
  flex: 1;
}

.example-card {
  flex: 0 0 auto;
  width: min(380px, 80vw);
  scroll-snap-align: center;
}

.example-card .comparison-slider {
  width: 100%;
}

.example-category {
  display: inline-block;
  margin-top: var(--space-3);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--color-text-muted);
}

.gallery-arrow {
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-full);
  color: var(--color-text-primary);
  cursor: pointer;
  transition: background var(--transition-fast), border-color var(--transition-fast), opacity var(--transition-fast);
}

.gallery-arrow:hover {
  border-color: var(--color-accent);
  color: var(--color-accent);
}

.gallery-arrow:disabled {
  opacity: 0.3;
  cursor: default;
}

@media (max-width: 640px) {
  .gallery-arrow {
    display: none;
  }
}

.comparison-slider {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  border: 1px solid var(--color-border-light);
  cursor: col-resize;
  user-select: none;
  -webkit-user-select: none;
}

.comparison-slider img {
  display: block;
  width: 100%;
  height: auto;
}

.comparison-before {
  position: relative;
}

.comparison-after {
  position: absolute;
  inset: 0;
  overflow: hidden;
}

.comparison-after img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  image-rendering: pixelated;
}

.comparison-handle {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 3px;
  background: var(--color-accent);
  cursor: col-resize;
  z-index: 10;
  box-shadow: 0 0 8px var(--color-accent-glow);
}

.comparison-handle::before {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 36px;
  height: 36px;
  background: var(--color-accent);
  border-radius: var(--radius-full);
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 0 12px var(--color-accent-glow);
}

.comparison-handle::after {
  content: '◄ ►';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  font-size: 10px;
  color: var(--color-text-inverse);
  white-space: nowrap;
  letter-spacing: 2px;
  font-weight: var(--weight-bold);
  z-index: 1;
}

.comparison-label {
  position: absolute;
  bottom: var(--space-3);
  padding: var(--space-1) var(--space-3);
  background: rgba(13, 17, 23, 0.75);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  color: var(--color-text-primary);
  font-size: var(--text-xs);
  font-weight: var(--weight-medium);
  border-radius: var(--radius-sm);
  z-index: 5;
}

.comparison-label-before {
  left: var(--space-3);
}

.comparison-label-after {
  right: var(--space-3);
}

.comparison-label a {
  color: var(--color-accent);
}


/* ===========================================
   DEVLOG TIMELINE (Homepage strip)
   =========================================== */
.devlog-strip {
  overflow-x: auto;
  padding: var(--space-4) 0;
  scrollbar-width: thin;
}

.devlog-strip-inner {
  display: flex;
  gap: var(--space-4);
  padding: var(--space-2) var(--space-6);
  min-width: max-content;
}

.devlog-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-3);
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  width: 160px;
  flex-shrink: 0;
  text-align: center;
  transition: border-color var(--transition-fast), transform var(--transition-fast);
  cursor: pointer;
  text-decoration: none;
}

.devlog-chip:hover {
  border-color: var(--color-accent-soft);
  transform: translateY(-2px);
}

.devlog-chip.has-video {
  border-color: rgba(0, 212, 255, 0.15);
}

.devlog-version {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--color-accent);
}

.devlog-title {
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  line-height: var(--leading-tight);
}

.devlog-date {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

.devlog-thumbnail {
  position: relative;
  width: 100%;
  height: 120px;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-bg-deep);
  display: flex;
  align-items: center;
  justify-content: center;
}

.devlog-thumbnail img {
  max-width: none;
  object-fit: cover;
  image-rendering: pixelated;
}

.devlog-play {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.3);
  opacity: 0;
  transition: opacity var(--transition-fast);
}

.devlog-play i {
  color: white;
  font-size: var(--text-lg);
  filter: drop-shadow(0 1px 4px rgba(0, 0, 0, 0.5));
}

.devlog-chip:hover .devlog-play {
  opacity: 1;
}


/* ===========================================
   ROADMAP PAGE (Vertical timeline)
   =========================================== */
.roadmap-timeline {
  position: relative;
  padding-left: var(--space-8);
}

.roadmap-item {
  position: relative;
  padding-bottom: var(--space-8);
}

/* Connecting segment, drawn from each item's dot down to the next one. */
.roadmap-item:not(:last-child)::before {
  content: '';
  position: absolute;
  left: calc(-1 * var(--space-8) + 15px);
  top: 6px;
  bottom: -6px;
  width: 2px;
  background: var(--color-accent);
}

/* The planned/future portion of the timeline reads as not-yet-shipped. */
.roadmap-item.is-future::before,
.roadmap-item.is-upcoming::before {
  width: 0;
  border-left: 2px dashed var(--color-accent);
  background: none;
  opacity: 0.5;
}

.roadmap-dot {
  position: absolute;
  left: calc(-1 * var(--space-8) + 8px);
  top: 4px;
  width: 16px;
  height: 16px;
  border-radius: var(--radius-full);
  background: var(--color-accent);
  border: 3px solid var(--color-bg-primary);
  box-shadow: 0 0 0 2px var(--color-accent);
}

/* Next up: hollow accent ring. */
.roadmap-dot.upcoming {
  background: var(--color-bg-primary);
  box-shadow: 0 0 0 2px var(--color-accent);
}

/* Planned: dashed accent ring with a soft glow + gentle pulse. */
.roadmap-dot.future {
  background: var(--color-bg-primary);
  border: 2px dashed var(--color-accent);
  box-shadow: 0 0 12px 0 color-mix(in srgb, var(--color-accent) 45%, transparent);
  animation: roadmap-dot-pulse 2.8s ease-in-out infinite;
}

@keyframes roadmap-dot-pulse {
  0%, 100% {
    box-shadow: 0 0 8px 0 color-mix(in srgb, var(--color-accent) 30%, transparent);
  }
  50% {
    box-shadow: 0 0 14px 2px color-mix(in srgb, var(--color-accent) 55%, transparent);
  }
}

@media (prefers-reduced-motion: reduce) {
  .roadmap-dot.future {
    animation: none;
  }
}

.roadmap-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
}

.roadmap-card-header {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}

.roadmap-version {
  font-family: var(--font-mono);
  font-size: var(--text-sm);
  font-weight: var(--weight-bold);
  color: var(--color-accent);
}

.roadmap-date {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.roadmap-title {
  font-size: var(--text-base);
  font-weight: var(--weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-3);
}

.roadmap-features {
  list-style: disc;
  padding-left: var(--space-5);
}

.roadmap-features li {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  margin-bottom: var(--space-1);
}

.roadmap-category-title {
  font-weight: var(--weight-semibold);
  color: var(--color-text-primary);
  margin: var(--space-4) 0 var(--space-2);
  font-size: var(--text-sm);
}

.roadmap-features .completed {
  color: var(--color-success);
}

.roadmap-features .completed::marker {
  color: var(--color-success);
}

.roadmap-preview {
  display: block;
  margin-top: var(--space-4);
  border-radius: var(--radius-md);
  overflow: hidden;
  border: 1px solid var(--glass-border);
  line-height: 0;
  transition: border-color var(--transition-base), transform var(--transition-base);
}

.roadmap-preview img {
  display: block;
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
  object-fit: cover;
}

.roadmap-preview:hover {
  border-color: var(--color-accent);
  transform: translateY(-2px);
}

.roadmap-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-4);
  font-size: var(--text-sm);
  color: var(--color-accent);
  font-weight: var(--weight-medium);
}

.roadmap-link:hover {
  text-decoration: underline;
}


/* ===========================================
   BUY SECTION
   =========================================== */
.buy-section {
  background: linear-gradient(180deg, var(--color-bg-primary) 0%, var(--color-bg-elevated) 100%);
  text-align: center;
  padding: var(--space-20) var(--space-6);
}

.buy-section h2 {
  margin-bottom: var(--space-2);
}

.buy-platforms {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  margin-bottom: var(--space-4);
}

.buy-button-wrapper {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin-bottom: var(--space-4);
}

#buy_button {
  padding: var(--space-4) var(--space-10);
  font-size: var(--text-lg);
  font-weight: var(--weight-bold);
  background: linear-gradient(135deg, var(--color-accent), #0090b0);
  color: var(--color-text-inverse);
  border: none;
  border-radius: var(--radius-xl);
  cursor: pointer;
  box-shadow: var(--shadow-glow-accent);
  transition: all var(--transition-base);
}

#buy_button:hover {
  transform: translateY(-2px);
  box-shadow: 0 0 40px var(--color-accent-glow);
}

.buy-stores {
  display: flex;
  gap: var(--space-4);
  justify-content: center;
  margin-bottom: var(--space-4);
  font-size: var(--text-sm);
}

.buy-stores a {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-secondary);
}

.buy-stores a:hover {
  color: var(--color-accent);
}

.buy-note {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
}

.buy-note a {
  color: var(--color-accent);
}

.buy-info {
  margin-top: var(--space-10);
  max-width: 800px;
  margin-left: auto;
  margin-right: auto;
}

.buy-info-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-6);
  text-align: left;
}

@media (max-width: 640px) {
  .buy-info-cards {
    grid-template-columns: 1fr;
  }
}

.buy-info-card {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
}

.buy-info-card h4 {
  font-size: var(--text-lg);
  color: var(--color-text-primary);
  margin-bottom: var(--space-4);
}

.buy-info-card ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.buy-info-card li {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}

.buy-info-card li strong {
  color: var(--color-text-primary);
}

.buy-info-card li i {
  color: var(--color-text-muted);
  margin-right: var(--space-1);
}

.buy-info-card p {
  font-size: var(--text-sm);
  margin-bottom: var(--space-3);
}

.buy-info-card a {
  color: var(--color-accent);
}

.original-price {
  text-decoration: line-through;
  opacity: 0.5;
  margin-right: var(--space-2);
}


/* ===========================================
   FOOTER
   =========================================== */
.site-footer {
  background: var(--color-bg-deep);
  border-top: 1px solid var(--color-border);
  padding: var(--space-16) var(--space-6) var(--space-8);
}

.footer-grid {
  display: grid;
  grid-template-columns: 2fr repeat(3, 1fr);
  gap: var(--space-12);
  max-width: var(--container-xl);
  margin: 0 auto var(--space-12);
}

@media (max-width: 768px) {
  .footer-grid {
    grid-template-columns: 1fr 1fr;
    gap: var(--space-8);
  }
}

@media (max-width: 480px) {
  .footer-grid {
    grid-template-columns: 1fr;
  }
}

.footer-brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.footer-brand-logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  font-family: var(--font-heading);
  font-weight: var(--weight-bold);
  font-size: var(--text-lg);
  color: var(--color-text-primary);
}

.footer-brand-logo img {
  width: 28px;
  height: 28px;
}

.footer-brand p {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  max-width: 280px;
}

.footer-social {
  display: flex;
  gap: var(--space-3);
}

.footer-social a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  background: var(--color-bg-card);
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  transition: all var(--transition-fast);
}

.footer-social a:hover {
  background: var(--color-accent-soft);
  color: var(--color-accent);
}

.footer-social svg {
  width: 16px;
  height: 16px;
}

.footer-column h5 {
  font-size: var(--text-sm);
  font-weight: var(--weight-semibold);
  color: var(--color-text-primary);
  margin-bottom: var(--space-4);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.footer-column ul {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.footer-column a {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.footer-column a:hover {
  color: var(--color-text-primary);
}

.footer-bottom {
  max-width: var(--container-xl);
  margin: 0 auto;
  padding-top: var(--space-8);
  border-top: 1px solid var(--color-border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

@media (max-width: 640px) {
  .footer-bottom {
    flex-direction: column;
    gap: var(--space-4);
    text-align: center;
  }
}

.footer-legal {
  display: flex;
  gap: var(--space-6);
}

.footer-legal a {
  color: var(--color-text-muted);
  transition: color var(--transition-fast);
}

.footer-legal a:hover {
  color: var(--color-text-primary);
}


/* ===========================================
   CONTACT PAGE
   =========================================== */
.contact-layout {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-12);
  max-width: var(--container-xl);
  margin: 0 auto;
}

@media (max-width: 768px) {
  .contact-layout {
    grid-template-columns: 1fr;
  }
}

.faq-section h3 {
  margin-bottom: var(--space-6);
}

.faq-item {
  margin-bottom: var(--space-6);
}

.faq-item h5 {
  color: var(--color-accent);
  margin-bottom: var(--space-2);
  font-size: var(--text-base);
}

.faq-item p {
  font-size: var(--text-sm);
}

.contact-form-section h3 {
  margin-bottom: var(--space-6);
}

.contact-form {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

.form-group label {
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  color: var(--color-text-secondary);
}

.contact-form .btn {
  align-self: flex-start;
}

.contact-form .btn.loading {
  opacity: 0.6;
  pointer-events: none;
}

/* Toast notifications */
.toast {
  position: fixed;
  bottom: var(--space-6);
  right: var(--space-6);
  padding: var(--space-4) var(--space-6);
  border-radius: var(--radius-lg);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  z-index: 300;
  transform: translateY(100px);
  opacity: 0;
  transition: transform var(--transition-spring), opacity var(--transition-base);
}

.toast.visible {
  transform: translateY(0);
  opacity: 1;
}

.toast-success {
  background: var(--color-success);
  color: white;
}

.toast-error {
  background: var(--color-error);
  color: white;
}


/* ===========================================
   PAGE CONTENT (legal, privacy)
   =========================================== */
.page-content {
  max-width: var(--container-md);
  margin: 0 auto;
}

.page-content h1 {
  margin-bottom: var(--space-8);
}

.page-content h2 {
  font-size: var(--text-2xl);
  margin-top: var(--space-10);
  margin-bottom: var(--space-4);
}

.page-content h3 {
  font-size: var(--text-xl);
  margin-top: var(--space-8);
  margin-bottom: var(--space-3);
}

.page-content p {
  margin-bottom: var(--space-4);
}

.page-content ul,
.page-content ol {
  list-style: disc;
  padding-left: var(--space-6);
  margin-bottom: var(--space-4);
}

.page-content li {
  color: var(--color-text-secondary);
  margin-bottom: var(--space-2);
}

.page-content strong {
  color: var(--color-text-primary);
  font-weight: var(--weight-semibold);
}

.page-content a {
  color: var(--color-accent);
}

.page-content hr {
  margin: var(--space-8) 0;
  border-color: var(--color-border);
}


/* ===========================================
   404 PAGE
   =========================================== */
.error-page {
  min-height: 80vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: var(--space-20) var(--space-6);
}

.error-code {
  font-family: var(--font-mono);
  font-size: 8rem;
  font-weight: var(--weight-bold);
  background: linear-gradient(135deg, var(--color-accent), var(--color-accent-hover));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  line-height: 1;
  margin-bottom: var(--space-4);
}

.error-page h2 {
  margin-bottom: var(--space-4);
}

.error-page p {
  margin-bottom: var(--space-8);
  font-size: var(--text-lg);
}


/* ===========================================
   BACK LINK
   =========================================== */
.back-link {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  font-weight: var(--weight-medium);
  margin-top: var(--space-8);
  transition: color var(--transition-fast);
}

.back-link:hover {
  color: var(--color-accent);
}