/**
 * Klaritee Child Theme - Block Styles
 * 
 * This is the MAIN stylesheet that defines:
 * 1. CSS Variables (design tokens)
 * 2. Layout System (sections, containers, grids)
 * 3. Component Styles (cards, buttons, hover effects)
 * 4. Animation Utilities
 * 
 * IMPORTANT: Do NOT use inline styles or editor spacing.
 * All spacing/layout must come from these classes.
 * 
 * @package Klaritee_Child
 * @since 1.0.0
 */

/* ============================================
   1. CSS VARIABLES (Design Tokens)
   ============================================ */

:root {
  /* Colors */
  --kt-black: #0A0A0C;
  --kt-charcoal: #111214;
  --kt-deep-indigo: #0F1A3A;
  --kt-cyan: #00D4FF;
  --kt-gold: #F5C98A;
  --kt-white: #F4F7FA;
  
  /* Spacing Scale (matches React) */
  --kt-space-1: 0.25rem;    /* 4px */
  --kt-space-2: 0.5rem;     /* 8px */
  --kt-space-3: 0.75rem;    /* 12px */
  --kt-space-4: 1rem;       /* 16px */
  --kt-space-5: 1.25rem;    /* 20px */
  --kt-space-6: 1.5rem;     /* 24px */
  --kt-space-8: 2rem;       /* 32px */
  --kt-space-10: 2.5rem;    /* 40px */
  --kt-space-12: 3rem;      /* 48px */
  --kt-space-16: 4rem;      /* 64px */
  --kt-space-20: 5rem;      /* 80px */
  --kt-space-24: 6rem;      /* 96px */
  --kt-space-32: 8rem;      /* 128px */
  --kt-space-40: 10rem;     /* 160px */
  
  /* Container Widths */
  --kt-container-sm: 40rem;   /* 640px */
  --kt-container-md: 48rem;   /* 768px */
  --kt-container-lg: 64rem;   /* 1024px */
  --kt-container-xl: 80rem;   /* 1280px */
  --kt-container-2xl: 96rem;  /* 1536px */
  
  /* Typography */
  --kt-font-light: 300;
  --kt-font-normal: 400;
  --kt-font-medium: 500;
  
  /* Line Heights */
  --kt-leading-tight: 1.1;
  --kt-leading-snug: 1.375;
  --kt-leading-normal: 1.5;
  --kt-leading-relaxed: 1.625;
  --kt-leading-loose: 2;
  
  /* Letter Spacing */
  --kt-tracking-tighter: -0.02em;
  --kt-tracking-tight: -0.01em;
  --kt-tracking-normal: 0;
  --kt-tracking-wide: 0.01em;
  --kt-tracking-wider: 0.05em;
  --kt-tracking-widest: 0.2em;
  
  /* Border Radius */
  --kt-radius-sm: 4px;
  --kt-radius-md: 8px;
  --kt-radius-lg: 12px;
  --kt-radius-xl: 16px;
  --kt-radius-full: 9999px;
  
  /* Shadows */
  --kt-shadow-sm: 0 1px 2px rgba(0, 0, 0, 0.05);
  --kt-shadow-md: 0 4px 6px rgba(0, 0, 0, 0.1);
  --kt-shadow-lg: 0 10px 15px rgba(0, 0, 0, 0.1);
  --kt-shadow-xl: 0 20px 25px rgba(0, 0, 0, 0.15);
  --kt-shadow-2xl: 0 25px 50px rgba(0, 0, 0, 0.25);
  --kt-shadow-glow-cyan: 0 0 20px rgba(0, 212, 255, 0.6);
  --kt-shadow-glow-gold: 0 0 20px rgba(245, 201, 138, 0.6);
  
  /* Transitions */
  --kt-transition-fast: 200ms ease;
  --kt-transition-base: 300ms ease;
  --kt-transition-slow: 500ms ease;
}
/* ============================================
   RESPONSIVE TOKENS — MOBILE
   ============================================ */

@media (max-width: 768px) {
  :root {
    /* Tighten vertical rhythm */
    --kt-space-40: 6rem;   /* was 10rem */
    --kt-space-32: 4.5rem;/* was 8rem */
    --kt-space-24: 4rem;  /* was 6rem */
    --kt-space-20: 3rem;  /* was 5rem */
    --kt-space-16: 2.5rem;/* was 4rem */
    --kt-space-12: 2rem;  /* was 3rem */

    /* Horizontal comfort */
    --kt-space-10: 2rem;  /* was 2.5rem */
    --kt-space-8: 1.5rem; /* was 2rem */

    /* Line-height slightly looser for readability */
    --kt-leading-tight: 1.2;
    --kt-leading-snug: 1.45;
  }
}
/* ============================================
   RESPONSIVE TOKENS — TABLET
   ============================================ */

@media (min-width: 769px) and (max-width: 1024px) {
  :root {
    /* Balanced cinematic spacing */
    --kt-space-40: 8rem;  /* was 10rem */
    --kt-space-32: 6rem;  /* was 8rem */
    --kt-space-24: 5rem;  /* was 6rem */
    --kt-space-20: 4rem;  /* was 5rem */

    /* Slight tightening */
    --kt-space-12: 2.5rem;
    --kt-space-10: 2.25rem;
  }
}

/* ============================================
   2. RESET & BASE STYLES
   ============================================ */

/* --------------------------------------------
   Global box model
   -------------------------------------------- */
*,
*::before,
*::after {
  box-sizing: border-box;
}

/* --------------------------------------------
   Remove default WordPress content padding
   -------------------------------------------- */
.wp-site-blocks,
.wp-block-post-content {
  padding: 0 !important;
  margin: 0;
}

/* --------------------------------------------
   Body reset (Twenty Twenty-Four safe)
   -------------------------------------------- */
html,
body {
  margin: 0;
  padding: 0;
}

/* --------------------------------------------
   Neutralise block margins (vertical rhythm
   is controlled ONLY by Klaritee utilities)
   -------------------------------------------- */
.wp-block-group,
.wp-block-columns,
.wp-block-column {
  margin-block-start: 0 !important;
  margin-block-end: 0 !important;
}

/* --------------------------------------------
   Kill WordPress-injected gaps on mobile/tablet
   (Desktop gaps are intentional via kt-stack/grid)
   -------------------------------------------- */
@media (max-width: 1024px) {
  .wp-block-group,
  .wp-block-columns,
  .wp-block-column {
    gap: 0 !important;
  }
}

/* --------------------------------------------
   Images & media safety
   -------------------------------------------- */
img,
video,
svg {
  max-width: 100%;
  height: auto;
  display: block;
}

/* --------------------------------------------
   Remove accidental overflow from WP wrappers
   -------------------------------------------- */
body {
  overflow-x: hidden;
}

/* ============================================
   3. LAYOUT SYSTEM
   ============================================ */

/**
 * Section Wrapper (.kt-section)
 * - Full-width container
 * - Background holder
 * - Vertical rhythm via tokens
 */
.kt-section {
  position: relative;
  width: 100%;
  overflow: hidden;
}

/* --------------------------------------------
   Section Variants
   -------------------------------------------- */

/* Default section rhythm */
.kt-section--default {
  padding-top: var(--kt-space-32);
  padding-bottom: var(--kt-space-32);
}

.kt-section--large {
  padding-top: var(--kt-space-40);
  padding-bottom: var(--kt-space-40);
}

.kt-section--small {
  padding-top: var(--kt-space-20);
  padding-bottom: var(--kt-space-20);
}

/* Hero: cinematic only on desktop */
.kt-section--hero {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-top: var(--kt-space-32);
  padding-bottom: var(--kt-space-32);
}

/* Desktop only: full viewport height */
@media (min-width: 1025px) {
  .kt-section--hero {
    min-height: 100vh;
  }
}

/* Mobile + Tablet: natural flow */
@media (max-width: 1024px) {
  .kt-section--hero {
    min-height: auto;
  }
}

/* --------------------------------------------
   Container (.kt-container)
   -------------------------------------------- */

.kt-container {
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: var(--kt-space-6);
  padding-right: var(--kt-space-6);
}

.kt-container--sm { max-width: var(--kt-container-sm); }
.kt-container--md { max-width: var(--kt-container-md); }
.kt-container--lg { max-width: var(--kt-container-lg); }
.kt-container--xl { max-width: var(--kt-container-xl); }
.kt-container--2xl { max-width: var(--kt-container-2xl); }

@media (min-width: 768px) {
  .kt-container {
    padding-left: var(--kt-space-8);
    padding-right: var(--kt-space-8);
  }
}

/* --------------------------------------------
   Stack Layout (.kt-stack)
   -------------------------------------------- */

.kt-stack > * + * {
  margin-top: var(--kt-space-8);
}

.kt-stack--sm > * + * { margin-top: var(--kt-space-4); }
.kt-stack--md > * + * { margin-top: var(--kt-space-8); }
.kt-stack--lg > * + * { margin-top: var(--kt-space-12); }
.kt-stack--xl > * + * { margin-top: var(--kt-space-16); }

/* --------------------------------------------
   Grid Layout (.kt-grid)
   -------------------------------------------- */

.kt-grid {
  display: grid;
  gap: var(--kt-space-8);
}

/* 2 columns */
.kt-grid--2 {
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .kt-grid--2 {
    grid-template-columns: repeat(2, 1fr);
  }
}

/* 3 columns */
.kt-grid--3 {
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .kt-grid--3 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .kt-grid--3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* 4 columns */
.kt-grid--4 {
  grid-template-columns: 1fr;
}

@media (min-width: 768px) {
  .kt-grid--4 {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .kt-grid--4 {
    grid-template-columns: repeat(4, 1fr);
  }
}

/* Grid gap modifiers */
.kt-grid--gap-sm { gap: var(--kt-space-4); }
.kt-grid--gap-md { gap: var(--kt-space-8); }
.kt-grid--gap-lg { gap: var(--kt-space-12); }

/* ============================================
   4. BACKGROUND UTILITIES
   ============================================ */

/* --------------------------------------------
   Solid Backgrounds
   -------------------------------------------- */
.kt-bg-black {
  background-color: var(--kt-black);
}

.kt-bg-charcoal {
  background-color: var(--kt-charcoal);
}

.kt-bg-indigo {
  background-color: var(--kt-deep-indigo);
}

/* --------------------------------------------
   Gradient Backgrounds
   -------------------------------------------- */

/* Hero / major sections */
.kt-bg-gradient-hero {
  background: linear-gradient(
    180deg,
    var(--kt-charcoal) 0%,
    var(--kt-deep-indigo) 50%,
    var(--kt-black) 100%
  );
}

/* Downward flow between sections */
.kt-bg-gradient-down {
  background: linear-gradient(
    180deg,
    var(--kt-black) 0%,
    var(--kt-charcoal) 40%,
    var(--kt-deep-indigo) 70%,
    var(--kt-black) 100%
  );
}

/* Upward flow (used sparingly) */
.kt-bg-gradient-up {
  background: linear-gradient(
    180deg,
    var(--kt-deep-indigo) 0%,
    var(--kt-charcoal) 50%,
    var(--kt-black) 100%
  );
}

/* --------------------------------------------
   Background Layers
   -------------------------------------------- */
/**
 * Usage:
 * <div class="kt-section kt-bg-black">
 *   <div class="kt-bg-layer kt-bg-layer--blur"></div>
 *   <div class="kt-container kt-relative kt-z-10">...</div>
 * </div>
 */

.kt-bg-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
  z-index: 0;
}

/* Soft glow / atmospheric layers */
.kt-bg-layer--blur {
  filter: blur(60px);
}

/* --------------------------------------------
   Mobile & Tablet Safety
   -------------------------------------------- */

/* Reduce heavy blur cost on smaller screens */
@media (max-width: 1024px) {
  .kt-bg-layer--blur {
    filter: blur(40px);
  }
}

@media (max-width: 768px) {
  .kt-bg-layer--blur {
    filter: blur(28px);
  }
}
/* ============================================
   5. CARD COMPONENTS
   ============================================ */

/**
 * --------------------------------------------
 * Base Card (.kt-card)
 * --------------------------------------------
 * - Primary reusable card
 * - Token-based padding
 * - Safe hover accent
 * - Works across all breakpoints
 */
.kt-card {
  position: relative;
  padding: var(--kt-space-10);
  border-radius: var(--kt-radius-md);
  background: linear-gradient(
    180deg,
    var(--kt-charcoal) 0%,
    var(--kt-deep-indigo) 100%
  );
  border: 1px solid rgba(0, 212, 255, 0.2);
  overflow: hidden;
  transition: border-color var(--kt-transition-slow);
}

.kt-card:hover {
  border-color: rgba(0, 212, 255, 0.4);
}

/* Bottom glow accent */
.kt-card::after {
  content: '';
  position: absolute;
  inset-inline: 0;
  bottom: 0;
  height: 2px;
  background: linear-gradient(
    90deg,
    transparent,
    var(--kt-cyan),
    transparent
  );
  box-shadow: var(--kt-shadow-glow-cyan);
  opacity: 0;
  transition: opacity var(--kt-transition-slow);
}

.kt-card:hover::after {
  opacity: 1;
}

/* --------------------------------------------
   Glass Card Variant
   -------------------------------------------- */
.kt-card--glass {
  height: 100%;
  padding: var(--kt-space-10);
  border-radius: var(--kt-radius-lg);
  background: linear-gradient(to bottom, #111214, #0F1A3A);
  border: 1px solid rgba(0, 212, 255, 0.2);
  transition: all var(--kt-transition-slow);
}

/* --------------------------------------------
   Humanity Glass Card
   -------------------------------------------- */
.kt-card--glass-humanity {
  height: 100%;
  padding: var(--kt-space-8);
  border-radius: var(--kt-radius-lg);
  background: rgba(17, 18, 20, 0.5);
  backdrop-filter: blur(4px);
  border: 1px solid rgba(0, 212, 255, 0.15);
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.3);
  transition: transform var(--kt-transition-slow);
}

@media (hover: hover) {
  .kt-card--glass-humanity:hover {
    transform: scale(1.02);
  }
}

/* --------------------------------------------
   Progress Columns
   -------------------------------------------- */
.kt-progress-columns {
  gap: var(--kt-space-12);
}

.kt-progress-column {
  position: relative;
}

.kt-progress-column--divider::before {
  content: '';
  position: absolute;
  left: -1.5rem;
  inset-block: 0;
  width: 1px;
  background: linear-gradient(
    to bottom,
    transparent,
    rgba(0, 212, 255, 0.3),
    transparent
  );
}

@media (max-width: 781px) {
  .kt-progress-column--divider::before {
    display: none;
  }
}

/* Progress dots */
.kt-progress-column__title {
  display: flex;
  align-items: center;
  color: var(--kt-white);
}

.kt-progress-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  margin-right: 12px;
  flex-shrink: 0;
}

.kt-progress-dot--cyan {
  background: var(--kt-cyan);
  box-shadow: 0 0 10px rgba(0, 212, 255, 0.6);
}

.kt-progress-dot--gold {
  background: var(--kt-gold);
  box-shadow: 0 0 10px rgba(245, 201, 138, 0.6);
}

.kt-progress-dot--gray {
  background: rgba(244, 247, 250, 0.3);
}

/* Progress list */
.kt-progress-list {
  list-style: none;
  padding: 0;
  margin: 0;
  color: rgba(244, 247, 250, 0.9);
  font-size: 1.05rem;
  line-height: 1.8;
  font-weight: 300;
}

.kt-progress-list li {
  margin-bottom: 0.5rem;
}

.kt-progress-list li::before {
  content: '•';
  color: rgba(0, 212, 255, 0.4);
  display: inline-block;
  width: 1em;
}

/* --------------------------------------------
   Philosophy Section Elements
   -------------------------------------------- */
.kt-philosophy-principles {
  max-width: 64rem;
  margin-inline: auto;
}

.kt-philosophy-principle {
  padding: var(--kt-space-12) 0;
  color: var(--kt-white);
}

.kt-philosophy-divider {
  height: 1px;
  max-width: 48rem;
  margin-inline: auto;
  background: linear-gradient(
    to right,
    transparent,
    rgba(0, 212, 255, 0.4),
    transparent
  );
  box-shadow: 0 0 8px rgba(0, 212, 255, 0.3);
}

/* --------------------------------------------
   Origin Section (Responsive)
   -------------------------------------------- */
.kt-section--origin {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--kt-black);
}

.kt-origin-content {
  max-width: 80rem;
  margin-inline: auto;
  padding: var(--kt-space-32) var(--kt-space-6);
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

/* Desktop cinematic */
@media (min-width: 1025px) {
  .kt-section--origin,
  .kt-origin-content {
    min-height: 100vh;
  }
}

/* --------------------------------------------
   Safety Section
   -------------------------------------------- */
.kt-section--safety {
  display: flex;
  align-items: center;
  justify-content: center;
}

.kt-safety-grid {
  gap: var(--kt-space-12);
  align-items: center;
}

.kt-safety-metrics {
  display: flex;
  flex-direction: column;
  gap: var(--kt-space-6);
}

/* --------------------------------------------
   Animations (unchanged behavior)
   -------------------------------------------- */
@keyframes kt-zoom-in {
  from { opacity: 0; transform: scale(0.8); }
  to   { opacity: 1; transform: scale(1); }
}

@keyframes kt-fade-slide-left {
  from { opacity: 0; transform: translateX(-30px); }
  to   { opacity: 1; transform: translateX(0); }
}

@keyframes kt-fade-slide-right {
  from { opacity: 0; transform: translateX(30px); }
  to   { opacity: 1; transform: translateX(0); }
}

.kt-zoom-in { animation: kt-zoom-in 1s ease forwards; opacity: 0; }
.kt-fade-slide-left { animation: kt-fade-slide-left 0.8s ease forwards; opacity: 0; }
.kt-fade-slide-right { animation: kt-fade-slide-right 0.8s ease forwards; opacity: 0; }

/* --------------------------------------------
   Solid Card Variant
   -------------------------------------------- */
.kt-card--solid {
  background: var(--kt-charcoal);
  border: 1px solid rgba(0, 212, 255, 0.1);
}

/* --------------------------------------------
   Capabilities Cards
   -------------------------------------------- */
.kt-section--capabilities {
  display: flex;
  align-items: center;
  justify-content: center;
}

.kt-capabilities-grid {
  gap: var(--kt-space-6);
  margin-bottom: var(--kt-space-6);
}

@media (min-width: 1024px) {
  .kt-capabilities-grid {
    gap: var(--kt-space-8);
    margin-bottom: var(--kt-space-8);
  }
}

.kt-capability-card {
  position: relative;
  height: 100%;
  padding: var(--kt-space-8);
  background: linear-gradient(
    135deg,
    rgba(17, 18, 20, 0.8),
    rgba(10, 10, 12, 0.9)
  );
  border: 1px solid rgba(244, 247, 250, 0.08);
  overflow: hidden;
  transition: all var(--kt-transition-slow);
}

/* Hover grid pattern */
.kt-capability-card::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    repeating-linear-gradient(0deg, transparent, transparent 39px, rgba(0, 212, 255, 0.2) 39px, rgba(0, 212, 255, 0.2) 40px),
    repeating-linear-gradient(90deg, transparent, transparent 39px, rgba(0, 212, 255, 0.2) 39px, rgba(0, 212, 255, 0.2) 40px);
  opacity: 0;
  transition: opacity var(--kt-transition-slow);
  pointer-events: none;
}

.kt-capability-card:hover::before {
  opacity: 1;
}

.kt-capability-card::after {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  height: 2px;
  width: 0;
  background: linear-gradient(90deg, var(--kt-cyan), transparent);
  transition: width var(--kt-transition-slow);
}

.kt-capability-card:hover::after {
  width: 100%;
}

.kt-capability-number {
  font-family: monospace;
  font-size: 0.875rem;
  letter-spacing: 0.1em;
  margin-bottom: var(--kt-space-6);
  color: rgba(0, 212, 255, 0.4);
}
/* ============================================
   ROADMAP SECTION - GLOBAL & LAYOUT
   ============================================ */
:root {
  --kt-cyan: #00d4ff;
  --kt-white: #f4f7fa;
  --kt-space-8: 2rem;
  --kt-space-20: 5rem;
}

.kt-section--roadmap {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #0b0c0d; /* Matching your dark theme */
  color: var(--kt-white);
  padding: 4rem 1rem;
}

@media (min-width: 1025px) {
  .kt-section--roadmap { min-height: 100vh; }
}

/* --------------------------------------------
   DESKTOP TIMELINE (Horizontal)
   -------------------------------------------- */
.kt-roadmap-desktop {
  display: none;
  position: relative;
  width: 100%;
  max-width: 1200px;
}

@media (min-width: 1024px) {
  .kt-roadmap-desktop { display: block; }
}

.kt-roadmap-line-horizontal {
  position: absolute;
  top: 2rem;
  inset-inline: 0;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(244, 247, 250, 0.15) 20%, rgba(244, 247, 250, 0.15) 80%, transparent);
  transform-origin: left;
  transform: scaleX(0);
  animation: kt-line-grow-horizontal 1.5s ease forwards 0.3s;
}

@keyframes kt-line-grow-horizontal { to { transform: scaleX(1); } }

.kt-roadmap-phases-desktop {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: var(--kt-space-8);
}

/* --------------------------------------------
   MOBILE / TABLET TIMELINE (Vertical)
   -------------------------------------------- */
.kt-roadmap-mobile {
  display: block;
  position: relative;
  width: 100%;
}

@media (min-width: 1024px) {
  .kt-roadmap-mobile { display: none; }
}

.kt-roadmap-line-vertical {
  position: absolute;
  left: 2rem;
  inset-block: 0;
  width: 1px;
  background: linear-gradient(180deg, transparent, rgba(244, 247, 250, 0.15) 20%, rgba(244, 247, 250, 0.15) 80%, transparent);
  transform-origin: top;
  transform: scaleY(0);
  animation: kt-line-grow-vertical 1.5s ease forwards 0.3s;
}

@keyframes kt-line-grow-vertical { to { transform: scaleY(1); } }

.kt-roadmap-phases-mobile {
  display: flex;
  flex-direction: column;
  gap: var(--kt-space-20);
}

/* --------------------------------------------
   SHARED PHASE STYLING (Node & Content)
   -------------------------------------------- */
.kt-roadmap-phase, .kt-roadmap-phase-mobile {
  display: flex;
  opacity: 0;
  animation: kt-fade-in 0.8s ease forwards;
}

/* Desktop Stack */
.kt-roadmap-phase { flex-direction: column; align-items: center; }
/* Mobile Row */
.kt-roadmap-phase-mobile { gap: var(--kt-space-8); align-items: flex-start; }

@keyframes kt-fade-in {
  from { opacity: 0; transform: translateY(20px); }
  to { opacity: 1; transform: translateY(0); }
}

.kt-roadmap-node {
  position: relative;
  flex-shrink: 0;
  margin-bottom: 1.5rem;
}

.kt-roadmap-node-glow {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: var(--kt-cyan);
  opacity: 0.15;
  filter: blur(12px);
  transform: scale(1.3);
}

.kt-roadmap-node-circle {
  width: 4rem;
  height: 4rem;
  border-radius: 50%;
  background: rgba(17, 18, 20, 0.95);
  border: 1px solid rgba(244, 247, 250, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 2;
  position: relative;
}

.kt-roadmap-node-number {
  font-size: 1.5rem;
  font-weight: 300;
  font-family: serif;
  color: var(--kt-white);
}

.kt-roadmap-phase-content, .kt-roadmap-phase-content-mobile {
  text-align: center;
}

.kt-roadmap-phase-content-mobile { text-align: left; }

.kt-roadmap-status {
  display: block;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--kt-cyan);
  margin-bottom: 0.5rem;
}

h3 { font-size: 1.125rem; margin-bottom: 0.5rem; color: #fff; }
p { font-size: 0.875rem; color: rgba(244, 247, 250, 0.5); line-height: 1.5; }

/* ============================================
   THE FLASH / PULSE EFFECT (PHASE II ONLY)
   ============================================ */

/* Target Phase II on Desktop AND Mobile */
.kt-roadmap-phases-desktop .kt-roadmap-phase:nth-child(2) .kt-roadmap-node-circle,
.kt-roadmap-phases-mobile .kt-roadmap-phase-mobile:nth-child(2) .kt-roadmap-node-circle {
  border-color: rgba(0, 212, 255, 0.8);
  animation: kt-continuous-flash 1.8s ease-in-out infinite;
  box-shadow: 0 0 20px rgba(0, 212, 255, 0.4);
}

.kt-roadmap-phases-desktop .kt-roadmap-phase:nth-child(2) .kt-roadmap-node-glow,
.kt-roadmap-phases-mobile .kt-roadmap-phase-mobile:nth-child(2) .kt-roadmap-node-glow {
  animation: kt-glow-breathing 1.8s ease-in-out infinite;
}

/* Brightness Flash Animation */
@keyframes kt-continuous-flash {
  0%, 100% { filter: brightness(1); box-shadow: 0 0 15px rgba(0, 212, 255, 0.3); }
  50% { filter: brightness(2.2); box-shadow: 0 0 35px rgba(0, 212, 255, 0.7); }
}

/* Expansion Glow Animation */
@keyframes kt-glow-breathing {
  0%, 100% { opacity: 0.2; transform: scale(1.3); }
  50% { opacity: 0.9; transform: scale(2.2); }
}

/* Style for Completed (Phase I) */
.kt-phase-complete .kt-roadmap-node-circle {
  border-color: var(--kt-cyan);
  background: rgba(0, 212, 255, 0.05);
}

/* ============================================
   CLOSING CTA SECTION
   ============================================ */

/**
 * Closing CTA
 * - Mobile/Tablet: top-aligned, natural flow
 * - Desktop: vertically centered, full-height
 */
.kt-section--closing {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start; /*  KEY FIX */
  text-align: center;
  padding-top: var(--kt-space-20);
  padding-bottom: var(--kt-space-20);
}

/* Tablet */
@media (min-width: 768px) {
  .kt-section--closing {
    padding-top: var(--kt-space-24);
    padding-bottom: var(--kt-space-24);
  }
}

/* Desktop only */
@media (min-width: 1025px) {
  .kt-section--closing {
    min-height: 100vh;
    justify-content: center;   /* ✅ Center ONLY on desktop */
    padding-top: var(--kt-space-32);
    padding-bottom: var(--kt-space-32);
  }
}

/* --------------------------------------------
   Email Form
   -------------------------------------------- */

.kt-closing-form-wrapper {
  max-width: 40rem;
  margin-inline: auto;
  margin-bottom: var(--kt-space-12);
}

.kt-closing-form {
  display: flex;
  flex-direction: column;
  gap: var(--kt-space-4);
}

/* Tablet & up */
@media (min-width: 640px) {
  .kt-closing-form {
    flex-direction: row;
    gap: var(--kt-space-3);
  }
}

/* --------------------------------------------
   Social Links
   -------------------------------------------- */

.kt-closing-social {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--kt-space-6);
}

/* Tablet & up */
@media (min-width: 640px) {
  .kt-closing-social {
    flex-direction: row;
  }
}

/* ============================================
   TYPOGRAPHY UTILITIES
   ============================================ */

.kt-text-center { text-align: center; }

.kt-text-white { color: var(--kt-white); }
.kt-text-cyan  { color: var(--kt-cyan); }
.kt-text-gold  { color: var(--kt-gold); }

.kt-text-opacity-85 { opacity: 0.85; }
.kt-text-opacity-75 { opacity: 0.75; }
.kt-text-opacity-70 { opacity: 0.7; }
.kt-text-opacity-60 { opacity: 0.6; }
.kt-text-opacity-50 { opacity: 0.5; }

/* ============================================
   BUTTON COMPONENTS
   ============================================ */

.kt-button {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--kt-space-2);
  padding: var(--kt-space-5) var(--kt-space-10);
  border-radius: var(--kt-radius-md);
  font-size: 1.125rem;
  font-weight: var(--kt-font-normal);
  letter-spacing: var(--kt-tracking-wide);
  cursor: pointer;
  transition: all var(--kt-transition-base);
}

/* ============================================
   ICON UTILITIES
   ============================================ */

.kt-icon {
  display: inline-flex;
  flex-shrink: 0;
}

.kt-icon--sm  { width: 1rem; height: 1rem; }
.kt-icon--md  { width: 1.5rem; height: 1.5rem; }
.kt-icon--lg  { width: 2rem; height: 2rem; }
.kt-icon--xl  { width: 3rem; height: 3rem; }
.kt-icon--2xl { width: 4rem; height: 4rem; }

/* ============================================
   ANIMATION UTILITIES
   ============================================ */

@keyframes kt-fade-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

@keyframes kt-float {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(-20px); }
}

@keyframes kt-pulse {
  0%, 100% { opacity: 0.6; }
  50%      { opacity: 1; }
}

@keyframes kt-glow {
  0%, 100% { opacity: 0.3; }
  50%      { opacity: 0.6; }
}

.kt-animate-fade-in { animation: kt-fade-in 1s ease forwards; }
.kt-animate-float   { animation: kt-float 3s ease-in-out infinite; }
.kt-animate-pulse   { animation: kt-pulse 2s ease-in-out infinite; }
.kt-animate-glow    { animation: kt-glow 3s ease-in-out infinite; }

/* ============================================
   RESPONSIVE VISIBILITY UTILITIES
   ============================================ */

.kt-hide-mobile { display: none; }

@media (min-width: 768px) {
  .kt-hide-mobile { display: block; }
}

.kt-hide-desktop { display: block; }

@media (min-width: 768px) {
  .kt-hide-desktop { display: none; }
}

/* ============================================
   SPACING UTILITIES
   ============================================ */

/* Margin Top */
.kt-mt-0  { margin-top: 0 !important; }
.kt-mt-4  { margin-top: var(--kt-space-4) !important; }
.kt-mt-6  { margin-top: var(--kt-space-6) !important; }
.kt-mt-8  { margin-top: var(--kt-space-8) !important; }
.kt-mt-12 { margin-top: var(--kt-space-12) !important; }
.kt-mt-16 { margin-top: var(--kt-space-16) !important; }
.kt-mt-20 { margin-top: var(--kt-space-20) !important; }
.kt-mt-24 { margin-top: var(--kt-space-24) !important; }

/* Margin Bottom */
.kt-mb-0  { margin-bottom: 0 !important; }
.kt-mb-4  { margin-bottom: var(--kt-space-4) !important; }
.kt-mb-6  { margin-bottom: var(--kt-space-6) !important; }
.kt-mb-8  { margin-bottom: var(--kt-space-8) !important; }
.kt-mb-12 { margin-bottom: var(--kt-space-12) !important; }
.kt-mb-16 { margin-bottom: var(--kt-space-16) !important; }
.kt-mb-20 { margin-bottom: var(--kt-space-20) !important; }
.kt-mb-24 { margin-bottom: var(--kt-space-24) !important; }

/* Padding */
.kt-p-0  { padding: 0 !important; }
.kt-p-4  { padding: var(--kt-space-4) !important; }
.kt-p-6  { padding: var(--kt-space-6) !important; }
.kt-p-8  { padding: var(--kt-space-8) !important; }
.kt-p-10 { padding: var(--kt-space-10) !important; }
.kt-p-12 { padding: var(--kt-space-12) !important; }

/* ============================================
   FLEX & WIDTH UTILITIES
   ============================================ */

.kt-flex        { display: flex; }
.kt-flex-col    { flex-direction: column; }
.kt-flex-center { display: flex; align-items: center; justify-content: center; }

.kt-gap-2 { gap: var(--kt-space-2); }
.kt-gap-4 { gap: var(--kt-space-4); }
.kt-gap-6 { gap: var(--kt-space-6); }
.kt-gap-8 { gap: var(--kt-space-8); }

.kt-max-w-sm  { max-width: var(--kt-container-sm); }
.kt-max-w-md  { max-width: var(--kt-container-md); }
.kt-max-w-lg  { max-width: var(--kt-container-lg); }
.kt-max-w-xl  { max-width: var(--kt-container-xl); }
.kt-max-w-2xl { max-width: var(--kt-container-2xl); }

.kt-mx-auto {
  margin-left: auto;
  margin-right: auto;
}
/* ============================================
   SECTION SIZE MODIFIERS (Mobile-first)
   ============================================ */

/**
 * Mobile: compact, content-driven
 */
.kt-section--default {
  padding-top: var(--kt-space-16);
  padding-bottom: var(--kt-space-16);
}

.kt-section--large {
  padding-top: var(--kt-space-20);
  padding-bottom: var(--kt-space-20);
}

/**
 * Tablet: more breathing room
 */
@media (min-width: 768px) {
  .kt-section--default {
    padding-top: var(--kt-space-24);
    padding-bottom: var(--kt-space-24);
  }

  .kt-section--large {
    padding-top: var(--kt-space-32);
    padding-bottom: var(--kt-space-32);
  }
}

/**
 * Desktop: full design intent
 */
@media (min-width: 1025px) {
  .kt-section--default {
    padding-top: var(--kt-space-32);
    padding-bottom: var(--kt-space-32);
  }

  .kt-section--large {
    padding-top: var(--kt-space-40);
    padding-bottom: var(--kt-space-40);
  }
}
.kt-bg-gradient-origin {
  background:
    linear-gradient(
      to bottom,
      #0a0a0c 0%,
      rgba(10, 10, 12, 0.85) 20%,
      transparent 45%,
      transparent 70%,
      rgba(10, 10, 12, 0.9) 90%,
      #0a0a0c 100%
    );
}


/* ============================================
   END — CLEAN, RESPONSIVE, DOCUMENTED
   ============================================ */
