/* ========================================
   NowWorksAI — Production Website Styles
   ======================================== */

/* --- CSS Variables --- */
:root {
   /* Brand gradient */
   --grad-1: #FF4D88;
   --grad-2: #FF8C42;
   --grad-3: #FFD166;
   --grad-4: #06D6A0;
   --grad-5: #4D96FF;

   /* Neutrals */
   --ink: #111827;
   --slate: #6B7280;
   --paper: #F9FAFB;
   --dark: #0A0F1A;
   --dark-card: #111827;
   --dark-border: rgba(255,255,255,0.06);
   --dark-hover: rgba(255,255,255,0.04);

   /* Typography */
   --font-display: 'Syne', sans-serif;
   --font-body: 'Plus Jakarta Sans', sans-serif;

   /* Spacing */
   --space-xs: 0.5rem;
   --space-sm: 0.75rem;
   --space-md: 1rem;
   --space-lg: 1.5rem;
   --space-xl: 2rem;
   --space-2xl: 3rem;
   --space-3xl: 4rem;
   --space-4xl: 6rem;
   --space-5xl: 8rem;

   /* Radius */
   --radius: 16px;
   --radius-lg: 20px;

   /* Transitions */
   --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
   --ease-spring: cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* --- Reset & Base --- */
*, *::before, *::after {
   margin: 0;
   padding: 0;
   box-sizing: border-box;
}

html {
   scroll-behavior: smooth;
   font-size: 16px;
   -webkit-font-smoothing: antialiased;
   -moz-osx-font-smoothing: grayscale;
}

body {
   font-family: var(--font-body);
   color: var(--ink);
   background: var(--paper);
   overflow-x: hidden;
   line-height: 1.6;
}

a {
   text-decoration: none;
   color: inherit;
}

ul { list-style: none; }
img { max-width: 100%; display: block; }

.container {
   max-width: 1280px;
   margin: 0 auto;
   padding: 0 var(--space-xl);
}

/* --- Cursor Follower --- */
.cursor-follower {
   position: fixed;
   width: 24px;
   height: 24px;
   border-radius: 50%;
   background: radial-gradient(circle, rgba(77,150,255,0.15), transparent 70%);
   pointer-events: none;
   z-index: 9999;
   transform: translate(-50%, -50%);
   transition: width 0.3s var(--ease-out), height 0.3s var(--ease-out), opacity 0.3s;
   opacity: 0;
}

body:hover .cursor-follower {
   opacity: 1;
}

.cursor-follower.hovering {
   width: 48px;
   height: 48px;
   background: radial-gradient(circle, rgba(255,77,136,0.2), transparent 70%);
}

/* --- Navigation --- */
.nav {
   position: fixed;
   top: 0;
   left: 0;
   right: 0;
   z-index: 1000;
   padding: var(--space-lg) 0;
   transition: all 0.4s var(--ease-out);
}

/* Nav background always visible */
.nav::before {
   content: '';
   position: absolute;
   inset: 0;
   background: rgba(10, 15, 26, 0.85);
   backdrop-filter: blur(16px);
   -webkit-backdrop-filter: blur(16px);
   border-bottom: 1px solid var(--dark-border);
   z-index: -1;
}

.nav.scrolled {
   background: transparent;
   padding: var(--space-md) 0;
}

.nav.scrolled::before {
   background: rgba(10, 15, 26, 0.95);
}

.nav.scrolled {
   background: rgba(17, 24, 39, 0.92);
   backdrop-filter: blur(20px);
   -webkit-backdrop-filter: blur(20px);
   border-bottom: 1px solid var(--dark-border);
   padding: var(--space-md) 0;
}

.nav-inner {
   max-width: 1280px;
   margin: 0 auto;
   padding: 0 var(--space-xl);
   display: flex;
   align-items: center;
   justify-content: space-between;
}

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

.nav-wordmark {
   font-family: var(--font-display);
   font-weight: 800;
   font-size: 1.125rem;
   background: linear-gradient(90deg, var(--grad-1), var(--grad-2), var(--grad-3), var(--grad-4), var(--grad-5));
   -webkit-background-clip: text;
   -webkit-text-fill-color: transparent;
   background-clip: text;
}

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

.nav-link {
   font-size: 0.875rem;
   font-weight: 500;
   color: rgba(255,255,255,0.7);
   transition: color 0.3s;
   position: relative;
}

.nav-link::after {
   content: '';
   position: absolute;
   bottom: -4px;
   left: 0;
   width: 0;
   height: 2px;
   background: linear-gradient(90deg, var(--grad-1), var(--grad-5));
   transition: width 0.3s var(--ease-out);
   border-radius: 1px;
}

.nav-link:hover {
   color: #fff;
}

.nav-link:hover::after {
   width: 100%;
}

.nav-cta {
   padding: 10px 24px;
   border: 1px solid rgba(255,255,255,0.2);
   border-radius: 100px;
   transition: all 0.3s var(--ease-out);
}

.nav-cta:hover {
   background: rgba(255,255,255,0.1);
   border-color: rgba(255,255,255,0.4);
}

/* Hamburger */
.nav-hamburger {
   display: none;
   flex-direction: column;
   gap: 5px;
   background: none;
   border: none;
   cursor: pointer;
   padding: 4px;
   z-index: 1001;
}

.nav-hamburger span {
   display: block;
   width: 24px;
   height: 2px;
   background: #fff;
   border-radius: 1px;
   transition: all 0.3s var(--ease-out);
}

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

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

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

/* Mobile menu */
.mobile-menu {
   position: fixed;
   top: 0;
   left: 0;
   right: 0;
   bottom: 0;
   background: rgba(10, 15, 26, 0.98);
   backdrop-filter: blur(24px);
   z-index: 999;
   display: flex;
   flex-direction: column;
   align-items: center;
   justify-content: center;
   gap: var(--space-xl);
   opacity: 0;
   visibility: hidden;
   transition: all 0.4s var(--ease-out);
}

.mobile-menu.active {
   opacity: 1;
   visibility: visible;
}

.mobile-menu-close {
   position: absolute;
   top: var(--space-xl);
   right: var(--space-xl);
   background: none;
   border: none;
   color: #fff;
   font-size: 2rem;
   cursor: pointer;
   width: 48px;
   height: 48px;
   display: flex;
   align-items: center;
   justify-content: center;
   border-radius: 50%;
   transition: background 0.3s;
}

.mobile-menu-close:hover {
   background: rgba(255,255,255,0.1);
}

.mobile-menu-link {
   font-family: var(--font-display);
   font-size: 2rem;
   font-weight: 700;
   color: rgba(255,255,255,0.8);
   transition: color 0.3s;
   opacity: 0;
   transform: translateY(20px);
}

.mobile-menu.active .mobile-menu-link {
   opacity: 1;
   transform: translateY(0);
}

.mobile-menu.active .mobile-menu-link:nth-child(2) { transition-delay: 0.1s; }
.mobile-menu.active .mobile-menu-link:nth-child(3) { transition-delay: 0.15s; }
.mobile-menu.active .mobile-menu-link:nth-child(4) { transition-delay: 0.2s; }
.mobile-menu.active .mobile-menu-link:nth-child(5) { transition-delay: 0.25s; }

.mobile-menu-link:hover {
   color: #fff;
}

.mobile-cta {
   margin-top: var(--space-lg);
   padding: 14px 36px;
   border: 1px solid rgba(255,255,255,0.2);
   border-radius: 100px;
   font-size: 1rem;
}

/* --- Buttons --- */
.btn {
   display: inline-flex;
   align-items: center;
   gap: var(--space-sm);
   padding: 14px 28px;
   border-radius: 100px;
   font-family: var(--font-body);
   font-weight: 600;
   font-size: 0.9375rem;
   cursor: pointer;
   transition: all 0.3s var(--ease-out);
   border: none;
   position: relative;
   overflow: hidden;
}

.btn-primary {
   background: linear-gradient(90deg, var(--grad-1), var(--grad-2), var(--grad-3), var(--grad-4), var(--grad-5));
   background-size: 200% 100%;
   color: var(--ink);
   box-shadow: 0 4px 24px rgba(255,77,136,0.25), 0 0 0 0 rgba(77,150,255,0);
}

.btn-primary:hover {
   background-position: 100% 0;
   box-shadow: 0 8px 32px rgba(255,77,136,0.35), 0 0 60px rgba(77,150,255,0.15);
   transform: translateY(-2px);
}

.btn-primary:active {
   transform: translateY(0);
}

.btn-ghost {
   background: transparent;
   color: rgba(255,255,255,0.8);
   border: 1px solid rgba(255,255,255,0.2);
}

.btn-ghost:hover {
   background: rgba(255,255,255,0.08);
   border-color: rgba(255,255,255,0.4);
   color: #fff;
}

.btn--large {
   padding: 16px 36px;
   font-size: 1rem;
}

/* --- Hero Section --- */
.hero {
   min-height: 100vh;
   background: var(--dark);
   position: relative;
   overflow: visible;
   display: flex;
   align-items: center;
   padding: 160px 0 var(--space-5xl);
}

/* Grid background */
.hero-grid-bg {
   position: absolute;
   inset: 0;
   background-image:
      linear-gradient(rgba(255,255,255,0.02) 1px, transparent 1px),
      linear-gradient(90deg, rgba(255,255,255,0.02) 1px, transparent 1px);
   background-size: 60px 60px;
   mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black 20%, transparent 70%);
   -webkit-mask-image: radial-gradient(ellipse 70% 70% at 50% 50%, black 20%, transparent 70%);
}

/* Gradient orbs */
.hero-orb {
   position: absolute;
   border-radius: 50%;
   filter: blur(100px);
   opacity: 0.4;
   animation: orbFloat 8s var(--ease-out) infinite alternate;
}

.hero-orb--1 {
   width: 500px;
   height: 500px;
   background: radial-gradient(circle, rgba(255,77,136,0.3), transparent 70%);
   top: -10%;
   right: 10%;
   animation-delay: 0s;
}

.hero-orb--2 {
   width: 400px;
   height: 400px;
   background: radial-gradient(circle, rgba(77,150,255,0.25), transparent 70%);
   bottom: -5%;
   left: 5%;
   animation-delay: 2s;
}

.hero-orb--3 {
   width: 300px;
   height: 300px;
   background: radial-gradient(circle, rgba(6,214,160,0.2), transparent 70%);
   top: 40%;
   right: 30%;
   animation-delay: 4s;
}

@keyframes orbFloat {
   0% { transform: translate(0, 0) scale(1); }
   100% { transform: translate(30px, -20px) scale(1.1); }
}

/* Floating hexagons */
.hex-float {
   position: absolute;
   opacity: 0.6;
   animation: hexDrift 12s var(--ease-out) infinite alternate;
}

.hex-float--1 {
   top: 15%;
   left: 8%;
   animation-delay: 0s;
}

.hex-float--2 {
   top: 60%;
   right: 12%;
   animation-delay: 3s;
}

.hex-float--3 {
   bottom: 20%;
   left: 25%;
   animation-delay: 6s;
}

@keyframes hexDrift {
   0% { transform: translate(0, 0) rotate(0deg); }
   100% { transform: translate(-20px, 15px) rotate(15deg); }
}

/* Hero inner */
.hero-inner {
   max-width: 1280px;
   margin: 0 auto;
   padding: 0 var(--space-xl) 80px;
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: var(--space-5xl);
   align-items: center;
   position: relative;
   z-index: 2;
}

/* Hero content */
.hero-content {
   max-width: 600px;
}

.hero-badge {
   display: inline-flex;
   align-items: center;
   gap: var(--space-sm);
   padding: 8px 20px;
   background: rgba(255,255,255,0.05);
   border: 1px solid rgba(255,255,255,0.1);
   border-radius: 100px;
   font-size: 0.8125rem;
   font-weight: 500;
   color: rgba(255,255,255,0.8);
   margin-bottom: var(--space-xl);
   letter-spacing: 0.02em;
}

.badge-dot {
   width: 6px;
   height: 6px;
   border-radius: 50%;
   background: var(--grad-4);
   animation: badgePulse 2s ease-in-out infinite;
}

@keyframes badgePulse {
   0%, 100% { opacity: 1; box-shadow: 0 0 0 0 rgba(6,214,160,0.4); }
   50% { opacity: 0.6; box-shadow: 0 0 0 6px rgba(6,214,160,0); }
}

.hero-title {
   font-family: var(--font-display);
   font-size: clamp(2.5rem, 5vw, 4rem);
   font-weight: 800;
   line-height: 1.08;
   color: #fff;
   margin-bottom: var(--space-xl);
   letter-spacing: -0.02em;
}

.gradient-text {
   background: linear-gradient(90deg, var(--grad-1), var(--grad-2), var(--grad-3), var(--grad-4), var(--grad-5));
   -webkit-background-clip: text;
   -webkit-text-fill-color: transparent;
   background-clip: text;
}

.gradient-text--underline {
   position: relative;
}

.gradient-text--underline::after {
   content: '';
   position: absolute;
   bottom: -4px;
   left: 0;
   width: 100%;
   height: 4px;
   background: linear-gradient(90deg, var(--grad-1), var(--grad-2), var(--grad-3), var(--grad-4), var(--grad-5));
   border-radius: 2px;
   opacity: 0.5;
}

.hero-subtitle {
   font-size: 1.125rem;
   line-height: 1.7;
   color: rgba(255,255,255,0.75);
   margin-bottom: var(--space-2xl);
   max-width: 520px;
}

.hero-actions {
   display: flex;
   gap: var(--space-md);
   margin-bottom: var(--space-3xl);
   flex-wrap: wrap;
}

/* Hero stats */
.hero-stats {
   display: flex;
   gap: var(--space-2xl);
   padding-top: var(--space-xl);
   border-top: 1px solid rgba(255,255,255,0.08);
}

.stat {
   display: flex;
   flex-direction: column;
   gap: 4px;
}

.stat-number {
   font-family: var(--font-display);
   font-size: 2rem;
   font-weight: 800;
   color: #fff;
   line-height: 1;
}

.stat-suffix {
   font-family: var(--font-display);
   font-size: 1.5rem;
   font-weight: 700;
   background: linear-gradient(90deg, var(--grad-4), var(--grad-5));
   -webkit-background-clip: text;
   -webkit-text-fill-color: transparent;
   background-clip: text;
}

.stat-label {
   font-size: 0.8125rem;
   color: rgba(255,255,255,0.4);
   font-weight: 500;
}

.stat-stat {
   width: 1px;
   background: rgba(255,255,255,0.08);
   align-self: stretch;
}

/* Hero visual */
.hero-visual {
   display: flex;
   align-items: center;
   justify-content: center;
}

.hex-network svg {
   width: 100%;
   max-width: 700px;
   height: auto;
   filter: drop-shadow(0 0 80px rgba(77,150,255,0.2));
}

.hex-pulse {
   animation: hexPulse 4s ease-in-out infinite;
}

@keyframes hexPulse {
   0%, 100% { opacity: 0.6; }
   50% { opacity: 1; }
}

.node-pulse {
   animation: nodeGlow 3s ease-in-out infinite;
}

@keyframes nodeGlow {
   0%, 100% { opacity: 0.5; r: 4; }
   50% { opacity: 1; r: 6; }
}

/* Scroll indicator */
.scroll-indicator {
   position: absolute;
   bottom: var(--space-2xl);
   left: 50%;
   transform: translateX(-50%);
   display: flex;
   flex-direction: column;
   align-items: center;
   gap: var(--space-sm);
   color: rgba(255,255,255,0.3);
   font-size: 0.75rem;
   font-weight: 500;
   letter-spacing: 0.1em;
   text-transform: uppercase;
   animation: scrollBounce 2s ease-in-out infinite;
   z-index: 10;
}

/* Ensure hero has room at bottom for scroll indicator */
.hero-inner {
   padding-bottom: 60px;
}

.scroll-line {
   width: 1px;
   height: 40px;
   background: linear-gradient(to bottom, rgba(255,255,255,0.3), transparent);
   animation: scrollLine 2s ease-in-out infinite;
}

@keyframes scrollBounce {
   0%, 100% { transform: translateX(-50%) translateY(0); }
   50% { transform: translateX(-50%) translateY(8px); }
}

@keyframes scrollLine {
   0% { opacity: 0; transform: scaleY(0); transform-origin: top; }
   50% { opacity: 1; transform: scaleY(1); }
   100% { opacity: 0; transform: scaleY(0); transform-origin: bottom; }
}

/* --- Reveal animations --- */
.hero-reveal {
   opacity: 0;
   transform: translateY(30px);
   animation: reveal 0.8s var(--ease-out) forwards;
}

.hero-reveal[data-delay="100"] { animation-delay: 0.1s; }
.hero-reveal[data-delay="200"] { animation-delay: 0.2s; }
.hero-reveal[data-delay="300"] { animation-delay: 0.3s; }
.hero-reveal[data-delay="400"] { animation-delay: 0.4s; }

@keyframes reveal {
   to { opacity: 1; transform: translateY(0); }
}

/* --- Section shared --- */
.section-header {
   text-align: center;
   margin-bottom: var(--space-4xl);
}

.section-tag {
   display: inline-flex;
   align-items: center;
   gap: var(--space-sm);
   padding: 6px 16px;
   background: rgba(255,77,136,0.08);
   border: 1px solid rgba(255,77,136,0.15);
   border-radius: 100px;
   font-size: 0.75rem;
   font-weight: 600;
   color: var(--grad-1);
   letter-spacing: 0.05em;
   text-transform: uppercase;
   margin-bottom: var(--space-lg);
}

.section-tag--light {
   background: rgba(77,150,255,0.08);
   border-color: rgba(77,150,255,0.15);
   color: var(--grad-5);
}

.section-title {
   font-family: var(--font-display);
   font-size: clamp(2rem, 4vw, 3rem);
   font-weight: 800;
   color: var(--ink);
   line-height: 1.15;
   letter-spacing: -0.02em;
   margin-bottom: var(--space-md);
}

.section-title-light {
   color: #fff;
}

.gradient-text-light {
   background: linear-gradient(90deg, var(--grad-1), var(--grad-2), var(--grad-3), var(--grad-4), var(--grad-5));
   -webkit-background-clip: text;
   -webkit-text-fill-color: transparent;
   background-clip: text;
}

.section-desc-light {
   font-size: 1.125rem;
   color: rgba(255,255,255,0.5);
   max-width: 600px;
   margin: 0 auto;
   line-height: 1.7;
}

/* --- Services Section --- */
.services {
   padding: var(--space-5xl) 0;
   background: var(--paper);
   position: relative;
}

.services::before {
   content: '';
   position: absolute;
   top: 0;
   left: 0;
   right: 0;
   height: 1px;
   background: linear-gradient(90deg, transparent, rgba(77,150,255,0.2), transparent);
}

.services-grid {
   display: grid;
   grid-template-columns: repeat(3, 1fr);
   gap: var(--space-xl);
}

.service-card {
   background: #fff;
   border: 1px solid rgba(0,0,0,0.06);
   border-radius: var(--radius-lg);
   padding: var(--space-2xl);
   transition: all 0.4s var(--ease-out);
   position: relative;
   overflow: hidden;
   opacity: 0;
   transform: translateY(40px);
}

.service-card.visible {
   opacity: 1;
   transform: translateY(0);
}

.service-card::before {
   content: '';
   position: absolute;
   top: 0;
   left: 0;
   right: 0;
   height: 3px;
   background: linear-gradient(90deg, var(--grad-1), var(--grad-5));
   opacity: 0;
   transition: opacity 0.4s var(--ease-out);
}

.service-card:hover {
   transform: translateY(-4px);
   box-shadow: 0 20px 60px rgba(0,0,0,0.08);
   border-color: rgba(77,150,255,0.15);
}

.service-card:hover::before {
   opacity: 1;
}

.service-icon {
   width: 56px;
   height: 56px;
   border-radius: var(--radius);
   background: linear-gradient(135deg, rgba(255,77,136,0.08), rgba(77,150,255,0.08));
   display: flex;
   align-items: center;
   justify-content: center;
   margin-bottom: var(--space-lg);
   transition: transform 0.3s var(--ease-spring);
}

.service-card:hover .service-icon {
   transform: scale(1.1) rotate(-3deg);
}

.service-icon svg {
   width: 28px;
   height: 28px;
}

.service-card h3 {
   font-family: var(--font-display);
   font-size: 1.25rem;
   font-weight: 700;
   color: var(--ink);
   margin-bottom: var(--space-sm);
   letter-spacing: -0.01em;
}

.service-card p {
   font-size: 0.9375rem;
   color: var(--slate);
   line-height: 1.65;
   margin-bottom: var(--space-lg);
}

.service-list {
   display: flex;
   flex-direction: column;
   gap: 6px;
}

.service-list li {
   font-size: 0.8125rem;
   color: var(--slate);
   padding-left: 16px;
   position: relative;
}

.service-list li::before {
   content: '';
   position: absolute;
   left: 0;
   top: 8px;
   width: 6px;
   height: 6px;
   border-radius: 50%;
   background: linear-gradient(135deg, var(--grad-4), var(--grad-5));
}

/* --- Approach Section --- */
.approach {
   padding: var(--space-5xl) 0;
   background: var(--dark);
   position: relative;
   overflow: hidden;
}

.approach::before {
   content: '';
   position: absolute;
   top: 0;
   left: 0;
   right: 0;
   height: 1px;
   background: linear-gradient(90deg, transparent, rgba(255,77,136,0.3), transparent);
}

.approach-layout {
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: var(--space-4xl);
   align-items: center;
}

.approach-content {
   max-width: 560px;
}

.process-steps {
   margin-top: var(--space-3xl);
   display: flex;
   flex-direction: column;
   gap: var(--space-lg);
}

.process-step {
   display: flex;
   gap: var(--space-lg);
   padding: var(--space-lg);
   border-radius: var(--radius);
   transition: all 0.3s var(--ease-out);
   cursor: default;
   opacity: 0;
   transform: translateX(-30px);
}

.process-step.visible {
   opacity: 1;
   transform: translateX(0);
}

.process-step:hover {
   background: rgba(255,255,255,0.03);
}

.step-number {
   font-family: var(--font-display);
   font-size: 1.5rem;
   font-weight: 800;
   background: linear-gradient(135deg, var(--grad-1), var(--grad-5));
   -webkit-background-clip: text;
   -webkit-text-fill-color: transparent;
   background-clip: text;
   line-height: 1.2;
   min-width: 48px;
}

.step-content h4 {
   font-family: var(--font-display);
   font-size: 1.125rem;
   font-weight: 700;
   color: #fff;
   margin-bottom: 4px;
}

.step-content p {
   font-size: 0.9375rem;
   color: rgba(255,255,255,0.45);
   line-height: 1.65;
}

/* Approach visual */
.approach-visual {
   display: flex;
   align-items: center;
   justify-content: center;
}

.hex-visual svg {
   width: 100%;
   max-width: 420px;
   height: auto;
   animation: hexVisualRotate 30s linear infinite;
   filter: drop-shadow(0 0 40px rgba(77,150,255,0.1));
}

@keyframes hexVisualRotate {
   from { transform: rotate(0deg); }
   to { transform: rotate(360deg); }
}

/* --- Why Section --- */
.why {
   padding: var(--space-5xl) 0;
   background: var(--paper);
   position: relative;
}

.why-grid {
   display: grid;
   grid-template-columns: repeat(2, 1fr);
   gap: var(--space-xl);
   margin-top: var(--space-3xl);
}

.why-card {
   background: #fff;
   border: 1px solid rgba(0,0,0,0.06);
   border-radius: var(--radius-lg);
   padding: var(--space-2xl);
   position: relative;
   overflow: hidden;
   transition: all 0.4s var(--ease-out);
   opacity: 0;
   transform: translateY(30px);
}

.why-card.visible {
   opacity: 1;
   transform: translateY(0);
}

.why-card:hover {
   transform: translateY(-4px);
   box-shadow: 0 16px 48px rgba(0,0,0,0.06);
}

.why-number {
   font-family: var(--font-display);
   font-size: 3rem;
   font-weight: 800;
   background: linear-gradient(135deg, rgba(255,77,136,0.15), rgba(77,150,255,0.15));
   -webkit-background-clip: text;
   -webkit-text-fill-color: transparent;
   background-clip: text;
   line-height: 1;
   margin-bottom: var(--space-md);
}

.why-card h3 {
   font-family: var(--font-display);
   font-size: 1.25rem;
   font-weight: 700;
   color: var(--ink);
   margin-bottom: var(--space-sm);
}

.why-card p {
   font-size: 0.9375rem;
   color: var(--slate);
   line-height: 1.65;
}

/* --- Marquee Section --- */
.marquee-section {
   padding: var(--space-2xl) 0;
   background: var(--dark);
   border-top: 1px solid var(--dark-border);
   border-bottom: 1px solid var(--dark-border);
   overflow: hidden;
}

.marquee-track {
   animation: marqueeScroll 25s linear infinite;
}

.marquee-content {
   display: flex;
   align-items: center;
   gap: var(--space-2xl);
   white-space: nowrap;
}

.marquee-content span {
   font-family: var(--font-display);
   font-size: 1.25rem;
   font-weight: 700;
   color: rgba(255,255,255,0.2);
   text-transform: uppercase;
   letter-spacing: 0.05em;
   flex-shrink: 0;
}

.marquee-dot {
   width: 6px;
   height: 6px;
   border-radius: 50%;
   background: linear-gradient(135deg, var(--grad-1), var(--grad-5));
   flex-shrink: 0;
}

@keyframes marqueeScroll {
   from { transform: translateX(0); }
   to { transform: translateX(-50%); }
}

/* --- CTA / Contact Section --- */
.cta-section {
   padding: var(--space-5xl) 0;
   background: var(--dark);
   position: relative;
   overflow: hidden;
}

.cta-bg-orb {
   position: absolute;
   width: 600px;
   height: 600px;
   border-radius: 50%;
   background: radial-gradient(circle, rgba(77,150,255,0.12), transparent 70%);
   top: 50%;
   left: 50%;
   transform: translate(-50%, -50%);
   filter: blur(80px);
   pointer-events: none;
}

.cta-card {
   position: relative;
   z-index: 1;
   background: rgba(255,255,255,0.03);
   border: 1px solid rgba(255,255,255,0.08);
   border-radius: var(--radius-lg);
   padding: var(--space-4xl);
   max-width: 780px;
   margin: 0 auto;
   backdrop-filter: blur(12px);
}

.cta-content {
   text-align: center;
}

.cta-content h2 {
   font-family: var(--font-display);
   font-size: clamp(1.75rem, 3.5vw, 2.5rem);
   font-weight: 800;
   color: #fff;
   line-height: 1.2;
   margin-bottom: var(--space-md);
   letter-spacing: -0.02em;
}

.cta-content > p {
   font-size: 1.0625rem;
   color: rgba(255,255,255,0.5);
   margin-bottom: var(--space-2xl);
   line-height: 1.7;
}

.cta-form {
   text-align: left;
   display: flex;
   flex-direction: column;
   gap: var(--space-lg);
}

.form-row {
   display: grid;
   grid-template-columns: 1fr 1fr;
   gap: var(--space-lg);
}

.form-group {
   display: flex;
   flex-direction: column;
   gap: 6px;
}

.form-group--full {
   grid-column: 1 / -1;
}

.form-group label {
   font-size: 0.8125rem;
   font-weight: 600;
   color: rgba(255,255,255,0.6);
   letter-spacing: 0.03em;
}

.form-group input,
.form-group select,
.form-group textarea {
   background: rgba(255,255,255,0.04);
   border: 1px solid rgba(255,255,255,0.1);
   border-radius: 12px;
   padding: 14px 16px;
   font-family: var(--font-body);
   font-size: 0.9375rem;
   color: #fff;
   transition: all 0.3s var(--ease-out);
   outline: none;
}

.form-group input::placeholder,
.form-group textarea::placeholder {
   color: rgba(255,255,255,0.25);
}

.form-group input:focus,
.form-group select:focus,
.form-group textarea:focus {
   border-color: rgba(77,150,255,0.5);
   background: rgba(255,255,255,0.06);
   box-shadow: 0 0 0 3px rgba(77,150,255,0.1);
}

.form-group select {
   appearance: none;
   cursor: pointer;
   background-image: url("data:image/svg+xml,%3Csvg width='12' height='8' viewBox='0 0 12 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='rgba(255,255,255,0.4)' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
   background-repeat: no-repeat;
   background-position: right 16px center;
   padding-right: 40px;
}

.form-group select option {
   background: var(--dark-card);
   color: #fff;
}

.form-group textarea {
   resize: vertical;
   min-height: 100px;
}

.cta-form .btn {
   align-self: center;
   margin-top: var(--space-sm);
}

/* --- Footer --- */
.footer {
   padding: var(--space-3xl) 0 var(--space-xl);
   background: var(--dark);
   border-top: 1px solid var(--dark-border);
}

.footer-top {
   display: grid;
   grid-template-columns: 1.5fr 1fr;
   gap: var(--space-3xl);
   padding-bottom: var(--space-2xl);
   border-bottom: 1px solid var(--dark-border);
}

.footer-brand p {
   font-size: 0.875rem;
   color: rgba(255,255,255,0.4);
   margin-top: var(--space-md);
   max-width: 280px;
   line-height: 1.6;
}

.footer-logo {
   display: flex;
   align-items: center;
   gap: var(--space-sm);
   font-family: var(--font-display);
   font-weight: 700;
   font-size: 1.125rem;
   color: #fff;
}

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

.footer-col h4 {
   font-family: var(--font-display);
   font-size: 0.8125rem;
   font-weight: 700;
   color: rgba(255,255,255,0.5);
   text-transform: uppercase;
   letter-spacing: 0.08em;
   margin-bottom: var(--space-md);
}

.footer-col a {
   display: block;
   font-size: 0.875rem;
   color: rgba(255,255,255,0.35);
   padding: 4px 0;
   transition: color 0.3s;
}

.footer-col a:hover {
   color: rgba(255,255,255,0.8);
}

.footer-bottom {
   padding-top: var(--space-xl);
   text-align: center;
}

.footer-bottom p {
   font-size: 0.8125rem;
   color: rgba(255,255,255,0.25);
}

/* --- Scroll reveal (general) --- */
.scroll-reveal {
   opacity: 0;
   transform: translateY(30px);
   transition: opacity 0.7s var(--ease-out), transform 0.7s var(--ease-out);
}

.scroll-reveal.visible {
   opacity: 1;
   transform: translateY(0);
}

/* --- Responsive --- */
@media (max-width: 1024px) {
   .hero-inner {
      grid-template-columns: 1fr;
      text-align: center;
   }

   .hero-content {
      max-width: 100%;
   }

   .hero-subtitle {
      max-width: 100%;
      margin-left: auto;
      margin-right: auto;
   }

   .hero-actions {
      justify-content: center;
   }

   .hero-stats {
      justify-content: center;
   }

   .hero-visual {
      max-width: 400px;
      margin: var(--space-2xl) auto 0;
   }

   .services-grid {
      grid-template-columns: repeat(2, 1fr);
   }

   .approach-layout {
      grid-template-columns: 1fr;
      gap: var(--space-3xl);
   }

   .approach-content {
      max-width: 100%;
      text-align: center;
   }

   .process-steps {
      max-width: 500px;
      margin-left: auto;
      margin-right: auto;
   }

   .approach-visual {
      order: -1;
   }

   .why-grid {
      grid-template-columns: 1fr;
   }

   .footer-top {
      grid-template-columns: 1fr;
      gap: var(--space-2xl);
   }
}

@media (max-width: 768px) {
   :root {
      --space-4xl: 4rem;
      --space-5xl: 5rem;
   }

   .nav-links {
      display: none;
   }

   .nav-hamburger {
      display: flex;
   }

   .hero {
      min-height: auto;
      padding: var(--space-5xl) 0 var(--space-3xl);
   }

   .hero-title {
      font-size: 2.25rem;
   }

   .hero-stats {
      flex-direction: column;
      align-items: center;
      gap: var(--space-lg);
   }

   .stat-stat {
      width: 40px;
      height: 1px;
   }

   .services-grid {
      grid-template-columns: 1fr;
   }

   .form-row {
      grid-template-columns: 1fr;
   }

   .cta-card {
      padding: var(--space-xl);
   }

   .footer-links {
      flex-direction: column;
      gap: var(--space-xl);
   }

   .hex-float {
      display: none;
   }

   .cursor-follower {
      display: none;
   }
}

@media (max-width: 480px) {
   .hero-title {
      font-size: 1.875rem;
   }

   .hero-actions {
      flex-direction: column;
      align-items: stretch;
   }

   .btn {
      justify-content: center;
   }

   .cta-content h2 {
      font-size: 1.5rem;
   }
}
