/* ═══════════════════════════════════════════════════════════
   TS-GLASS-V2  ·  ThreadSync Glass Design System
   Release: 2026-03-04  ·  Tokenized · Layered · Fallback-safe
   ═══════════════════════════════════════════════════════════

   Layer 1: Tokens (variables)
   Layer 2: Background atmosphere
   Layer 3: Glass primitives (.glass-surface, --strong, --soft)
   Layer 4: Component overrides (nav, cards, panels, pills, buttons)
   Layer 5: Motion rules
   Layer 6: Fallbacks + mobile perf
   ═══════════════════════════════════════════════════════════ */


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LAYER 1 · DESIGN TOKENS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */
:root {
  /* Surface + blur */
  --glass-bg:          rgba(255,255,255,0.07);
  --glass-bg-hover:    rgba(255,255,255,0.11);
  --glass-bg-strong:   rgba(255,255,255,0.10);
  --glass-bg-soft:     rgba(255,255,255,0.04);
  --glass-border:      rgba(255,255,255,0.12);
  --glass-border-hover:rgba(255,255,255,0.22);
  --glass-blur:        20px;
  --glass-blur-strong: 28px;
  --glass-blur-soft:   12px;
  --glass-sat:         1.5;
  --glass-bright:      1.1;
  --glass-shadow:      0 8px 32px rgba(0,0,0,0.35),
                       inset 0 1px 0 rgba(255,255,255,0.07);
  --glass-shadow-hover:0 20px 60px rgba(0,0,0,0.45),
                       0 0 40px rgba(59,130,246,0.10),
                       inset 0 1px 0 rgba(255,255,255,0.10);

  /* Radius + spacing (8px grid) */
  --radius-card:  16px;
  --radius-panel: 20px;
  --radius-pill:  9999px;
  --radius-nav:   0;

  /* Atmosphere glows */
  --glow-blue:   rgba(59,130,246,0.22);
  --glow-purple: rgba(139,92,246,0.18);
  --glow-cyan:   rgba(34,211,238,0.12);
  --glow-pink:   rgba(236,72,153,0.07);

  /* Canvas */
  --canvas-bg:   #060810;
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LAYER 2 · BACKGROUND ATMOSPHERE
   Glass needs something to blur — these radial glows provide it
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Darken body so glows pop */
body {
  background: var(--canvas-bg) !important;
}

/* Page canvas wrapper creates the glow layer */
.page-canvas {
  position: relative;
  min-height: 100vh;
  /* NOTE: overflow-x:hidden breaks position:sticky on the nav header
     in several browsers. Use clip instead to hide horizontal overflow
     without creating a new scroll container. */
  overflow-x: clip;
}

.page-canvas::before {
  content: "";
  position: fixed;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 12% 8%,  var(--glow-blue),   transparent 65%),
    radial-gradient(ellipse 65% 55% at 88% 18%, var(--glow-purple), transparent 65%),
    radial-gradient(ellipse 70% 45% at 50% 82%, var(--glow-cyan),   transparent 65%),
    radial-gradient(ellipse 50% 35% at 72% 55%, var(--glow-pink),   transparent 65%);
  pointer-events: none;
  z-index: 0;
}

.page-canvas > * {
  position: relative;
  z-index: 1;
}

/* Replace old fixed-position orbs with the canvas atmosphere */
.page-canvas .ts-orb {
  display: none !important;
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LAYER 3 · GLASS PRIMITIVES
   Base classes everything routes through
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Default glass surface */
.glass-surface {
  background: var(--glass-bg) !important;
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright)) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius-card) !important;
  box-shadow: var(--glass-shadow) !important;
}

/* Strong: nav, modals, hero panels — higher blur + opacity */
.glass-surface--strong {
  --glass-bg: var(--glass-bg-strong);
  --glass-blur: var(--glass-blur-strong);
  --glass-sat: 1.7;
}

/* Soft: pills, badges, chips — lighter touch */
.glass-surface--soft {
  --glass-bg: var(--glass-bg-soft);
  --glass-blur: var(--glass-blur-soft);
  --glass-sat: 1.2;
  --radius-card: var(--radius-pill);
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LAYER 4 · COMPONENT OVERRIDES
   Override the existing bundled CSS with glass treatment
   Using .page-canvas ancestor for specificity over page CSS
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── 4.1 Sticky Glass Nav ── */
.ts-site-header.glass.glass--nav {
  background: rgba(6,8,16,0.60) !important;
  backdrop-filter: blur(var(--glass-blur-strong)) saturate(1.8) brightness(1.08) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur-strong)) saturate(1.8) brightness(1.08) !important;
  border-bottom: 1px solid rgba(255,255,255,0.07) !important;
  border-radius: 0 !important;
  box-shadow: 0 4px 30px rgba(0,0,0,0.25) !important;
  transition: background 0.3s ease, backdrop-filter 0.3s ease !important;
}
/* Scroll state: denser glass */
.ts-site-header.glass.glass--nav.ts-scrolled {
  background: rgba(6,8,16,0.78) !important;
  box-shadow: 0 4px 30px rgba(0,0,0,0.4), 0 1px 0 rgba(255,255,255,0.04) !important;
}

/* ── 4.2 Glass Cards ──
   Platform cards, solution cards, integration boxes, dev cards
   These override the bundled "CRISP SURFACES" + page-specific index.css */
.page-canvas .platform-card,
.page-canvas .solution-card,
.page-canvas .integration-box,
.page-canvas .dev-card {
  background: var(--glass-bg) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius-card) !important;
  box-shadow: var(--glass-shadow) !important;
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright)) !important;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1) !important;
}

.page-canvas .platform-card:hover,
.page-canvas .solution-card:hover,
.page-canvas .integration-box:hover,
.page-canvas .dev-card:hover {
  background: var(--glass-bg-hover) !important;
  border-color: var(--glass-border-hover) !important;
  box-shadow: var(--glass-shadow-hover) !important;
  transform: translateY(-6px) !important;
}

/* Card accent lines — brighter glow on hover */
.page-canvas .platform-card::before,
.page-canvas .solution-card::before {
  background: linear-gradient(90deg, transparent, rgba(59,130,246,0.6), rgba(139,92,246,0.4), transparent) !important;
  height: 2px !important;
}
.page-canvas .platform-card::after,
.page-canvas .solution-card::after {
  background: radial-gradient(ellipse at top center, rgba(59,130,246,0.15), transparent 70%) !important;
}

/* ── 4.3 Glass Stat Boxes ── */
.page-canvas .stat-box {
  background: rgba(255,255,255,0.05) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  border-radius: 14px !important;
  box-shadow: 0 4px 24px rgba(0,0,0,0.30),
              inset 0 1px 0 rgba(255,255,255,0.06) !important;
  backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-sat)) brightness(var(--glass-bright)) !important;
  transition: all 0.3s ease !important;
}
.page-canvas .stat-box:hover {
  background: rgba(255,255,255,0.08) !important;
  border-color: rgba(96,165,250,0.30) !important;
  transform: translateY(-2px) !important;
}

/* ── 4.4 Glass Panels: arch-box, cta-box, trust, portfolio ── */
.page-canvas .arch-box,
.page-canvas .cta-box,
.page-canvas .glass--panel {
  background: var(--glass-bg) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius-panel) !important;
  box-shadow: 0 12px 48px rgba(0,0,0,0.35),
              inset 0 1px 0 rgba(255,255,255,0.07) !important;
  backdrop-filter: blur(var(--glass-blur-strong)) saturate(1.6) brightness(var(--glass-bright)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur-strong)) saturate(1.6) brightness(var(--glass-bright)) !important;
  transition: all 0.4s ease !important;
}
.page-canvas .arch-box:hover,
.page-canvas .cta-box:hover,
.page-canvas .glass--panel:hover {
  background: var(--glass-bg-hover) !important;
  border-color: var(--glass-border-hover) !important;
  box-shadow: 0 20px 60px rgba(0,0,0,0.45),
              0 0 50px rgba(59,130,246,0.08),
              inset 0 1px 0 rgba(255,255,255,0.10) !important;
}

/* Arch box: indigo accent */
.page-canvas .arch-box {
  border-color: rgba(99,102,241,0.20) !important;
}

/* CTA box: blue glow accent */
.page-canvas .cta-box {
  background: rgba(59,130,246,0.06) !important;
  border-color: rgba(59,130,246,0.22) !important;
  box-shadow: 0 16px 50px rgba(0,0,0,0.35),
              0 0 80px rgba(59,130,246,0.10),
              inset 0 1px 0 rgba(255,255,255,0.06) !important;
}

/* Trust section: cyan accent */
.page-canvas .trustbar-section .glass--panel {
  border-color: rgba(34,211,238,0.20) !important;
}

/* ── 4.5 Glass Buttons ── */
.ts-btn.glass-btn-primary {
  background: linear-gradient(135deg, #3b82f6, #7c3aed) !important;
  border: 1px solid rgba(124,58,237,0.45) !important;
  box-shadow: 0 0 24px rgba(59,130,246,0.30),
              0 0 8px rgba(124,58,237,0.15),
              inset 0 1px 0 rgba(255,255,255,0.12) !important;
  transition: all 0.3s ease !important;
}
.ts-btn.glass-btn-primary:hover {
  box-shadow: 0 0 36px rgba(59,130,246,0.45),
              0 0 14px rgba(124,58,237,0.25),
              inset 0 1px 0 rgba(255,255,255,0.18) !important;
  transform: translateY(-2px) !important;
}

/* ── 4.5a Enterprise Button Icons ── */
.btn-icon {
  flex-shrink: 0 !important;
  width: 18px !important;
  height: 18px !important;
  opacity: 0.9 !important;
  transition: all 0.3s ease !important;
  filter: drop-shadow(0 0 3px rgba(255,255,255,0.15)) !important;
}

/* Primary button icons — white glow */
.ts-btn.glass-btn-primary .btn-icon {
  opacity: 1 !important;
  filter: drop-shadow(0 0 4px rgba(255,255,255,0.3)) !important;
}
.ts-btn.glass-btn-primary:hover .btn-icon {
  filter: drop-shadow(0 0 6px rgba(255,255,255,0.5))
          drop-shadow(0 0 12px rgba(59,130,246,0.4)) !important;
  transform: scale(1.05) !important;
}

/* Secondary button icons — subtle blue accent */
.ts-btn-secondary .btn-icon {
  opacity: 0.75 !important;
  filter: drop-shadow(0 0 2px rgba(96,165,250,0.2)) !important;
}
.ts-btn-secondary:hover .btn-icon {
  opacity: 1 !important;
  filter: drop-shadow(0 0 5px rgba(96,165,250,0.4)) !important;
  transform: scale(1.05) !important;
}

/* Inline arrow icons (Trust Center link etc) */
.btn-icon--inline {
  width: 14px !important;
  height: 14px !important;
  vertical-align: middle !important;
  margin-left: 4px !important;
  transition: transform 0.3s ease !important;
}
.glass-link:hover .btn-icon--inline {
  transform: translateX(3px) !important;
}

/* Architecture diagram icons — keep FA but refine */
.page-canvas .arch-layer-name .fas,
.page-canvas .arch-layer-name .fa {
  font-size: 0.875rem !important;
  opacity: 0.7 !important;
  filter: drop-shadow(0 0 4px rgba(99,102,241,0.3)) !important;
}

/* Platform module icons — glass circle treatment */
.page-canvas .platform-icon {
  width: 48px !important;
  height: 48px !important;
  border-radius: 14px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  backdrop-filter: blur(12px) saturate(1.4) !important;
  -webkit-backdrop-filter: blur(12px) saturate(1.4) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25),
              inset 0 1px 0 rgba(255,255,255,0.08) !important;
  transition: all 0.3s ease !important;
}
.page-canvas .platform-icon.blue {
  background: rgba(59,130,246,0.15) !important;
  border-color: rgba(59,130,246,0.25) !important;
}
.page-canvas .platform-icon.green {
  background: rgba(34,197,94,0.15) !important;
  border-color: rgba(34,197,94,0.25) !important;
}
.page-canvas .platform-icon.pink {
  background: rgba(236,72,153,0.15) !important;
  border-color: rgba(236,72,153,0.25) !important;
}
.page-canvas .platform-card:hover .platform-icon {
  transform: scale(1.08) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3),
              0 0 16px var(--glow-blue),
              inset 0 1px 0 rgba(255,255,255,0.12) !important;
}
.page-canvas .platform-icon .fas,
.page-canvas .platform-icon .fa {
  font-size: 1.125rem !important;
  filter: drop-shadow(0 0 6px currentColor) !important;
}

/* Dev card icon — glass treatment */
.page-canvas .dev-icon {
  width: 44px !important;
  height: 44px !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  backdrop-filter: blur(10px) !important;
  -webkit-backdrop-filter: blur(10px) !important;
  border: 1px solid rgba(255,255,255,0.10) !important;
  box-shadow: 0 4px 12px rgba(0,0,0,0.2),
              inset 0 1px 0 rgba(255,255,255,0.06) !important;
  transition: all 0.3s ease !important;
}
.page-canvas .dev-icon.emerald {
  background: rgba(16,185,129,0.15) !important;
  border-color: rgba(16,185,129,0.25) !important;
}
.page-canvas .dev-card:hover .dev-icon {
  transform: scale(1.08) !important;
  box-shadow: 0 4px 20px rgba(0,0,0,0.3),
              0 0 14px rgba(16,185,129,0.3),
              inset 0 1px 0 rgba(255,255,255,0.10) !important;
}

/* Check list icons — subtle glow */
.page-canvas li .fas.fa-check,
.page-canvas li .fa-check {
  color: #60a5fa !important;
  filter: drop-shadow(0 0 4px rgba(96,165,250,0.35)) !important;
  font-size: 0.75rem !important;
}

/* ── 4.6 Glass Pills (trust badges) ── */
.glass-pill {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 16px !important;
  background: var(--glass-bg-soft) !important;
  backdrop-filter: blur(var(--glass-blur-soft)) saturate(1.2) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur-soft)) saturate(1.2) !important;
  border: 1px solid rgba(255,255,255,0.08) !important;
  border-radius: var(--radius-pill) !important;
  font-size: 0.8125rem !important;
  color: #cbd5e1 !important;
  transition: all 0.3s ease !important;
}
.glass-pill:hover {
  background: rgba(255,255,255,0.09) !important;
  border-color: rgba(255,255,255,0.20) !important;
  color: #f1f5f9 !important;
  box-shadow: 0 0 16px rgba(59,130,246,0.10) !important;
}

/* ── 4.7 Section Dividers ── */
.page-canvas .section-alt {
  position: relative;
}
.page-canvas .section-alt::before {
  content: "" !important;
  position: absolute !important;
  top: 0 !important;
  left: 5% !important;
  right: 5% !important;
  height: 1px !important;
  background: linear-gradient(90deg,
    transparent,
    rgba(59,130,246,0.30),
    rgba(139,92,246,0.25),
    rgba(34,211,238,0.18),
    transparent) !important;
  z-index: 2 !important;
}


/* ── 4.7a Proof Bar ── */
.proof-bar {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 8px 20px !important;
  margin-top: 2rem !important;
  margin-bottom: 3rem !important;
  padding: 14px 24px !important;
  background: rgba(255,255,255,0.03) !important;
  border: 1px solid rgba(255,255,255,0.06) !important;
  border-radius: var(--radius-card) !important;
  backdrop-filter: blur(10px) saturate(1.3) !important;
  -webkit-backdrop-filter: blur(10px) saturate(1.3) !important;
}
.proof-bar__item {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  font-size: 0.8125rem !important;
  font-weight: 500 !important;
  color: rgba(203,213,225,0.85) !important;
  white-space: nowrap !important;
}
.proof-bar__item svg {
  flex-shrink: 0 !important;
  color: #60a5fa !important;
  filter: drop-shadow(0 0 3px rgba(96,165,250,0.3)) !important;
}
.proof-bar__item a {
  color: inherit !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  transition: color 0.2s ease !important;
}
.proof-bar__item a:hover {
  color: #93c5fd !important;
}

/* ── 4.8 Unified Section Spacing ──
   Normalizes .section, .ts-section, and .e-section to one rhythm.
   Uses responsive clamp so sections breathe on mobile + desktop. */

.section,
.ts-section,
.e-section {
  padding-block: clamp(3rem, 5vw, 5rem) !important;
}

/* CTA boxes: responsive inner padding for mobile safety */
.cta-box {
  padding: clamp(1.5rem, 5vw, 3.5rem) !important;
}

/* Intro/centered blocks: standardize max-width */
.intro-box {
  max-width: 900px !important;
  margin-inline: auto !important;
}


/* ── 4.8a Enterprise Spacing System ──
   Gap-based section→header→grid hierarchy.
   Kills floating labels and uneven card heights. */

/* ── A. Section Header Component ──
   Every section uses: .section-header (flex + gap, no margins) */
.section-header {
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  margin-bottom: 32px !important;
  text-align: center !important;
}
.section-header h2 {
  margin: 0 !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
}
.section-header p,
.section-header .section-subcopy {
  margin: 0 !important;
  max-width: 600px !important;
  margin-inline: auto !important;
  color: rgba(156,163,175,0.9) !important;
}
.section-header .eyebrow {
  margin: 0 !important;
  display: block !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #60a5fa !important;
  opacity: 0.85 !important;
}

/* ── B. Card Internal Spacing ──
   Flex column + gap, no default heading margins.
   Prevents "why is this card taller?" */
.platform-card,
.solution-card,
.dev-card {
  display: flex !important;
  flex-direction: column !important;
  gap: 0 !important;
}
.platform-card :where(h3, .subtitle, p),
.solution-card :where(h3, p),
.dev-card :where(h3, .subtitle, p) {
  margin: 0 !important;
}
.platform-card h3,
.solution-card h3 {
  margin-bottom: 6px !important;
}
.platform-card .subtitle {
  margin-bottom: 12px !important;
  color: #6b7280 !important;
  font-size: 0.875rem !important;
}
.platform-card p,
.solution-card > p {
  margin-bottom: 14px !important;
  color: rgba(156,163,175,0.9) !important;
  font-size: 0.95rem !important;
  line-height: 1.6 !important;
}
/* Card list items: grid with gap, no default spacing */
.platform-card ul,
.solution-card ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 !important;
  display: grid !important;
  gap: 8px !important;
}
.platform-card li,
.solution-card li {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  padding: 0 !important;
  margin: 0 !important;
  color: #d1d5db !important;
  font-size: 0.9rem !important;
}
.platform-card li svg,
.solution-card li svg {
  color: #60a5fa !important;
  filter: drop-shadow(0 0 4px rgba(96,165,250,0.35)) !important;
}

/* ── C. Card Footer CTA Alignment ──
   Push CTA to bottom so cards align regardless of content height. */
.platform-card > a,
.solution-card > a {
  margin-top: auto !important;
  padding-top: 14px !important;
  color: #60a5fa !important;
  font-size: 0.9rem !important;
  text-decoration: none !important;
  display: inline-block !important;
}
.platform-card > a:hover,
.solution-card > a:hover {
  text-decoration: underline !important;
  color: #93c5fd !important;
}

/* ── D. How It Works → 3-Card Step Grid ──
   Replaces stacked arch-layer rows with equal glass cards. */
.steps-grid {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 20px !important;
}
@media (max-width: 768px) {
  .steps-grid {
    grid-template-columns: 1fr !important;
  }
}
.step-card {
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  text-align: center !important;
  gap: 12px !important;
  padding: 2rem 1.5rem !important;
  background: var(--glass-bg, rgba(255,255,255,0.07)) !important;
  backdrop-filter: blur(var(--glass-blur, 20px)) saturate(var(--glass-sat, 1.5)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur, 20px)) saturate(var(--glass-sat, 1.5)) !important;
  border: 1px solid var(--glass-border, rgba(255,255,255,0.10)) !important;
  border-radius: var(--radius-card, 16px) !important;
  box-shadow: var(--glass-shadow) !important;
  transition: all 0.3s ease !important;
}
.step-card:hover {
  border-color: var(--glass-border-hover, rgba(96,165,250,0.25)) !important;
  transform: translateY(-4px) !important;
  box-shadow: var(--glass-shadow-hover) !important;
}
.step-card .step-number {
  width: 36px !important;
  height: 36px !important;
  border-radius: 50% !important;
  background: linear-gradient(135deg, rgba(59,130,246,0.2), rgba(99,102,241,0.15)) !important;
  border: 1px solid rgba(59,130,246,0.3) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  font-size: 0.875rem !important;
  font-weight: 700 !important;
  color: #60a5fa !important;
}
.step-card .step-icon {
  color: #60a5fa !important;
  filter: drop-shadow(0 0 6px rgba(96,165,250,0.3)) !important;
}
.step-card h3 {
  margin: 0 !important;
  font-size: 1.1rem !important;
  font-weight: 600 !important;
}
.step-card p {
  margin: 0 !important;
  color: rgba(148,163,184,0.85) !important;
  font-size: 0.875rem !important;
  line-height: 1.5 !important;
}
/* Desktop: arrow connectors between step cards */
@media (min-width: 769px) {
  .steps-grid {
    position: relative !important;
  }
  .step-card:not(:last-child)::after {
    content: "→" !important;
    position: absolute !important;
    right: -14px !important;
    top: 50% !important;
    transform: translateY(-50%) !important;
    color: rgba(96,165,250,0.4) !important;
    font-size: 1.25rem !important;
    pointer-events: none !important;
  }
  .step-card {
    position: relative !important;
  }
}

/* ── E. Integrations Block ──
   Explicit wrapper with controlled gap between logo grid and stats. */
.integrations-block {
  display: grid !important;
  gap: 32px !important;
}
.stats-row {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

/* ── Hero spacing ── */
.hero.section {
  min-height: auto !important;
  padding-top: 3rem !important;
  padding-bottom: 1rem !important;
}
.hero-logo-img {
  height: 40vh !important;
  max-height: 380px !important;
}
.hero-logo::before,
.hero-logo::after {
  pointer-events: none !important;
  z-index: -1 !important;
}
.section.ts-sf32ef6fd1b {
  padding-top: 0 !important;
  padding-bottom: clamp(2rem, 4vw, 4rem) !important;
}
.portfolio-callout {
  margin-top: 0 !important;
}
.trustbar-section.section {
  padding-block: clamp(2.5rem, 4vw, 4rem) !important;
}

/* ── F. Dev card link colors (homepage uses <a> wrapping entire card) ── */
section .dev-grid .dev-card[href] {
  text-decoration: none !important;
  color: inherit !important;
}
section .dev-grid .dev-card[href]:hover h3 {
  color: #93c5fd !important;
}

/* ── 4.9 Developer Hub ──
   Styles for /developers/ index — must be external (CSP blocks inline <style>).
   Glass-treated cards with gradient accent icons. */

.dev-hero {
  background: linear-gradient(135deg, rgba(99,102,241,0.08) 0%, rgba(139,92,246,0.08) 100%) !important;
  padding: clamp(3rem, 5vw, 5rem) 0 !important;
}
.dev-hero h1 {
  font-size: clamp(2rem, 4vw, 2.75rem) !important;
  font-weight: 700 !important;
  margin-bottom: 1rem !important;
}
.dev-hero .subtitle {
  font-size: 1.25rem !important;
  color: rgba(148,163,184,0.9) !important;
  margin-bottom: 1.5rem !important;
  max-width: 600px !important;
}

/* Breadcrumb nav */
.breadcrumb {
  margin-bottom: 2rem !important;
  font-size: 0.875rem !important;
}
.breadcrumb a {
  color: #6366f1 !important;
  text-decoration: none !important;
}
.breadcrumb a:hover { text-decoration: underline !important; }
.breadcrumb span { color: #64748b !important; margin: 0 0.5rem !important; }

/* Dev card grid */
.dev-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)) !important;
  gap: 1.5rem !important;
  margin: 2.5rem 0 !important;
}

/* Dev cards — glass treatment */
.dev-card {
  background: var(--glass-bg, rgba(255,255,255,0.07)) !important;
  backdrop-filter: blur(var(--glass-blur, 20px)) saturate(var(--glass-sat, 1.5)) !important;
  -webkit-backdrop-filter: blur(var(--glass-blur, 20px)) saturate(var(--glass-sat, 1.5)) !important;
  border: 1px solid var(--glass-border, rgba(255,255,255,0.10)) !important;
  border-radius: var(--radius-card, 16px) !important;
  padding: 2rem !important;
  transition: transform 0.25s ease, border-color 0.25s ease, box-shadow 0.25s ease !important;
}
.dev-card:hover {
  border-color: rgba(99,102,241,0.4) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 8px 32px rgba(99,102,241,0.12),
              0 0 0 1px rgba(99,102,241,0.15) !important;
}

/* Card icon — gradient circle */
.dev-card-icon {
  width: 48px !important;
  height: 48px !important;
  background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%) !important;
  border-radius: 12px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin-bottom: 1rem !important;
  box-shadow: 0 4px 12px rgba(99,102,241,0.25) !important;
}
.dev-card-icon svg {
  width: 24px !important;
  height: 24px !important;
  color: white !important;
}

/* Card content */
.dev-card .category {
  font-size: 0.6875rem !important;
  text-transform: uppercase !important;
  letter-spacing: 0.08em !important;
  color: #8b5cf6 !important;
  margin-bottom: 0.75rem !important;
  display: block !important;
}
.dev-card h3 {
  font-size: 1.2rem !important;
  font-weight: 600 !important;
  margin-bottom: 0.5rem !important;
  color: #f1f5f9 !important;
}
.dev-card p {
  color: rgba(148,163,184,0.85) !important;
  font-size: 0.9375rem !important;
  line-height: 1.6 !important;
  margin-bottom: 1rem !important;
}
.dev-card .link {
  color: #818cf8 !important;
  font-size: 0.875rem !important;
  font-weight: 500 !important;
  text-decoration: none !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 0.25rem !important;
  transition: color 0.2s ease !important;
}
.dev-card .link:hover {
  color: #a5b4fc !important;
  text-decoration: underline !important;
}

/* Resources section */
.resources-section {
  background: rgba(8,8,10,0.6) !important;
  padding: clamp(3rem, 5vw, 5rem) 0 !important;
}

/* Quick links row */
.quick-links {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 1rem !important;
  margin-top: 2rem !important;
}
.quick-link {
  background: var(--glass-bg, rgba(255,255,255,0.07)) !important;
  backdrop-filter: blur(12px) saturate(1.3) !important;
  -webkit-backdrop-filter: blur(12px) saturate(1.3) !important;
  border: 1px solid var(--glass-border, rgba(255,255,255,0.10)) !important;
  border-radius: 10px !important;
  padding: 1rem 1.5rem !important;
  color: #e2e8f0 !important;
  text-decoration: none !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.75rem !important;
  transition: all 0.2s ease !important;
  font-size: 0.9375rem !important;
}
.quick-link:hover {
  border-color: rgba(99,102,241,0.35) !important;
  background: rgba(255,255,255,0.10) !important;
  transform: translateY(-1px) !important;
}
.quick-link svg {
  width: 20px !important;
  height: 20px !important;
  color: #818cf8 !important;
  flex-shrink: 0 !important;
}

/* Section header (used on dev page and others) */
.dev-hero + .ts-container .section-header,
.resources-section .section-header {
  margin-bottom: 1.5rem !important;
}
.dev-hero + .ts-container .section-header h2,
.resources-section .section-header h2 {
  font-size: 1.75rem !important;
  font-weight: 600 !important;
  margin-bottom: 0.5rem !important;
}
.dev-hero + .ts-container .section-header p,
.resources-section .section-header p {
  color: rgba(148,163,184,0.85) !important;
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LAYER 5 · MOTION RULES
   Subtle, expensive-feeling transitions
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Respect user preference */
@media (prefers-reduced-motion: reduce) {
  .page-canvas .platform-card,
  .page-canvas .solution-card,
  .page-canvas .integration-box,
  .page-canvas .stat-box,
  .page-canvas .arch-box,
  .page-canvas .cta-box,
  .page-canvas .glass--panel,
  .glass-pill,
  .ts-btn.glass-btn-primary {
    transition: none !important;
  }
  .page-canvas .platform-card:hover,
  .page-canvas .solution-card:hover,
  .page-canvas .stat-box:hover,
  .ts-btn.glass-btn-primary:hover {
    transform: none !important;
  }
  .page-canvas::before {
    animation: none !important;
  }
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LAYER 6 · FALLBACKS + MOBILE PERFORMANCE
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* Browsers without backdrop-filter: solid fallback */
@supports not ((backdrop-filter: blur(1px)) or (-webkit-backdrop-filter: blur(1px))) {
  .page-canvas .platform-card,
  .page-canvas .solution-card,
  .page-canvas .integration-box,
  .page-canvas .dev-card,
  .page-canvas .stat-box,
  .page-canvas .arch-box,
  .page-canvas .cta-box,
  .page-canvas .glass--panel,
  .ts-site-header.glass.glass--nav {
    background: rgba(12,14,22,0.93) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
  }
}

/* Mobile: reduce blur for GPU perf, shrink atmosphere */
@media (max-width: 640px) {
  :root {
    --glass-blur: 14px;
    --glass-blur-strong: 18px;
    --glass-blur-soft: 8px;
    --glass-sat: 1.3;
  }
  .page-canvas::before {
    opacity: 0.55;
  }
}

/* Tablet: moderate reduction */
@media (min-width: 641px) and (max-width: 1024px) {
  :root {
    --glass-blur: 16px;
    --glass-blur-strong: 22px;
    --glass-sat: 1.4;
  }
  .page-canvas::before {
    opacity: 0.75;
  }
}


/* ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━
   LAYER 7 · CSP COMPLIANCE
   Inline style="" attributes blocked by style-src-attr 'none'.
   All visual properties moved to named classes.
   ━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━ */

/* ── Portfolio Callout ── */
.portfolio-container {
  text-align: center !important;
}
.portfolio-callout {
  max-width: 680px !important;
  margin: 0 auto !important;
  padding: 2.5rem 3rem !important;
  text-align: center !important;
}
.portfolio-callout h2 {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  margin-bottom: 0.75rem !important;
}
.portfolio-callout p {
  color: #94a3b8 !important;
  font-size: 0.9375rem !important;
  margin-bottom: 1.25rem !important;
}

/* ── Dev Card Title Rows ── */
.dev-card-title-row {
  display: flex !important;
  align-items: center !important;
  gap: 0.5rem !important;
  margin-bottom: 0.25rem !important;
}

/* ── Tag Badges ── */
.tag {
  font-size: 0.65rem !important;
  padding: 2px 8px !important;
  border-radius: 999px !important;
}
.tag--blue {
  background: rgba(59,130,246,0.15) !important;
  color: #60a5fa !important;
}
.tag--indigo {
  background: rgba(99,102,241,0.15) !important;
  color: #818cf8 !important;
}
.tag--cyan {
  background: rgba(6,182,212,0.15) !important;
  color: #22d3ee !important;
}

/* ── Dev Card Subtitles ── */
.dev-card .subtitle {
  color: #6b7280 !important;
  font-size: 0.85rem !important;
  margin-bottom: 0.75rem !important;
}

/* ── Dev Card Links ── */
.dev-card .link {
  color: #60a5fa !important;
  font-size: 0.9rem !important;
  margin-top: auto !important;
}
.dev-card .link--indigo {
  color: #818cf8 !important;
}
.dev-card .link--cyan {
  color: #22d3ee !important;
}

/* ── Dev Icon Variants ── */
.dev-icon.indigo {
  background: rgba(99,102,241,0.15) !important;
  color: #818cf8 !important;
}
.dev-icon.cyan {
  background: rgba(6,182,212,0.15) !important;
  color: #22d3ee !important;
}

/* ── Section Header Tight (How It Works) ── */
.section-header--tight {
  margin-top: 1rem !important;
}

/* ── Integration Logos ── */
.integration-logo {
  display: block !important;
  margin: 0 auto 0.6rem !important;
  width: 36px !important;
  height: 36px !important;
}

/* ── Check Icons (list items) ── */
.check-icon {
  flex-shrink: 0 !important;
  margin-top: 3px !important;
}

/* ── Footer Brand Logo ── */
.footer-brand-logo {
  height: 24px !important;
  margin-bottom: 6px !important;
  opacity: 0.85 !important;
}

/* ── Nav Magic Link ── */
.nav-magic-link {
  color: #a78bfa !important;
}

/* ── Release Stamp ── */
.release-stamp {
  color: #6b7280 !important;
  font-size: 0.7rem !important;
  white-space: nowrap !important;
}

/* ── Link Inherit ── */
.link-inherit {
  color: inherit !important;
  text-decoration: none !important;
}

/* ── Portfolio Bar (moved from inline <style>) ── */
@media(min-width:1024px) {
  #ts-portfolio-bar { display: block !important; border-bottom: 1px solid rgba(255,255,255,0.06); background: rgba(0,0,0,0.3); padding: 6px 0; font-size: 12px; }
}
.ts-portfolio { display: flex; align-items: center; justify-content: space-between; max-width: 1280px; margin: 0 auto; padding: 0 1.5rem; }
.ts-portfolio-pills { display: flex; align-items: center; gap: 4px; }
.ts-portfolio-pill { display: inline-flex; align-items: center; gap: 6px; padding: 4px 12px; border-radius: 9999px; font-size: 12px; font-weight: 500; color: #6b7280; text-decoration: none; border: 1px solid transparent; transition: all 0.2s; }
.ts-portfolio-pill:hover { color: #60a5fa; background: rgba(96,165,250,0.08); border-color: rgba(96,165,250,0.2); }
.ts-portfolio-pill.active { color: #60a5fa; background: rgba(96,165,250,0.1); border-color: rgba(96,165,250,0.3); font-weight: 600; }
.ts-portfolio-pill .dot { width: 6px; height: 6px; border-radius: 50%; }
.ts-portfolio-pill .dot-amber { width: 6px; height: 6px; border-radius: 50%; background: #d97706; }
.ts-portfolio-pill .dot-blue { width: 6px; height: 6px; border-radius: 50%; background: #3b82f6; }
.ts-portfolio-pill .dot-purple { width: 6px; height: 6px; border-radius: 50%; background: #8b5cf6; }
.ts-portfolio-label { font-size: 12px; color: #4b5563; }

/* ── Enterprise Spacing Tokens ── */
:root {
  --sp-eyebrow-h2: 10px;
  --sp-h2-subcopy: 12px;
  --sp-header-grid: 32px;
  --sp-card-pad: 24px;
  --sp-card-title-body: 10px;
  --sp-grid-gap: 20px;
}

/* ── Unified SectionHeader ── */
.section-header {
  display: flex !important;
  flex-direction: column !important;
  gap: var(--sp-eyebrow-h2) !important;
  margin-bottom: var(--sp-header-grid) !important;
  text-align: center !important;
}
.section-header :where(h1, h2, h3, p) {
  margin: 0 !important;
}
.section-header .eyebrow {
  margin: 0 !important;
  font-size: 0.75rem !important;
  font-weight: 600 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
  color: #60a5fa !important;
  opacity: 0.85 !important;
}
.section-header h2 {
  margin: 0 !important;
  font-size: 2rem !important;
  font-weight: 700 !important;
}
.section-header p,
.section-header .section-subcopy {
  margin: 0 !important;
  max-width: 600px !important;
  margin-inline: auto !important;
  color: rgba(156,163,175,0.9) !important;
  opacity: 0.85 !important;
}

/* ── Unified Card Grids ── */
.platform-grid,
.solutions-grid {
  display: grid !important;
  gap: var(--sp-grid-gap) !important;
}
.platform-grid {
  grid-template-columns: repeat(3, 1fr) !important;
}
.solutions-grid {
  grid-template-columns: repeat(2, 1fr) !important;
}
@media (max-width: 768px) {
  .platform-grid,
  .solutions-grid {
    grid-template-columns: 1fr !important;
  }
}

/* ── Card Internal Anatomy ── */
.platform-card,
.solution-card {
  display: flex !important;
  flex-direction: column !important;
  padding: var(--sp-card-pad) !important;
}
.platform-card h3,
.solution-card h3 {
  margin: 0 0 var(--sp-card-title-body) 0 !important;
}
.platform-card p,
.solution-card p {
  margin: 0 0 14px 0 !important;
  color: rgba(156,163,175,0.9) !important;
  font-size: 0.95rem !important;
  line-height: 1.6 !important;
}
.platform-card .subtitle,
.solution-card .subtitle {
  margin: 0 0 8px 0 !important;
  color: #6b7280 !important;
  font-size: 0.85rem !important;
}
/* Card list items */
.platform-card ul,
.solution-card ul {
  list-style: none !important;
  padding: 0 !important;
  margin: 0 0 0 0 !important;
  display: grid !important;
  gap: 8px !important;
}
.platform-card li,
.solution-card li {
  display: flex !important;
  align-items: flex-start !important;
  gap: 10px !important;
  padding: 0 !important;
  margin: 0 !important;
  color: #d1d5db !important;
  font-size: 0.9rem !important;
}
.platform-card li svg,
.solution-card li svg {
  color: #60a5fa !important;
  filter: drop-shadow(0 0 4px rgba(96,165,250,0.35)) !important;
}
/* Card CTA pinned to bottom */
.platform-card > a,
.solution-card > a {
  margin-top: auto !important;
  padding-top: 14px !important;
  color: #60a5fa !important;
  font-size: 0.9rem !important;
  text-decoration: none !important;
  display: inline-block !important;
}
.platform-card > a:hover,
.solution-card > a:hover {
  text-decoration: underline !important;
  color: #93c5fd !important;
}

/* ── Dev Card Anatomy ── */
.dev-card {
  display: flex !important;
  flex-direction: column !important;
  padding: var(--sp-card-pad) !important;
}
.dev-card h3 {
  margin: 0 !important;
  font-size: 1.1rem !important;
}
.dev-card p {
  margin: 0 0 14px 0 !important;
  color: rgba(156,163,175,0.9) !important;
  font-size: 0.9rem !important;
  line-height: 1.6 !important;
  flex: 1 !important;
}
.dev-card .link {
  margin-top: auto !important;
}
