/* ========================================
   STRATIFY — Design System v4
   ======================================== */
:root {
    --primary: #4F46E5;
    --primary-light: #818CF8;
    --primary-dark: #3730A3;
    --accent-purple: #7C3AED;
    --accent-green: #10B981;
    --accent-blue: #06B6D4;
    --accent-amber: #F59E0B;
    --accent-red: #EF4444;
    --bg-dark: #0B0F1A;
    --bg-card: #111827;
    --bg-elevated: #1a2236;
    --text-primary: #F9FAFB;
    --text-secondary: #9CA3AF;
    --text-muted: #6B7280;
    --border: rgba(255,255,255,0.06);
    --border-hover: rgba(255,255,255,0.12);
    --gradient-primary: linear-gradient(135deg, #4F46E5 0%, #7C3AED 50%, #06B6D4 100%);
    --gradient-glow: radial-gradient(600px circle at var(--mouse-x,50%) var(--mouse-y,50%), rgba(79,70,229,0.07), transparent 40%);
    --font-body: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    --font-heading: 'Space Grotesk', 'Inter', sans-serif;
    --section-padding: 120px 0;
    --radius-sm: 8px; --radius-md: 12px; --radius-lg: 20px; --radius-xl: 24px;
    --transition: 0.3s cubic-bezier(0.4,0,0.2,1);
    --transition-slow: 0.6s cubic-bezier(0.4,0,0.2,1);
}

/* Reset */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;overflow-x:hidden}
body{font-family:var(--font-body);background:var(--bg-dark);color:var(--text-primary);line-height:1.6;overflow-x:hidden;cursor:none}
body.loading{overflow:hidden}
::selection{background:rgba(79,70,229,0.3);color:#fff}
a{text-decoration:none;color:inherit;transition:var(--transition);cursor:none}
button{cursor:none}
ul{list-style:none}
img{max-width:100%;display:block}
.container{max-width:1200px;margin:0 auto;padding:0 24px}
.text-gradient{background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}

/* Noise overlay */
body::after{content:'';position:fixed;inset:0;pointer-events:none;z-index:9998;opacity:0.018;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ========================================
   Custom Cursor
   ======================================== */
.custom-cursor{position:fixed;z-index:99999;pointer-events:none;mix-blend-mode:difference}
.cursor-dot{width:6px;height:6px;background:#fff;border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:width 0.15s,height 0.15s}
.cursor-ring{width:36px;height:36px;border:1.5px solid rgba(255,255,255,0.5);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:width 0.25s,height 0.25s,border-color 0.25s}
.custom-cursor.hovering .cursor-dot{width:10px;height:10px}
.custom-cursor.hovering .cursor-ring{width:50px;height:50px;border-color:var(--primary-light)}

/* ========================================
   Scroll Progress Bar
   ======================================== */
.scroll-progress{position:fixed;top:0;left:0;height:3px;background:var(--gradient-primary);z-index:10001;width:0;transition:none;border-radius:0 2px 2px 0;box-shadow:0 0 10px rgba(79,70,229,0.5)}

/* ========================================
   Page Loader
   ======================================== */
.page-loader{position:fixed;inset:0;z-index:9999;background:var(--bg-dark);display:flex;align-items:center;justify-content:center;transition:opacity 0.6s ease,visibility 0.6s ease}
.page-loader.hidden{opacity:0;visibility:hidden;pointer-events:none}
.loader-content{display:flex;flex-direction:column;align-items:center;gap:24px}
.page-loader .logo-icon{width:52px;height:52px;font-size:1.5rem;animation:loader-pulse 1.2s ease-in-out infinite}
@keyframes loader-pulse{0%,100%{transform:scale(1);box-shadow:0 0 0 0 rgba(79,70,229,0.4)}50%{transform:scale(1.08);box-shadow:0 0 0 15px rgba(79,70,229,0)}}
.loader-bar{width:200px;height:3px;background:rgba(255,255,255,0.06);border-radius:3px;overflow:hidden}
.loader-progress{height:100%;background:var(--gradient-primary);border-radius:3px;animation:load 1.2s ease-in-out forwards}
@keyframes load{0%{width:0}50%{width:70%}100%{width:100%}}
.loader-percent{font-family:var(--font-heading);font-size:0.85rem;font-weight:600;color:var(--text-muted);letter-spacing:0.05em}

/* ========================================
   Cookie Consent Banner
   ======================================== */
.cookie-banner{position:fixed;bottom:0;left:0;right:0;background:rgba(17,24,39,0.95);backdrop-filter:blur(20px);border-top:1px solid var(--border);padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px;z-index:9997;transform:translateY(100%);transition:transform 0.5s cubic-bezier(0.4,0,0.2,1);flex-wrap:wrap}
.cookie-banner.show{transform:translateY(0)}
.cookie-banner.hide{transform:translateY(100%)}
.cookie-text{display:flex;align-items:center;gap:12px;flex:1;min-width:280px}
.cookie-text svg{color:var(--accent-amber);flex-shrink:0}
.cookie-text p{font-size:0.85rem;color:var(--text-secondary);line-height:1.5}
.cookie-text a{color:var(--primary-light);font-weight:500}
.cookie-text a:hover{text-decoration:underline}
.cookie-actions{display:flex;gap:10px;flex-shrink:0}
.cookie-btn{padding:8px 20px;border-radius:var(--radius-sm);font-size:0.84rem;font-weight:600;border:none;cursor:pointer;transition:var(--transition);font-family:var(--font-body)}
.cookie-decline{background:rgba(255,255,255,0.06);color:var(--text-secondary)}
.cookie-decline:hover{background:rgba(255,255,255,0.1);color:var(--text-primary)}
.cookie-accept{background:var(--primary);color:#fff}
.cookie-accept:hover{background:var(--primary-light)}

/* ========================================
   Cursor Glow
   ======================================== */
.cursor-glow{position:fixed;width:500px;height:500px;border-radius:50%;background:radial-gradient(circle,rgba(79,70,229,0.06) 0%,transparent 70%);pointer-events:none;z-index:0;transform:translate(-50%,-50%);transition:opacity 0.3s;opacity:0}
.cursor-glow.visible{opacity:1}

/* ========================================
   Floating Notification
   ======================================== */
.floating-notification{position:fixed;bottom:32px;left:32px;display:flex;align-items:center;gap:12px;background:rgba(17,24,39,0.9);backdrop-filter:blur(20px);border:1px solid var(--border-hover);border-radius:var(--radius-md);padding:14px 20px;z-index:100;opacity:0;transform:translateY(20px);transition:all 0.5s cubic-bezier(0.4,0,0.2,1);box-shadow:0 12px 40px rgba(0,0,0,0.4)}
.floating-notification.show{opacity:1;transform:translateY(0)}
.floating-notification.hide{opacity:0;transform:translateY(20px)}
.notification-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(16,185,129,0.15);border-radius:50%;color:var(--accent-green);flex-shrink:0}
.notification-text{display:flex;flex-direction:column}
.notification-text strong{font-size:0.82rem;font-weight:600}
.notification-text span{font-size:0.75rem;color:var(--text-muted)}
.notification-time{font-size:0.7rem;color:var(--text-muted);margin-left:auto;white-space:nowrap}

/* ========================================
   Section Navigation Dots
   ======================================== */
.section-dots{position:fixed;right:24px;top:50%;transform:translateY(-50%);z-index:100;display:flex;flex-direction:column;gap:12px;opacity:0;transition:opacity 0.4s}
.section-dots.visible{opacity:1}
.dot{width:10px;height:10px;border-radius:50%;background:rgba(255,255,255,0.15);transition:var(--transition);position:relative;cursor:pointer}
.dot.active{background:var(--primary);box-shadow:0 0 10px rgba(79,70,229,0.5)}
.dot span{position:absolute;right:20px;top:50%;transform:translateY(-50%);white-space:nowrap;font-size:0.72rem;color:var(--text-muted);opacity:0;pointer-events:none;transition:var(--transition);background:var(--bg-card);padding:4px 10px;border-radius:4px;border:1px solid var(--border)}
.dot:hover span{opacity:1}

/* ========================================
   Navigation
   ======================================== */
.navbar{position:fixed;top:0;left:0;right:0;z-index:1000;padding:20px 0;transition:var(--transition);backdrop-filter:blur(0px)}
.navbar.scrolled{padding:12px 0;background:rgba(11,15,26,0.8);backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border);box-shadow:0 4px 30px rgba(0,0,0,0.2)}
.nav-container{display:flex;align-items:center;justify-content:space-between}
.logo{display:flex;align-items:center;gap:10px;font-family:var(--font-heading);font-weight:700;font-size:1.4rem}
.logo-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;background:var(--gradient-primary);border-radius:var(--radius-sm);font-size:1.1rem;font-weight:700;color:#fff;transition:var(--transition)}
.logo:hover .logo-icon{transform:rotate(-5deg) scale(1.05)}
.nav-links{display:flex;align-items:center;gap:32px}
.nav-links a{font-size:0.88rem;font-weight:500;color:var(--text-secondary);position:relative}
.nav-links a:hover{color:var(--text-primary)}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:2px;background:var(--gradient-primary);transition:var(--transition);border-radius:1px}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{background:var(--primary);color:#fff!important;padding:10px 24px;border-radius:var(--radius-sm);font-weight:600!important;position:relative;overflow:hidden}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 4px 15px rgba(79,70,229,0.4)}
.mobile-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:4px}
.mobile-toggle span{width:24px;height:2px;background:var(--text-primary);border-radius:2px;transition:var(--transition)}
.mobile-toggle.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.mobile-toggle.active span:nth-child(2){opacity:0}
.mobile-toggle.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* ========================================
   Hero
   ======================================== */
.hero{min-height:100vh;display:flex;flex-direction:column;justify-content:center;position:relative;padding:120px 0 80px;overflow:hidden}
.hero-bg-grid{position:absolute;inset:0;background-image:linear-gradient(rgba(255,255,255,0.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,0.025) 1px,transparent 1px);background-size:60px 60px;mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 20%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse 80% 60% at 50% 40%,black 20%,transparent 70%)}
.hero-particles{position:absolute;inset:0;pointer-events:none;z-index:0}
.hero-orb{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;opacity:0.35}
.hero-orb-1{width:600px;height:600px;background:radial-gradient(circle,rgba(79,70,229,0.3),transparent 70%);top:-200px;left:20%;animation:orb1 12s ease-in-out infinite}
.hero-orb-2{width:400px;height:400px;background:radial-gradient(circle,rgba(124,58,237,0.25),transparent 70%);bottom:-100px;right:10%;animation:orb2 10s ease-in-out infinite}
.hero-orb-3{width:300px;height:300px;background:radial-gradient(circle,rgba(6,182,212,0.2),transparent 70%);top:40%;left:-100px;animation:orb3 14s ease-in-out infinite}
@keyframes orb1{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,30px) scale(1.1)}66%{transform:translate(-20px,-20px) scale(0.95)}}
@keyframes orb2{0%,100%{transform:translate(0,0) scale(1)}50%{transform:translate(-30px,-40px) scale(1.1)}}
@keyframes orb3{0%,100%{transform:translate(0,0)}50%{transform:translate(50px,-30px)}}
.hero-container{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;position:relative;z-index:1}
.hero-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 16px;background:rgba(79,70,229,0.1);border:1px solid rgba(79,70,229,0.2);border-radius:100px;font-size:0.82rem;font-weight:500;color:var(--primary-light);margin-bottom:24px;width:fit-content;backdrop-filter:blur(10px)}
.badge-dot{width:8px;height:8px;background:var(--accent-green);border-radius:50%;animation:pulse-dot 2s infinite;flex-shrink:0}
@keyframes pulse-dot{0%,100%{opacity:1;box-shadow:0 0 0 0 rgba(16,185,129,0.4)}50%{opacity:0.8;box-shadow:0 0 0 6px rgba(16,185,129,0)}}
.hero h1{font-family:var(--font-heading);font-size:clamp(2.8rem,5vw,4.5rem);font-weight:700;line-height:1.08;letter-spacing:-0.03em;margin-bottom:24px}
.text-reveal{display:inline-block}
.hero-subtitle{font-size:1.12rem;color:var(--text-secondary);line-height:1.75;max-width:540px;margin-bottom:36px}
.hero-actions{display:flex;gap:16px;margin-bottom:56px}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:14px 28px;border-radius:var(--radius-sm);font-size:0.95rem;font-weight:600;cursor:none;border:none;transition:var(--transition);white-space:nowrap;position:relative;overflow:hidden}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 0 20px rgba(79,70,229,0.3),inset 0 1px 0 rgba(255,255,255,0.1)}
.btn-primary:hover{background:var(--primary-light);box-shadow:0 0 40px rgba(79,70,229,0.5),inset 0 1px 0 rgba(255,255,255,0.1);transform:translateY(-2px)}
.btn-primary:active{transform:translateY(0)}
.btn-shine{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.12),transparent);transition:none}
.btn:hover .btn-shine{animation:shine 0.6s ease}
@keyframes shine{to{left:100%}}
.btn-secondary{background:rgba(255,255,255,0.03);color:var(--text-primary);border:1px solid var(--border-hover);backdrop-filter:blur(10px)}
.btn-secondary:hover{background:rgba(255,255,255,0.08);border-color:rgba(255,255,255,0.2);transform:translateY(-2px)}
.btn-call{background:rgba(16,185,129,0.1);color:var(--accent-green);border:1px solid rgba(16,185,129,0.3)}
.btn-call:hover{background:var(--accent-green);color:#fff;transform:translateY(-2px);box-shadow:0 0 30px rgba(16,185,129,0.4)}
.btn-call .btn-text{display:flex;align-items:center;gap:8px}
.form-buttons{display:flex;flex-direction:column;gap:12px}
.btn-full{width:100%;justify-content:center}
.btn-icon{display:flex;transition:transform 0.3s}
.btn:hover .btn-icon{transform:translateX(3px)}

/* Hero Stats */
.hero-stats{display:flex;align-items:center;gap:32px}
.stat-row{display:flex;align-items:baseline}
.stat{display:flex;flex-direction:column}
.stat-number{font-family:var(--font-heading);font-size:2.2rem;font-weight:700;color:var(--text-primary);line-height:1}
.stat-suffix{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--primary-light)}
.stat-label{font-size:0.8rem;color:var(--text-muted);margin-top:6px}
.stat-divider{width:1px;height:40px;background:var(--border)}

/* Hero Visual */
.hero-visual{position:relative;display:flex;align-items:center;justify-content:center;min-height:480px}
.hero-graphic{position:relative;width:100%;height:480px}
.graphic-ring{position:absolute;top:50%;left:50%;border-radius:50%}
.graphic-ring.ring-1{width:200px;height:200px;transform:translate(-50%,-50%);animation:ring-spin 20s linear infinite;border:1px solid rgba(79,70,229,0.12)}
.graphic-ring.ring-2{width:320px;height:320px;transform:translate(-50%,-50%);animation:ring-spin 30s linear infinite reverse;border:1px dashed rgba(124,58,237,0.08)}
.graphic-ring.ring-3{width:440px;height:440px;transform:translate(-50%,-50%);animation:ring-spin 40s linear infinite;border:1px solid rgba(6,182,212,0.06)}
@keyframes ring-spin{to{transform:translate(-50%,-50%) rotate(360deg)}}
.graphic-center-dot{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:16px;height:16px;background:var(--primary);border-radius:50%;box-shadow:0 0 20px rgba(79,70,229,0.6),0 0 60px rgba(79,70,229,0.3),0 0 100px rgba(79,70,229,0.1)}
.graphic-center-dot::after{content:'';position:absolute;inset:-4px;border-radius:50%;border:2px solid rgba(79,70,229,0.3);animation:pulse-ring 2s ease-out infinite}
@keyframes pulse-ring{0%{transform:scale(1);opacity:1}100%{transform:scale(2.5);opacity:0}}
.graphic-card{position:absolute;background:rgba(17,24,39,0.85);backdrop-filter:blur(20px) saturate(150%);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-md);padding:14px 18px;display:flex;align-items:center;gap:12px;font-size:0.85rem;font-weight:500;box-shadow:0 8px 32px rgba(0,0,0,0.4),inset 0 0 0 1px rgba(255,255,255,0.03);transition:transform 0.4s cubic-bezier(0.4,0,0.2,1)}
.card-1{top:30px;left:5%;animation:float1 7s ease-in-out infinite}
.card-2{top:45%;right:0%;animation:float2 6s ease-in-out infinite}
.card-3{bottom:60px;left:10%;animation:float3 8s ease-in-out infinite}
.card-4{top:15%;right:10%;animation:float4 7.5s ease-in-out infinite}
@keyframes float1{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-14px) rotate(1deg)}}
@keyframes float2{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px) rotate(-1deg)}}
@keyframes float3{0%,100%{transform:translateY(0)}50%{transform:translateY(-16px) rotate(1.5deg)}}
@keyframes float4{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px) rotate(-0.5deg)}}
.card-icon{display:flex;align-items:center;justify-content:center;width:38px;height:38px;background:rgba(79,70,229,0.15);border-radius:var(--radius-sm);color:var(--primary-light);flex-shrink:0}
.card-icon.purple{background:rgba(124,58,237,0.15);color:var(--accent-purple)}
.card-icon.green{background:rgba(16,185,129,0.15);color:var(--accent-green)}
.card-icon.cyan{background:rgba(6,182,212,0.15);color:var(--accent-blue)}
.card-status{margin-left:auto;font-size:0.72rem;font-weight:600;color:var(--accent-green);background:rgba(16,185,129,0.1);padding:4px 10px;border-radius:100px}
.card-progress{margin-left:auto;width:80px;height:5px;background:rgba(255,255,255,0.08);border-radius:3px;overflow:hidden}
.card-progress-bar{height:100%;width:0;background:var(--gradient-primary);border-radius:3px;animation:progress-fill 2s 1.5s ease-out forwards}
@keyframes progress-fill{to{width:78%}}
.card-metric{margin-left:auto;font-weight:700;color:var(--accent-green);font-size:0.95rem}
.card-sparkline{margin-left:auto;color:var(--accent-blue);opacity:0.8}

/* Scroll indicator */
.hero-scroll{position:absolute;bottom:32px;left:50%;transform:translateX(-50%)}
.hero-scroll a{display:flex;flex-direction:column;align-items:center;gap:10px;font-size:0.7rem;color:var(--text-muted);letter-spacing:0.15em;text-transform:uppercase}
.scroll-mouse{width:22px;height:34px;border:2px solid rgba(255,255,255,0.2);border-radius:11px;position:relative}
.scroll-wheel{width:3px;height:8px;background:var(--primary-light);border-radius:3px;position:absolute;top:6px;left:50%;transform:translateX(-50%);animation:scroll-wheel 2s ease-in-out infinite}
@keyframes scroll-wheel{0%{opacity:1;top:6px}100%{opacity:0;top:18px}}

/* ========================================
   Trust Bar
   ======================================== */
.trust-bar{padding:48px 0;border-bottom:1px solid var(--border);overflow:hidden}
.trust-label{text-align:center;font-size:0.76rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:0.15em;margin-bottom:28px}
.marquee{position:relative;width:100%;overflow:hidden;mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 10%,black 90%,transparent)}
.marquee-track{display:flex;gap:32px;animation:marquee 35s linear infinite;width:max-content;align-items:center}
@keyframes marquee{to{transform:translateX(-50%)}}
.trust-logo{font-family:var(--font-heading);font-size:1.1rem;font-weight:600;color:var(--text-muted);opacity:0.35;transition:var(--transition);white-space:nowrap;flex-shrink:0}
.trust-logo:hover{opacity:0.7}
.trust-logo-sep{color:rgba(255,255,255,0.08);font-size:0.6rem;flex-shrink:0}

/* ========================================
   Section Headers
   ======================================== */
.section-header{text-align:center;max-width:680px;margin:0 auto 72px}
.section-tag{display:inline-block;font-size:0.76rem;font-weight:600;color:var(--primary-light);text-transform:uppercase;letter-spacing:0.15em;margin-bottom:16px;padding:6px 14px;background:rgba(79,70,229,0.08);border-radius:100px;border:1px solid rgba(79,70,229,0.12)}
.section-header h2{font-family:var(--font-heading);font-size:clamp(2rem,3.5vw,2.8rem);font-weight:700;line-height:1.15;letter-spacing:-0.02em;margin-bottom:20px}
.section-subtitle{font-size:1.05rem;color:var(--text-secondary);line-height:1.7}

/* ========================================
   About
   ======================================== */
.about{padding:var(--section-padding)}
.about-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.about-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 32px;transition:var(--transition);position:relative;overflow:hidden;cursor:default}
.about-card-glow{position:absolute;inset:0;background:var(--gradient-glow);opacity:0;transition:var(--transition);pointer-events:none}
.about-card:hover .about-card-glow{opacity:1}
.about-card:hover{border-color:var(--border-hover);transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,0.2)}
.about-icon{display:flex;align-items:center;justify-content:center;width:56px;height:56px;background:rgba(79,70,229,0.1);border-radius:var(--radius-md);color:var(--primary-light);margin-bottom:24px;position:relative;transition:var(--transition)}
.about-card:hover .about-icon{transform:scale(1.1)}
.about-icon.purple{background:rgba(124,58,237,0.1);color:var(--accent-purple)}
.about-icon.green{background:rgba(16,185,129,0.1);color:var(--accent-green)}
.about-card h3{font-family:var(--font-heading);font-size:1.3rem;font-weight:600;margin-bottom:12px;position:relative}
.about-card p{color:var(--text-secondary);font-size:0.95rem;line-height:1.7;position:relative}
.about-card-arrow{position:absolute;bottom:28px;right:28px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.03);border-radius:50%;color:var(--text-muted);opacity:0;transform:translate(-8px,8px);transition:var(--transition)}
.about-card:hover .about-card-arrow{opacity:1;transform:translate(0,0)}

/* ========================================
   Services — Bento Grid
   ======================================== */
.services{padding:var(--section-padding);position:relative}
.services::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:800px;height:800px;background:radial-gradient(circle,rgba(79,70,229,0.04) 0%,transparent 70%);pointer-events:none}
.services-bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:auto;gap:24px}
.bento-wide{grid-column:span 2}
.bento-tall{grid-row:span 2}
.service-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;transition:all 0.4s cubic-bezier(0.4,0,0.2,1);position:relative;overflow:hidden}
.service-card-border{position:absolute;inset:0;border-radius:var(--radius-lg);padding:1px;background:linear-gradient(135deg,transparent 40%,rgba(79,70,229,0.3),transparent 60%);-webkit-mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);mask:linear-gradient(#fff 0 0) content-box,linear-gradient(#fff 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:var(--transition-slow);pointer-events:none}
.service-card:hover .service-card-border{opacity:1}
.service-card:hover{transform:translateY(-6px);box-shadow:0 25px 50px rgba(0,0,0,0.25);border-color:transparent}
.service-card.featured{border-color:rgba(79,70,229,0.3);background:linear-gradient(135deg,rgba(79,70,229,0.06),var(--bg-card) 50%)}

/* Border Beam Animation */
.border-beam{position:absolute;inset:0;border-radius:var(--radius-lg);overflow:hidden;pointer-events:none;opacity:0;transition:opacity 0.4s}
.service-card:hover .border-beam,.pricing-card.popular .border-beam{opacity:1}
.border-beam::before{content:'';position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:conic-gradient(from 0deg,transparent 0%,var(--primary) 10%,transparent 20%);animation:border-beam-spin 4s linear infinite}
.border-beam::after{content:'';position:absolute;inset:1px;border-radius:calc(var(--radius-lg) - 1px);background:var(--bg-card)}
@keyframes border-beam-spin{to{transform:rotate(360deg)}}

.service-badge{position:absolute;top:20px;right:20px;font-size:0.72rem;font-weight:600;color:var(--primary-light);background:rgba(79,70,229,0.15);padding:6px 14px;border-radius:100px;z-index:1;border:1px solid rgba(79,70,229,0.2)}
.service-number{font-family:var(--font-heading);font-size:3.5rem;font-weight:700;color:rgba(255,255,255,0.03);position:absolute;top:12px;left:32px;z-index:0;transition:var(--transition)}
.service-card:hover .service-number{color:rgba(79,70,229,0.06)}
.service-icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;background:rgba(79,70,229,0.1);border-radius:var(--radius-md);color:var(--primary-light);margin-bottom:24px;position:relative;z-index:1;transition:var(--transition)}
.service-card:hover .service-icon{transform:scale(1.1) rotate(-3deg);background:rgba(79,70,229,0.15)}
.service-card h3{font-family:var(--font-heading);font-size:1.35rem;font-weight:600;margin-bottom:12px;position:relative;z-index:1}
.service-card>p{color:var(--text-secondary);font-size:0.93rem;line-height:1.7;margin-bottom:24px;position:relative;z-index:1}
.service-features{display:grid;grid-template-columns:1fr 1fr;gap:10px;position:relative;z-index:1;margin-bottom:24px}
.service-features li{font-size:0.84rem;color:var(--text-secondary);padding-left:20px;position:relative}
.service-features li::before{content:'';position:absolute;left:0;top:7px;width:7px;height:7px;background:var(--primary);border-radius:50%;opacity:0.6}
.service-link{display:inline-flex;align-items:center;gap:6px;font-size:0.84rem;font-weight:600;color:var(--primary-light);position:relative;z-index:1;opacity:0;transform:translateY(8px);transition:var(--transition)}
.service-card:hover .service-link{opacity:1;transform:translateY(0)}
.service-link:hover{gap:10px}

/* ========================================
   Tech Stack
   ======================================== */
.tech-stack{padding:80px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.tech-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px;max-width:800px;margin:0 auto}
.tech-item{display:flex;flex-direction:column;align-items:center;gap:10px;padding:20px 12px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);transition:var(--transition);cursor:default}
.tech-item:hover{border-color:rgba(79,70,229,0.3);transform:translateY(-4px);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.tech-icon-wrap{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(79,70,229,0.08);border-radius:var(--radius-sm);font-family:var(--font-heading);font-weight:700;font-size:0.85rem;color:var(--primary-light);transition:var(--transition)}
.tech-item:hover .tech-icon-wrap{background:rgba(79,70,229,0.15);transform:scale(1.1)}
.tech-item span{font-size:0.75rem;color:var(--text-muted);font-weight:500}

/* ========================================
   Case Study Showcase
   ======================================== */
.showcase{padding:var(--section-padding);overflow:hidden}
.showcase-scroll{overflow-x:auto;overflow-y:visible;padding:0 24px 20px;cursor:grab;-webkit-overflow-scrolling:touch;scrollbar-width:none}
.showcase-scroll::-webkit-scrollbar{display:none}
.showcase-track{display:flex;gap:24px;width:max-content;padding:10px 0}
.showcase-card{width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:var(--transition);flex-shrink:0}
.showcase-card:hover{transform:translateY(-8px);box-shadow:0 24px 48px rgba(0,0,0,0.3);border-color:var(--border-hover)}
.showcase-visual{height:240px;display:flex;align-items:center;justify-content:center;padding:28px;position:relative;overflow:hidden}
.showcase-mockup{width:100%;height:100%;background:rgba(0,0,0,0.3);border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,0.06);overflow:hidden;display:flex;flex-direction:column}
.mockup-bar{display:flex;gap:5px;padding:8px 12px;border-bottom:1px solid rgba(255,255,255,0.05)}
.mockup-bar span{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.12)}
.mockup-bar span:first-child{background:rgba(239,68,68,0.5)}
.mockup-bar span:nth-child(2){background:rgba(234,179,8,0.5)}
.mockup-bar span:nth-child(3){background:rgba(34,197,94,0.5)}
.mockup-content{flex:1;padding:12px;display:flex;gap:10px}
.mockup-sidebar{width:40px;background:rgba(255,255,255,0.04);border-radius:4px;flex-shrink:0}
.mockup-main{flex:1;display:flex;flex-direction:column;gap:8px}
.mockup-chart{height:50%;background:rgba(79,70,229,0.15);border-radius:4px}
.mockup-cards{display:flex;gap:6px}
.mockup-cards div{flex:1;height:40px;background:rgba(255,255,255,0.04);border-radius:4px}
.mockup-hero-block{height:45%;background:rgba(16,185,129,0.12);border-radius:4px}
.mockup-grid{display:flex;gap:6px;flex:1}
.mockup-grid div{flex:1;background:rgba(255,255,255,0.04);border-radius:4px}
.mockup-chat{flex:1;display:flex;flex-direction:column;gap:8px;justify-content:center;padding:8px}
.chat-bubble{border-radius:12px;padding:0;height:24px}
.chat-bubble.bot{background:rgba(124,58,237,0.2);width:80%;border-bottom-left-radius:4px}
.chat-bubble.user{background:rgba(79,70,229,0.2);width:65%;align-self:flex-end;border-bottom-right-radius:4px}
.chat-bubble.short{width:50%}
.mockup-flow{display:flex;align-items:center;justify-content:center;gap:8px;flex:1}
.flow-node{width:50px;height:50px;background:rgba(234,88,12,0.2);border-radius:var(--radius-sm);border:1px solid rgba(234,88,12,0.2)}
.flow-arrow{width:20px;height:2px;background:rgba(255,255,255,0.15)}
.showcase-info{padding:24px}
.showcase-tag{display:inline-block;font-size:0.72rem;font-weight:600;color:var(--primary-light);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:8px;background:rgba(79,70,229,0.1);padding:4px 10px;border-radius:100px}
.showcase-info h3{font-family:var(--font-heading);font-size:1.2rem;font-weight:600;margin-bottom:8px}
.showcase-info p{font-size:0.88rem;color:var(--text-secondary);line-height:1.6;margin-bottom:16px}
.showcase-results{display:flex;gap:20px}
.showcase-results div{font-size:0.82rem;color:var(--text-muted)}
.showcase-results strong{color:var(--primary-light);font-weight:700;margin-right:4px}
.showcase-hint{display:flex;align-items:center;justify-content:center;gap:8px;font-size:0.78rem;color:var(--text-muted);margin-top:24px;opacity:0.6}

/* ========================================
   Pricing
   ======================================== */
.pricing{padding:var(--section-padding)}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;align-items:start}
.pricing-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px 32px;position:relative;overflow:hidden;transition:var(--transition)}
.pricing-card:hover{border-color:var(--border-hover);transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,0.2)}
.pricing-card-glow{position:absolute;inset:0;background:var(--gradient-glow);opacity:0;transition:var(--transition);pointer-events:none}
.pricing-card:hover .pricing-card-glow{opacity:1}
.pricing-card.popular{border-color:rgba(79,70,229,0.4);background:linear-gradient(180deg,rgba(79,70,229,0.06),var(--bg-card) 30%);transform:scale(1.03)}
.pricing-card.popular:hover{transform:scale(1.03) translateY(-6px)}
.pricing-popular-badge{position:absolute;top:0;left:50%;transform:translateX(-50%);background:var(--gradient-primary);color:#fff;font-size:0.72rem;font-weight:700;text-transform:uppercase;letter-spacing:0.1em;padding:6px 20px;border-radius:0 0 var(--radius-sm) var(--radius-sm)}
.pricing-header{margin-bottom:28px;padding-top:8px}
.pricing-card.popular .pricing-header{padding-top:20px}
.pricing-tier{font-family:var(--font-heading);font-size:0.9rem;font-weight:600;color:var(--primary-light);text-transform:uppercase;letter-spacing:0.1em}
.pricing-price{display:flex;align-items:baseline;gap:4px;margin:12px 0 16px}
.pricing-currency{font-size:0.9rem;color:var(--text-muted);font-weight:500}
.pricing-amount{font-family:var(--font-heading);font-size:3rem;font-weight:700;color:var(--text-primary);line-height:1}
.pricing-unit{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--text-muted)}
.pricing-desc{font-size:0.9rem;color:var(--text-secondary);line-height:1.6}
.pricing-features{display:flex;flex-direction:column;gap:14px;margin-bottom:32px;padding-top:28px;border-top:1px solid var(--border)}
.pricing-features li{display:flex;align-items:flex-start;gap:10px;font-size:0.88rem;line-height:1.4}
.pricing-features li.included{color:var(--text-secondary)}
.pricing-features li.included svg{color:var(--accent-green);flex-shrink:0;margin-top:2px}
.pricing-features li.excluded{color:var(--text-muted);opacity:0.5}
.pricing-features li.excluded svg{color:var(--text-muted);flex-shrink:0;margin-top:2px}
.pricing-note{text-align:center;font-size:0.85rem;color:var(--text-muted);margin-top:40px}
.pricing-note a{color:var(--primary-light);font-weight:500}
.pricing-note a:hover{text-decoration:underline}

/* ========================================
   Comparison
   ======================================== */
.comparison{padding:var(--section-padding)}
.comparison-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);overflow:hidden;max-width:600px;margin:0 auto;position:relative}
/* Column Headers */
.comparison-col-headers{display:grid;grid-template-columns:1.4fr 1fr 1fr;align-items:end;padding:0}
.comparison-col-label{padding:24px 28px 16px}
.comparison-col-stratify{display:flex;flex-direction:column;align-items:center;gap:10px;padding:28px 16px 18px;background:linear-gradient(180deg,rgba(79,70,229,0.25) 0%,rgba(124,58,237,0.10) 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0;position:relative}
.comparison-col-stratify::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:rgba(79,70,229,0.2)}
.comparison-logo-badge{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(79,70,229,0.2);border:2px solid rgba(79,70,229,0.4);border-radius:50%;box-shadow:0 0 20px rgba(79,70,229,0.3)}
.comparison-logo-badge svg{width:28px;height:28px}
.comparison-col-stratify span{font-family:var(--font-heading);font-size:0.95rem;font-weight:700;color:var(--primary-light)}
.comparison-col-other{display:flex;flex-direction:column;align-items:center;justify-content:flex-end;padding:28px 16px 18px}
.comparison-col-other span{font-size:0.9rem;font-weight:600;color:var(--text-muted);text-align:center;line-height:1.3}
/* Rows */
.comparison-card .comparison-row{display:grid;grid-template-columns:1.4fr 1fr 1fr;align-items:center;border-top:1px solid var(--border);padding:0;transition:var(--transition)}
.comparison-card .comparison-row:hover{background:rgba(255,255,255,0.02)}
.comparison-card .comparison-feature{font-size:0.92rem;font-weight:500;color:var(--text-primary);padding:18px 28px}
.comparison-check{display:flex;align-items:center;justify-content:center;padding:18px 16px;background:rgba(79,70,229,0.06);border-left:1px solid rgba(79,70,229,0.08);border-right:1px solid rgba(79,70,229,0.08)}
.comparison-cross{display:flex;align-items:center;justify-content:center;padding:18px 16px}
.comparison-check-text{font-family:var(--font-heading);font-size:0.82rem;font-weight:700;color:var(--accent-green);text-align:center}
.comparison-cross-text{font-size:0.85rem;font-weight:500;color:var(--text-muted)}
/* Bottom Badge */
.comparison-badge{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:linear-gradient(135deg,rgba(16,185,129,0.08),rgba(16,185,129,0.03));border-top:1px solid rgba(16,185,129,0.15)}
.comparison-badge span{font-family:var(--font-heading);font-size:0.85rem;font-weight:700;color:var(--accent-green);text-transform:uppercase;letter-spacing:0.05em}

/* ========================================
   Process — Card Layout
   ======================================== */
.process{padding:var(--section-padding)}
.process-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.process-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:32px 28px;position:relative;overflow:hidden;transition:var(--transition)}
.process-card:hover{border-color:var(--border-hover);transform:translateY(-6px);box-shadow:0 20px 40px rgba(0,0,0,0.2)}
.process-card-number{font-family:var(--font-heading);font-size:4rem;font-weight:700;color:rgba(79,70,229,0.06);position:absolute;top:-8px;right:16px;line-height:1}
.process-card-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(79,70,229,0.1);border-radius:var(--radius-md);color:var(--primary-light);margin-bottom:16px;transition:var(--transition)}
.process-card:hover .process-card-icon{background:rgba(79,70,229,0.15);transform:scale(1.1)}
.step-tag{display:inline-block;font-size:0.7rem;font-weight:600;color:var(--accent-blue);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:8px}
.process-card h3{font-family:var(--font-heading);font-size:1.15rem;font-weight:600;margin-bottom:8px}
.process-card p{color:var(--text-secondary);font-size:0.88rem;line-height:1.65}

/* ========================================
   Results / Testimonial Carousel
   ======================================== */
.results{padding:var(--section-padding);position:relative}
.results::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:600px;height:600px;background:radial-gradient(circle,rgba(124,58,237,0.04) 0%,transparent 70%);pointer-events:none}
.testimonial-carousel{max-width:720px;margin:0 auto;position:relative}
.carousel-track{position:relative;min-height:380px}
.result-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px;display:flex;flex-direction:column;position:absolute;inset:0;opacity:0;transform:translateX(60px) scale(0.95);transition:all 0.5s cubic-bezier(0.4,0,0.2,1);pointer-events:none}
.result-card.active{opacity:1;transform:translateX(0) scale(1);pointer-events:auto;position:relative}
.result-card.exit-left{opacity:0;transform:translateX(-60px) scale(0.95)}
.result-stars{display:flex;gap:2px;color:var(--accent-amber);margin-bottom:20px}
.result-quote{font-size:1.1rem;line-height:1.8;color:var(--text-primary);margin-bottom:28px;flex-grow:1;font-style:italic}
.result-quote::before{content:'\201C';font-size:3rem;line-height:0;vertical-align:-.4em;color:var(--primary);opacity:0.3;margin-right:4px}
.result-metrics{display:flex;gap:32px;padding:20px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border);margin-bottom:24px}
.result-metric{display:flex;flex-direction:column}
.metric-value{font-family:var(--font-heading);font-size:1.5rem;font-weight:700;color:var(--primary-light)}
.metric-label{font-size:0.8rem;color:var(--text-muted)}
.result-author{display:flex;align-items:center;gap:12px}
.author-avatar{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:rgba(79,70,229,0.15);border-radius:50%;font-weight:700;font-size:0.85rem;color:var(--primary-light);flex-shrink:0}
.result-author strong{display:block;font-size:0.9rem;font-weight:600}
.result-author span{font-size:0.8rem;color:var(--text-muted)}
.carousel-controls{display:flex;align-items:center;justify-content:center;gap:20px;margin-top:32px}
.carousel-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:50%;color:var(--text-secondary);cursor:pointer;transition:var(--transition)}
.carousel-btn:hover{background:var(--primary);border-color:var(--primary);color:#fff}
.carousel-dots{display:flex;gap:8px}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.15);transition:var(--transition);cursor:pointer}
.carousel-dot.active{background:var(--primary);width:24px;border-radius:4px}

/* ========================================
   FAQ — Side Layout
   ======================================== */
.faq{padding:var(--section-padding)}
.faq-layout{display:grid;grid-template-columns:1fr 1.5fr;gap:64px;align-items:start}
.faq-left h2{font-family:var(--font-heading);font-size:clamp(1.8rem,3vw,2.4rem);font-weight:700;line-height:1.15;margin-bottom:16px}
.faq-left p{color:var(--text-secondary);margin-bottom:24px;line-height:1.7}
.faq-list{display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;transition:var(--transition)}
.faq-item:hover{border-color:var(--border-hover)}
.faq-item.open{border-color:rgba(79,70,229,0.2);background:rgba(79,70,229,0.03)}
.faq-question{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 24px;background:none;border:none;cursor:pointer;text-align:left;font-family:var(--font-body);font-size:0.95rem;font-weight:600;color:var(--text-primary);transition:var(--transition)}
.faq-question:hover{color:var(--primary-light)}
.faq-icon{width:24px;height:24px;position:relative;flex-shrink:0}
.faq-icon span{position:absolute;background:var(--text-secondary);border-radius:1px;transition:var(--transition)}
.faq-icon span:first-child{width:14px;height:2px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-icon span:last-child{width:2px;height:14px;top:50%;left:50%;transform:translate(-50%,-50%)}
.faq-item.open .faq-icon span:last-child{transform:translate(-50%,-50%) rotate(90deg);opacity:0}
.faq-answer{max-height:0;overflow:hidden;transition:max-height 0.4s cubic-bezier(0.4,0,0.2,1)}
.faq-item.open .faq-answer{max-height:300px}
.faq-answer p{padding:0 24px 20px;color:var(--text-secondary);font-size:0.93rem;line-height:1.7}

/* ========================================
   CTA Section
   ======================================== */
.cta-section{padding:var(--section-padding)}
.cta-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:64px;display:grid;grid-template-columns:1fr 1fr;gap:64px;position:relative;overflow:hidden}
.cta-card-bg{position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(79,70,229,0.06) 0%,transparent 70%);pointer-events:none}
.cta-content .section-tag{margin-bottom:12px}
.cta-content h2{font-family:var(--font-heading);font-size:clamp(1.6rem,2.5vw,2.2rem);font-weight:700;line-height:1.2;margin-bottom:16px}
.cta-content>p{color:var(--text-secondary);margin-bottom:32px;line-height:1.7}
.cta-features{display:flex;flex-direction:column;gap:14px}
.cta-feature{display:flex;align-items:center;gap:10px;font-size:0.9rem;color:var(--text-secondary)}
.cta-feature svg{color:var(--accent-green);flex-shrink:0}
.cta-form{display:flex;flex-direction:column;gap:16px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group label{font-size:0.84rem;font-weight:500;color:var(--text-secondary)}
.form-group input,.form-group select,.form-group textarea{background:var(--bg-dark);border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px 16px;font-family:var(--font-body);font-size:0.9rem;color:var(--text-primary);transition:var(--transition);outline:none}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);box-shadow:0 0 0 3px rgba(79,70,229,0.1)}
.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-muted)}
.form-group select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none'%3E%3Cpath d='M3 4.5L6 7.5L9 4.5' stroke='%236B7280' 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 textarea{resize:vertical;min-height:100px}
.form-hint{text-align:center;font-size:0.8rem;color:var(--text-muted);margin-top:4px}

/* Confetti Canvas */
.confetti-canvas{position:fixed;inset:0;z-index:99998;pointer-events:none}

/* ========================================
   Footer
   ======================================== */
.footer{padding:48px 0 32px;border-top:1px solid var(--border)}
.footer-compact{margin-bottom:32px}
.footer-brand{display:flex;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:28px}
.footer-brand p{font-size:0.88rem;color:var(--text-muted);line-height:1.6;max-width:420px;margin:0}
.footer-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:24px;padding-top:24px;border-top:1px solid var(--border)}
.footer-nav{display:flex;gap:24px;flex-wrap:wrap}
.footer-nav a{font-size:0.88rem;color:var(--text-muted);transition:var(--transition)}
.footer-nav a:hover{color:var(--text-primary)}
.footer-contact{display:flex;gap:20px;flex-wrap:wrap;align-items:center}
.footer-contact a,.footer-contact span{font-size:0.88rem;color:var(--text-muted)}
.footer-contact a:hover{color:var(--text-primary)}
.footer-socials{display:flex;gap:12px}
.social-link{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,0.04);border:1px solid var(--border);border-radius:50%;color:var(--text-muted);transition:var(--transition)}
.social-link:hover{background:rgba(79,70,229,0.1);border-color:rgba(79,70,229,0.3);color:var(--primary-light);transform:translateY(-2px)}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;padding-top:24px;border-top:1px solid var(--border)}
.footer-bottom p{font-size:0.85rem;color:var(--text-muted)}
.footer-legal{display:flex;gap:24px}
.footer-legal a{font-size:0.85rem;color:var(--text-muted)}
.footer-legal a:hover{color:var(--text-primary)}

/* ========================================
   Back to Top
   ======================================== */
.back-to-top{position:fixed;bottom:32px;right:32px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:var(--bg-card);border:1px solid var(--border);border-radius:50%;color:var(--text-secondary);cursor:pointer;z-index:100;opacity:0;visibility:hidden;transform:translateY(10px);transition:var(--transition);backdrop-filter:blur(10px)}
.back-to-top.visible{opacity:1;visibility:visible;transform:translateY(0)}
.back-to-top:hover{background:var(--primary);border-color:var(--primary);color:#fff;transform:translateY(-3px);box-shadow:0 8px 20px rgba(79,70,229,0.4)}

/* ========================================
   Animations
   ======================================== */
[data-animate]{opacity:0;transform:translateY(30px);transition:opacity 0.8s cubic-bezier(0.4,0,0.2,1),transform 0.8s cubic-bezier(0.4,0,0.2,1)}
[data-animate="fade-left"]{transform:translateX(40px)}
[data-animate].animated{opacity:1;transform:translate(0,0)}

/* ========================================
   Responsive
   ======================================== */
@media(max-width:1024px){
    body{cursor:auto}
    a,button,.btn{cursor:pointer}
    .custom-cursor{display:none}
    .hero-container{grid-template-columns:1fr;gap:60px;text-align:center}
    .hero-badge{margin:0 auto 24px}.hero-subtitle{margin:0 auto 36px;max-width:100%}
    .hero-actions{justify-content:center}.hero-stats{justify-content:center}
    .hero-visual{display:none}.hero-scroll{display:none}
    .services-bento{grid-template-columns:1fr}.bento-wide,.bento-tall{grid-column:span 1;grid-row:span 1}
    .results-grid{grid-template-columns:1fr}
    .pricing-grid{grid-template-columns:1fr;max-width:480px;margin:0 auto}
    .pricing-card.popular{transform:none}
    .pricing-card.popular:hover{transform:translateY(-6px)}
    .comparison-card{font-size:0.85rem}
    .process-cards{grid-template-columns:repeat(2,1fr)}
    .faq-layout{grid-template-columns:1fr}
    .faq-left{text-align:center}
    .cta-card{grid-template-columns:1fr;padding:40px;gap:40px}
    .form-row{grid-template-columns:1fr}
    .footer-row{flex-direction:column;align-items:flex-start}
    .section-dots{display:none}
    .tech-grid{grid-template-columns:repeat(4,1fr)}
}
@media(max-width:768px){
    :root{--section-padding:80px 0}
    .nav-links{display:flex;position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(11,15,26,0.98);backdrop-filter:blur(20px);flex-direction:column;justify-content:center;align-items:center;gap:36px;z-index:999;opacity:0;visibility:hidden;transform:translateY(-20px);transition:opacity 0.35s ease,transform 0.35s ease,visibility 0.35s ease}
    .nav-links.open{opacity:1;visibility:visible;transform:translateY(0)}
    .nav-links a{font-size:1.4rem;font-weight:600;color:var(--text-primary);opacity:0;transform:translateY(16px);transition:opacity 0.3s ease,transform 0.3s ease,color 0.2s ease}
    .nav-links.open a{opacity:1;transform:translateY(0)}
    .nav-links.open li:nth-child(1) a{transition-delay:0.08s}
    .nav-links.open li:nth-child(2) a{transition-delay:0.14s}
    .nav-links.open li:nth-child(3) a{transition-delay:0.20s}
    .nav-links.open li:nth-child(4) a{transition-delay:0.26s}
    .nav-links.open li:nth-child(5) a{transition-delay:0.32s}
    .nav-links .nav-cta{background:var(--primary);padding:12px 28px;border-radius:var(--radius-sm);color:#fff !important;font-size:1.1rem}
    .mobile-toggle{display:flex;z-index:1001}
    .about-grid{grid-template-columns:1fr}
    .process-cards{grid-template-columns:1fr}
    .hero h1{font-size:2.2rem}
    .hero-stats{flex-direction:column;gap:16px}
    .stat-divider{width:40px;height:1px}
    .hero-actions{flex-direction:column;align-items:center}
    .footer-brand{flex-direction:column;align-items:flex-start}
    .footer-bottom{flex-direction:column;gap:16px;text-align:center}
    .cta-card{padding:32px 24px}
    .cursor-glow{display:none}
    .floating-notification{display:none}
    .tech-grid{grid-template-columns:repeat(3,1fr)}
    .showcase-card{width:320px}
    .comparison-col-headers,.comparison-card .comparison-row{grid-template-columns:1.2fr 0.9fr 0.9fr}
    .comparison-card .comparison-feature{padding:14px 16px}
    .comparison-check,.comparison-cross{padding:14px 12px}
    .result-card{padding:28px}
    .result-quote{font-size:1rem}
    .result-metrics{gap:20px}
    .carousel-track{min-height:420px}
}
@media(max-width:480px){
    .container{padding:0 16px}
    .service-features{grid-template-columns:1fr}
    .result-metrics{flex-direction:column;gap:12px}
    .back-to-top{bottom:20px;right:20px;width:42px;height:42px}
    .tech-grid{grid-template-columns:repeat(3,1fr);gap:12px}
    .tech-item{padding:14px 8px}
    .comparison-col-headers,.comparison-card .comparison-row{grid-template-columns:1.2fr 0.8fr 0.8fr}
    .comparison-card .comparison-feature{padding:14px 12px;font-size:0.82rem}
    .comparison-check,.comparison-cross{padding:14px 8px}
    .comparison-col-stratify{padding:20px 8px 14px}
    .comparison-col-other{padding:20px 8px 14px}
    .comparison-col-other span{font-size:0.8rem}
    .comparison-col-stratify span{font-size:0.85rem}
    .comparison-logo-badge{width:36px;height:36px}
    .comparison-logo-badge svg{width:22px;height:22px}
    .cookie-banner{flex-direction:column;gap:16px}
    .carousel-track{min-height:480px}
}
